{"diffoscope-json-version": 1, "source1": "/input1", "source2": "/input2", "unified_diff": null, "details": [{"source1": "zipinfo {}", "source2": "zipinfo {}", "unified_diff": "@@ -1,17 +1,17 @@\n-Zip file size: 957509 bytes, number of entries: 15\n+Zip file size: 1019524 bytes, number of entries: 15\n -rw----     1.0 fat        0 bx stor 24-May-13 18:01 META-INF/\n -rw----     2.0 fat      215 bl defN 24-May-13 18:01 META-INF/MANIFEST.MF\n -rw----     1.0 fat        0 b- stor 24-May-13 18:01 graphiql/\n -rw----     1.0 fat        0 b- stor 24-May-13 18:01 io/\n -rw----     1.0 fat        0 b- stor 24-May-13 18:01 io/jooby/\n -rw----     1.0 fat        0 b- stor 24-May-13 18:01 io/jooby/graphiql/\n -rw----     1.0 fat        0 b- stor 24-May-13 18:01 META-INF/maven/\n -rw----     1.0 fat        0 b- stor 24-May-13 18:01 META-INF/maven/io.jooby/\n -rw----     1.0 fat        0 b- stor 24-May-13 18:01 META-INF/maven/io.jooby/jooby-graphiql/\n--rw----     2.0 fat   413290 bl defN 24-May-13 18:01 graphiql/graphiql.css\n--rw----     2.0 fat  3182005 bl defN 24-May-13 18:01 graphiql/graphiql.min.js\n+-rw----     2.0 fat   425363 bl defN 24-May-13 18:01 graphiql/graphiql.css\n+-rw----     2.0 fat  3513576 bl defN 24-May-13 18:01 graphiql/graphiql.min.js\n -rw----     2.0 fat    11842 bl defN 24-May-13 18:01 io/jooby/graphiql/GraphiQLModule.class\n -rw----     2.0 fat     2291 bl defN 24-May-13 18:01 META-INF/maven/io.jooby/jooby-graphiql/pom.xml\n -rw----     2.0 fat       57 bl defN 24-May-13 18:01 META-INF/maven/io.jooby/jooby-graphiql/pom.properties\n -rw----     2.0 fat      331 bl defN 24-May-13 18:01 module-info.class\n-15 files, 3610031 bytes uncompressed, 955537 bytes compressed:  73.5%\n+15 files, 3953675 bytes uncompressed, 1017552 bytes compressed:  74.3%\n"}, {"source1": "zipdetails --redact --scan --utc {}", "source2": "zipdetails --redact --scan --utc {}", "unified_diff": "@@ -189,561 +189,561 @@\n 0025D Filename              'XXXXXXXXXXXXXXXXXXXXX'\n #\n # WARNING: Offset 0x25D: Filename 'XXXXXXXXXXXXXXXXXXXXX'\n #          Zero length filename\n #\n 00272 PAYLOAD\n \n-43A52 DATA DESCRIPTOR       08074B50 (134695760)\n-43A56 CRC                   1ED61AD6 (517348054)\n-43A5A Compressed Size       000437E0 (276448)\n-43A5E Uncompressed Size     00064E6A (413290)\n+445D3 DATA DESCRIPTOR       08074B50 (134695760)\n+445D7 CRC                   51FB39FC (1375418876)\n+445DB Compressed Size       00044361 (279393)\n+445DF Uncompressed Size     00067D93 (425363)\n \n-43A62 LOCAL HEADER #11      04034B50 (67324752)\n-43A66 Extract Zip Spec      14 (20) '2.0'\n-43A67 Extract OS            00 (0) 'MS-DOS'\n-43A68 General Purpose Flag  0808 (2056)\n+445E3 LOCAL HEADER #11      04034B50 (67324752)\n+445E7 Extract Zip Spec      14 (20) '2.0'\n+445E8 Extract OS            00 (0) 'MS-DOS'\n+445E9 General Purpose Flag  0808 (2056)\n       [Bits 1-2]            0 'Normal Compression'\n       [Bit  3]              1 'Streamed'\n       [Bit 11]              1 'Language Encoding'\n-43A6A Compression Method    0008 (8) 'Deflated'\n-43A6C Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n-43A70 CRC                   00000000 (0)\n-43A74 Compressed Size       00000000 (0)\n-43A78 Uncompressed Size     00000000 (0)\n-43A7C Filename Length       0018 (24)\n-43A7E Extra Length          0000 (0)\n-43A80 Filename              'XXXXXXXXXXXXXXXXXXXXXXXX'\n+445EB Compression Method    0008 (8) 'Deflated'\n+445ED Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n+445F1 CRC                   00000000 (0)\n+445F5 Compressed Size       00000000 (0)\n+445F9 Uncompressed Size     00000000 (0)\n+445FD Filename Length       0018 (24)\n+445FF Extra Length          0000 (0)\n+44601 Filename              'XXXXXXXXXXXXXXXXXXXXXXXX'\n #\n-# WARNING: Offset 0x43A80: Filename 'XXXXXXXXXXXXXXXXXXXXXXXX'\n+# WARNING: Offset 0x44601: Filename 'XXXXXXXXXXXXXXXXXXXXXXXX'\n #          Zero length filename\n #\n-43A98 PAYLOAD\n+44619 PAYLOAD\n \n-E85C0 DATA DESCRIPTOR       08074B50 (134695760)\n-E85C4 CRC                   FB1D5E8A (4213005962)\n-E85C8 Compressed Size       000A4B28 (674600)\n-E85CC Uncompressed Size     00308DB5 (3182005)\n+F77FF DATA DESCRIPTOR       08074B50 (134695760)\n+F7803 CRC                   6A282AC4 (1781017284)\n+F7807 Compressed Size       000B31E6 (733670)\n+F780B Uncompressed Size     00359CE8 (3513576)\n \n-E85D0 LOCAL HEADER #12      04034B50 (67324752)\n-E85D4 Extract Zip Spec      14 (20) '2.0'\n-E85D5 Extract OS            00 (0) 'MS-DOS'\n-E85D6 General Purpose Flag  0808 (2056)\n+F780F LOCAL HEADER #12      04034B50 (67324752)\n+F7813 Extract Zip Spec      14 (20) '2.0'\n+F7814 Extract OS            00 (0) 'MS-DOS'\n+F7815 General Purpose Flag  0808 (2056)\n       [Bits 1-2]            0 'Normal Compression'\n       [Bit  3]              1 'Streamed'\n       [Bit 11]              1 'Language Encoding'\n-E85D8 Compression Method    0008 (8) 'Deflated'\n-E85DA Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n-E85DE CRC                   00000000 (0)\n-E85E2 Compressed Size       00000000 (0)\n-E85E6 Uncompressed Size     00000000 (0)\n-E85EA Filename Length       0026 (38)\n-E85EC Extra Length          0000 (0)\n-E85EE Filename              'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n+F7817 Compression Method    0008 (8) 'Deflated'\n+F7819 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n+F781D CRC                   00000000 (0)\n+F7821 Compressed Size       00000000 (0)\n+F7825 Uncompressed Size     00000000 (0)\n+F7829 Filename Length       0026 (38)\n+F782B Extra Length          0000 (0)\n+F782D Filename              'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n #\n-# WARNING: Offset 0xE85EE: Filename 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n+# WARNING: Offset 0xF782D: Filename 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n #          Zero length filename\n #\n-E8614 PAYLOAD\n+F7853 PAYLOAD\n \n-E9357 DATA DESCRIPTOR       08074B50 (134695760)\n-E935B CRC                   B0DD7B98 (2967305112)\n-E935F Compressed Size       00000D43 (3395)\n-E9363 Uncompressed Size     00002E42 (11842)\n+F8596 DATA DESCRIPTOR       08074B50 (134695760)\n+F859A CRC                   B0DD7B98 (2967305112)\n+F859E Compressed Size       00000D43 (3395)\n+F85A2 Uncompressed Size     00002E42 (11842)\n \n-E9367 LOCAL HEADER #13      04034B50 (67324752)\n-E936B Extract Zip Spec      14 (20) '2.0'\n-E936C Extract OS            00 (0) 'MS-DOS'\n-E936D General Purpose Flag  0808 (2056)\n+F85A6 LOCAL HEADER #13      04034B50 (67324752)\n+F85AA Extract Zip Spec      14 (20) '2.0'\n+F85AB Extract OS            00 (0) 'MS-DOS'\n+F85AC General Purpose Flag  0808 (2056)\n       [Bits 1-2]            0 'Normal Compression'\n       [Bit  3]              1 'Streamed'\n       [Bit 11]              1 'Language Encoding'\n-E936F Compression Method    0008 (8) 'Deflated'\n-E9371 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n-E9375 CRC                   00000000 (0)\n-E9379 Compressed Size       00000000 (0)\n-E937D Uncompressed Size     00000000 (0)\n-E9381 Filename Length       002E (46)\n-E9383 Extra Length          0000 (0)\n-E9385 Filename              'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n+F85AE Compression Method    0008 (8) 'Deflated'\n+F85B0 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n+F85B4 CRC                   00000000 (0)\n+F85B8 Compressed Size       00000000 (0)\n+F85BC Uncompressed Size     00000000 (0)\n+F85C0 Filename Length       002E (46)\n+F85C2 Extra Length          0000 (0)\n+F85C4 Filename              'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n #\n-# WARNING: Offset 0xE9385: Filename 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n+# WARNING: Offset 0xF85C4: Filename 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n #          Zero length filename\n #\n-E93B3 PAYLOAD\n+F85F2 PAYLOAD\n \n-E964E DATA DESCRIPTOR       08074B50 (134695760)\n-E9652 CRC                   53A5DFB4 (1403379636)\n-E9656 Compressed Size       0000029B (667)\n-E965A Uncompressed Size     000008F3 (2291)\n+F888D DATA DESCRIPTOR       08074B50 (134695760)\n+F8891 CRC                   53A5DFB4 (1403379636)\n+F8895 Compressed Size       0000029B (667)\n+F8899 Uncompressed Size     000008F3 (2291)\n \n-E965E LOCAL HEADER #14      04034B50 (67324752)\n-E9662 Extract Zip Spec      14 (20) '2.0'\n-E9663 Extract OS            00 (0) 'MS-DOS'\n-E9664 General Purpose Flag  0808 (2056)\n+F889D LOCAL HEADER #14      04034B50 (67324752)\n+F88A1 Extract Zip Spec      14 (20) '2.0'\n+F88A2 Extract OS            00 (0) 'MS-DOS'\n+F88A3 General Purpose Flag  0808 (2056)\n       [Bits 1-2]            0 'Normal Compression'\n       [Bit  3]              1 'Streamed'\n       [Bit 11]              1 'Language Encoding'\n-E9666 Compression Method    0008 (8) 'Deflated'\n-E9668 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n-E966C CRC                   00000000 (0)\n-E9670 Compressed Size       00000000 (0)\n-E9674 Uncompressed Size     00000000 (0)\n-E9678 Filename Length       0035 (53)\n-E967A Extra Length          0000 (0)\n-E967C Filename              'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n+F88A5 Compression Method    0008 (8) 'Deflated'\n+F88A7 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n+F88AB CRC                   00000000 (0)\n+F88AF Compressed Size       00000000 (0)\n+F88B3 Uncompressed Size     00000000 (0)\n+F88B7 Filename Length       0035 (53)\n+F88B9 Extra Length          0000 (0)\n+F88BB Filename              'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n #\n-# WARNING: Offset 0xE967C: Filename 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n+# WARNING: Offset 0xF88BB: Filename 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n #          Zero length filename\n #\n-E96B1 PAYLOAD               XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX\n+F88F0 PAYLOAD               XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX\n \n-E96E7 DATA DESCRIPTOR       08074B50 (134695760)\n-E96EB CRC                   35B620D5 (901128405)\n-E96EF Compressed Size       00000036 (54)\n-E96F3 Uncompressed Size     00000039 (57)\n+F8926 DATA DESCRIPTOR       08074B50 (134695760)\n+F892A CRC                   35B620D5 (901128405)\n+F892E Compressed Size       00000036 (54)\n+F8932 Uncompressed Size     00000039 (57)\n \n-E96F7 LOCAL HEADER #15      04034B50 (67324752)\n-E96FB Extract Zip Spec      14 (20) '2.0'\n-E96FC Extract OS            00 (0) 'MS-DOS'\n-E96FD General Purpose Flag  0808 (2056)\n+F8936 LOCAL HEADER #15      04034B50 (67324752)\n+F893A Extract Zip Spec      14 (20) '2.0'\n+F893B Extract OS            00 (0) 'MS-DOS'\n+F893C General Purpose Flag  0808 (2056)\n       [Bits 1-2]            0 'Normal Compression'\n       [Bit  3]              1 'Streamed'\n       [Bit 11]              1 'Language Encoding'\n-E96FF Compression Method    0008 (8) 'Deflated'\n-E9701 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n-E9705 CRC                   00000000 (0)\n-E9709 Compressed Size       00000000 (0)\n-E970D Uncompressed Size     00000000 (0)\n-E9711 Filename Length       0011 (17)\n-E9713 Extra Length          0000 (0)\n-E9715 Filename              'XXXXXXXXXXXXXXXXX'\n+F893E Compression Method    0008 (8) 'Deflated'\n+F8940 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n+F8944 CRC                   00000000 (0)\n+F8948 Compressed Size       00000000 (0)\n+F894C Uncompressed Size     00000000 (0)\n+F8950 Filename Length       0011 (17)\n+F8952 Extra Length          0000 (0)\n+F8954 Filename              'XXXXXXXXXXXXXXXXX'\n #\n-# WARNING: Offset 0xE9715: Filename 'XXXXXXXXXXXXXXXXX'\n+# WARNING: Offset 0xF8954: Filename 'XXXXXXXXXXXXXXXXX'\n #          Zero length filename\n #\n-E9726 PAYLOAD               XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX\n+F8965 PAYLOAD               XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX\n                             XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX\n \n-E9810 DATA DESCRIPTOR       08074B50 (134695760)\n-E9814 CRC                   A840B382 (2822812546)\n-E9818 Compressed Size       000000EA (234)\n-E981C Uncompressed Size     0000014B (331)\n+F8A4F DATA DESCRIPTOR       08074B50 (134695760)\n+F8A53 CRC                   A840B382 (2822812546)\n+F8A57 Compressed Size       000000EA (234)\n+F8A5B Uncompressed Size     0000014B (331)\n \n-E9820 CENTRAL HEADER #1     02014B50 (33639248)\n-E9824 Created Zip Spec      0A (10) '1.0'\n-E9825 Created OS            00 (0) 'MS-DOS'\n-E9826 Extract Zip Spec      0A (10) '1.0'\n-E9827 Extract OS            00 (0) 'MS-DOS'\n-E9828 General Purpose Flag  0800 (2048)\n+F8A5F CENTRAL HEADER #1     02014B50 (33639248)\n+F8A63 Created Zip Spec      0A (10) '1.0'\n+F8A64 Created OS            00 (0) 'MS-DOS'\n+F8A65 Extract Zip Spec      0A (10) '1.0'\n+F8A66 Extract OS            00 (0) 'MS-DOS'\n+F8A67 General Purpose Flag  0800 (2048)\n       [Bit 11]              1 'Language Encoding'\n-E982A Compression Method    0000 (0) 'Stored'\n-E982C Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n-E9830 CRC                   00000000 (0)\n-E9834 Compressed Size       00000000 (0)\n-E9838 Uncompressed Size     00000000 (0)\n-E983C Filename Length       0009 (9)\n-E983E Extra Length          0004 (4)\n-E9840 Comment Length        0000 (0)\n-E9842 Disk Start            0000 (0)\n-E9844 Int File Attributes   0000 (0)\n+F8A69 Compression Method    0000 (0) 'Stored'\n+F8A6B Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n+F8A6F CRC                   00000000 (0)\n+F8A73 Compressed Size       00000000 (0)\n+F8A77 Uncompressed Size     00000000 (0)\n+F8A7B Filename Length       0009 (9)\n+F8A7D Extra Length          0004 (4)\n+F8A7F Comment Length        0000 (0)\n+F8A81 Disk Start            0000 (0)\n+F8A83 Int File Attributes   0000 (0)\n       [Bit 0]               0 'Binary Data'\n-E9846 Ext File Attributes   00000000 (0)\n-E984A Local Header Offset   00000000 (0)\n-E984E Filename              'XXXXXXXXX'\n+F8A85 Ext File Attributes   00000000 (0)\n+F8A89 Local Header Offset   00000000 (0)\n+F8A8D Filename              'XXXXXXXXX'\n #\n-# WARNING: Offset 0xE984E: Filename 'XXXXXXXXX'\n+# WARNING: Offset 0xF8A8D: Filename 'XXXXXXXXX'\n #          Zero length filename\n #\n-E9857 Extra ID #1           CAFE (51966) 'Java Executable'\n-E9859   Length              0000 (0)\n+F8A96 Extra ID #1           CAFE (51966) 'Java Executable'\n+F8A98   Length              0000 (0)\n \n-E985B CENTRAL HEADER #2     02014B50 (33639248)\n-E985F Created Zip Spec      14 (20) '2.0'\n-E9860 Created OS            00 (0) 'MS-DOS'\n-E9861 Extract Zip Spec      14 (20) '2.0'\n-E9862 Extract OS            00 (0) 'MS-DOS'\n-E9863 General Purpose Flag  0808 (2056)\n+F8A9A CENTRAL HEADER #2     02014B50 (33639248)\n+F8A9E Created Zip Spec      14 (20) '2.0'\n+F8A9F Created OS            00 (0) 'MS-DOS'\n+F8AA0 Extract Zip Spec      14 (20) '2.0'\n+F8AA1 Extract OS            00 (0) 'MS-DOS'\n+F8AA2 General Purpose Flag  0808 (2056)\n       [Bits 1-2]            0 'Normal Compression'\n       [Bit  3]              1 'Streamed'\n       [Bit 11]              1 'Language Encoding'\n-E9865 Compression Method    0008 (8) 'Deflated'\n-E9867 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n-E986B CRC                   2AFBFC44 (721157188)\n-E986F Compressed Size       0000008B (139)\n-E9873 Uncompressed Size     000000D7 (215)\n-E9877 Filename Length       0014 (20)\n-E9879 Extra Length          0000 (0)\n-E987B Comment Length        0000 (0)\n-E987D Disk Start            0000 (0)\n-E987F Int File Attributes   0000 (0)\n+F8AA4 Compression Method    0008 (8) 'Deflated'\n+F8AA6 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n+F8AAA CRC                   2AFBFC44 (721157188)\n+F8AAE Compressed Size       0000008B (139)\n+F8AB2 Uncompressed Size     000000D7 (215)\n+F8AB6 Filename Length       0014 (20)\n+F8AB8 Extra Length          0000 (0)\n+F8ABA Comment Length        0000 (0)\n+F8ABC Disk Start            0000 (0)\n+F8ABE Int File Attributes   0000 (0)\n       [Bit 0]               0 'Binary Data'\n-E9881 Ext File Attributes   00000000 (0)\n-E9885 Local Header Offset   0000002B (43)\n-E9889 Filename              'XXXXXXXXXXXXXXXXXXXX'\n+F8AC0 Ext File Attributes   00000000 (0)\n+F8AC4 Local Header Offset   0000002B (43)\n+F8AC8 Filename              'XXXXXXXXXXXXXXXXXXXX'\n #\n-# WARNING: Offset 0xE9889: Filename 'XXXXXXXXXXXXXXXXXXXX'\n+# WARNING: Offset 0xF8AC8: Filename 'XXXXXXXXXXXXXXXXXXXX'\n #          Zero length filename\n #\n \n-E989D CENTRAL HEADER #3     02014B50 (33639248)\n-E98A1 Created Zip Spec      0A (10) '1.0'\n-E98A2 Created OS            00 (0) 'MS-DOS'\n-E98A3 Extract Zip Spec      0A (10) '1.0'\n-E98A4 Extract OS            00 (0) 'MS-DOS'\n-E98A5 General Purpose Flag  0800 (2048)\n+F8ADC CENTRAL HEADER #3     02014B50 (33639248)\n+F8AE0 Created Zip Spec      0A (10) '1.0'\n+F8AE1 Created OS            00 (0) 'MS-DOS'\n+F8AE2 Extract Zip Spec      0A (10) '1.0'\n+F8AE3 Extract OS            00 (0) 'MS-DOS'\n+F8AE4 General Purpose Flag  0800 (2048)\n       [Bit 11]              1 'Language Encoding'\n-E98A7 Compression Method    0000 (0) 'Stored'\n-E98A9 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n-E98AD CRC                   00000000 (0)\n-E98B1 Compressed Size       00000000 (0)\n-E98B5 Uncompressed Size     00000000 (0)\n-E98B9 Filename Length       0009 (9)\n-E98BB Extra Length          0000 (0)\n-E98BD Comment Length        0000 (0)\n-E98BF Disk Start            0000 (0)\n-E98C1 Int File Attributes   0000 (0)\n+F8AE6 Compression Method    0000 (0) 'Stored'\n+F8AE8 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n+F8AEC CRC                   00000000 (0)\n+F8AF0 Compressed Size       00000000 (0)\n+F8AF4 Uncompressed Size     00000000 (0)\n+F8AF8 Filename Length       0009 (9)\n+F8AFA Extra Length          0000 (0)\n+F8AFC Comment Length        0000 (0)\n+F8AFE Disk Start            0000 (0)\n+F8B00 Int File Attributes   0000 (0)\n       [Bit 0]               0 'Binary Data'\n-E98C3 Ext File Attributes   00000000 (0)\n-E98C7 Local Header Offset   000000F8 (248)\n-E98CB Filename              'XXXXXXXXX'\n+F8B02 Ext File Attributes   00000000 (0)\n+F8B06 Local Header Offset   000000F8 (248)\n+F8B0A Filename              'XXXXXXXXX'\n #\n-# WARNING: Offset 0xE98CB: Filename 'XXXXXXXXX'\n+# WARNING: Offset 0xF8B0A: Filename 'XXXXXXXXX'\n #          Zero length filename\n #\n \n-E98D4 CENTRAL HEADER #4     02014B50 (33639248)\n-E98D8 Created Zip Spec      0A (10) '1.0'\n-E98D9 Created OS            00 (0) 'MS-DOS'\n-E98DA Extract Zip Spec      0A (10) '1.0'\n-E98DB Extract OS            00 (0) 'MS-DOS'\n-E98DC General Purpose Flag  0800 (2048)\n+F8B13 CENTRAL HEADER #4     02014B50 (33639248)\n+F8B17 Created Zip Spec      0A (10) '1.0'\n+F8B18 Created OS            00 (0) 'MS-DOS'\n+F8B19 Extract Zip Spec      0A (10) '1.0'\n+F8B1A Extract OS            00 (0) 'MS-DOS'\n+F8B1B General Purpose Flag  0800 (2048)\n       [Bit 11]              1 'Language Encoding'\n-E98DE Compression Method    0000 (0) 'Stored'\n-E98E0 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n-E98E4 CRC                   00000000 (0)\n-E98E8 Compressed Size       00000000 (0)\n-E98EC Uncompressed Size     00000000 (0)\n-E98F0 Filename Length       0003 (3)\n-E98F2 Extra Length          0000 (0)\n-E98F4 Comment Length        0000 (0)\n-E98F6 Disk Start            0000 (0)\n-E98F8 Int File Attributes   0000 (0)\n+F8B1D Compression Method    0000 (0) 'Stored'\n+F8B1F Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n+F8B23 CRC                   00000000 (0)\n+F8B27 Compressed Size       00000000 (0)\n+F8B2B Uncompressed Size     00000000 (0)\n+F8B2F Filename Length       0003 (3)\n+F8B31 Extra Length          0000 (0)\n+F8B33 Comment Length        0000 (0)\n+F8B35 Disk Start            0000 (0)\n+F8B37 Int File Attributes   0000 (0)\n       [Bit 0]               0 'Binary Data'\n-E98FA Ext File Attributes   00000000 (0)\n-E98FE Local Header Offset   0000011F (287)\n-E9902 Filename              'XXX'\n+F8B39 Ext File Attributes   00000000 (0)\n+F8B3D Local Header Offset   0000011F (287)\n+F8B41 Filename              'XXX'\n #\n-# WARNING: Offset 0xE9902: Filename 'XXX'\n+# WARNING: Offset 0xF8B41: Filename 'XXX'\n #          Zero length filename\n #\n \n-E9905 CENTRAL HEADER #5     02014B50 (33639248)\n-E9909 Created Zip Spec      0A (10) '1.0'\n-E990A Created OS            00 (0) 'MS-DOS'\n-E990B Extract Zip Spec      0A (10) '1.0'\n-E990C Extract OS            00 (0) 'MS-DOS'\n-E990D General Purpose Flag  0800 (2048)\n+F8B44 CENTRAL HEADER #5     02014B50 (33639248)\n+F8B48 Created Zip Spec      0A (10) '1.0'\n+F8B49 Created OS            00 (0) 'MS-DOS'\n+F8B4A Extract Zip Spec      0A (10) '1.0'\n+F8B4B Extract OS            00 (0) 'MS-DOS'\n+F8B4C General Purpose Flag  0800 (2048)\n       [Bit 11]              1 'Language Encoding'\n-E990F Compression Method    0000 (0) 'Stored'\n-E9911 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n-E9915 CRC                   00000000 (0)\n-E9919 Compressed Size       00000000 (0)\n-E991D Uncompressed Size     00000000 (0)\n-E9921 Filename Length       0009 (9)\n-E9923 Extra Length          0000 (0)\n-E9925 Comment Length        0000 (0)\n-E9927 Disk Start            0000 (0)\n-E9929 Int File Attributes   0000 (0)\n+F8B4E Compression Method    0000 (0) 'Stored'\n+F8B50 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n+F8B54 CRC                   00000000 (0)\n+F8B58 Compressed Size       00000000 (0)\n+F8B5C Uncompressed Size     00000000 (0)\n+F8B60 Filename Length       0009 (9)\n+F8B62 Extra Length          0000 (0)\n+F8B64 Comment Length        0000 (0)\n+F8B66 Disk Start            0000 (0)\n+F8B68 Int File Attributes   0000 (0)\n       [Bit 0]               0 'Binary Data'\n-E992B Ext File Attributes   00000000 (0)\n-E992F Local Header Offset   00000140 (320)\n-E9933 Filename              'XXXXXXXXX'\n+F8B6A Ext File Attributes   00000000 (0)\n+F8B6E Local Header Offset   00000140 (320)\n+F8B72 Filename              'XXXXXXXXX'\n #\n-# WARNING: Offset 0xE9933: Filename 'XXXXXXXXX'\n+# WARNING: Offset 0xF8B72: Filename 'XXXXXXXXX'\n #          Zero length filename\n #\n \n-E993C CENTRAL HEADER #6     02014B50 (33639248)\n-E9940 Created Zip Spec      0A (10) '1.0'\n-E9941 Created OS            00 (0) 'MS-DOS'\n-E9942 Extract Zip Spec      0A (10) '1.0'\n-E9943 Extract OS            00 (0) 'MS-DOS'\n-E9944 General Purpose Flag  0800 (2048)\n+F8B7B CENTRAL HEADER #6     02014B50 (33639248)\n+F8B7F Created Zip Spec      0A (10) '1.0'\n+F8B80 Created OS            00 (0) 'MS-DOS'\n+F8B81 Extract Zip Spec      0A (10) '1.0'\n+F8B82 Extract OS            00 (0) 'MS-DOS'\n+F8B83 General Purpose Flag  0800 (2048)\n       [Bit 11]              1 'Language Encoding'\n-E9946 Compression Method    0000 (0) 'Stored'\n-E9948 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n-E994C CRC                   00000000 (0)\n-E9950 Compressed Size       00000000 (0)\n-E9954 Uncompressed Size     00000000 (0)\n-E9958 Filename Length       0012 (18)\n-E995A Extra Length          0000 (0)\n-E995C Comment Length        0000 (0)\n-E995E Disk Start            0000 (0)\n-E9960 Int File Attributes   0000 (0)\n+F8B85 Compression Method    0000 (0) 'Stored'\n+F8B87 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n+F8B8B CRC                   00000000 (0)\n+F8B8F Compressed Size       00000000 (0)\n+F8B93 Uncompressed Size     00000000 (0)\n+F8B97 Filename Length       0012 (18)\n+F8B99 Extra Length          0000 (0)\n+F8B9B Comment Length        0000 (0)\n+F8B9D Disk Start            0000 (0)\n+F8B9F Int File Attributes   0000 (0)\n       [Bit 0]               0 'Binary Data'\n-E9962 Ext File Attributes   00000000 (0)\n-E9966 Local Header Offset   00000167 (359)\n-E996A Filename              'XXXXXXXXXXXXXXXXXX'\n+F8BA1 Ext File Attributes   00000000 (0)\n+F8BA5 Local Header Offset   00000167 (359)\n+F8BA9 Filename              'XXXXXXXXXXXXXXXXXX'\n #\n-# WARNING: Offset 0xE996A: Filename 'XXXXXXXXXXXXXXXXXX'\n+# WARNING: Offset 0xF8BA9: Filename 'XXXXXXXXXXXXXXXXXX'\n #          Zero length filename\n #\n \n-E997C CENTRAL HEADER #7     02014B50 (33639248)\n-E9980 Created Zip Spec      0A (10) '1.0'\n-E9981 Created OS            00 (0) 'MS-DOS'\n-E9982 Extract Zip Spec      0A (10) '1.0'\n-E9983 Extract OS            00 (0) 'MS-DOS'\n-E9984 General Purpose Flag  0800 (2048)\n+F8BBB CENTRAL HEADER #7     02014B50 (33639248)\n+F8BBF Created Zip Spec      0A (10) '1.0'\n+F8BC0 Created OS            00 (0) 'MS-DOS'\n+F8BC1 Extract Zip Spec      0A (10) '1.0'\n+F8BC2 Extract OS            00 (0) 'MS-DOS'\n+F8BC3 General Purpose Flag  0800 (2048)\n       [Bit 11]              1 'Language Encoding'\n-E9986 Compression Method    0000 (0) 'Stored'\n-E9988 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n-E998C CRC                   00000000 (0)\n-E9990 Compressed Size       00000000 (0)\n-E9994 Uncompressed Size     00000000 (0)\n-E9998 Filename Length       000F (15)\n-E999A Extra Length          0000 (0)\n-E999C Comment Length        0000 (0)\n-E999E Disk Start            0000 (0)\n-E99A0 Int File Attributes   0000 (0)\n+F8BC5 Compression Method    0000 (0) 'Stored'\n+F8BC7 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n+F8BCB CRC                   00000000 (0)\n+F8BCF Compressed Size       00000000 (0)\n+F8BD3 Uncompressed Size     00000000 (0)\n+F8BD7 Filename Length       000F (15)\n+F8BD9 Extra Length          0000 (0)\n+F8BDB Comment Length        0000 (0)\n+F8BDD Disk Start            0000 (0)\n+F8BDF Int File Attributes   0000 (0)\n       [Bit 0]               0 'Binary Data'\n-E99A2 Ext File Attributes   00000000 (0)\n-E99A6 Local Header Offset   00000197 (407)\n-E99AA Filename              'XXXXXXXXXXXXXXX'\n+F8BE1 Ext File Attributes   00000000 (0)\n+F8BE5 Local Header Offset   00000197 (407)\n+F8BE9 Filename              'XXXXXXXXXXXXXXX'\n #\n-# WARNING: Offset 0xE99AA: Filename 'XXXXXXXXXXXXXXX'\n+# WARNING: Offset 0xF8BE9: Filename 'XXXXXXXXXXXXXXX'\n #          Zero length filename\n #\n \n-E99B9 CENTRAL HEADER #8     02014B50 (33639248)\n-E99BD Created Zip Spec      0A (10) '1.0'\n-E99BE Created OS            00 (0) 'MS-DOS'\n-E99BF Extract Zip Spec      0A (10) '1.0'\n-E99C0 Extract OS            00 (0) 'MS-DOS'\n-E99C1 General Purpose Flag  0800 (2048)\n+F8BF8 CENTRAL HEADER #8     02014B50 (33639248)\n+F8BFC Created Zip Spec      0A (10) '1.0'\n+F8BFD Created OS            00 (0) 'MS-DOS'\n+F8BFE Extract Zip Spec      0A (10) '1.0'\n+F8BFF Extract OS            00 (0) 'MS-DOS'\n+F8C00 General Purpose Flag  0800 (2048)\n       [Bit 11]              1 'Language Encoding'\n-E99C3 Compression Method    0000 (0) 'Stored'\n-E99C5 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n-E99C9 CRC                   00000000 (0)\n-E99CD Compressed Size       00000000 (0)\n-E99D1 Uncompressed Size     00000000 (0)\n-E99D5 Filename Length       0018 (24)\n-E99D7 Extra Length          0000 (0)\n-E99D9 Comment Length        0000 (0)\n-E99DB Disk Start            0000 (0)\n-E99DD Int File Attributes   0000 (0)\n+F8C02 Compression Method    0000 (0) 'Stored'\n+F8C04 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n+F8C08 CRC                   00000000 (0)\n+F8C0C Compressed Size       00000000 (0)\n+F8C10 Uncompressed Size     00000000 (0)\n+F8C14 Filename Length       0018 (24)\n+F8C16 Extra Length          0000 (0)\n+F8C18 Comment Length        0000 (0)\n+F8C1A Disk Start            0000 (0)\n+F8C1C Int File Attributes   0000 (0)\n       [Bit 0]               0 'Binary Data'\n-E99DF Ext File Attributes   00000000 (0)\n-E99E3 Local Header Offset   000001C4 (452)\n-E99E7 Filename              'XXXXXXXXXXXXXXXXXXXXXXXX'\n+F8C1E Ext File Attributes   00000000 (0)\n+F8C22 Local Header Offset   000001C4 (452)\n+F8C26 Filename              'XXXXXXXXXXXXXXXXXXXXXXXX'\n #\n-# WARNING: Offset 0xE99E7: Filename 'XXXXXXXXXXXXXXXXXXXXXXXX'\n+# WARNING: Offset 0xF8C26: Filename 'XXXXXXXXXXXXXXXXXXXXXXXX'\n #          Zero length filename\n #\n \n-E99FF CENTRAL HEADER #9     02014B50 (33639248)\n-E9A03 Created Zip Spec      0A (10) '1.0'\n-E9A04 Created OS            00 (0) 'MS-DOS'\n-E9A05 Extract Zip Spec      0A (10) '1.0'\n-E9A06 Extract OS            00 (0) 'MS-DOS'\n-E9A07 General Purpose Flag  0800 (2048)\n+F8C3E CENTRAL HEADER #9     02014B50 (33639248)\n+F8C42 Created Zip Spec      0A (10) '1.0'\n+F8C43 Created OS            00 (0) 'MS-DOS'\n+F8C44 Extract Zip Spec      0A (10) '1.0'\n+F8C45 Extract OS            00 (0) 'MS-DOS'\n+F8C46 General Purpose Flag  0800 (2048)\n       [Bit 11]              1 'Language Encoding'\n-E9A09 Compression Method    0000 (0) 'Stored'\n-E9A0B Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n-E9A0F CRC                   00000000 (0)\n-E9A13 Compressed Size       00000000 (0)\n-E9A17 Uncompressed Size     00000000 (0)\n-E9A1B Filename Length       0027 (39)\n-E9A1D Extra Length          0000 (0)\n-E9A1F Comment Length        0000 (0)\n-E9A21 Disk Start            0000 (0)\n-E9A23 Int File Attributes   0000 (0)\n+F8C48 Compression Method    0000 (0) 'Stored'\n+F8C4A Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n+F8C4E CRC                   00000000 (0)\n+F8C52 Compressed Size       00000000 (0)\n+F8C56 Uncompressed Size     00000000 (0)\n+F8C5A Filename Length       0027 (39)\n+F8C5C Extra Length          0000 (0)\n+F8C5E Comment Length        0000 (0)\n+F8C60 Disk Start            0000 (0)\n+F8C62 Int File Attributes   0000 (0)\n       [Bit 0]               0 'Binary Data'\n-E9A25 Ext File Attributes   00000000 (0)\n-E9A29 Local Header Offset   000001FA (506)\n-E9A2D Filename              'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n+F8C64 Ext File Attributes   00000000 (0)\n+F8C68 Local Header Offset   000001FA (506)\n+F8C6C Filename              'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n #\n-# WARNING: Offset 0xE9A2D: Filename 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n+# WARNING: Offset 0xF8C6C: Filename 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n #          Zero length filename\n #\n \n-E9A54 CENTRAL HEADER #10    02014B50 (33639248)\n-E9A58 Created Zip Spec      14 (20) '2.0'\n-E9A59 Created OS            00 (0) 'MS-DOS'\n-E9A5A Extract Zip Spec      14 (20) '2.0'\n-E9A5B Extract OS            00 (0) 'MS-DOS'\n-E9A5C General Purpose Flag  0808 (2056)\n+F8C93 CENTRAL HEADER #10    02014B50 (33639248)\n+F8C97 Created Zip Spec      14 (20) '2.0'\n+F8C98 Created OS            00 (0) 'MS-DOS'\n+F8C99 Extract Zip Spec      14 (20) '2.0'\n+F8C9A Extract OS            00 (0) 'MS-DOS'\n+F8C9B General Purpose Flag  0808 (2056)\n       [Bits 1-2]            0 'Normal Compression'\n       [Bit  3]              1 'Streamed'\n       [Bit 11]              1 'Language Encoding'\n-E9A5E Compression Method    0008 (8) 'Deflated'\n-E9A60 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n-E9A64 CRC                   1ED61AD6 (517348054)\n-E9A68 Compressed Size       000437E0 (276448)\n-E9A6C Uncompressed Size     00064E6A (413290)\n-E9A70 Filename Length       0015 (21)\n-E9A72 Extra Length          0000 (0)\n-E9A74 Comment Length        0000 (0)\n-E9A76 Disk Start            0000 (0)\n-E9A78 Int File Attributes   0000 (0)\n+F8C9D Compression Method    0008 (8) 'Deflated'\n+F8C9F Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n+F8CA3 CRC                   51FB39FC (1375418876)\n+F8CA7 Compressed Size       00044361 (279393)\n+F8CAB Uncompressed Size     00067D93 (425363)\n+F8CAF Filename Length       0015 (21)\n+F8CB1 Extra Length          0000 (0)\n+F8CB3 Comment Length        0000 (0)\n+F8CB5 Disk Start            0000 (0)\n+F8CB7 Int File Attributes   0000 (0)\n       [Bit 0]               0 'Binary Data'\n-E9A7A Ext File Attributes   00000000 (0)\n-E9A7E Local Header Offset   0000023F (575)\n-E9A82 Filename              'XXXXXXXXXXXXXXXXXXXXX'\n+F8CB9 Ext File Attributes   00000000 (0)\n+F8CBD Local Header Offset   0000023F (575)\n+F8CC1 Filename              'XXXXXXXXXXXXXXXXXXXXX'\n #\n-# WARNING: Offset 0xE9A82: Filename 'XXXXXXXXXXXXXXXXXXXXX'\n+# WARNING: Offset 0xF8CC1: Filename 'XXXXXXXXXXXXXXXXXXXXX'\n #          Zero length filename\n #\n \n-E9A97 CENTRAL HEADER #11    02014B50 (33639248)\n-E9A9B Created Zip Spec      14 (20) '2.0'\n-E9A9C Created OS            00 (0) 'MS-DOS'\n-E9A9D Extract Zip Spec      14 (20) '2.0'\n-E9A9E Extract OS            00 (0) 'MS-DOS'\n-E9A9F General Purpose Flag  0808 (2056)\n+F8CD6 CENTRAL HEADER #11    02014B50 (33639248)\n+F8CDA Created Zip Spec      14 (20) '2.0'\n+F8CDB Created OS            00 (0) 'MS-DOS'\n+F8CDC Extract Zip Spec      14 (20) '2.0'\n+F8CDD Extract OS            00 (0) 'MS-DOS'\n+F8CDE General Purpose Flag  0808 (2056)\n       [Bits 1-2]            0 'Normal Compression'\n       [Bit  3]              1 'Streamed'\n       [Bit 11]              1 'Language Encoding'\n-E9AA1 Compression Method    0008 (8) 'Deflated'\n-E9AA3 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n-E9AA7 CRC                   FB1D5E8A (4213005962)\n-E9AAB Compressed Size       000A4B28 (674600)\n-E9AAF Uncompressed Size     00308DB5 (3182005)\n-E9AB3 Filename Length       0018 (24)\n-E9AB5 Extra Length          0000 (0)\n-E9AB7 Comment Length        0000 (0)\n-E9AB9 Disk Start            0000 (0)\n-E9ABB Int File Attributes   0000 (0)\n+F8CE0 Compression Method    0008 (8) 'Deflated'\n+F8CE2 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n+F8CE6 CRC                   6A282AC4 (1781017284)\n+F8CEA Compressed Size       000B31E6 (733670)\n+F8CEE Uncompressed Size     00359CE8 (3513576)\n+F8CF2 Filename Length       0018 (24)\n+F8CF4 Extra Length          0000 (0)\n+F8CF6 Comment Length        0000 (0)\n+F8CF8 Disk Start            0000 (0)\n+F8CFA Int File Attributes   0000 (0)\n       [Bit 0]               0 'Binary Data'\n-E9ABD Ext File Attributes   00000000 (0)\n-E9AC1 Local Header Offset   00043A62 (277090)\n-E9AC5 Filename              'XXXXXXXXXXXXXXXXXXXXXXXX'\n+F8CFC Ext File Attributes   00000000 (0)\n+F8D00 Local Header Offset   000445E3 (280035)\n+F8D04 Filename              'XXXXXXXXXXXXXXXXXXXXXXXX'\n #\n-# WARNING: Offset 0xE9AC5: Filename 'XXXXXXXXXXXXXXXXXXXXXXXX'\n+# WARNING: Offset 0xF8D04: Filename 'XXXXXXXXXXXXXXXXXXXXXXXX'\n #          Zero length filename\n #\n \n-E9ADD CENTRAL HEADER #12    02014B50 (33639248)\n-E9AE1 Created Zip Spec      14 (20) '2.0'\n-E9AE2 Created OS            00 (0) 'MS-DOS'\n-E9AE3 Extract Zip Spec      14 (20) '2.0'\n-E9AE4 Extract OS            00 (0) 'MS-DOS'\n-E9AE5 General Purpose Flag  0808 (2056)\n+F8D1C CENTRAL HEADER #12    02014B50 (33639248)\n+F8D20 Created Zip Spec      14 (20) '2.0'\n+F8D21 Created OS            00 (0) 'MS-DOS'\n+F8D22 Extract Zip Spec      14 (20) '2.0'\n+F8D23 Extract OS            00 (0) 'MS-DOS'\n+F8D24 General Purpose Flag  0808 (2056)\n       [Bits 1-2]            0 'Normal Compression'\n       [Bit  3]              1 'Streamed'\n       [Bit 11]              1 'Language Encoding'\n-E9AE7 Compression Method    0008 (8) 'Deflated'\n-E9AE9 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n-E9AED CRC                   B0DD7B98 (2967305112)\n-E9AF1 Compressed Size       00000D43 (3395)\n-E9AF5 Uncompressed Size     00002E42 (11842)\n-E9AF9 Filename Length       0026 (38)\n-E9AFB Extra Length          0000 (0)\n-E9AFD Comment Length        0000 (0)\n-E9AFF Disk Start            0000 (0)\n-E9B01 Int File Attributes   0000 (0)\n+F8D26 Compression Method    0008 (8) 'Deflated'\n+F8D28 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n+F8D2C CRC                   B0DD7B98 (2967305112)\n+F8D30 Compressed Size       00000D43 (3395)\n+F8D34 Uncompressed Size     00002E42 (11842)\n+F8D38 Filename Length       0026 (38)\n+F8D3A Extra Length          0000 (0)\n+F8D3C Comment Length        0000 (0)\n+F8D3E Disk Start            0000 (0)\n+F8D40 Int File Attributes   0000 (0)\n       [Bit 0]               0 'Binary Data'\n-E9B03 Ext File Attributes   00000000 (0)\n-E9B07 Local Header Offset   000E85D0 (951760)\n-E9B0B Filename              'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n+F8D42 Ext File Attributes   00000000 (0)\n+F8D46 Local Header Offset   000F780F (1013775)\n+F8D4A Filename              'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n #\n-# WARNING: Offset 0xE9B0B: Filename 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n+# WARNING: Offset 0xF8D4A: Filename 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n #          Zero length filename\n #\n \n-E9B31 CENTRAL HEADER #13    02014B50 (33639248)\n-E9B35 Created Zip Spec      14 (20) '2.0'\n-E9B36 Created OS            00 (0) 'MS-DOS'\n-E9B37 Extract Zip Spec      14 (20) '2.0'\n-E9B38 Extract OS            00 (0) 'MS-DOS'\n-E9B39 General Purpose Flag  0808 (2056)\n+F8D70 CENTRAL HEADER #13    02014B50 (33639248)\n+F8D74 Created Zip Spec      14 (20) '2.0'\n+F8D75 Created OS            00 (0) 'MS-DOS'\n+F8D76 Extract Zip Spec      14 (20) '2.0'\n+F8D77 Extract OS            00 (0) 'MS-DOS'\n+F8D78 General Purpose Flag  0808 (2056)\n       [Bits 1-2]            0 'Normal Compression'\n       [Bit  3]              1 'Streamed'\n       [Bit 11]              1 'Language Encoding'\n-E9B3B Compression Method    0008 (8) 'Deflated'\n-E9B3D Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n-E9B41 CRC                   53A5DFB4 (1403379636)\n-E9B45 Compressed Size       0000029B (667)\n-E9B49 Uncompressed Size     000008F3 (2291)\n-E9B4D Filename Length       002E (46)\n-E9B4F Extra Length          0000 (0)\n-E9B51 Comment Length        0000 (0)\n-E9B53 Disk Start            0000 (0)\n-E9B55 Int File Attributes   0000 (0)\n+F8D7A Compression Method    0008 (8) 'Deflated'\n+F8D7C Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n+F8D80 CRC                   53A5DFB4 (1403379636)\n+F8D84 Compressed Size       0000029B (667)\n+F8D88 Uncompressed Size     000008F3 (2291)\n+F8D8C Filename Length       002E (46)\n+F8D8E Extra Length          0000 (0)\n+F8D90 Comment Length        0000 (0)\n+F8D92 Disk Start            0000 (0)\n+F8D94 Int File Attributes   0000 (0)\n       [Bit 0]               0 'Binary Data'\n-E9B57 Ext File Attributes   00000000 (0)\n-E9B5B Local Header Offset   000E9367 (955239)\n-E9B5F Filename              'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n+F8D96 Ext File Attributes   00000000 (0)\n+F8D9A Local Header Offset   000F85A6 (1017254)\n+F8D9E Filename              'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n #\n-# WARNING: Offset 0xE9B5F: Filename 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n+# WARNING: Offset 0xF8D9E: Filename 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n #          Zero length filename\n #\n \n-E9B8D CENTRAL HEADER #14    02014B50 (33639248)\n-E9B91 Created Zip Spec      14 (20) '2.0'\n-E9B92 Created OS            00 (0) 'MS-DOS'\n-E9B93 Extract Zip Spec      14 (20) '2.0'\n-E9B94 Extract OS            00 (0) 'MS-DOS'\n-E9B95 General Purpose Flag  0808 (2056)\n+F8DCC CENTRAL HEADER #14    02014B50 (33639248)\n+F8DD0 Created Zip Spec      14 (20) '2.0'\n+F8DD1 Created OS            00 (0) 'MS-DOS'\n+F8DD2 Extract Zip Spec      14 (20) '2.0'\n+F8DD3 Extract OS            00 (0) 'MS-DOS'\n+F8DD4 General Purpose Flag  0808 (2056)\n       [Bits 1-2]            0 'Normal Compression'\n       [Bit  3]              1 'Streamed'\n       [Bit 11]              1 'Language Encoding'\n-E9B97 Compression Method    0008 (8) 'Deflated'\n-E9B99 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n-E9B9D CRC                   35B620D5 (901128405)\n-E9BA1 Compressed Size       00000036 (54)\n-E9BA5 Uncompressed Size     00000039 (57)\n-E9BA9 Filename Length       0035 (53)\n-E9BAB Extra Length          0000 (0)\n-E9BAD Comment Length        0000 (0)\n-E9BAF Disk Start            0000 (0)\n-E9BB1 Int File Attributes   0000 (0)\n+F8DD6 Compression Method    0008 (8) 'Deflated'\n+F8DD8 Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n+F8DDC CRC                   35B620D5 (901128405)\n+F8DE0 Compressed Size       00000036 (54)\n+F8DE4 Uncompressed Size     00000039 (57)\n+F8DE8 Filename Length       0035 (53)\n+F8DEA Extra Length          0000 (0)\n+F8DEC Comment Length        0000 (0)\n+F8DEE Disk Start            0000 (0)\n+F8DF0 Int File Attributes   0000 (0)\n       [Bit 0]               0 'Binary Data'\n-E9BB3 Ext File Attributes   00000000 (0)\n-E9BB7 Local Header Offset   000E965E (955998)\n-E9BBB Filename              'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n+F8DF2 Ext File Attributes   00000000 (0)\n+F8DF6 Local Header Offset   000F889D (1018013)\n+F8DFA Filename              'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n #\n-# WARNING: Offset 0xE9BBB: Filename 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n+# WARNING: Offset 0xF8DFA: Filename 'XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'\n #          Zero length filename\n #\n \n-E9BF0 CENTRAL HEADER #15    02014B50 (33639248)\n-E9BF4 Created Zip Spec      14 (20) '2.0'\n-E9BF5 Created OS            00 (0) 'MS-DOS'\n-E9BF6 Extract Zip Spec      14 (20) '2.0'\n-E9BF7 Extract OS            00 (0) 'MS-DOS'\n-E9BF8 General Purpose Flag  0808 (2056)\n+F8E2F CENTRAL HEADER #15    02014B50 (33639248)\n+F8E33 Created Zip Spec      14 (20) '2.0'\n+F8E34 Created OS            00 (0) 'MS-DOS'\n+F8E35 Extract Zip Spec      14 (20) '2.0'\n+F8E36 Extract OS            00 (0) 'MS-DOS'\n+F8E37 General Purpose Flag  0808 (2056)\n       [Bits 1-2]            0 'Normal Compression'\n       [Bit  3]              1 'Streamed'\n       [Bit 11]              1 'Language Encoding'\n-E9BFA Compression Method    0008 (8) 'Deflated'\n-E9BFC Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n-E9C00 CRC                   A840B382 (2822812546)\n-E9C04 Compressed Size       000000EA (234)\n-E9C08 Uncompressed Size     0000014B (331)\n-E9C0C Filename Length       0011 (17)\n-E9C0E Extra Length          0000 (0)\n-E9C10 Comment Length        0000 (0)\n-E9C12 Disk Start            0000 (0)\n-E9C14 Int File Attributes   0000 (0)\n+F8E39 Compression Method    0008 (8) 'Deflated'\n+F8E3B Modification Time     58AD9030 (1487769648) 'Mon May 13 18:01:32 2024'\n+F8E3F CRC                   A840B382 (2822812546)\n+F8E43 Compressed Size       000000EA (234)\n+F8E47 Uncompressed Size     0000014B (331)\n+F8E4B Filename Length       0011 (17)\n+F8E4D Extra Length          0000 (0)\n+F8E4F Comment Length        0000 (0)\n+F8E51 Disk Start            0000 (0)\n+F8E53 Int File Attributes   0000 (0)\n       [Bit 0]               0 'Binary Data'\n-E9C16 Ext File Attributes   00000000 (0)\n-E9C1A Local Header Offset   000E96F7 (956151)\n-E9C1E Filename              'XXXXXXXXXXXXXXXXX'\n+F8E55 Ext File Attributes   00000000 (0)\n+F8E59 Local Header Offset   000F8936 (1018166)\n+F8E5D Filename              'XXXXXXXXXXXXXXXXX'\n #\n-# WARNING: Offset 0xE9C1E: Filename 'XXXXXXXXXXXXXXXXX'\n+# WARNING: Offset 0xF8E5D: Filename 'XXXXXXXXXXXXXXXXX'\n #          Zero length filename\n #\n \n-E9C2F END CENTRAL HEADER    06054B50 (101010256)\n-E9C33 Number of this disk   0000 (0)\n-E9C35 Central Dir Disk no   0000 (0)\n-E9C37 Entries in this disk  000F (15)\n-E9C39 Total Entries         000F (15)\n-E9C3B Size of Central Dir   0000040F (1039)\n-E9C3F Offset to Central Dir 000E9820 (956448)\n-E9C43 Comment Length        0000 (0)\n+F8E6E END CENTRAL HEADER    06054B50 (101010256)\n+F8E72 Number of this disk   0000 (0)\n+F8E74 Central Dir Disk no   0000 (0)\n+F8E76 Entries in this disk  000F (15)\n+F8E78 Total Entries         000F (15)\n+F8E7A Size of Central Dir   0000040F (1039)\n+F8E7E Offset to Central Dir 000F8A5F (1018463)\n+F8E82 Comment Length        0000 (0)\n #\n # Warning Count: 30\n #\n # Done\n"}, {"source1": "graphiql/graphiql.css", "source2": "graphiql/graphiql.css", "has_internal_linenos": true, "unified_diff": "@@ -22652,3180 +22652,3935 @@\n 000587b0: 742f 7374 796c 652e 6373 7320 2a2a 2a21  t/style.css ***!\n 000587c0: 0a20 205c 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  .  \\************\n 000587d0: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n 000587e0: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n 000587f0: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n 00058800: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n 00058810: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n-00058820: 2f0a 2e67 7261 7068 6971 6c2d 636f 6e74  /..graphiql-cont\n-00058830: 6169 6e65 7220 2a7b 626f 782d 7369 7a69  ainer *{box-sizi\n-00058840: 6e67 3a62 6f72 6465 722d 626f 783b 666f  ng:border-box;fo\n-00058850: 6e74 2d76 6172 6961 6e74 2d6c 6967 6174  nt-variant-ligat\n-00058860: 7572 6573 3a6e 6f6e 657d 2e67 7261 7068  ures:none}.graph\n-00058870: 6971 6c2d 636f 6e74 6169 6e65 722c 2e43  iql-container,.C\n-00058880: 6f64 654d 6972 726f 722d 696e 666f 2c2e  odeMirror-info,.\n-00058890: 436f 6465 4d69 7272 6f72 2d6c 696e 742d  CodeMirror-lint-\n-000588a0: 746f 6f6c 7469 702c 2e67 7261 7068 6971  tooltip,.graphiq\n-000588b0: 6c2d 6469 616c 6f67 2c2e 6772 6170 6869  l-dialog,.graphi\n-000588c0: 716c 2d64 6961 6c6f 672d 6f76 6572 6c61  ql-dialog-overla\n-000588d0: 792c 2e67 7261 7068 6971 6c2d 746f 6f6c  y,.graphiql-tool\n-000588e0: 7469 702c 5b64 6174 612d 7261 6469 782d  tip,[data-radix-\n-000588f0: 706f 7070 6572 2d63 6f6e 7465 6e74 2d77  popper-content-w\n-00058900: 7261 7070 6572 5d7b 2d2d 636f 6c6f 722d  rapper]{--color-\n-00058910: 7072 696d 6172 793a 2033 3230 2c20 3935  primary: 320, 95\n-00058920: 252c 2034 3325 3b2d 2d63 6f6c 6f72 2d73  %, 43%;--color-s\n-00058930: 6563 6f6e 6461 7279 3a20 3234 322c 2035  econdary: 242, 5\n-00058940: 3125 2c20 3631 253b 2d2d 636f 6c6f 722d  1%, 61%;--color-\n-00058950: 7465 7274 6961 7279 3a20 3138 382c 2031  tertiary: 188, 1\n-00058960: 3030 252c 2033 3625 3b2d 2d63 6f6c 6f72  00%, 36%;--color\n-00058970: 2d69 6e66 6f3a 2032 3038 2c20 3130 3025  -info: 208, 100%\n-00058980: 2c20 3436 253b 2d2d 636f 6c6f 722d 7375  , 46%;--color-su\n-00058990: 6363 6573 733a 2031 3538 2c20 3630 252c  ccess: 158, 60%,\n-000589a0: 2034 3225 3b2d 2d63 6f6c 6f72 2d77 6172   42%;--color-war\n-000589b0: 6e69 6e67 3a20 3336 2c20 3130 3025 2c20  ning: 36, 100%, \n-000589c0: 3431 253b 2d2d 636f 6c6f 722d 6572 726f  41%;--color-erro\n-000589d0: 723a 2031 332c 2039 3325 2c20 3538 253b  r: 13, 93%, 58%;\n-000589e0: 2d2d 636f 6c6f 722d 6e65 7574 7261 6c3a  --color-neutral:\n-000589f0: 2032 3139 2c20 3238 252c 2033 3225 3b2d   219, 28%, 32%;-\n-00058a00: 2d63 6f6c 6f72 2d62 6173 653a 2032 3139  -color-base: 219\n-00058a10: 2c20 3238 252c 2031 3030 253b 2d2d 616c  , 28%, 100%;--al\n-00058a20: 7068 612d 7365 636f 6e64 6172 793a 202e  pha-secondary: .\n-00058a30: 3736 3b2d 2d61 6c70 6861 2d74 6572 7469  76;--alpha-terti\n-00058a40: 6172 793a 202e 353b 2d2d 616c 7068 612d  ary: .5;--alpha-\n-00058a50: 6261 636b 6772 6f75 6e64 2d68 6561 7679  background-heavy\n-00058a60: 3a20 2e31 353b 2d2d 616c 7068 612d 6261  : .15;--alpha-ba\n-00058a70: 636b 6772 6f75 6e64 2d6d 6564 6975 6d3a  ckground-medium:\n-00058a80: 202e 313b 2d2d 616c 7068 612d 6261 636b   .1;--alpha-back\n-00058a90: 6772 6f75 6e64 2d6c 6967 6874 3a20 2e30  ground-light: .0\n-00058aa0: 373b 2d2d 666f 6e74 2d66 616d 696c 793a  7;--font-family:\n-00058ab0: 2022 526f 626f 746f 222c 2073 616e 732d   \"Roboto\", sans-\n-00058ac0: 7365 7269 663b 2d2d 666f 6e74 2d66 616d  serif;--font-fam\n-00058ad0: 696c 792d 6d6f 6e6f 3a20 2246 6972 6120  ily-mono: \"Fira \n-00058ae0: 436f 6465 222c 206d 6f6e 6f73 7061 6365  Code\", monospace\n-00058af0: 3b2d 2d66 6f6e 742d 7369 7a65 2d68 696e  ;--font-size-hin\n-00058b00: 743a 2e37 3572 656d 3b2d 2d66 6f6e 742d  t:.75rem;--font-\n-00058b10: 7369 7a65 2d69 6e6c 696e 652d 636f 6465  size-inline-code\n-00058b20: 3a2e 3831 3235 7265 6d3b 2d2d 666f 6e74  :.8125rem;--font\n-00058b30: 2d73 697a 652d 626f 6479 3a2e 3933 3735  -size-body:.9375\n-00058b40: 7265 6d3b 2d2d 666f 6e74 2d73 697a 652d  rem;--font-size-\n-00058b50: 6834 3a31 2e31 3235 7265 6d3b 2d2d 666f  h4:1.125rem;--fo\n-00058b60: 6e74 2d73 697a 652d 6833 3a31 2e33 3735  nt-size-h3:1.375\n-00058b70: 7265 6d3b 2d2d 666f 6e74 2d73 697a 652d  rem;--font-size-\n-00058b80: 6832 3a31 2e38 3132 3572 656d 3b2d 2d66  h2:1.8125rem;--f\n-00058b90: 6f6e 742d 7765 6967 6874 2d72 6567 756c  ont-weight-regul\n-00058ba0: 6172 3a20 3430 303b 2d2d 666f 6e74 2d77  ar: 400;--font-w\n-00058bb0: 6569 6768 742d 6d65 6469 756d 3a20 3530  eight-medium: 50\n-00058bc0: 303b 2d2d 6c69 6e65 2d68 6569 6768 743a  0;--line-height:\n-00058bd0: 2031 2e35 3b2d 2d70 782d 323a 2032 7078   1.5;--px-2: 2px\n-00058be0: 3b2d 2d70 782d 343a 2034 7078 3b2d 2d70  ;--px-4: 4px;--p\n-00058bf0: 782d 363a 2036 7078 3b2d 2d70 782d 383a  x-6: 6px;--px-8:\n-00058c00: 2038 7078 3b2d 2d70 782d 3130 3a20 3130   8px;--px-10: 10\n-00058c10: 7078 3b2d 2d70 782d 3132 3a20 3132 7078  px;--px-12: 12px\n-00058c20: 3b2d 2d70 782d 3136 3a20 3136 7078 3b2d  ;--px-16: 16px;-\n-00058c30: 2d70 782d 3230 3a20 3230 7078 3b2d 2d70  -px-20: 20px;--p\n-00058c40: 782d 3234 3a20 3234 7078 3b2d 2d62 6f72  x-24: 24px;--bor\n-00058c50: 6465 722d 7261 6469 7573 2d32 3a20 3270  der-radius-2: 2p\n-00058c60: 783b 2d2d 626f 7264 6572 2d72 6164 6975  x;--border-radiu\n-00058c70: 732d 343a 2034 7078 3b2d 2d62 6f72 6465  s-4: 4px;--borde\n-00058c80: 722d 7261 6469 7573 2d38 3a20 3870 783b  r-radius-8: 8px;\n-00058c90: 2d2d 626f 7264 6572 2d72 6164 6975 732d  --border-radius-\n-00058ca0: 3132 3a20 3132 7078 3b2d 2d70 6f70 6f76  12: 12px;--popov\n-00058cb0: 6572 2d62 6f78 2d73 6861 646f 773a 2030  er-box-shadow: 0\n-00058cc0: 7078 2036 7078 2032 3070 7820 7267 6261  px 6px 20px rgba\n-00058cd0: 2835 392c 2037 362c 2031 3036 2c20 2e31  (59, 76, 106, .1\n-00058ce0: 3329 2c20 3070 7820 312e 3334 3031 3870  3), 0px 1.34018p\n-00058cf0: 7820 342e 3436 3732 3670 7820 7267 6261  x 4.46726px rgba\n-00058d00: 2835 392c 2037 362c 2031 3036 2c20 2e30  (59, 76, 106, .0\n-00058d10: 3737 3439 3339 292c 2030 7078 202e 3339  774939), 0px .39\n-00058d20: 3930 3036 7078 2031 2e33 3330 3032 7078  9006px 1.33002px\n-00058d30: 2072 6762 6128 3539 2c20 3736 2c20 3130   rgba(59, 76, 10\n-00058d40: 362c 202e 3035 3235 3036 3129 3b2d 2d70  6, .0525061);--p\n-00058d50: 6f70 6f76 6572 2d62 6f72 6465 723a 206e  opover-border: n\n-00058d60: 6f6e 653b 2d2d 7369 6465 6261 722d 7769  one;--sidebar-wi\n-00058d70: 6474 683a 2036 3070 783b 2d2d 746f 6f6c  dth: 60px;--tool\n-00058d80: 6261 722d 7769 6474 683a 2034 3070 783b  bar-width: 40px;\n-00058d90: 2d2d 7365 7373 696f 6e2d 6865 6164 6572  --session-header\n-00058da0: 2d68 6569 6768 743a 2035 3170 787d 406d  -height: 51px}@m\n-00058db0: 6564 6961 2028 7072 6566 6572 732d 636f  edia (prefers-co\n-00058dc0: 6c6f 722d 7363 6865 6d65 3a20 6461 726b  lor-scheme: dark\n-00058dd0: 297b 626f 6479 3a6e 6f74 282e 6772 6170  ){body:not(.grap\n-00058de0: 6869 716c 2d6c 6967 6874 2920 2e67 7261  hiql-light) .gra\n-00058df0: 7068 6971 6c2d 636f 6e74 6169 6e65 722c  phiql-container,\n-00058e00: 626f 6479 3a6e 6f74 282e 6772 6170 6869  body:not(.graphi\n-00058e10: 716c 2d6c 6967 6874 2920 2e43 6f64 654d  ql-light) .CodeM\n-00058e20: 6972 726f 722d 696e 666f 2c62 6f64 793a  irror-info,body:\n-00058e30: 6e6f 7428 2e67 7261 7068 6971 6c2d 6c69  not(.graphiql-li\n-00058e40: 6768 7429 202e 436f 6465 4d69 7272 6f72  ght) .CodeMirror\n-00058e50: 2d6c 696e 742d 746f 6f6c 7469 702c 626f  -lint-tooltip,bo\n-00058e60: 6479 3a6e 6f74 282e 6772 6170 6869 716c  dy:not(.graphiql\n-00058e70: 2d6c 6967 6874 2920 2e67 7261 7068 6971  -light) .graphiq\n-00058e80: 6c2d 6469 616c 6f67 2c62 6f64 793a 6e6f  l-dialog,body:no\n-00058e90: 7428 2e67 7261 7068 6971 6c2d 6c69 6768  t(.graphiql-ligh\n-00058ea0: 7429 202e 6772 6170 6869 716c 2d64 6961  t) .graphiql-dia\n-00058eb0: 6c6f 672d 6f76 6572 6c61 792c 626f 6479  log-overlay,body\n-00058ec0: 3a6e 6f74 282e 6772 6170 6869 716c 2d6c  :not(.graphiql-l\n-00058ed0: 6967 6874 2920 2e67 7261 7068 6971 6c2d  ight) .graphiql-\n-00058ee0: 746f 6f6c 7469 702c 626f 6479 3a6e 6f74  tooltip,body:not\n-00058ef0: 282e 6772 6170 6869 716c 2d6c 6967 6874  (.graphiql-light\n-00058f00: 2920 5b64 6174 612d 7261 6469 782d 706f  ) [data-radix-po\n-00058f10: 7070 6572 2d63 6f6e 7465 6e74 2d77 7261  pper-content-wra\n-00058f20: 7070 6572 5d7b 2d2d 636f 6c6f 722d 7072  pper]{--color-pr\n-00058f30: 696d 6172 793a 2033 3338 2c20 3130 3025  imary: 338, 100%\n-00058f40: 2c20 3637 253b 2d2d 636f 6c6f 722d 7365  , 67%;--color-se\n-00058f50: 636f 6e64 6172 793a 2032 3433 2c20 3130  condary: 243, 10\n-00058f60: 3025 2c20 3737 253b 2d2d 636f 6c6f 722d  0%, 77%;--color-\n-00058f70: 7465 7274 6961 7279 3a20 3138 382c 2031  tertiary: 188, 1\n-00058f80: 3030 252c 2034 3425 3b2d 2d63 6f6c 6f72  00%, 44%;--color\n-00058f90: 2d69 6e66 6f3a 2032 3038 2c20 3130 3025  -info: 208, 100%\n-00058fa0: 2c20 3732 253b 2d2d 636f 6c6f 722d 7375  , 72%;--color-su\n-00058fb0: 6363 6573 733a 2031 3538 2c20 3130 3025  ccess: 158, 100%\n-00058fc0: 2c20 3432 253b 2d2d 636f 6c6f 722d 7761  , 42%;--color-wa\n-00058fd0: 726e 696e 673a 2033 302c 2031 3030 252c  rning: 30, 100%,\n-00058fe0: 2038 3025 3b2d 2d63 6f6c 6f72 2d65 7272   80%;--color-err\n-00058ff0: 6f72 3a20 3133 2c20 3130 3025 2c20 3538  or: 13, 100%, 58\n-00059000: 253b 2d2d 636f 6c6f 722d 6e65 7574 7261  %;--color-neutra\n-00059010: 6c3a 2032 3139 2c20 3239 252c 2037 3825  l: 219, 29%, 78%\n-00059020: 3b2d 2d63 6f6c 6f72 2d62 6173 653a 2032  ;--color-base: 2\n-00059030: 3139 2c20 3239 252c 2031 3825 3b2d 2d70  19, 29%, 18%;--p\n-00059040: 6f70 6f76 6572 2d62 6f78 2d73 6861 646f  opover-box-shado\n-00059050: 773a 206e 6f6e 653b 2d2d 706f 706f 7665  w: none;--popove\n-00059060: 722d 626f 7264 6572 3a20 3170 7820 736f  r-border: 1px so\n-00059070: 6c69 6420 6873 6c28 7661 7228 2d2d 636f  lid hsl(var(--co\n-00059080: 6c6f 722d 6e65 7574 7261 6c29 297d 7d62  lor-neutral))}}b\n-00059090: 6f64 792e 6772 6170 6869 716c 2d64 6172  ody.graphiql-dar\n-000590a0: 6b20 2e67 7261 7068 6971 6c2d 636f 6e74  k .graphiql-cont\n-000590b0: 6169 6e65 722c 626f 6479 2e67 7261 7068  ainer,body.graph\n-000590c0: 6971 6c2d 6461 726b 202e 436f 6465 4d69  iql-dark .CodeMi\n-000590d0: 7272 6f72 2d69 6e66 6f2c 626f 6479 2e67  rror-info,body.g\n-000590e0: 7261 7068 6971 6c2d 6461 726b 202e 436f  raphiql-dark .Co\n-000590f0: 6465 4d69 7272 6f72 2d6c 696e 742d 746f  deMirror-lint-to\n-00059100: 6f6c 7469 702c 626f 6479 2e67 7261 7068  oltip,body.graph\n-00059110: 6971 6c2d 6461 726b 202e 6772 6170 6869  iql-dark .graphi\n-00059120: 716c 2d64 6961 6c6f 672c 626f 6479 2e67  ql-dialog,body.g\n-00059130: 7261 7068 6971 6c2d 6461 726b 202e 6772  raphiql-dark .gr\n-00059140: 6170 6869 716c 2d64 6961 6c6f 672d 6f76  aphiql-dialog-ov\n-00059150: 6572 6c61 792c 626f 6479 2e67 7261 7068  erlay,body.graph\n-00059160: 6971 6c2d 6461 726b 202e 6772 6170 6869  iql-dark .graphi\n-00059170: 716c 2d74 6f6f 6c74 6970 2c62 6f64 792e  ql-tooltip,body.\n-00059180: 6772 6170 6869 716c 2d64 6172 6b20 5b64  graphiql-dark [d\n-00059190: 6174 612d 7261 6469 782d 706f 7070 6572  ata-radix-popper\n-000591a0: 2d63 6f6e 7465 6e74 2d77 7261 7070 6572  -content-wrapper\n-000591b0: 5d7b 2d2d 636f 6c6f 722d 7072 696d 6172  ]{--color-primar\n-000591c0: 793a 2033 3338 2c20 3130 3025 2c20 3637  y: 338, 100%, 67\n-000591d0: 253b 2d2d 636f 6c6f 722d 7365 636f 6e64  %;--color-second\n-000591e0: 6172 793a 2032 3433 2c20 3130 3025 2c20  ary: 243, 100%, \n-000591f0: 3737 253b 2d2d 636f 6c6f 722d 7465 7274  77%;--color-tert\n-00059200: 6961 7279 3a20 3138 382c 2031 3030 252c  iary: 188, 100%,\n-00059210: 2034 3425 3b2d 2d63 6f6c 6f72 2d69 6e66   44%;--color-inf\n-00059220: 6f3a 2032 3038 2c20 3130 3025 2c20 3732  o: 208, 100%, 72\n-00059230: 253b 2d2d 636f 6c6f 722d 7375 6363 6573  %;--color-succes\n-00059240: 733a 2031 3538 2c20 3130 3025 2c20 3432  s: 158, 100%, 42\n-00059250: 253b 2d2d 636f 6c6f 722d 7761 726e 696e  %;--color-warnin\n-00059260: 673a 2033 302c 2031 3030 252c 2038 3025  g: 30, 100%, 80%\n-00059270: 3b2d 2d63 6f6c 6f72 2d65 7272 6f72 3a20  ;--color-error: \n-00059280: 3133 2c20 3130 3025 2c20 3538 253b 2d2d  13, 100%, 58%;--\n-00059290: 636f 6c6f 722d 6e65 7574 7261 6c3a 2032  color-neutral: 2\n-000592a0: 3139 2c20 3239 252c 2037 3825 3b2d 2d63  19, 29%, 78%;--c\n-000592b0: 6f6c 6f72 2d62 6173 653a 2032 3139 2c20  olor-base: 219, \n-000592c0: 3239 252c 2031 3825 3b2d 2d70 6f70 6f76  29%, 18%;--popov\n-000592d0: 6572 2d62 6f78 2d73 6861 646f 773a 206e  er-box-shadow: n\n-000592e0: 6f6e 653b 2d2d 706f 706f 7665 722d 626f  one;--popover-bo\n-000592f0: 7264 6572 3a20 3170 7820 736f 6c69 6420  rder: 1px solid \n-00059300: 6873 6c28 7661 7228 2d2d 636f 6c6f 722d  hsl(var(--color-\n-00059310: 6e65 7574 7261 6c29 297d 2e67 7261 7068  neutral))}.graph\n-00059320: 6971 6c2d 636f 6e74 6169 6e65 722c 2e43  iql-container,.C\n-00059330: 6f64 654d 6972 726f 722d 696e 666f 2c2e  odeMirror-info,.\n-00059340: 436f 6465 4d69 7272 6f72 2d6c 696e 742d  CodeMirror-lint-\n-00059350: 746f 6f6c 7469 702c 2e67 7261 7068 6971  tooltip,.graphiq\n-00059360: 6c2d 6469 616c 6f67 2c2e 6772 6170 6869  l-dialog,.graphi\n-00059370: 716c 2d63 6f6e 7461 696e 6572 3a69 7328  ql-container:is(\n-00059380: 6275 7474 6f6e 292c 2e43 6f64 654d 6972  button),.CodeMir\n-00059390: 726f 722d 696e 666f 3a69 7328 6275 7474  ror-info:is(butt\n-000593a0: 6f6e 292c 2e43 6f64 654d 6972 726f 722d  on),.CodeMirror-\n-000593b0: 6c69 6e74 2d74 6f6f 6c74 6970 3a69 7328  lint-tooltip:is(\n-000593c0: 6275 7474 6f6e 292c 2e67 7261 7068 6971  button),.graphiq\n-000593d0: 6c2d 6469 616c 6f67 3a69 7328 6275 7474  l-dialog:is(butt\n-000593e0: 6f6e 297b 636f 6c6f 723a 6873 6c61 2876  on){color:hsla(v\n-000593f0: 6172 282d 2d63 6f6c 6f72 2d6e 6575 7472  ar(--color-neutr\n-00059400: 616c 292c 3129 3b66 6f6e 742d 6661 6d69  al),1);font-fami\n-00059410: 6c79 3a76 6172 282d 2d66 6f6e 742d 6661  ly:var(--font-fa\n-00059420: 6d69 6c79 293b 666f 6e74 2d73 697a 653a  mily);font-size:\n-00059430: 7661 7228 2d2d 666f 6e74 2d73 697a 652d  var(--font-size-\n-00059440: 626f 6479 293b 666f 6e74 2d77 6569 6768  body);font-weigh\n-00059450: 743a 7661 7228 2d2d 2d2d 666f 6e74 2d77  t:var(----font-w\n-00059460: 6569 6768 742d 7265 6775 6c61 7229 3b6c  eight-regular);l\n-00059470: 696e 652d 6865 6967 6874 3a76 6172 282d  ine-height:var(-\n-00059480: 2d6c 696e 652d 6865 6967 6874 297d 2e67  -line-height)}.g\n-00059490: 7261 7068 6971 6c2d 636f 6e74 6169 6e65  raphiql-containe\n-000594a0: 7220 696e 7075 742c 2e43 6f64 654d 6972  r input,.CodeMir\n-000594b0: 726f 722d 696e 666f 2069 6e70 7574 2c2e  ror-info input,.\n-000594c0: 436f 6465 4d69 7272 6f72 2d6c 696e 742d  CodeMirror-lint-\n-000594d0: 746f 6f6c 7469 7020 696e 7075 742c 2e67  tooltip input,.g\n-000594e0: 7261 7068 6971 6c2d 6469 616c 6f67 2069  raphiql-dialog i\n-000594f0: 6e70 7574 7b63 6f6c 6f72 3a68 736c 6128  nput{color:hsla(\n-00059500: 7661 7228 2d2d 636f 6c6f 722d 6e65 7574  var(--color-neut\n-00059510: 7261 6c29 2c31 293b 666f 6e74 2d66 616d  ral),1);font-fam\n-00059520: 696c 793a 7661 7228 2d2d 666f 6e74 2d66  ily:var(--font-f\n-00059530: 616d 696c 7929 3b66 6f6e 742d 7369 7a65  amily);font-size\n-00059540: 3a76 6172 282d 2d66 6f6e 742d 7369 7a65  :var(--font-size\n-00059550: 2d63 6170 7469 6f6e 297d 2e67 7261 7068  -caption)}.graph\n-00059560: 6971 6c2d 636f 6e74 6169 6e65 7220 696e  iql-container in\n-00059570: 7075 743a 3a70 6c61 6365 686f 6c64 6572  put::placeholder\n-00059580: 2c2e 436f 6465 4d69 7272 6f72 2d69 6e66  ,.CodeMirror-inf\n-00059590: 6f20 696e 7075 743a 3a70 6c61 6365 686f  o input::placeho\n-000595a0: 6c64 6572 2c2e 436f 6465 4d69 7272 6f72  lder,.CodeMirror\n-000595b0: 2d6c 696e 742d 746f 6f6c 7469 7020 696e  -lint-tooltip in\n-000595c0: 7075 743a 3a70 6c61 6365 686f 6c64 6572  put::placeholder\n-000595d0: 2c2e 6772 6170 6869 716c 2d64 6961 6c6f  ,.graphiql-dialo\n-000595e0: 6720 696e 7075 743a 3a70 6c61 6365 686f  g input::placeho\n-000595f0: 6c64 6572 7b63 6f6c 6f72 3a68 736c 6128  lder{color:hsla(\n-00059600: 7661 7228 2d2d 636f 6c6f 722d 6e65 7574  var(--color-neut\n-00059610: 7261 6c29 2c76 6172 282d 2d61 6c70 6861  ral),var(--alpha\n-00059620: 2d73 6563 6f6e 6461 7279 2929 7d2e 6772  -secondary))}.gr\n-00059630: 6170 6869 716c 2d63 6f6e 7461 696e 6572  aphiql-container\n-00059640: 2061 2c2e 436f 6465 4d69 7272 6f72 2d69   a,.CodeMirror-i\n-00059650: 6e66 6f20 612c 2e43 6f64 654d 6972 726f  nfo a,.CodeMirro\n-00059660: 722d 6c69 6e74 2d74 6f6f 6c74 6970 2061  r-lint-tooltip a\n-00059670: 2c2e 6772 6170 6869 716c 2d64 6961 6c6f  ,.graphiql-dialo\n-00059680: 6720 617b 636f 6c6f 723a 6873 6c28 7661  g a{color:hsl(va\n-00059690: 7228 2d2d 636f 6c6f 722d 7072 696d 6172  r(--color-primar\n-000596a0: 7929 297d 2e67 7261 7068 6971 6c2d 636f  y))}.graphiql-co\n-000596b0: 6e74 6169 6e65 7220 613a 666f 6375 732c  ntainer a:focus,\n-000596c0: 2e43 6f64 654d 6972 726f 722d 696e 666f  .CodeMirror-info\n-000596d0: 2061 3a66 6f63 7573 2c2e 436f 6465 4d69   a:focus,.CodeMi\n-000596e0: 7272 6f72 2d6c 696e 742d 746f 6f6c 7469  rror-lint-toolti\n-000596f0: 7020 613a 666f 6375 732c 2e67 7261 7068  p a:focus,.graph\n-00059700: 6971 6c2d 6469 616c 6f67 2061 3a66 6f63  iql-dialog a:foc\n-00059710: 7573 7b6f 7574 6c69 6e65 3a68 736c 2876  us{outline:hsl(v\n-00059720: 6172 282d 2d63 6f6c 6f72 2d70 7269 6d61  ar(--color-prima\n-00059730: 7279 2929 2061 7574 6f20 3170 787d 2e67  ry)) auto 1px}.g\n-00059740: 7261 7068 6971 6c2d 756e 2d73 7479 6c65  raphiql-un-style\n-00059750: 642c 6275 7474 6f6e 2e67 7261 7068 6971  d,button.graphiq\n-00059760: 6c2d 756e 2d73 7479 6c65 647b 616c 6c3a  l-un-styled{all:\n-00059770: 756e 7365 743b 626f 7264 6572 2d72 6164  unset;border-rad\n-00059780: 6975 733a 7661 7228 2d2d 626f 7264 6572  ius:var(--border\n-00059790: 2d72 6164 6975 732d 3429 3b63 7572 736f  -radius-4);curso\n-000597a0: 723a 706f 696e 7465 727d 3a69 7328 2e67  r:pointer}:is(.g\n-000597b0: 7261 7068 6971 6c2d 756e 2d73 7479 6c65  raphiql-un-style\n-000597c0: 642c 6275 7474 6f6e 2e67 7261 7068 6971  d,button.graphiq\n-000597d0: 6c2d 756e 2d73 7479 6c65 6429 3a68 6f76  l-un-styled):hov\n-000597e0: 6572 7b62 6163 6b67 726f 756e 642d 636f  er{background-co\n-000597f0: 6c6f 723a 6873 6c61 2876 6172 282d 2d63  lor:hsla(var(--c\n-00059800: 6f6c 6f72 2d6e 6575 7472 616c 292c 7661  olor-neutral),va\n-00059810: 7228 2d2d 616c 7068 612d 6261 636b 6772  r(--alpha-backgr\n-00059820: 6f75 6e64 2d6c 6967 6874 2929 7d3a 6973  ound-light))}:is\n-00059830: 282e 6772 6170 6869 716c 2d75 6e2d 7374  (.graphiql-un-st\n-00059840: 796c 6564 2c62 7574 746f 6e2e 6772 6170  yled,button.grap\n-00059850: 6869 716c 2d75 6e2d 7374 796c 6564 293a  hiql-un-styled):\n-00059860: 6163 7469 7665 7b62 6163 6b67 726f 756e  active{backgroun\n-00059870: 642d 636f 6c6f 723a 6873 6c61 2876 6172  d-color:hsla(var\n-00059880: 282d 2d63 6f6c 6f72 2d6e 6575 7472 616c  (--color-neutral\n-00059890: 292c 7661 7228 2d2d 616c 7068 612d 6261  ),var(--alpha-ba\n-000598a0: 636b 6772 6f75 6e64 2d6d 6564 6975 6d29  ckground-medium)\n-000598b0: 297d 3a69 7328 2e67 7261 7068 6971 6c2d  )}:is(.graphiql-\n-000598c0: 756e 2d73 7479 6c65 642c 6275 7474 6f6e  un-styled,button\n-000598d0: 2e67 7261 7068 6971 6c2d 756e 2d73 7479  .graphiql-un-sty\n-000598e0: 6c65 6429 3a66 6f63 7573 7b6f 7574 6c69  led):focus{outli\n-000598f0: 6e65 3a68 736c 6128 7661 7228 2d2d 636f  ne:hsla(var(--co\n-00059900: 6c6f 722d 6e65 7574 7261 6c29 2c76 6172  lor-neutral),var\n-00059910: 282d 2d61 6c70 6861 2d62 6163 6b67 726f  (--alpha-backgro\n-00059920: 756e 642d 6865 6176 7929 2920 6175 746f  und-heavy)) auto\n-00059930: 2031 7078 7d2e 6772 6170 6869 716c 2d62   1px}.graphiql-b\n-00059940: 7574 746f 6e2c 6275 7474 6f6e 2e67 7261  utton,button.gra\n-00059950: 7068 6971 6c2d 6275 7474 6f6e 7b62 6163  phiql-button{bac\n-00059960: 6b67 726f 756e 642d 636f 6c6f 723a 6873  kground-color:hs\n-00059970: 6c61 2876 6172 282d 2d63 6f6c 6f72 2d6e  la(var(--color-n\n-00059980: 6575 7472 616c 292c 7661 7228 2d2d 616c  eutral),var(--al\n-00059990: 7068 612d 6261 636b 6772 6f75 6e64 2d6c  pha-background-l\n-000599a0: 6967 6874 2929 3b62 6f72 6465 723a 6e6f  ight));border:no\n-000599b0: 6e65 3b62 6f72 6465 722d 7261 6469 7573  ne;border-radius\n-000599c0: 3a76 6172 282d 2d62 6f72 6465 722d 7261  :var(--border-ra\n-000599d0: 6469 7573 2d34 293b 636f 6c6f 723a 6873  dius-4);color:hs\n-000599e0: 6c61 2876 6172 282d 2d63 6f6c 6f72 2d6e  la(var(--color-n\n-000599f0: 6575 7472 616c 292c 3129 3b63 7572 736f  eutral),1);curso\n-00059a00: 723a 706f 696e 7465 723b 666f 6e74 2d73  r:pointer;font-s\n-00059a10: 697a 653a 7661 7228 2d2d 666f 6e74 2d73  ize:var(--font-s\n-00059a20: 697a 652d 626f 6479 293b 7061 6464 696e  ize-body);paddin\n-00059a30: 673a 7661 7228 2d2d 7078 2d38 2920 7661  g:var(--px-8) va\n-00059a40: 7228 2d2d 7078 2d31 3229 7d3a 6973 282e  r(--px-12)}:is(.\n-00059a50: 6772 6170 6869 716c 2d62 7574 746f 6e2c  graphiql-button,\n-00059a60: 6275 7474 6f6e 2e67 7261 7068 6971 6c2d  button.graphiql-\n-00059a70: 6275 7474 6f6e 293a 686f 7665 722c 3a69  button):hover,:i\n-00059a80: 7328 2e67 7261 7068 6971 6c2d 6275 7474  s(.graphiql-butt\n-00059a90: 6f6e 2c62 7574 746f 6e2e 6772 6170 6869  on,button.graphi\n-00059aa0: 716c 2d62 7574 746f 6e29 3a61 6374 6976  ql-button):activ\n-00059ab0: 657b 6261 636b 6772 6f75 6e64 2d63 6f6c  e{background-col\n-00059ac0: 6f72 3a68 736c 6128 7661 7228 2d2d 636f  or:hsla(var(--co\n-00059ad0: 6c6f 722d 6e65 7574 7261 6c29 2c76 6172  lor-neutral),var\n-00059ae0: 282d 2d61 6c70 6861 2d62 6163 6b67 726f  (--alpha-backgro\n-00059af0: 756e 642d 6d65 6469 756d 2929 7d3a 6973  und-medium))}:is\n-00059b00: 282e 6772 6170 6869 716c 2d62 7574 746f  (.graphiql-butto\n-00059b10: 6e2c 6275 7474 6f6e 2e67 7261 7068 6971  n,button.graphiq\n-00059b20: 6c2d 6275 7474 6f6e 293a 666f 6375 737b  l-button):focus{\n-00059b30: 6f75 746c 696e 653a 6873 6c61 2876 6172  outline:hsla(var\n-00059b40: 282d 2d63 6f6c 6f72 2d6e 6575 7472 616c  (--color-neutral\n-00059b50: 292c 7661 7228 2d2d 616c 7068 612d 6261  ),var(--alpha-ba\n-00059b60: 636b 6772 6f75 6e64 2d68 6561 7679 2929  ckground-heavy))\n-00059b70: 2061 7574 6f20 3170 787d 2e67 7261 7068   auto 1px}.graph\n-00059b80: 6971 6c2d 6275 7474 6f6e 2d73 7563 6365  iql-button-succe\n-00059b90: 7373 3a69 7328 2e67 7261 7068 6971 6c2d  ss:is(.graphiql-\n-00059ba0: 6275 7474 6f6e 2c62 7574 746f 6e2e 6772  button,button.gr\n-00059bb0: 6170 6869 716c 2d62 7574 746f 6e29 7b62  aphiql-button){b\n-00059bc0: 6163 6b67 726f 756e 642d 636f 6c6f 723a  ackground-color:\n-00059bd0: 6873 6c61 2876 6172 282d 2d63 6f6c 6f72  hsla(var(--color\n-00059be0: 2d73 7563 6365 7373 292c 7661 7228 2d2d  -success),var(--\n-00059bf0: 616c 7068 612d 6261 636b 6772 6f75 6e64  alpha-background\n-00059c00: 2d68 6561 7679 2929 7d2e 6772 6170 6869  -heavy))}.graphi\n-00059c10: 716c 2d62 7574 746f 6e2d 6572 726f 723a  ql-button-error:\n-00059c20: 6973 282e 6772 6170 6869 716c 2d62 7574  is(.graphiql-but\n-00059c30: 746f 6e2c 6275 7474 6f6e 2e67 7261 7068  ton,button.graph\n-00059c40: 6971 6c2d 6275 7474 6f6e 297b 6261 636b  iql-button){back\n-00059c50: 6772 6f75 6e64 2d63 6f6c 6f72 3a68 736c  ground-color:hsl\n-00059c60: 6128 7661 7228 2d2d 636f 6c6f 722d 6572  a(var(--color-er\n-00059c70: 726f 7229 2c76 6172 282d 2d61 6c70 6861  ror),var(--alpha\n-00059c80: 2d62 6163 6b67 726f 756e 642d 6865 6176  -background-heav\n-00059c90: 7929 297d 2e67 7261 7068 6971 6c2d 6275  y))}.graphiql-bu\n-00059ca0: 7474 6f6e 2d67 726f 7570 7b62 6163 6b67  tton-group{backg\n-00059cb0: 726f 756e 642d 636f 6c6f 723a 6873 6c61  round-color:hsla\n-00059cc0: 2876 6172 282d 2d63 6f6c 6f72 2d6e 6575  (var(--color-neu\n-00059cd0: 7472 616c 292c 7661 7228 2d2d 616c 7068  tral),var(--alph\n-00059ce0: 612d 6261 636b 6772 6f75 6e64 2d6c 6967  a-background-lig\n-00059cf0: 6874 2929 3b62 6f72 6465 722d 7261 6469  ht));border-radi\n-00059d00: 7573 3a63 616c 6328 7661 7228 2d2d 626f  us:calc(var(--bo\n-00059d10: 7264 6572 2d72 6164 6975 732d 3429 202b  rder-radius-4) +\n-00059d20: 2076 6172 282d 2d70 782d 3429 293b 6469   var(--px-4));di\n-00059d30: 7370 6c61 793a 666c 6578 3b70 6164 6469  splay:flex;paddi\n-00059d40: 6e67 3a76 6172 282d 2d70 782d 3429 7d2e  ng:var(--px-4)}.\n-00059d50: 6772 6170 6869 716c 2d62 7574 746f 6e2d  graphiql-button-\n-00059d60: 6772 6f75 703e 6275 7474 6f6e 2e67 7261  group>button.gra\n-00059d70: 7068 6971 6c2d 6275 7474 6f6e 7b62 6163  phiql-button{bac\n-00059d80: 6b67 726f 756e 642d 636f 6c6f 723a 7472  kground-color:tr\n-00059d90: 616e 7370 6172 656e 747d 2e67 7261 7068  ansparent}.graph\n-00059da0: 6971 6c2d 6275 7474 6f6e 2d67 726f 7570  iql-button-group\n-00059db0: 3e62 7574 746f 6e2e 6772 6170 6869 716c  >button.graphiql\n-00059dc0: 2d62 7574 746f 6e3a 686f 7665 727b 6261  -button:hover{ba\n-00059dd0: 636b 6772 6f75 6e64 2d63 6f6c 6f72 3a68  ckground-color:h\n-00059de0: 736c 6128 7661 7228 2d2d 636f 6c6f 722d  sla(var(--color-\n-00059df0: 6e65 7574 7261 6c29 2c76 6172 282d 2d61  neutral),var(--a\n-00059e00: 6c70 6861 2d62 6163 6b67 726f 756e 642d  lpha-background-\n-00059e10: 6c69 6768 7429 297d 2e67 7261 7068 6971  light))}.graphiq\n-00059e20: 6c2d 6275 7474 6f6e 2d67 726f 7570 3e62  l-button-group>b\n-00059e30: 7574 746f 6e2e 6772 6170 6869 716c 2d62  utton.graphiql-b\n-00059e40: 7574 746f 6e2e 6163 7469 7665 7b62 6163  utton.active{bac\n-00059e50: 6b67 726f 756e 642d 636f 6c6f 723a 6873  kground-color:hs\n-00059e60: 6c28 7661 7228 2d2d 636f 6c6f 722d 6261  l(var(--color-ba\n-00059e70: 7365 2929 3b63 7572 736f 723a 6465 6661  se));cursor:defa\n-00059e80: 756c 747d 2e67 7261 7068 6971 6c2d 6275  ult}.graphiql-bu\n-00059e90: 7474 6f6e 2d67 726f 7570 3e2a 2b2a 7b6d  tton-group>*+*{m\n-00059ea0: 6172 6769 6e2d 6c65 6674 3a76 6172 282d  argin-left:var(-\n-00059eb0: 2d70 782d 3829 7d2e 6772 6170 6869 716c  -px-8)}.graphiql\n-00059ec0: 2d64 6961 6c6f 672d 6f76 6572 6c61 797b  -dialog-overlay{\n-00059ed0: 706f 7369 7469 6f6e 3a66 6978 6564 3b69  position:fixed;i\n-00059ee0: 6e73 6574 3a30 3b62 6163 6b67 726f 756e  nset:0;backgroun\n-00059ef0: 642d 636f 6c6f 723a 6873 6c61 2876 6172  d-color:hsla(var\n-00059f00: 282d 2d63 6f6c 6f72 2d6e 6575 7472 616c  (--color-neutral\n-00059f10: 292c 7661 7228 2d2d 616c 7068 612d 6261  ),var(--alpha-ba\n-00059f20: 636b 6772 6f75 6e64 2d68 6561 7679 2929  ckground-heavy))\n-00059f30: 3b7a 2d69 6e64 6578 3a31 307d 2e67 7261  ;z-index:10}.gra\n-00059f40: 7068 6971 6c2d 6469 616c 6f67 7b62 6163  phiql-dialog{bac\n-00059f50: 6b67 726f 756e 642d 636f 6c6f 723a 6873  kground-color:hs\n-00059f60: 6c28 7661 7228 2d2d 636f 6c6f 722d 6261  l(var(--color-ba\n-00059f70: 7365 2929 3b62 6f72 6465 723a 7661 7228  se));border:var(\n-00059f80: 2d2d 706f 706f 7665 722d 626f 7264 6572  --popover-border\n-00059f90: 293b 626f 7264 6572 2d72 6164 6975 733a  );border-radius:\n-00059fa0: 7661 7228 2d2d 626f 7264 6572 2d72 6164  var(--border-rad\n-00059fb0: 6975 732d 3132 293b 626f 782d 7368 6164  ius-12);box-shad\n-00059fc0: 6f77 3a76 6172 282d 2d70 6f70 6f76 6572  ow:var(--popover\n-00059fd0: 2d62 6f78 2d73 6861 646f 7729 3b6d 6172  -box-shadow);mar\n-00059fe0: 6769 6e3a 303b 6d61 782d 6865 6967 6874  gin:0;max-height\n-00059ff0: 3a38 3076 683b 6d61 782d 7769 6474 683a  :80vh;max-width:\n-0005a000: 3830 7677 3b6f 7665 7266 6c6f 773a 6175  80vw;overflow:au\n-0005a010: 746f 3b70 6164 6469 6e67 3a30 3b77 6964  to;padding:0;wid\n-0005a020: 7468 3a75 6e73 6574 3b74 7261 6e73 666f  th:unset;transfo\n-0005a030: 726d 3a74 7261 6e73 6c61 7465 282d 3530  rm:translate(-50\n-0005a040: 252c 2d35 3025 293b 746f 703a 3530 253b  %,-50%);top:50%;\n-0005a050: 6c65 6674 3a35 3025 3b70 6f73 6974 696f  left:50%;positio\n-0005a060: 6e3a 6669 7865 643b 7a2d 696e 6465 783a  n:fixed;z-index:\n-0005a070: 3130 7d2e 6772 6170 6869 716c 2d64 6961  10}.graphiql-dia\n-0005a080: 6c6f 672d 636c 6f73 653e 7376 677b 636f  log-close>svg{co\n-0005a090: 6c6f 723a 6873 6c61 2876 6172 282d 2d63  lor:hsla(var(--c\n-0005a0a0: 6f6c 6f72 2d6e 6575 7472 616c 292c 7661  olor-neutral),va\n-0005a0b0: 7228 2d2d 616c 7068 612d 7365 636f 6e64  r(--alpha-second\n-0005a0c0: 6172 7929 293b 6469 7370 6c61 793a 626c  ary));display:bl\n-0005a0d0: 6f63 6b3b 6865 6967 6874 3a76 6172 282d  ock;height:var(-\n-0005a0e0: 2d70 782d 3132 293b 7061 6464 696e 673a  -px-12);padding:\n-0005a0f0: 7661 7228 2d2d 7078 2d31 3229 3b77 6964  var(--px-12);wid\n-0005a100: 7468 3a76 6172 282d 2d70 782d 3132 297d  th:var(--px-12)}\n-0005a110: 2e67 7261 7068 6971 6c2d 6472 6f70 646f  .graphiql-dropdo\n-0005a120: 776e 2d63 6f6e 7465 6e74 7b62 6163 6b67  wn-content{backg\n-0005a130: 726f 756e 642d 636f 6c6f 723a 6873 6c28  round-color:hsl(\n-0005a140: 7661 7228 2d2d 636f 6c6f 722d 6261 7365  var(--color-base\n-0005a150: 2929 3b62 6f72 6465 723a 7661 7228 2d2d  ));border:var(--\n-0005a160: 706f 706f 7665 722d 626f 7264 6572 293b  popover-border);\n-0005a170: 626f 7264 6572 2d72 6164 6975 733a 7661  border-radius:va\n-0005a180: 7228 2d2d 626f 7264 6572 2d72 6164 6975  r(--border-radiu\n-0005a190: 732d 3829 3b62 6f78 2d73 6861 646f 773a  s-8);box-shadow:\n-0005a1a0: 7661 7228 2d2d 706f 706f 7665 722d 626f  var(--popover-bo\n-0005a1b0: 782d 7368 6164 6f77 293b 666f 6e74 2d73  x-shadow);font-s\n-0005a1c0: 697a 653a 696e 6865 7269 743b 6d61 782d  ize:inherit;max-\n-0005a1d0: 7769 6474 683a 3235 3070 783b 7061 6464  width:250px;padd\n-0005a1e0: 696e 673a 7661 7228 2d2d 7078 2d34 293b  ing:var(--px-4);\n-0005a1f0: 666f 6e74 2d66 616d 696c 793a 7661 7228  font-family:var(\n-0005a200: 2d2d 666f 6e74 2d66 616d 696c 7929 3b63  --font-family);c\n-0005a210: 6f6c 6f72 3a68 736c 2876 6172 282d 2d63  olor:hsl(var(--c\n-0005a220: 6f6c 6f72 2d6e 6575 7472 616c 2929 3b6d  olor-neutral));m\n-0005a230: 6178 2d68 6569 6768 743a 6d69 6e28 6361  ax-height:min(ca\n-0005a240: 6c63 2876 6172 282d 2d72 6164 6978 2d64  lc(var(--radix-d\n-0005a250: 726f 7064 6f77 6e2d 6d65 6e75 2d63 6f6e  ropdown-menu-con\n-0005a260: 7465 6e74 2d61 7661 696c 6162 6c65 2d68  tent-available-h\n-0005a270: 6569 6768 7429 202d 2031 3070 7829 2c34  eight) - 10px),4\n-0005a280: 3030 7078 293b 6f76 6572 666c 6f77 2d79  00px);overflow-y\n-0005a290: 3a73 6372 6f6c 6c7d 2e67 7261 7068 6971  :scroll}.graphiq\n-0005a2a0: 6c2d 6472 6f70 646f 776e 2d69 7465 6d7b  l-dropdown-item{\n-0005a2b0: 626f 7264 6572 2d72 6164 6975 733a 7661  border-radius:va\n-0005a2c0: 7228 2d2d 626f 7264 6572 2d72 6164 6975  r(--border-radiu\n-0005a2d0: 732d 3429 3b66 6f6e 742d 7369 7a65 3a69  s-4);font-size:i\n-0005a2e0: 6e68 6572 6974 3b6d 6172 6769 6e3a 7661  nherit;margin:va\n-0005a2f0: 7228 2d2d 7078 2d34 293b 6f76 6572 666c  r(--px-4);overfl\n-0005a300: 6f77 3a68 6964 6465 6e3b 7061 6464 696e  ow:hidden;paddin\n-0005a310: 673a 7661 7228 2d2d 7078 2d36 2920 7661  g:var(--px-6) va\n-0005a320: 7228 2d2d 7078 2d38 293b 7465 7874 2d6f  r(--px-8);text-o\n-0005a330: 7665 7266 6c6f 773a 656c 6c69 7073 6973  verflow:ellipsis\n-0005a340: 3b77 6869 7465 2d73 7061 6365 3a6e 6f77  ;white-space:now\n-0005a350: 7261 703b 6f75 746c 696e 653a 6e6f 6e65  rap;outline:none\n-0005a360: 3b63 7572 736f 723a 706f 696e 7465 723b  ;cursor:pointer;\n-0005a370: 6c69 6e65 2d68 6569 6768 743a 7661 7228  line-height:var(\n-0005a380: 2d2d 6c69 6e65 2d68 6569 6768 7429 7d2e  --line-height)}.\n-0005a390: 6772 6170 6869 716c 2d64 726f 7064 6f77  graphiql-dropdow\n-0005a3a0: 6e2d 6974 656d 5b64 6174 612d 7365 6c65  n-item[data-sele\n-0005a3b0: 6374 6564 5d2c 2e67 7261 7068 6971 6c2d  cted],.graphiql-\n-0005a3c0: 6472 6f70 646f 776e 2d69 7465 6d5b 6461  dropdown-item[da\n-0005a3d0: 7461 2d63 7572 7265 6e74 2d6e 6176 5d2c  ta-current-nav],\n-0005a3e0: 2e67 7261 7068 6971 6c2d 6472 6f70 646f  .graphiql-dropdo\n-0005a3f0: 776e 2d69 7465 6d3a 686f 7665 727b 6261  wn-item:hover{ba\n-0005a400: 636b 6772 6f75 6e64 2d63 6f6c 6f72 3a68  ckground-color:h\n-0005a410: 736c 6128 7661 7228 2d2d 636f 6c6f 722d  sla(var(--color-\n-0005a420: 6e65 7574 7261 6c29 2c76 6172 282d 2d61  neutral),var(--a\n-0005a430: 6c70 6861 2d62 6163 6b67 726f 756e 642d  lpha-background-\n-0005a440: 6c69 6768 7429 293b 636f 6c6f 723a 696e  light));color:in\n-0005a450: 6865 7269 747d 2e67 7261 7068 6971 6c2d  herit}.graphiql-\n-0005a460: 6472 6f70 646f 776e 2d69 7465 6d3a 6e6f  dropdown-item:no\n-0005a470: 7428 3a66 6972 7374 2d63 6869 6c64 297b  t(:first-child){\n-0005a480: 6d61 7267 696e 2d74 6f70 3a30 7d3a 6973  margin-top:0}:is\n-0005a490: 282e 6772 6170 6869 716c 2d6d 6172 6b64  (.graphiql-markd\n-0005a4a0: 6f77 6e2d 6465 7363 7269 7074 696f 6e2c  own-description,\n-0005a4b0: 2e67 7261 7068 6971 6c2d 6d61 726b 646f  .graphiql-markdo\n-0005a4c0: 776e 2d64 6570 7265 6361 7469 6f6e 2c2e  wn-deprecation,.\n-0005a4d0: 436f 6465 4d69 7272 6f72 2d68 696e 742d  CodeMirror-hint-\n-0005a4e0: 696e 666f 726d 6174 696f 6e2d 6465 7363  information-desc\n-0005a4f0: 7269 7074 696f 6e2c 2e43 6f64 654d 6972  ription,.CodeMir\n-0005a500: 726f 722d 6869 6e74 2d69 6e66 6f72 6d61  ror-hint-informa\n-0005a510: 7469 6f6e 2d64 6570 7265 6361 7469 6f6e  tion-deprecation\n-0005a520: 2d72 6561 736f 6e2c 2e43 6f64 654d 6972  -reason,.CodeMir\n-0005a530: 726f 722d 696e 666f 202e 696e 666f 2d64  ror-info .info-d\n-0005a540: 6573 6372 6970 7469 6f6e 2c2e 436f 6465  escription,.Code\n-0005a550: 4d69 7272 6f72 2d69 6e66 6f20 2e69 6e66  Mirror-info .inf\n-0005a560: 6f2d 6465 7072 6563 6174 696f 6e29 2062  o-deprecation) b\n-0005a570: 6c6f 636b 7175 6f74 657b 6d61 7267 696e  lockquote{margin\n-0005a580: 2d6c 6566 743a 303b 6d61 7267 696e 2d72  -left:0;margin-r\n-0005a590: 6967 6874 3a30 3b70 6164 6469 6e67 2d6c  ight:0;padding-l\n-0005a5a0: 6566 743a 7661 7228 2d2d 7078 2d38 297d  eft:var(--px-8)}\n-0005a5b0: 3a69 7328 2e67 7261 7068 6971 6c2d 6d61  :is(.graphiql-ma\n-0005a5c0: 726b 646f 776e 2d64 6573 6372 6970 7469  rkdown-descripti\n-0005a5d0: 6f6e 2c2e 6772 6170 6869 716c 2d6d 6172  on,.graphiql-mar\n-0005a5e0: 6b64 6f77 6e2d 6465 7072 6563 6174 696f  kdown-deprecatio\n-0005a5f0: 6e2c 2e43 6f64 654d 6972 726f 722d 6869  n,.CodeMirror-hi\n-0005a600: 6e74 2d69 6e66 6f72 6d61 7469 6f6e 2d64  nt-information-d\n-0005a610: 6573 6372 6970 7469 6f6e 2c2e 436f 6465  escription,.Code\n-0005a620: 4d69 7272 6f72 2d68 696e 742d 696e 666f  Mirror-hint-info\n-0005a630: 726d 6174 696f 6e2d 6465 7072 6563 6174  rmation-deprecat\n-0005a640: 696f 6e2d 7265 6173 6f6e 2c2e 436f 6465  ion-reason,.Code\n-0005a650: 4d69 7272 6f72 2d69 6e66 6f20 2e69 6e66  Mirror-info .inf\n-0005a660: 6f2d 6465 7363 7269 7074 696f 6e2c 2e43  o-description,.C\n-0005a670: 6f64 654d 6972 726f 722d 696e 666f 202e  odeMirror-info .\n-0005a680: 696e 666f 2d64 6570 7265 6361 7469 6f6e  info-deprecation\n-0005a690: 2920 636f 6465 2c3a 6973 282e 6772 6170  ) code,:is(.grap\n-0005a6a0: 6869 716c 2d6d 6172 6b64 6f77 6e2d 6465  hiql-markdown-de\n-0005a6b0: 7363 7269 7074 696f 6e2c 2e67 7261 7068  scription,.graph\n-0005a6c0: 6971 6c2d 6d61 726b 646f 776e 2d64 6570  iql-markdown-dep\n-0005a6d0: 7265 6361 7469 6f6e 2c2e 436f 6465 4d69  recation,.CodeMi\n-0005a6e0: 7272 6f72 2d68 696e 742d 696e 666f 726d  rror-hint-inform\n-0005a6f0: 6174 696f 6e2d 6465 7363 7269 7074 696f  ation-descriptio\n-0005a700: 6e2c 2e43 6f64 654d 6972 726f 722d 6869  n,.CodeMirror-hi\n-0005a710: 6e74 2d69 6e66 6f72 6d61 7469 6f6e 2d64  nt-information-d\n-0005a720: 6570 7265 6361 7469 6f6e 2d72 6561 736f  eprecation-reaso\n-0005a730: 6e2c 2e43 6f64 654d 6972 726f 722d 696e  n,.CodeMirror-in\n-0005a740: 666f 202e 696e 666f 2d64 6573 6372 6970  fo .info-descrip\n-0005a750: 7469 6f6e 2c2e 436f 6465 4d69 7272 6f72  tion,.CodeMirror\n-0005a760: 2d69 6e66 6f20 2e69 6e66 6f2d 6465 7072  -info .info-depr\n-0005a770: 6563 6174 696f 6e29 2070 7265 7b62 6f72  ecation) pre{bor\n-0005a780: 6465 722d 7261 6469 7573 3a76 6172 282d  der-radius:var(-\n-0005a790: 2d62 6f72 6465 722d 7261 6469 7573 2d34  -border-radius-4\n-0005a7a0: 293b 666f 6e74 2d66 616d 696c 793a 7661  );font-family:va\n-0005a7b0: 7228 2d2d 666f 6e74 2d66 616d 696c 792d  r(--font-family-\n-0005a7c0: 6d6f 6e6f 293b 666f 6e74 2d73 697a 653a  mono);font-size:\n-0005a7d0: 7661 7228 2d2d 666f 6e74 2d73 697a 652d  var(--font-size-\n-0005a7e0: 696e 6c69 6e65 2d63 6f64 6529 7d3a 6973  inline-code)}:is\n-0005a7f0: 282e 6772 6170 6869 716c 2d6d 6172 6b64  (.graphiql-markd\n-0005a800: 6f77 6e2d 6465 7363 7269 7074 696f 6e2c  own-description,\n-0005a810: 2e67 7261 7068 6971 6c2d 6d61 726b 646f  .graphiql-markdo\n-0005a820: 776e 2d64 6570 7265 6361 7469 6f6e 2c2e  wn-deprecation,.\n-0005a830: 436f 6465 4d69 7272 6f72 2d68 696e 742d  CodeMirror-hint-\n-0005a840: 696e 666f 726d 6174 696f 6e2d 6465 7363  information-desc\n-0005a850: 7269 7074 696f 6e2c 2e43 6f64 654d 6972  ription,.CodeMir\n-0005a860: 726f 722d 6869 6e74 2d69 6e66 6f72 6d61  ror-hint-informa\n-0005a870: 7469 6f6e 2d64 6570 7265 6361 7469 6f6e  tion-deprecation\n-0005a880: 2d72 6561 736f 6e2c 2e43 6f64 654d 6972  -reason,.CodeMir\n-0005a890: 726f 722d 696e 666f 202e 696e 666f 2d64  ror-info .info-d\n-0005a8a0: 6573 6372 6970 7469 6f6e 2c2e 436f 6465  escription,.Code\n-0005a8b0: 4d69 7272 6f72 2d69 6e66 6f20 2e69 6e66  Mirror-info .inf\n-0005a8c0: 6f2d 6465 7072 6563 6174 696f 6e29 2063  o-deprecation) c\n-0005a8d0: 6f64 657b 7061 6464 696e 673a 7661 7228  ode{padding:var(\n-0005a8e0: 2d2d 7078 2d32 297d 3a69 7328 2e67 7261  --px-2)}:is(.gra\n-0005a8f0: 7068 6971 6c2d 6d61 726b 646f 776e 2d64  phiql-markdown-d\n-0005a900: 6573 6372 6970 7469 6f6e 2c2e 6772 6170  escription,.grap\n-0005a910: 6869 716c 2d6d 6172 6b64 6f77 6e2d 6465  hiql-markdown-de\n-0005a920: 7072 6563 6174 696f 6e2c 2e43 6f64 654d  precation,.CodeM\n-0005a930: 6972 726f 722d 6869 6e74 2d69 6e66 6f72  irror-hint-infor\n-0005a940: 6d61 7469 6f6e 2d64 6573 6372 6970 7469  mation-descripti\n-0005a950: 6f6e 2c2e 436f 6465 4d69 7272 6f72 2d68  on,.CodeMirror-h\n-0005a960: 696e 742d 696e 666f 726d 6174 696f 6e2d  int-information-\n-0005a970: 6465 7072 6563 6174 696f 6e2d 7265 6173  deprecation-reas\n-0005a980: 6f6e 2c2e 436f 6465 4d69 7272 6f72 2d69  on,.CodeMirror-i\n-0005a990: 6e66 6f20 2e69 6e66 6f2d 6465 7363 7269  nfo .info-descri\n-0005a9a0: 7074 696f 6e2c 2e43 6f64 654d 6972 726f  ption,.CodeMirro\n-0005a9b0: 722d 696e 666f 202e 696e 666f 2d64 6570  r-info .info-dep\n-0005a9c0: 7265 6361 7469 6f6e 2920 7072 657b 6f76  recation) pre{ov\n-0005a9d0: 6572 666c 6f77 3a61 7574 6f3b 7061 6464  erflow:auto;padd\n-0005a9e0: 696e 673a 7661 7228 2d2d 7078 2d36 2920  ing:var(--px-6) \n-0005a9f0: 7661 7228 2d2d 7078 2d38 297d 3a69 7328  var(--px-8)}:is(\n-0005aa00: 2e67 7261 7068 6971 6c2d 6d61 726b 646f  .graphiql-markdo\n-0005aa10: 776e 2d64 6573 6372 6970 7469 6f6e 2c2e  wn-description,.\n-0005aa20: 6772 6170 6869 716c 2d6d 6172 6b64 6f77  graphiql-markdow\n-0005aa30: 6e2d 6465 7072 6563 6174 696f 6e2c 2e43  n-deprecation,.C\n-0005aa40: 6f64 654d 6972 726f 722d 6869 6e74 2d69  odeMirror-hint-i\n-0005aa50: 6e66 6f72 6d61 7469 6f6e 2d64 6573 6372  nformation-descr\n-0005aa60: 6970 7469 6f6e 2c2e 436f 6465 4d69 7272  iption,.CodeMirr\n-0005aa70: 6f72 2d68 696e 742d 696e 666f 726d 6174  or-hint-informat\n-0005aa80: 696f 6e2d 6465 7072 6563 6174 696f 6e2d  ion-deprecation-\n-0005aa90: 7265 6173 6f6e 2c2e 436f 6465 4d69 7272  reason,.CodeMirr\n-0005aaa0: 6f72 2d69 6e66 6f20 2e69 6e66 6f2d 6465  or-info .info-de\n-0005aab0: 7363 7269 7074 696f 6e2c 2e43 6f64 654d  scription,.CodeM\n-0005aac0: 6972 726f 722d 696e 666f 202e 696e 666f  irror-info .info\n-0005aad0: 2d64 6570 7265 6361 7469 6f6e 2920 7072  -deprecation) pr\n-0005aae0: 6520 636f 6465 7b62 6163 6b67 726f 756e  e code{backgroun\n-0005aaf0: 642d 636f 6c6f 723a 696e 6974 6961 6c3b  d-color:initial;\n-0005ab00: 626f 7264 6572 2d72 6164 6975 733a 303b  border-radius:0;\n-0005ab10: 7061 6464 696e 673a 307d 3a69 7328 2e67  padding:0}:is(.g\n-0005ab20: 7261 7068 6971 6c2d 6d61 726b 646f 776e  raphiql-markdown\n-0005ab30: 2d64 6573 6372 6970 7469 6f6e 2c2e 6772  -description,.gr\n-0005ab40: 6170 6869 716c 2d6d 6172 6b64 6f77 6e2d  aphiql-markdown-\n-0005ab50: 6465 7072 6563 6174 696f 6e2c 2e43 6f64  deprecation,.Cod\n-0005ab60: 654d 6972 726f 722d 6869 6e74 2d69 6e66  eMirror-hint-inf\n-0005ab70: 6f72 6d61 7469 6f6e 2d64 6573 6372 6970  ormation-descrip\n-0005ab80: 7469 6f6e 2c2e 436f 6465 4d69 7272 6f72  tion,.CodeMirror\n-0005ab90: 2d68 696e 742d 696e 666f 726d 6174 696f  -hint-informatio\n-0005aba0: 6e2d 6465 7072 6563 6174 696f 6e2d 7265  n-deprecation-re\n-0005abb0: 6173 6f6e 2c2e 436f 6465 4d69 7272 6f72  ason,.CodeMirror\n-0005abc0: 2d69 6e66 6f20 2e69 6e66 6f2d 6465 7363  -info .info-desc\n-0005abd0: 7269 7074 696f 6e2c 2e43 6f64 654d 6972  ription,.CodeMir\n-0005abe0: 726f 722d 696e 666f 202e 696e 666f 2d64  ror-info .info-d\n-0005abf0: 6570 7265 6361 7469 6f6e 2920 6f6c 2c3a  eprecation) ol,:\n-0005ac00: 6973 282e 6772 6170 6869 716c 2d6d 6172  is(.graphiql-mar\n-0005ac10: 6b64 6f77 6e2d 6465 7363 7269 7074 696f  kdown-descriptio\n-0005ac20: 6e2c 2e67 7261 7068 6971 6c2d 6d61 726b  n,.graphiql-mark\n-0005ac30: 646f 776e 2d64 6570 7265 6361 7469 6f6e  down-deprecation\n-0005ac40: 2c2e 436f 6465 4d69 7272 6f72 2d68 696e  ,.CodeMirror-hin\n-0005ac50: 742d 696e 666f 726d 6174 696f 6e2d 6465  t-information-de\n-0005ac60: 7363 7269 7074 696f 6e2c 2e43 6f64 654d  scription,.CodeM\n-0005ac70: 6972 726f 722d 6869 6e74 2d69 6e66 6f72  irror-hint-infor\n-0005ac80: 6d61 7469 6f6e 2d64 6570 7265 6361 7469  mation-deprecati\n-0005ac90: 6f6e 2d72 6561 736f 6e2c 2e43 6f64 654d  on-reason,.CodeM\n-0005aca0: 6972 726f 722d 696e 666f 202e 696e 666f  irror-info .info\n-0005acb0: 2d64 6573 6372 6970 7469 6f6e 2c2e 436f  -description,.Co\n-0005acc0: 6465 4d69 7272 6f72 2d69 6e66 6f20 2e69  deMirror-info .i\n-0005acd0: 6e66 6f2d 6465 7072 6563 6174 696f 6e29  nfo-deprecation)\n-0005ace0: 2075 6c7b 7061 6464 696e 672d 6c65 6674   ul{padding-left\n-0005acf0: 3a76 6172 282d 2d70 782d 3136 297d 3a69  :var(--px-16)}:i\n-0005ad00: 7328 2e67 7261 7068 6971 6c2d 6d61 726b  s(.graphiql-mark\n-0005ad10: 646f 776e 2d64 6573 6372 6970 7469 6f6e  down-description\n-0005ad20: 2c2e 6772 6170 6869 716c 2d6d 6172 6b64  ,.graphiql-markd\n-0005ad30: 6f77 6e2d 6465 7072 6563 6174 696f 6e2c  own-deprecation,\n-0005ad40: 2e43 6f64 654d 6972 726f 722d 6869 6e74  .CodeMirror-hint\n-0005ad50: 2d69 6e66 6f72 6d61 7469 6f6e 2d64 6573  -information-des\n-0005ad60: 6372 6970 7469 6f6e 2c2e 436f 6465 4d69  cription,.CodeMi\n-0005ad70: 7272 6f72 2d68 696e 742d 696e 666f 726d  rror-hint-inform\n-0005ad80: 6174 696f 6e2d 6465 7072 6563 6174 696f  ation-deprecatio\n-0005ad90: 6e2d 7265 6173 6f6e 2c2e 436f 6465 4d69  n-reason,.CodeMi\n-0005ada0: 7272 6f72 2d69 6e66 6f20 2e69 6e66 6f2d  rror-info .info-\n-0005adb0: 6465 7363 7269 7074 696f 6e2c 2e43 6f64  description,.Cod\n-0005adc0: 654d 6972 726f 722d 696e 666f 202e 696e  eMirror-info .in\n-0005add0: 666f 2d64 6570 7265 6361 7469 6f6e 2920  fo-deprecation) \n-0005ade0: 6f6c 7b6c 6973 742d 7374 796c 652d 7479  ol{list-style-ty\n-0005adf0: 7065 3a64 6563 696d 616c 7d3a 6973 282e  pe:decimal}:is(.\n-0005ae00: 6772 6170 6869 716c 2d6d 6172 6b64 6f77  graphiql-markdow\n-0005ae10: 6e2d 6465 7363 7269 7074 696f 6e2c 2e67  n-description,.g\n-0005ae20: 7261 7068 6971 6c2d 6d61 726b 646f 776e  raphiql-markdown\n-0005ae30: 2d64 6570 7265 6361 7469 6f6e 2c2e 436f  -deprecation,.Co\n-0005ae40: 6465 4d69 7272 6f72 2d68 696e 742d 696e  deMirror-hint-in\n-0005ae50: 666f 726d 6174 696f 6e2d 6465 7363 7269  formation-descri\n-0005ae60: 7074 696f 6e2c 2e43 6f64 654d 6972 726f  ption,.CodeMirro\n-0005ae70: 722d 6869 6e74 2d69 6e66 6f72 6d61 7469  r-hint-informati\n-0005ae80: 6f6e 2d64 6570 7265 6361 7469 6f6e 2d72  on-deprecation-r\n-0005ae90: 6561 736f 6e2c 2e43 6f64 654d 6972 726f  eason,.CodeMirro\n-0005aea0: 722d 696e 666f 202e 696e 666f 2d64 6573  r-info .info-des\n-0005aeb0: 6372 6970 7469 6f6e 2c2e 436f 6465 4d69  cription,.CodeMi\n-0005aec0: 7272 6f72 2d69 6e66 6f20 2e69 6e66 6f2d  rror-info .info-\n-0005aed0: 6465 7072 6563 6174 696f 6e29 2075 6c7b  deprecation) ul{\n-0005aee0: 6c69 7374 2d73 7479 6c65 2d74 7970 653a  list-style-type:\n-0005aef0: 6469 7363 7d3a 6973 282e 6772 6170 6869  disc}:is(.graphi\n-0005af00: 716c 2d6d 6172 6b64 6f77 6e2d 6465 7363  ql-markdown-desc\n-0005af10: 7269 7074 696f 6e2c 2e67 7261 7068 6971  ription,.graphiq\n-0005af20: 6c2d 6d61 726b 646f 776e 2d64 6570 7265  l-markdown-depre\n-0005af30: 6361 7469 6f6e 2c2e 436f 6465 4d69 7272  cation,.CodeMirr\n-0005af40: 6f72 2d68 696e 742d 696e 666f 726d 6174  or-hint-informat\n-0005af50: 696f 6e2d 6465 7363 7269 7074 696f 6e2c  ion-description,\n-0005af60: 2e43 6f64 654d 6972 726f 722d 6869 6e74  .CodeMirror-hint\n-0005af70: 2d69 6e66 6f72 6d61 7469 6f6e 2d64 6570  -information-dep\n-0005af80: 7265 6361 7469 6f6e 2d72 6561 736f 6e2c  recation-reason,\n-0005af90: 2e43 6f64 654d 6972 726f 722d 696e 666f  .CodeMirror-info\n-0005afa0: 202e 696e 666f 2d64 6573 6372 6970 7469   .info-descripti\n-0005afb0: 6f6e 2c2e 436f 6465 4d69 7272 6f72 2d69  on,.CodeMirror-i\n-0005afc0: 6e66 6f20 2e69 6e66 6f2d 6465 7072 6563  nfo .info-deprec\n-0005afd0: 6174 696f 6e29 2069 6d67 7b62 6f72 6465  ation) img{borde\n-0005afe0: 722d 7261 6469 7573 3a76 6172 282d 2d62  r-radius:var(--b\n-0005aff0: 6f72 6465 722d 7261 6469 7573 2d34 293b  order-radius-4);\n-0005b000: 6d61 782d 6865 6967 6874 3a31 3230 7078  max-height:120px\n-0005b010: 3b6d 6178 2d77 6964 7468 3a31 3030 257d  ;max-width:100%}\n-0005b020: 3a69 7328 2e67 7261 7068 6971 6c2d 6d61  :is(.graphiql-ma\n-0005b030: 726b 646f 776e 2d64 6573 6372 6970 7469  rkdown-descripti\n-0005b040: 6f6e 2c2e 6772 6170 6869 716c 2d6d 6172  on,.graphiql-mar\n-0005b050: 6b64 6f77 6e2d 6465 7072 6563 6174 696f  kdown-deprecatio\n-0005b060: 6e2c 2e43 6f64 654d 6972 726f 722d 6869  n,.CodeMirror-hi\n-0005b070: 6e74 2d69 6e66 6f72 6d61 7469 6f6e 2d64  nt-information-d\n-0005b080: 6573 6372 6970 7469 6f6e 2c2e 436f 6465  escription,.Code\n-0005b090: 4d69 7272 6f72 2d68 696e 742d 696e 666f  Mirror-hint-info\n-0005b0a0: 726d 6174 696f 6e2d 6465 7072 6563 6174  rmation-deprecat\n-0005b0b0: 696f 6e2d 7265 6173 6f6e 2c2e 436f 6465  ion-reason,.Code\n-0005b0c0: 4d69 7272 6f72 2d69 6e66 6f20 2e69 6e66  Mirror-info .inf\n-0005b0d0: 6f2d 6465 7363 7269 7074 696f 6e2c 2e43  o-description,.C\n-0005b0e0: 6f64 654d 6972 726f 722d 696e 666f 202e  odeMirror-info .\n-0005b0f0: 696e 666f 2d64 6570 7265 6361 7469 6f6e  info-deprecation\n-0005b100: 293e 3a66 6972 7374 2d63 6869 6c64 7b6d  )>:first-child{m\n-0005b110: 6172 6769 6e2d 746f 703a 307d 3a69 7328  argin-top:0}:is(\n-0005b120: 2e67 7261 7068 6971 6c2d 6d61 726b 646f  .graphiql-markdo\n-0005b130: 776e 2d64 6573 6372 6970 7469 6f6e 2c2e  wn-description,.\n-0005b140: 6772 6170 6869 716c 2d6d 6172 6b64 6f77  graphiql-markdow\n-0005b150: 6e2d 6465 7072 6563 6174 696f 6e2c 2e43  n-deprecation,.C\n-0005b160: 6f64 654d 6972 726f 722d 6869 6e74 2d69  odeMirror-hint-i\n-0005b170: 6e66 6f72 6d61 7469 6f6e 2d64 6573 6372  nformation-descr\n-0005b180: 6970 7469 6f6e 2c2e 436f 6465 4d69 7272  iption,.CodeMirr\n-0005b190: 6f72 2d68 696e 742d 696e 666f 726d 6174  or-hint-informat\n-0005b1a0: 696f 6e2d 6465 7072 6563 6174 696f 6e2d  ion-deprecation-\n-0005b1b0: 7265 6173 6f6e 2c2e 436f 6465 4d69 7272  reason,.CodeMirr\n-0005b1c0: 6f72 2d69 6e66 6f20 2e69 6e66 6f2d 6465  or-info .info-de\n-0005b1d0: 7363 7269 7074 696f 6e2c 2e43 6f64 654d  scription,.CodeM\n-0005b1e0: 6972 726f 722d 696e 666f 202e 696e 666f  irror-info .info\n-0005b1f0: 2d64 6570 7265 6361 7469 6f6e 293e 3a6c  -deprecation)>:l\n-0005b200: 6173 742d 6368 696c 647b 6d61 7267 696e  ast-child{margin\n-0005b210: 2d62 6f74 746f 6d3a 307d 3a69 7328 2e67  -bottom:0}:is(.g\n-0005b220: 7261 7068 6971 6c2d 6d61 726b 646f 776e  raphiql-markdown\n-0005b230: 2d64 6573 6372 6970 7469 6f6e 2c2e 436f  -description,.Co\n-0005b240: 6465 4d69 7272 6f72 2d68 696e 742d 696e  deMirror-hint-in\n-0005b250: 666f 726d 6174 696f 6e2d 6465 7363 7269  formation-descri\n-0005b260: 7074 696f 6e2c 2e43 6f64 654d 6972 726f  ption,.CodeMirro\n-0005b270: 722d 696e 666f 202e 696e 666f 2d64 6573  r-info .info-des\n-0005b280: 6372 6970 7469 6f6e 2920 617b 636f 6c6f  cription) a{colo\n-0005b290: 723a 6873 6c28 7661 7228 2d2d 636f 6c6f  r:hsl(var(--colo\n-0005b2a0: 722d 7072 696d 6172 7929 293b 7465 7874  r-primary));text\n-0005b2b0: 2d64 6563 6f72 6174 696f 6e3a 6e6f 6e65  -decoration:none\n-0005b2c0: 7d3a 6973 282e 6772 6170 6869 716c 2d6d  }:is(.graphiql-m\n-0005b2d0: 6172 6b64 6f77 6e2d 6465 7363 7269 7074  arkdown-descript\n-0005b2e0: 696f 6e2c 2e43 6f64 654d 6972 726f 722d  ion,.CodeMirror-\n-0005b2f0: 6869 6e74 2d69 6e66 6f72 6d61 7469 6f6e  hint-information\n-0005b300: 2d64 6573 6372 6970 7469 6f6e 2c2e 436f  -description,.Co\n-0005b310: 6465 4d69 7272 6f72 2d69 6e66 6f20 2e69  deMirror-info .i\n-0005b320: 6e66 6f2d 6465 7363 7269 7074 696f 6e29  nfo-description)\n-0005b330: 2061 3a68 6f76 6572 7b74 6578 742d 6465   a:hover{text-de\n-0005b340: 636f 7261 7469 6f6e 3a75 6e64 6572 6c69  coration:underli\n-0005b350: 6e65 7d3a 6973 282e 6772 6170 6869 716c  ne}:is(.graphiql\n-0005b360: 2d6d 6172 6b64 6f77 6e2d 6465 7363 7269  -markdown-descri\n-0005b370: 7074 696f 6e2c 2e43 6f64 654d 6972 726f  ption,.CodeMirro\n-0005b380: 722d 6869 6e74 2d69 6e66 6f72 6d61 7469  r-hint-informati\n-0005b390: 6f6e 2d64 6573 6372 6970 7469 6f6e 2c2e  on-description,.\n-0005b3a0: 436f 6465 4d69 7272 6f72 2d69 6e66 6f20  CodeMirror-info \n-0005b3b0: 2e69 6e66 6f2d 6465 7363 7269 7074 696f  .info-descriptio\n-0005b3c0: 6e29 2062 6c6f 636b 7175 6f74 657b 626f  n) blockquote{bo\n-0005b3d0: 7264 6572 2d6c 6566 743a 312e 3570 7820  rder-left:1.5px \n-0005b3e0: 736f 6c69 6420 6873 6c61 2876 6172 282d  solid hsla(var(-\n-0005b3f0: 2d63 6f6c 6f72 2d6e 6575 7472 616c 292c  -color-neutral),\n-0005b400: 7661 7228 2d2d 616c 7068 612d 7465 7274  var(--alpha-tert\n-0005b410: 6961 7279 2929 7d3a 6973 282e 6772 6170  iary))}:is(.grap\n-0005b420: 6869 716c 2d6d 6172 6b64 6f77 6e2d 6465  hiql-markdown-de\n-0005b430: 7363 7269 7074 696f 6e2c 2e43 6f64 654d  scription,.CodeM\n-0005b440: 6972 726f 722d 6869 6e74 2d69 6e66 6f72  irror-hint-infor\n-0005b450: 6d61 7469 6f6e 2d64 6573 6372 6970 7469  mation-descripti\n-0005b460: 6f6e 2c2e 436f 6465 4d69 7272 6f72 2d69  on,.CodeMirror-i\n-0005b470: 6e66 6f20 2e69 6e66 6f2d 6465 7363 7269  nfo .info-descri\n-0005b480: 7074 696f 6e29 2063 6f64 652c 3a69 7328  ption) code,:is(\n-0005b490: 2e67 7261 7068 6971 6c2d 6d61 726b 646f  .graphiql-markdo\n-0005b4a0: 776e 2d64 6573 6372 6970 7469 6f6e 2c2e  wn-description,.\n-0005b4b0: 436f 6465 4d69 7272 6f72 2d68 696e 742d  CodeMirror-hint-\n-0005b4c0: 696e 666f 726d 6174 696f 6e2d 6465 7363  information-desc\n-0005b4d0: 7269 7074 696f 6e2c 2e43 6f64 654d 6972  ription,.CodeMir\n-0005b4e0: 726f 722d 696e 666f 202e 696e 666f 2d64  ror-info .info-d\n-0005b4f0: 6573 6372 6970 7469 6f6e 2920 7072 657b  escription) pre{\n-0005b500: 6261 636b 6772 6f75 6e64 2d63 6f6c 6f72  background-color\n-0005b510: 3a68 736c 6128 7661 7228 2d2d 636f 6c6f  :hsla(var(--colo\n-0005b520: 722d 6e65 7574 7261 6c29 2c76 6172 282d  r-neutral),var(-\n-0005b530: 2d61 6c70 6861 2d62 6163 6b67 726f 756e  -alpha-backgroun\n-0005b540: 642d 6c69 6768 7429 293b 636f 6c6f 723a  d-light));color:\n-0005b550: 6873 6c61 2876 6172 282d 2d63 6f6c 6f72  hsla(var(--color\n-0005b560: 2d6e 6575 7472 616c 292c 3129 7d3a 6973  -neutral),1)}:is\n-0005b570: 282e 6772 6170 6869 716c 2d6d 6172 6b64  (.graphiql-markd\n-0005b580: 6f77 6e2d 6465 7363 7269 7074 696f 6e2c  own-description,\n-0005b590: 2e43 6f64 654d 6972 726f 722d 6869 6e74  .CodeMirror-hint\n-0005b5a0: 2d69 6e66 6f72 6d61 7469 6f6e 2d64 6573  -information-des\n-0005b5b0: 6372 6970 7469 6f6e 2c2e 436f 6465 4d69  cription,.CodeMi\n-0005b5c0: 7272 6f72 2d69 6e66 6f20 2e69 6e66 6f2d  rror-info .info-\n-0005b5d0: 6465 7363 7269 7074 696f 6e29 3e2a 7b6d  description)>*{m\n-0005b5e0: 6172 6769 6e3a 7661 7228 2d2d 7078 2d31  argin:var(--px-1\n-0005b5f0: 3229 2030 7d3a 6973 282e 6772 6170 6869  2) 0}:is(.graphi\n-0005b600: 716c 2d6d 6172 6b64 6f77 6e2d 6465 7072  ql-markdown-depr\n-0005b610: 6563 6174 696f 6e2c 2e43 6f64 654d 6972  ecation,.CodeMir\n-0005b620: 726f 722d 6869 6e74 2d69 6e66 6f72 6d61  ror-hint-informa\n-0005b630: 7469 6f6e 2d64 6570 7265 6361 7469 6f6e  tion-deprecation\n-0005b640: 2d72 6561 736f 6e2c 2e43 6f64 654d 6972  -reason,.CodeMir\n-0005b650: 726f 722d 696e 666f 202e 696e 666f 2d64  ror-info .info-d\n-0005b660: 6570 7265 6361 7469 6f6e 2920 617b 636f  eprecation) a{co\n-0005b670: 6c6f 723a 6873 6c28 7661 7228 2d2d 636f  lor:hsl(var(--co\n-0005b680: 6c6f 722d 7761 726e 696e 6729 293b 7465  lor-warning));te\n-0005b690: 7874 2d64 6563 6f72 6174 696f 6e3a 756e  xt-decoration:un\n-0005b6a0: 6465 726c 696e 657d 3a69 7328 2e67 7261  derline}:is(.gra\n-0005b6b0: 7068 6971 6c2d 6d61 726b 646f 776e 2d64  phiql-markdown-d\n-0005b6c0: 6570 7265 6361 7469 6f6e 2c2e 436f 6465  eprecation,.Code\n-0005b6d0: 4d69 7272 6f72 2d68 696e 742d 696e 666f  Mirror-hint-info\n-0005b6e0: 726d 6174 696f 6e2d 6465 7072 6563 6174  rmation-deprecat\n-0005b6f0: 696f 6e2d 7265 6173 6f6e 2c2e 436f 6465  ion-reason,.Code\n-0005b700: 4d69 7272 6f72 2d69 6e66 6f20 2e69 6e66  Mirror-info .inf\n-0005b710: 6f2d 6465 7072 6563 6174 696f 6e29 2062  o-deprecation) b\n-0005b720: 6c6f 636b 7175 6f74 657b 626f 7264 6572  lockquote{border\n-0005b730: 2d6c 6566 743a 312e 3570 7820 736f 6c69  -left:1.5px soli\n-0005b740: 6420 6873 6c28 7661 7228 2d2d 636f 6c6f  d hsl(var(--colo\n-0005b750: 722d 7761 726e 696e 6729 297d 3a69 7328  r-warning))}:is(\n-0005b760: 2e67 7261 7068 6971 6c2d 6d61 726b 646f  .graphiql-markdo\n-0005b770: 776e 2d64 6570 7265 6361 7469 6f6e 2c2e  wn-deprecation,.\n-0005b780: 436f 6465 4d69 7272 6f72 2d68 696e 742d  CodeMirror-hint-\n-0005b790: 696e 666f 726d 6174 696f 6e2d 6465 7072  information-depr\n-0005b7a0: 6563 6174 696f 6e2d 7265 6173 6f6e 2c2e  ecation-reason,.\n-0005b7b0: 436f 6465 4d69 7272 6f72 2d69 6e66 6f20  CodeMirror-info \n-0005b7c0: 2e69 6e66 6f2d 6465 7072 6563 6174 696f  .info-deprecatio\n-0005b7d0: 6e29 2063 6f64 652c 3a69 7328 2e67 7261  n) code,:is(.gra\n-0005b7e0: 7068 6971 6c2d 6d61 726b 646f 776e 2d64  phiql-markdown-d\n-0005b7f0: 6570 7265 6361 7469 6f6e 2c2e 436f 6465  eprecation,.Code\n-0005b800: 4d69 7272 6f72 2d68 696e 742d 696e 666f  Mirror-hint-info\n-0005b810: 726d 6174 696f 6e2d 6465 7072 6563 6174  rmation-deprecat\n-0005b820: 696f 6e2d 7265 6173 6f6e 2c2e 436f 6465  ion-reason,.Code\n-0005b830: 4d69 7272 6f72 2d69 6e66 6f20 2e69 6e66  Mirror-info .inf\n-0005b840: 6f2d 6465 7072 6563 6174 696f 6e29 2070  o-deprecation) p\n-0005b850: 7265 7b62 6163 6b67 726f 756e 642d 636f  re{background-co\n-0005b860: 6c6f 723a 6873 6c61 2876 6172 282d 2d63  lor:hsla(var(--c\n-0005b870: 6f6c 6f72 2d77 6172 6e69 6e67 292c 7661  olor-warning),va\n-0005b880: 7228 2d2d 616c 7068 612d 6261 636b 6772  r(--alpha-backgr\n-0005b890: 6f75 6e64 2d68 6561 7679 2929 7d3a 6973  ound-heavy))}:is\n-0005b8a0: 282e 6772 6170 6869 716c 2d6d 6172 6b64  (.graphiql-markd\n-0005b8b0: 6f77 6e2d 6465 7072 6563 6174 696f 6e2c  own-deprecation,\n-0005b8c0: 2e43 6f64 654d 6972 726f 722d 6869 6e74  .CodeMirror-hint\n-0005b8d0: 2d69 6e66 6f72 6d61 7469 6f6e 2d64 6570  -information-dep\n-0005b8e0: 7265 6361 7469 6f6e 2d72 6561 736f 6e2c  recation-reason,\n-0005b8f0: 2e43 6f64 654d 6972 726f 722d 696e 666f  .CodeMirror-info\n-0005b900: 202e 696e 666f 2d64 6570 7265 6361 7469   .info-deprecati\n-0005b910: 6f6e 293e 2a7b 6d61 7267 696e 3a76 6172  on)>*{margin:var\n-0005b920: 282d 2d70 782d 3829 2030 7d2e 6772 6170  (--px-8) 0}.grap\n-0005b930: 6869 716c 2d6d 6172 6b64 6f77 6e2d 7072  hiql-markdown-pr\n-0005b940: 6576 6965 773e 3a6e 6f74 283a 6669 7273  eview>:not(:firs\n-0005b950: 742d 6368 696c 6429 7b64 6973 706c 6179  t-child){display\n-0005b960: 3a6e 6f6e 657d 2e43 6f64 654d 6972 726f  :none}.CodeMirro\n-0005b970: 722d 6869 6e74 2d69 6e66 6f72 6d61 7469  r-hint-informati\n-0005b980: 6f6e 2d64 6570 7265 6361 7469 6f6e 2c2e  on-deprecation,.\n-0005b990: 436f 6465 4d69 7272 6f72 2d69 6e66 6f20  CodeMirror-info \n-0005b9a0: 2e69 6e66 6f2d 6465 7072 6563 6174 696f  .info-deprecatio\n-0005b9b0: 6e7b 6261 636b 6772 6f75 6e64 2d63 6f6c  n{background-col\n-0005b9c0: 6f72 3a68 736c 6128 7661 7228 2d2d 636f  or:hsla(var(--co\n-0005b9d0: 6c6f 722d 7761 726e 696e 6729 2c76 6172  lor-warning),var\n-0005b9e0: 282d 2d61 6c70 6861 2d62 6163 6b67 726f  (--alpha-backgro\n-0005b9f0: 756e 642d 6c69 6768 7429 293b 626f 7264  und-light));bord\n-0005ba00: 6572 3a31 7078 2073 6f6c 6964 2068 736c  er:1px solid hsl\n-0005ba10: 2876 6172 282d 2d63 6f6c 6f72 2d77 6172  (var(--color-war\n-0005ba20: 6e69 6e67 2929 3b62 6f72 6465 722d 7261  ning));border-ra\n-0005ba30: 6469 7573 3a76 6172 282d 2d62 6f72 6465  dius:var(--borde\n-0005ba40: 722d 7261 6469 7573 2d34 293b 636f 6c6f  r-radius-4);colo\n-0005ba50: 723a 6873 6c28 7661 7228 2d2d 636f 6c6f  r:hsl(var(--colo\n-0005ba60: 722d 7761 726e 696e 6729 293b 6d61 7267  r-warning));marg\n-0005ba70: 696e 2d74 6f70 3a76 6172 282d 2d70 782d  in-top:var(--px-\n-0005ba80: 3132 293b 7061 6464 696e 673a 7661 7228  12);padding:var(\n-0005ba90: 2d2d 7078 2d36 2920 7661 7228 2d2d 7078  --px-6) var(--px\n-0005baa0: 2d38 297d 2e43 6f64 654d 6972 726f 722d  -8)}.CodeMirror-\n-0005bab0: 6869 6e74 2d69 6e66 6f72 6d61 7469 6f6e  hint-information\n-0005bac0: 2d64 6570 7265 6361 7469 6f6e 2d6c 6162  -deprecation-lab\n-0005bad0: 656c 2c2e 436f 6465 4d69 7272 6f72 2d69  el,.CodeMirror-i\n-0005bae0: 6e66 6f20 2e69 6e66 6f2d 6465 7072 6563  nfo .info-deprec\n-0005baf0: 6174 696f 6e2d 6c61 6265 6c7b 666f 6e74  ation-label{font\n-0005bb00: 2d73 697a 653a 7661 7228 2d2d 666f 6e74  -size:var(--font\n-0005bb10: 2d73 697a 652d 6869 6e74 293b 666f 6e74  -size-hint);font\n-0005bb20: 2d77 6569 6768 743a 7661 7228 2d2d 666f  -weight:var(--fo\n-0005bb30: 6e74 2d77 6569 6768 742d 6d65 6469 756d  nt-weight-medium\n-0005bb40: 297d 2e43 6f64 654d 6972 726f 722d 6869  )}.CodeMirror-hi\n-0005bb50: 6e74 2d69 6e66 6f72 6d61 7469 6f6e 2d64  nt-information-d\n-0005bb60: 6570 7265 6361 7469 6f6e 2d72 6561 736f  eprecation-reaso\n-0005bb70: 6e2c 2e43 6f64 654d 6972 726f 722d 696e  n,.CodeMirror-in\n-0005bb80: 666f 202e 696e 666f 2d64 6570 7265 6361  fo .info-depreca\n-0005bb90: 7469 6f6e 2d72 6561 736f 6e7b 6d61 7267  tion-reason{marg\n-0005bba0: 696e 2d74 6f70 3a76 6172 282d 2d70 782d  in-top:var(--px-\n-0005bbb0: 3629 7d2e 6772 6170 6869 716c 2d73 7069  6)}.graphiql-spi\n-0005bbc0: 6e6e 6572 7b68 6569 6768 743a 3536 7078  nner{height:56px\n-0005bbd0: 3b6d 6172 6769 6e3a 6175 746f 3b6d 6172  ;margin:auto;mar\n-0005bbe0: 6769 6e2d 746f 703a 7661 7228 2d2d 7078  gin-top:var(--px\n-0005bbf0: 2d31 3629 3b77 6964 7468 3a35 3670 787d  -16);width:56px}\n-0005bc00: 2e67 7261 7068 6971 6c2d 7370 696e 6e65  .graphiql-spinne\n-0005bc10: 723a 6166 7465 727b 616e 696d 6174 696f  r:after{animatio\n-0005bc20: 6e3a 726f 7461 7469 6f6e 202e 3873 206c  n:rotation .8s l\n-0005bc30: 696e 6561 7220 3073 2069 6e66 696e 6974  inear 0s infinit\n-0005bc40: 653b 626f 7264 6572 3a34 7078 2073 6f6c  e;border:4px sol\n-0005bc50: 6964 2074 7261 6e73 7061 7265 6e74 3b62  id transparent;b\n-0005bc60: 6f72 6465 722d 7261 6469 7573 3a31 3030  order-radius:100\n-0005bc70: 253b 626f 7264 6572 2d74 6f70 3a34 7078  %;border-top:4px\n-0005bc80: 2073 6f6c 6964 2068 736c 6128 7661 7228   solid hsla(var(\n-0005bc90: 2d2d 636f 6c6f 722d 6e65 7574 7261 6c29  --color-neutral)\n-0005bca0: 2c76 6172 282d 2d61 6c70 6861 2d74 6572  ,var(--alpha-ter\n-0005bcb0: 7469 6172 7929 293b 636f 6e74 656e 743a  tiary));content:\n-0005bcc0: 2222 3b64 6973 706c 6179 3a69 6e6c 696e  \"\";display:inlin\n-0005bcd0: 652d 626c 6f63 6b3b 6865 6967 6874 3a34  e-block;height:4\n-0005bce0: 3670 783b 7665 7274 6963 616c 2d61 6c69  6px;vertical-ali\n-0005bcf0: 676e 3a6d 6964 646c 653b 7769 6474 683a  gn:middle;width:\n-0005bd00: 3436 7078 7d40 6b65 7966 7261 6d65 7320  46px}@keyframes \n-0005bd10: 726f 7461 7469 6f6e 7b30 257b 7472 616e  rotation{0%{tran\n-0005bd20: 7366 6f72 6d3a 726f 7461 7465 2830 297d  sform:rotate(0)}\n-0005bd30: 746f 7b74 7261 6e73 666f 726d 3a72 6f74  to{transform:rot\n-0005bd40: 6174 6528 3336 3064 6567 297d 7d2e 6772  ate(360deg)}}.gr\n-0005bd50: 6170 6869 716c 2d74 6f6f 6c74 6970 7b62  aphiql-tooltip{b\n-0005bd60: 6163 6b67 726f 756e 643a 6873 6c28 7661  ackground:hsl(va\n-0005bd70: 7228 2d2d 636f 6c6f 722d 6261 7365 2929  r(--color-base))\n-0005bd80: 3b62 6f72 6465 723a 7661 7228 2d2d 706f  ;border:var(--po\n-0005bd90: 706f 7665 722d 626f 7264 6572 293b 626f  pover-border);bo\n-0005bda0: 7264 6572 2d72 6164 6975 733a 7661 7228  rder-radius:var(\n-0005bdb0: 2d2d 626f 7264 6572 2d72 6164 6975 732d  --border-radius-\n-0005bdc0: 3429 3b62 6f78 2d73 6861 646f 773a 7661  4);box-shadow:va\n-0005bdd0: 7228 2d2d 706f 706f 7665 722d 626f 782d  r(--popover-box-\n-0005bde0: 7368 6164 6f77 293b 636f 6c6f 723a 6873  shadow);color:hs\n-0005bdf0: 6c28 7661 7228 2d2d 636f 6c6f 722d 6e65  l(var(--color-ne\n-0005be00: 7574 7261 6c29 293b 666f 6e74 2d73 697a  utral));font-siz\n-0005be10: 653a 696e 6865 7269 743b 7061 6464 696e  e:inherit;paddin\n-0005be20: 673a 7661 7228 2d2d 7078 2d34 2920 7661  g:var(--px-4) va\n-0005be30: 7228 2d2d 7078 2d36 293b 666f 6e74 2d66  r(--px-6);font-f\n-0005be40: 616d 696c 793a 7661 7228 2d2d 666f 6e74  amily:var(--font\n-0005be50: 2d66 616d 696c 7929 7d2e 6772 6170 6869  -family)}.graphi\n-0005be60: 716c 2d74 6162 737b 6469 7370 6c61 793a  ql-tabs{display:\n-0005be70: 666c 6578 3b61 6c69 676e 2d69 7465 6d73  flex;align-items\n-0005be80: 3a63 656e 7465 723b 6f76 6572 666c 6f77  :center;overflow\n-0005be90: 2d78 3a61 7574 6f3b 7061 6464 696e 673a  -x:auto;padding:\n-0005bea0: 7661 7228 2d2d 7078 2d31 3229 7d2e 6772  var(--px-12)}.gr\n-0005beb0: 6170 6869 716c 2d74 6162 733e 3a6e 6f74  aphiql-tabs>:not\n-0005bec0: 283a 6669 7273 742d 6368 696c 6429 7b6d  (:first-child){m\n-0005bed0: 6172 6769 6e2d 6c65 6674 3a76 6172 282d  argin-left:var(-\n-0005bee0: 2d70 782d 3132 297d 2e67 7261 7068 6971  -px-12)}.graphiq\n-0005bef0: 6c2d 7461 627b 616c 6967 6e2d 6974 656d  l-tab{align-item\n-0005bf00: 733a 7374 7265 7463 683b 626f 7264 6572  s:stretch;border\n-0005bf10: 2d72 6164 6975 733a 7661 7228 2d2d 626f  -radius:var(--bo\n-0005bf20: 7264 6572 2d72 6164 6975 732d 3829 3b63  rder-radius-8);c\n-0005bf30: 6f6c 6f72 3a68 736c 6128 7661 7228 2d2d  olor:hsla(var(--\n-0005bf40: 636f 6c6f 722d 6e65 7574 7261 6c29 2c76  color-neutral),v\n-0005bf50: 6172 282d 2d61 6c70 6861 2d73 6563 6f6e  ar(--alpha-secon\n-0005bf60: 6461 7279 2929 3b64 6973 706c 6179 3a66  dary));display:f\n-0005bf70: 6c65 787d 2e67 7261 7068 6971 6c2d 7461  lex}.graphiql-ta\n-0005bf80: 623e 6275 7474 6f6e 2e67 7261 7068 6971  b>button.graphiq\n-0005bf90: 6c2d 7461 622d 636c 6f73 657b 7669 7369  l-tab-close{visi\n-0005bfa0: 6269 6c69 7479 3a68 6964 6465 6e7d 2e67  bility:hidden}.g\n-0005bfb0: 7261 7068 6971 6c2d 7461 622e 6772 6170  raphiql-tab.grap\n-0005bfc0: 6869 716c 2d74 6162 2d61 6374 6976 653e  hiql-tab-active>\n-0005bfd0: 6275 7474 6f6e 2e67 7261 7068 6971 6c2d  button.graphiql-\n-0005bfe0: 7461 622d 636c 6f73 652c 2e67 7261 7068  tab-close,.graph\n-0005bff0: 6971 6c2d 7461 623a 686f 7665 723e 6275  iql-tab:hover>bu\n-0005c000: 7474 6f6e 2e67 7261 7068 6971 6c2d 7461  tton.graphiql-ta\n-0005c010: 622d 636c 6f73 652c 2e67 7261 7068 6971  b-close,.graphiq\n-0005c020: 6c2d 7461 623a 666f 6375 732d 7769 7468  l-tab:focus-with\n-0005c030: 696e 3e62 7574 746f 6e2e 6772 6170 6869  in>button.graphi\n-0005c040: 716c 2d74 6162 2d63 6c6f 7365 7b76 6973  ql-tab-close{vis\n-0005c050: 6962 696c 6974 793a 756e 7365 747d 2e67  ibility:unset}.g\n-0005c060: 7261 7068 6971 6c2d 7461 622e 6772 6170  raphiql-tab.grap\n-0005c070: 6869 716c 2d74 6162 2d61 6374 6976 657b  hiql-tab-active{\n-0005c080: 6261 636b 6772 6f75 6e64 2d63 6f6c 6f72  background-color\n-0005c090: 3a68 736c 6128 7661 7228 2d2d 636f 6c6f  :hsla(var(--colo\n-0005c0a0: 722d 6e65 7574 7261 6c29 2c76 6172 282d  r-neutral),var(-\n-0005c0b0: 2d61 6c70 6861 2d62 6163 6b67 726f 756e  -alpha-backgroun\n-0005c0c0: 642d 6865 6176 7929 293b 636f 6c6f 723a  d-heavy));color:\n-0005c0d0: 6873 6c61 2876 6172 282d 2d63 6f6c 6f72  hsla(var(--color\n-0005c0e0: 2d6e 6575 7472 616c 292c 3129 7d62 7574  -neutral),1)}but\n-0005c0f0: 746f 6e2e 6772 6170 6869 716c 2d74 6162  ton.graphiql-tab\n-0005c100: 2d62 7574 746f 6e7b 7061 6464 696e 673a  -button{padding:\n-0005c110: 7661 7228 2d2d 7078 2d34 2920 3020 7661  var(--px-4) 0 va\n-0005c120: 7228 2d2d 7078 2d34 2920 7661 7228 2d2d  r(--px-4) var(--\n-0005c130: 7078 2d38 297d 6275 7474 6f6e 2e67 7261  px-8)}button.gra\n-0005c140: 7068 6971 6c2d 7461 622d 636c 6f73 657b  phiql-tab-close{\n-0005c150: 616c 6967 6e2d 6974 656d 733a 6365 6e74  align-items:cent\n-0005c160: 6572 3b64 6973 706c 6179 3a66 6c65 783b  er;display:flex;\n-0005c170: 7061 6464 696e 673a 7661 7228 2d2d 7078  padding:var(--px\n-0005c180: 2d34 2920 7661 7228 2d2d 7078 2d38 297d  -4) var(--px-8)}\n-0005c190: 6275 7474 6f6e 2e67 7261 7068 6971 6c2d  button.graphiql-\n-0005c1a0: 7461 622d 636c 6f73 653e 7376 677b 6865  tab-close>svg{he\n-0005c1b0: 6967 6874 3a76 6172 282d 2d70 782d 3829  ight:var(--px-8)\n-0005c1c0: 3b77 6964 7468 3a76 6172 282d 2d70 782d  ;width:var(--px-\n-0005c1d0: 3829 7d2e 6772 6170 6869 716c 2d68 6973  8)}.graphiql-his\n-0005c1e0: 746f 7279 2d68 6561 6465 727b 666f 6e74  tory-header{font\n-0005c1f0: 2d73 697a 653a 7661 7228 2d2d 666f 6e74  -size:var(--font\n-0005c200: 2d73 697a 652d 6832 293b 666f 6e74 2d77  -size-h2);font-w\n-0005c210: 6569 6768 743a 7661 7228 2d2d 666f 6e74  eight:var(--font\n-0005c220: 2d77 6569 6768 742d 6d65 6469 756d 293b  -weight-medium);\n-0005c230: 6469 7370 6c61 793a 666c 6578 3b6a 7573  display:flex;jus\n-0005c240: 7469 6679 2d63 6f6e 7465 6e74 3a73 7061  tify-content:spa\n-0005c250: 6365 2d62 6574 7765 656e 3b61 6c69 676e  ce-between;align\n-0005c260: 2d69 7465 6d73 3a63 656e 7465 727d 2e67  -items:center}.g\n-0005c270: 7261 7068 6971 6c2d 6869 7374 6f72 792d  raphiql-history-\n-0005c280: 6865 6164 6572 2062 7574 746f 6e7b 666f  header button{fo\n-0005c290: 6e74 2d73 697a 653a 7661 7228 2d2d 666f  nt-size:var(--fo\n-0005c2a0: 6e74 2d73 697a 652d 696e 6c69 6e65 2d63  nt-size-inline-c\n-0005c2b0: 6f64 6529 3b70 6164 6469 6e67 3a76 6172  ode);padding:var\n-0005c2c0: 282d 2d70 782d 3629 2076 6172 282d 2d70  (--px-6) var(--p\n-0005c2d0: 782d 3130 297d 2e67 7261 7068 6971 6c2d  x-10)}.graphiql-\n-0005c2e0: 6869 7374 6f72 792d 6974 656d 737b 6d61  history-items{ma\n-0005c2f0: 7267 696e 3a76 6172 282d 2d70 782d 3136  rgin:var(--px-16\n-0005c300: 2920 3020 303b 6c69 7374 2d73 7479 6c65  ) 0 0;list-style\n-0005c310: 3a6e 6f6e 653b 7061 6464 696e 673a 307d  :none;padding:0}\n-0005c320: 2e67 7261 7068 6971 6c2d 6869 7374 6f72  .graphiql-histor\n-0005c330: 792d 6974 656d 7b62 6f72 6465 722d 7261  y-item{border-ra\n-0005c340: 6469 7573 3a76 6172 282d 2d62 6f72 6465  dius:var(--borde\n-0005c350: 722d 7261 6469 7573 2d34 293b 636f 6c6f  r-radius-4);colo\n-0005c360: 723a 6873 6c61 2876 6172 282d 2d63 6f6c  r:hsla(var(--col\n-0005c370: 6f72 2d6e 6575 7472 616c 292c 7661 7228  or-neutral),var(\n-0005c380: 2d2d 616c 7068 612d 7365 636f 6e64 6172  --alpha-secondar\n-0005c390: 7929 293b 6469 7370 6c61 793a 666c 6578  y));display:flex\n-0005c3a0: 3b66 6f6e 742d 7369 7a65 3a76 6172 282d  ;font-size:var(-\n-0005c3b0: 2d66 6f6e 742d 7369 7a65 2d69 6e6c 696e  -font-size-inlin\n-0005c3c0: 652d 636f 6465 293b 666f 6e74 2d66 616d  e-code);font-fam\n-0005c3d0: 696c 793a 7661 7228 2d2d 666f 6e74 2d66  ily:var(--font-f\n-0005c3e0: 616d 696c 792d 6d6f 6e6f 293b 6865 6967  amily-mono);heig\n-0005c3f0: 6874 3a33 3470 787d 2e67 7261 7068 6971  ht:34px}.graphiq\n-0005c400: 6c2d 6869 7374 6f72 792d 6974 656d 3a68  l-history-item:h\n-0005c410: 6f76 6572 7b63 6f6c 6f72 3a68 736c 6128  over{color:hsla(\n-0005c420: 7661 7228 2d2d 636f 6c6f 722d 6e65 7574  var(--color-neut\n-0005c430: 7261 6c29 2c31 293b 6261 636b 6772 6f75  ral),1);backgrou\n-0005c440: 6e64 2d63 6f6c 6f72 3a68 736c 6128 7661  nd-color:hsla(va\n-0005c450: 7228 2d2d 636f 6c6f 722d 6e65 7574 7261  r(--color-neutra\n-0005c460: 6c29 2c76 6172 282d 2d61 6c70 6861 2d62  l),var(--alpha-b\n-0005c470: 6163 6b67 726f 756e 642d 6c69 6768 7429  ackground-light)\n-0005c480: 297d 2e67 7261 7068 6971 6c2d 6869 7374  )}.graphiql-hist\n-0005c490: 6f72 792d 6974 656d 3a6e 6f74 283a 6669  ory-item:not(:fi\n-0005c4a0: 7273 742d 6368 696c 6429 7b6d 6172 6769  rst-child){margi\n-0005c4b0: 6e2d 746f 703a 7661 7228 2d2d 7078 2d34  n-top:var(--px-4\n-0005c4c0: 297d 2e67 7261 7068 6971 6c2d 6869 7374  )}.graphiql-hist\n-0005c4d0: 6f72 792d 6974 656d 2e65 6469 7461 626c  ory-item.editabl\n-0005c4e0: 657b 6261 636b 6772 6f75 6e64 2d63 6f6c  e{background-col\n-0005c4f0: 6f72 3a68 736c 6128 7661 7228 2d2d 636f  or:hsla(var(--co\n-0005c500: 6c6f 722d 7072 696d 6172 7929 2c76 6172  lor-primary),var\n-0005c510: 282d 2d61 6c70 6861 2d62 6163 6b67 726f  (--alpha-backgro\n-0005c520: 756e 642d 6d65 6469 756d 2929 7d2e 6772  und-medium))}.gr\n-0005c530: 6170 6869 716c 2d68 6973 746f 7279 2d69  aphiql-history-i\n-0005c540: 7465 6d2e 6564 6974 6162 6c65 3e69 6e70  tem.editable>inp\n-0005c550: 7574 7b62 6163 6b67 726f 756e 643a 7472  ut{background:tr\n-0005c560: 616e 7370 6172 656e 743b 626f 7264 6572  ansparent;border\n-0005c570: 3a6e 6f6e 653b 666c 6578 3a31 3b6d 6172  :none;flex:1;mar\n-0005c580: 6769 6e3a 303b 6f75 746c 696e 653a 6e6f  gin:0;outline:no\n-0005c590: 6e65 3b70 6164 6469 6e67 3a30 2076 6172  ne;padding:0 var\n-0005c5a0: 282d 2d70 782d 3130 293b 7769 6474 683a  (--px-10);width:\n-0005c5b0: 3130 3025 7d2e 6772 6170 6869 716c 2d68  100%}.graphiql-h\n-0005c5c0: 6973 746f 7279 2d69 7465 6d2e 6564 6974  istory-item.edit\n-0005c5d0: 6162 6c65 3e69 6e70 7574 3a3a 706c 6163  able>input::plac\n-0005c5e0: 6568 6f6c 6465 727b 636f 6c6f 723a 6873  eholder{color:hs\n-0005c5f0: 6c61 2876 6172 282d 2d63 6f6c 6f72 2d6e  la(var(--color-n\n-0005c600: 6575 7472 616c 292c 7661 7228 2d2d 616c  eutral),var(--al\n-0005c610: 7068 612d 7365 636f 6e64 6172 7929 297d  pha-secondary))}\n-0005c620: 2e67 7261 7068 6971 6c2d 6869 7374 6f72  .graphiql-histor\n-0005c630: 792d 6974 656d 2e65 6469 7461 626c 653e  y-item.editable>\n-0005c640: 6275 7474 6f6e 7b63 6f6c 6f72 3a68 736c  button{color:hsl\n-0005c650: 2876 6172 282d 2d63 6f6c 6f72 2d70 7269  (var(--color-pri\n-0005c660: 6d61 7279 2929 3b70 6164 6469 6e67 3a30  mary));padding:0\n-0005c670: 2076 6172 282d 2d70 782d 3130 297d 2e67   var(--px-10)}.g\n-0005c680: 7261 7068 6971 6c2d 6869 7374 6f72 792d  raphiql-history-\n-0005c690: 6974 656d 2e65 6469 7461 626c 653e 6275  item.editable>bu\n-0005c6a0: 7474 6f6e 3a61 6374 6976 657b 6261 636b  tton:active{back\n-0005c6b0: 6772 6f75 6e64 2d63 6f6c 6f72 3a68 736c  ground-color:hsl\n-0005c6c0: 6128 7661 7228 2d2d 636f 6c6f 722d 7072  a(var(--color-pr\n-0005c6d0: 696d 6172 7929 2c76 6172 282d 2d61 6c70  imary),var(--alp\n-0005c6e0: 6861 2d62 6163 6b67 726f 756e 642d 6865  ha-background-he\n-0005c6f0: 6176 7929 297d 2e67 7261 7068 6971 6c2d  avy))}.graphiql-\n-0005c700: 6869 7374 6f72 792d 6974 656d 2e65 6469  history-item.edi\n-0005c710: 7461 626c 653e 6275 7474 6f6e 3a66 6f63  table>button:foc\n-0005c720: 7573 7b6f 7574 6c69 6e65 3a68 736c 2876  us{outline:hsl(v\n-0005c730: 6172 282d 2d63 6f6c 6f72 2d70 7269 6d61  ar(--color-prima\n-0005c740: 7279 2929 2061 7574 6f20 3170 787d 2e67  ry)) auto 1px}.g\n-0005c750: 7261 7068 6971 6c2d 6869 7374 6f72 792d  raphiql-history-\n-0005c760: 6974 656d 2e65 6469 7461 626c 653e 6275  item.editable>bu\n-0005c770: 7474 6f6e 3e73 7667 7b64 6973 706c 6179  tton>svg{display\n-0005c780: 3a62 6c6f 636b 7d62 7574 746f 6e2e 6772  :block}button.gr\n-0005c790: 6170 6869 716c 2d68 6973 746f 7279 2d69  aphiql-history-i\n-0005c7a0: 7465 6d2d 6c61 6265 6c7b 666c 6578 3a31  tem-label{flex:1\n-0005c7b0: 3b70 6164 6469 6e67 3a76 6172 282d 2d70  ;padding:var(--p\n-0005c7c0: 782d 3829 2076 6172 282d 2d70 782d 3130  x-8) var(--px-10\n-0005c7d0: 293b 6f76 6572 666c 6f77 3a68 6964 6465  );overflow:hidde\n-0005c7e0: 6e3b 7465 7874 2d6f 7665 7266 6c6f 773a  n;text-overflow:\n-0005c7f0: 656c 6c69 7073 6973 3b77 6869 7465 2d73  ellipsis;white-s\n-0005c800: 7061 6365 3a6e 6f77 7261 707d 6275 7474  pace:nowrap}butt\n-0005c810: 6f6e 2e67 7261 7068 6971 6c2d 6869 7374  on.graphiql-hist\n-0005c820: 6f72 792d 6974 656d 2d61 6374 696f 6e7b  ory-item-action{\n-0005c830: 616c 6967 6e2d 6974 656d 733a 6365 6e74  align-items:cent\n-0005c840: 6572 3b63 6f6c 6f72 3a68 736c 6128 7661  er;color:hsla(va\n-0005c850: 7228 2d2d 636f 6c6f 722d 6e65 7574 7261  r(--color-neutra\n-0005c860: 6c29 2c76 6172 282d 2d61 6c70 6861 2d73  l),var(--alpha-s\n-0005c870: 6563 6f6e 6461 7279 2929 3b64 6973 706c  econdary));displ\n-0005c880: 6179 3a66 6c65 783b 7061 6464 696e 673a  ay:flex;padding:\n-0005c890: 7661 7228 2d2d 7078 2d38 2920 7661 7228  var(--px-8) var(\n-0005c8a0: 2d2d 7078 2d36 297d 6275 7474 6f6e 2e67  --px-6)}button.g\n-0005c8b0: 7261 7068 6971 6c2d 6869 7374 6f72 792d  raphiql-history-\n-0005c8c0: 6974 656d 2d61 6374 696f 6e3a 686f 7665  item-action:hove\n-0005c8d0: 727b 636f 6c6f 723a 6873 6c61 2876 6172  r{color:hsla(var\n-0005c8e0: 282d 2d63 6f6c 6f72 2d6e 6575 7472 616c  (--color-neutral\n-0005c8f0: 292c 3129 7d62 7574 746f 6e2e 6772 6170  ),1)}button.grap\n-0005c900: 6869 716c 2d68 6973 746f 7279 2d69 7465  hiql-history-ite\n-0005c910: 6d2d 6163 7469 6f6e 3e73 7667 7b68 6569  m-action>svg{hei\n-0005c920: 6768 743a 3134 7078 3b77 6964 7468 3a31  ght:14px;width:1\n-0005c930: 3470 787d 2e67 7261 7068 6971 6c2d 6869  4px}.graphiql-hi\n-0005c940: 7374 6f72 792d 6974 656d 2d73 7061 6365  story-item-space\n-0005c950: 727b 6865 6967 6874 3a76 6172 282d 2d70  r{height:var(--p\n-0005c960: 782d 3136 297d 2e67 7261 7068 6971 6c2d  x-16)}.graphiql-\n-0005c970: 646f 632d 6578 706c 6f72 6572 2d64 6566  doc-explorer-def\n-0005c980: 6175 6c74 2d76 616c 7565 7b63 6f6c 6f72  ault-value{color\n-0005c990: 3a68 736c 2876 6172 282d 2d63 6f6c 6f72  :hsl(var(--color\n-0005c9a0: 2d73 7563 6365 7373 2929 7d61 2e67 7261  -success))}a.gra\n-0005c9b0: 7068 6971 6c2d 646f 632d 6578 706c 6f72  phiql-doc-explor\n-0005c9c0: 6572 2d74 7970 652d 6e61 6d65 7b63 6f6c  er-type-name{col\n-0005c9d0: 6f72 3a68 736c 2876 6172 282d 2d63 6f6c  or:hsl(var(--col\n-0005c9e0: 6f72 2d77 6172 6e69 6e67 2929 3b74 6578  or-warning));tex\n-0005c9f0: 742d 6465 636f 7261 7469 6f6e 3a6e 6f6e  t-decoration:non\n-0005ca00: 657d 612e 6772 6170 6869 716c 2d64 6f63  e}a.graphiql-doc\n-0005ca10: 2d65 7870 6c6f 7265 722d 7479 7065 2d6e  -explorer-type-n\n-0005ca20: 616d 653a 686f 7665 727b 7465 7874 2d64  ame:hover{text-d\n-0005ca30: 6563 6f72 6174 696f 6e3a 756e 6465 726c  ecoration:underl\n-0005ca40: 696e 657d 612e 6772 6170 6869 716c 2d64  ine}a.graphiql-d\n-0005ca50: 6f63 2d65 7870 6c6f 7265 722d 7479 7065  oc-explorer-type\n-0005ca60: 2d6e 616d 653a 666f 6375 737b 6f75 746c  -name:focus{outl\n-0005ca70: 696e 653a 6873 6c28 7661 7228 2d2d 636f  ine:hsl(var(--co\n-0005ca80: 6c6f 722d 7761 726e 696e 6729 2920 6175  lor-warning)) au\n-0005ca90: 746f 2031 7078 7d2e 6772 6170 6869 716c  to 1px}.graphiql\n-0005caa0: 2d64 6f63 2d65 7870 6c6f 7265 722d 6172  -doc-explorer-ar\n-0005cab0: 6775 6d65 6e74 3e2a 2b2a 7b6d 6172 6769  gument>*+*{margi\n-0005cac0: 6e2d 746f 703a 7661 7228 2d2d 7078 2d31  n-top:var(--px-1\n-0005cad0: 3229 7d2e 6772 6170 6869 716c 2d64 6f63  2)}.graphiql-doc\n-0005cae0: 2d65 7870 6c6f 7265 722d 6172 6775 6d65  -explorer-argume\n-0005caf0: 6e74 2d6e 616d 657b 636f 6c6f 723a 6873  nt-name{color:hs\n-0005cb00: 6c28 7661 7228 2d2d 636f 6c6f 722d 7365  l(var(--color-se\n-0005cb10: 636f 6e64 6172 7929 297d 2e67 7261 7068  condary))}.graph\n-0005cb20: 6971 6c2d 646f 632d 6578 706c 6f72 6572  iql-doc-explorer\n-0005cb30: 2d61 7267 756d 656e 742d 6465 7072 6563  -argument-deprec\n-0005cb40: 6174 696f 6e7b 6261 636b 6772 6f75 6e64  ation{background\n-0005cb50: 2d63 6f6c 6f72 3a68 736c 6128 7661 7228  -color:hsla(var(\n-0005cb60: 2d2d 636f 6c6f 722d 7761 726e 696e 6729  --color-warning)\n-0005cb70: 2c76 6172 282d 2d61 6c70 6861 2d62 6163  ,var(--alpha-bac\n-0005cb80: 6b67 726f 756e 642d 6c69 6768 7429 293b  kground-light));\n-0005cb90: 626f 7264 6572 3a31 7078 2073 6f6c 6964  border:1px solid\n-0005cba0: 2068 736c 2876 6172 282d 2d63 6f6c 6f72   hsl(var(--color\n-0005cbb0: 2d77 6172 6e69 6e67 2929 3b62 6f72 6465  -warning));borde\n-0005cbc0: 722d 7261 6469 7573 3a76 6172 282d 2d62  r-radius:var(--b\n-0005cbd0: 6f72 6465 722d 7261 6469 7573 2d34 293b  order-radius-4);\n-0005cbe0: 636f 6c6f 723a 6873 6c28 7661 7228 2d2d  color:hsl(var(--\n-0005cbf0: 636f 6c6f 722d 7761 726e 696e 6729 293b  color-warning));\n-0005cc00: 7061 6464 696e 673a 7661 7228 2d2d 7078  padding:var(--px\n-0005cc10: 2d38 297d 2e67 7261 7068 6971 6c2d 646f  -8)}.graphiql-do\n-0005cc20: 632d 6578 706c 6f72 6572 2d61 7267 756d  c-explorer-argum\n-0005cc30: 656e 742d 6465 7072 6563 6174 696f 6e2d  ent-deprecation-\n-0005cc40: 6c61 6265 6c7b 666f 6e74 2d73 697a 653a  label{font-size:\n-0005cc50: 7661 7228 2d2d 666f 6e74 2d73 697a 652d  var(--font-size-\n-0005cc60: 6869 6e74 293b 666f 6e74 2d77 6569 6768  hint);font-weigh\n-0005cc70: 743a 7661 7228 2d2d 666f 6e74 2d77 6569  t:var(--font-wei\n-0005cc80: 6768 742d 6d65 6469 756d 297d 2e67 7261  ght-medium)}.gra\n-0005cc90: 7068 6971 6c2d 646f 632d 6578 706c 6f72  phiql-doc-explor\n-0005cca0: 6572 2d64 6570 7265 6361 7469 6f6e 7b62  er-deprecation{b\n-0005ccb0: 6163 6b67 726f 756e 642d 636f 6c6f 723a  ackground-color:\n-0005ccc0: 6873 6c61 2876 6172 282d 2d63 6f6c 6f72  hsla(var(--color\n-0005ccd0: 2d77 6172 6e69 6e67 292c 7661 7228 2d2d  -warning),var(--\n-0005cce0: 616c 7068 612d 6261 636b 6772 6f75 6e64  alpha-background\n-0005ccf0: 2d6c 6967 6874 2929 3b62 6f72 6465 723a  -light));border:\n-0005cd00: 3170 7820 736f 6c69 6420 6873 6c28 7661  1px solid hsl(va\n-0005cd10: 7228 2d2d 636f 6c6f 722d 7761 726e 696e  r(--color-warnin\n-0005cd20: 6729 293b 626f 7264 6572 2d72 6164 6975  g));border-radiu\n-0005cd30: 733a 7661 7228 2d2d 7078 2d34 293b 636f  s:var(--px-4);co\n-0005cd40: 6c6f 723a 6873 6c28 7661 7228 2d2d 636f  lor:hsl(var(--co\n-0005cd50: 6c6f 722d 7761 726e 696e 6729 293b 7061  lor-warning));pa\n-0005cd60: 6464 696e 673a 7661 7228 2d2d 7078 2d38  dding:var(--px-8\n-0005cd70: 297d 2e67 7261 7068 6971 6c2d 646f 632d  )}.graphiql-doc-\n-0005cd80: 6578 706c 6f72 6572 2d64 6570 7265 6361  explorer-depreca\n-0005cd90: 7469 6f6e 2d6c 6162 656c 7b66 6f6e 742d  tion-label{font-\n-0005cda0: 7369 7a65 3a76 6172 282d 2d66 6f6e 742d  size:var(--font-\n-0005cdb0: 7369 7a65 2d68 696e 7429 3b66 6f6e 742d  size-hint);font-\n-0005cdc0: 7765 6967 6874 3a76 6172 282d 2d66 6f6e  weight:var(--fon\n-0005cdd0: 742d 7765 6967 6874 2d6d 6564 6975 6d29  t-weight-medium)\n-0005cde0: 7d2e 6772 6170 6869 716c 2d64 6f63 2d65  }.graphiql-doc-e\n-0005cdf0: 7870 6c6f 7265 722d 6469 7265 6374 6976  xplorer-directiv\n-0005ce00: 657b 636f 6c6f 723a 6873 6c28 7661 7228  e{color:hsl(var(\n-0005ce10: 2d2d 636f 6c6f 722d 7365 636f 6e64 6172  --color-secondar\n-0005ce20: 7929 297d 2e67 7261 7068 6971 6c2d 646f  y))}.graphiql-do\n-0005ce30: 632d 6578 706c 6f72 6572 2d73 6563 7469  c-explorer-secti\n-0005ce40: 6f6e 2d74 6974 6c65 7b61 6c69 676e 2d69  on-title{align-i\n-0005ce50: 7465 6d73 3a63 656e 7465 723b 6469 7370  tems:center;disp\n-0005ce60: 6c61 793a 666c 6578 3b66 6f6e 742d 7369  lay:flex;font-si\n-0005ce70: 7a65 3a76 6172 282d 2d66 6f6e 742d 7369  ze:var(--font-si\n-0005ce80: 7a65 2d68 696e 7429 3b66 6f6e 742d 7765  ze-hint);font-we\n-0005ce90: 6967 6874 3a76 6172 282d 2d66 6f6e 742d  ight:var(--font-\n-0005cea0: 7765 6967 6874 2d6d 6564 6975 6d29 3b6c  weight-medium);l\n-0005ceb0: 696e 652d 6865 6967 6874 3a31 7d2e 6772  ine-height:1}.gr\n-0005cec0: 6170 6869 716c 2d64 6f63 2d65 7870 6c6f  aphiql-doc-explo\n-0005ced0: 7265 722d 7365 6374 696f 6e2d 7469 746c  rer-section-titl\n-0005cee0: 653e 7376 677b 6865 6967 6874 3a76 6172  e>svg{height:var\n-0005cef0: 282d 2d70 782d 3136 293b 6d61 7267 696e  (--px-16);margin\n-0005cf00: 2d72 6967 6874 3a76 6172 282d 2d70 782d  -right:var(--px-\n-0005cf10: 3829 3b77 6964 7468 3a76 6172 282d 2d70  8);width:var(--p\n-0005cf20: 782d 3136 297d 2e67 7261 7068 6971 6c2d  x-16)}.graphiql-\n-0005cf30: 646f 632d 6578 706c 6f72 6572 2d73 6563  doc-explorer-sec\n-0005cf40: 7469 6f6e 2d63 6f6e 7465 6e74 7b6d 6172  tion-content{mar\n-0005cf50: 6769 6e2d 6c65 6674 3a76 6172 282d 2d70  gin-left:var(--p\n-0005cf60: 782d 3829 3b6d 6172 6769 6e2d 746f 703a  x-8);margin-top:\n-0005cf70: 7661 7228 2d2d 7078 2d31 3629 7d2e 6772  var(--px-16)}.gr\n-0005cf80: 6170 6869 716c 2d64 6f63 2d65 7870 6c6f  aphiql-doc-explo\n-0005cf90: 7265 722d 7365 6374 696f 6e2d 636f 6e74  rer-section-cont\n-0005cfa0: 656e 743e 2a2b 2a7b 6d61 7267 696e 2d74  ent>*+*{margin-t\n-0005cfb0: 6f70 3a76 6172 282d 2d70 782d 3136 297d  op:var(--px-16)}\n-0005cfc0: 2e67 7261 7068 6971 6c2d 646f 632d 6578  .graphiql-doc-ex\n-0005cfd0: 706c 6f72 6572 2d72 6f6f 742d 7479 7065  plorer-root-type\n-0005cfe0: 7b63 6f6c 6f72 3a68 736c 2876 6172 282d  {color:hsl(var(-\n-0005cff0: 2d63 6f6c 6f72 2d69 6e66 6f29 297d 2e67  -color-info))}.g\n-0005d000: 7261 7068 6971 6c2d 646f 632d 6578 706c  raphiql-doc-expl\n-0005d010: 6f72 6572 2d73 6561 7263 687b 636f 6c6f  orer-search{colo\n-0005d020: 723a 6873 6c61 2876 6172 282d 2d63 6f6c  r:hsla(var(--col\n-0005d030: 6f72 2d6e 6575 7472 616c 292c 7661 7228  or-neutral),var(\n-0005d040: 2d2d 616c 7068 612d 7365 636f 6e64 6172  --alpha-secondar\n-0005d050: 7929 297d 2e67 7261 7068 6971 6c2d 646f  y))}.graphiql-do\n-0005d060: 632d 6578 706c 6f72 6572 2d73 6561 7263  c-explorer-searc\n-0005d070: 683a 6e6f 7428 5b64 6174 612d 7374 6174  h:not([data-stat\n-0005d080: 653d 2269 646c 6522 5d29 7b62 6f72 6465  e=\"idle\"]){borde\n-0005d090: 723a 7661 7228 2d2d 706f 706f 7665 722d  r:var(--popover-\n-0005d0a0: 626f 7264 6572 293b 626f 7264 6572 2d72  border);border-r\n-0005d0b0: 6164 6975 733a 7661 7228 2d2d 626f 7264  adius:var(--bord\n-0005d0c0: 6572 2d72 6164 6975 732d 3429 3b62 6f78  er-radius-4);box\n-0005d0d0: 2d73 6861 646f 773a 7661 7228 2d2d 706f  -shadow:var(--po\n-0005d0e0: 706f 7665 722d 626f 782d 7368 6164 6f77  pover-box-shadow\n-0005d0f0: 293b 636f 6c6f 723a 6873 6c61 2876 6172  );color:hsla(var\n-0005d100: 282d 2d63 6f6c 6f72 2d6e 6575 7472 616c  (--color-neutral\n-0005d110: 292c 3129 7d2e 6772 6170 6869 716c 2d64  ),1)}.graphiql-d\n-0005d120: 6f63 2d65 7870 6c6f 7265 722d 7365 6172  oc-explorer-sear\n-0005d130: 6368 3a6e 6f74 285b 6461 7461 2d73 7461  ch:not([data-sta\n-0005d140: 7465 3d22 6964 6c65 225d 2920 2e67 7261  te=\"idle\"]) .gra\n-0005d150: 7068 6971 6c2d 646f 632d 6578 706c 6f72  phiql-doc-explor\n-0005d160: 6572 2d73 6561 7263 682d 696e 7075 747b  er-search-input{\n-0005d170: 6261 636b 6772 6f75 6e64 3a68 736c 2876  background:hsl(v\n-0005d180: 6172 282d 2d63 6f6c 6f72 2d62 6173 6529  ar(--color-base)\n-0005d190: 297d 2e67 7261 7068 6971 6c2d 646f 632d  )}.graphiql-doc-\n-0005d1a0: 6578 706c 6f72 6572 2d73 6561 7263 682d  explorer-search-\n-0005d1b0: 696e 7075 747b 616c 6967 6e2d 6974 656d  input{align-item\n-0005d1c0: 733a 6365 6e74 6572 3b62 6163 6b67 726f  s:center;backgro\n-0005d1d0: 756e 642d 636f 6c6f 723a 6873 6c61 2876  und-color:hsla(v\n-0005d1e0: 6172 282d 2d63 6f6c 6f72 2d6e 6575 7472  ar(--color-neutr\n-0005d1f0: 616c 292c 7661 7228 2d2d 616c 7068 612d  al),var(--alpha-\n-0005d200: 6261 636b 6772 6f75 6e64 2d6c 6967 6874  background-light\n-0005d210: 2929 3b62 6f72 6465 722d 7261 6469 7573  ));border-radius\n-0005d220: 3a76 6172 282d 2d62 6f72 6465 722d 7261  :var(--border-ra\n-0005d230: 6469 7573 2d34 293b 6469 7370 6c61 793a  dius-4);display:\n-0005d240: 666c 6578 3b70 6164 6469 6e67 3a76 6172  flex;padding:var\n-0005d250: 282d 2d70 782d 3829 2076 6172 282d 2d70  (--px-8) var(--p\n-0005d260: 782d 3132 297d 2e67 7261 7068 6971 6c2d  x-12)}.graphiql-\n-0005d270: 646f 632d 6578 706c 6f72 6572 2d73 6561  doc-explorer-sea\n-0005d280: 7263 6820 5b72 6f6c 653d 636f 6d62 6f62  rch [role=combob\n-0005d290: 6f78 5d7b 626f 7264 6572 3a6e 6f6e 653b  ox]{border:none;\n-0005d2a0: 6261 636b 6772 6f75 6e64 2d63 6f6c 6f72  background-color\n-0005d2b0: 3a74 7261 6e73 7061 7265 6e74 3b6d 6172  :transparent;mar\n-0005d2c0: 6769 6e2d 6c65 6674 3a76 6172 282d 2d70  gin-left:var(--p\n-0005d2d0: 782d 3429 3b77 6964 7468 3a31 3030 257d  x-4);width:100%}\n-0005d2e0: 2e67 7261 7068 6971 6c2d 646f 632d 6578  .graphiql-doc-ex\n-0005d2f0: 706c 6f72 6572 2d73 6561 7263 6820 5b72  plorer-search [r\n-0005d300: 6f6c 653d 636f 6d62 6f62 6f78 5d3a 666f  ole=combobox]:fo\n-0005d310: 6375 737b 6f75 746c 696e 653a 6e6f 6e65  cus{outline:none\n-0005d320: 7d2e 6772 6170 6869 716c 2d64 6f63 2d65  }.graphiql-doc-e\n-0005d330: 7870 6c6f 7265 722d 7365 6172 6368 205b  xplorer-search [\n-0005d340: 726f 6c65 3d6c 6973 7462 6f78 5d7b 6261  role=listbox]{ba\n-0005d350: 636b 6772 6f75 6e64 2d63 6f6c 6f72 3a68  ckground-color:h\n-0005d360: 736c 2876 6172 282d 2d63 6f6c 6f72 2d62  sl(var(--color-b\n-0005d370: 6173 6529 293b 626f 7264 6572 3a6e 6f6e  ase));border:non\n-0005d380: 653b 626f 7264 6572 2d62 6f74 746f 6d2d  e;border-bottom-\n-0005d390: 6c65 6674 2d72 6164 6975 733a 7661 7228  left-radius:var(\n-0005d3a0: 2d2d 626f 7264 6572 2d72 6164 6975 732d  --border-radius-\n-0005d3b0: 3429 3b62 6f72 6465 722d 626f 7474 6f6d  4);border-bottom\n-0005d3c0: 2d72 6967 6874 2d72 6164 6975 733a 7661  -right-radius:va\n-0005d3d0: 7228 2d2d 626f 7264 6572 2d72 6164 6975  r(--border-radiu\n-0005d3e0: 732d 3429 3b62 6f72 6465 722d 746f 703a  s-4);border-top:\n-0005d3f0: 3170 7820 736f 6c69 6420 6873 6c61 2876  1px solid hsla(v\n-0005d400: 6172 282d 2d63 6f6c 6f72 2d6e 6575 7472  ar(--color-neutr\n-0005d410: 616c 292c 7661 7228 2d2d 616c 7068 612d  al),var(--alpha-\n-0005d420: 6261 636b 6772 6f75 6e64 2d68 6561 7679  background-heavy\n-0005d430: 2929 3b6d 6178 2d68 6569 6768 743a 3430  ));max-height:40\n-0005d440: 3070 783b 6f76 6572 666c 6f77 2d79 3a61  0px;overflow-y:a\n-0005d450: 7574 6f3b 6d61 7267 696e 3a30 3b66 6f6e  uto;margin:0;fon\n-0005d460: 742d 7369 7a65 3a76 6172 282d 2d66 6f6e  t-size:var(--fon\n-0005d470: 742d 7369 7a65 2d62 6f64 7929 3b70 6164  t-size-body);pad\n-0005d480: 6469 6e67 3a76 6172 282d 2d70 782d 3429  ding:var(--px-4)\n-0005d490: 3b70 6f73 6974 696f 6e3a 7265 6c61 7469  ;position:relati\n-0005d4a0: 7665 7d2e 6772 6170 6869 716c 2d64 6f63  ve}.graphiql-doc\n-0005d4b0: 2d65 7870 6c6f 7265 722d 7365 6172 6368  -explorer-search\n-0005d4c0: 205b 726f 6c65 3d6f 7074 696f 6e5d 7b62   [role=option]{b\n-0005d4d0: 6f72 6465 722d 7261 6469 7573 3a76 6172  order-radius:var\n-0005d4e0: 282d 2d62 6f72 6465 722d 7261 6469 7573  (--border-radius\n-0005d4f0: 2d34 293b 636f 6c6f 723a 6873 6c61 2876  -4);color:hsla(v\n-0005d500: 6172 282d 2d63 6f6c 6f72 2d6e 6575 7472  ar(--color-neutr\n-0005d510: 616c 292c 7661 7228 2d2d 616c 7068 612d  al),var(--alpha-\n-0005d520: 7365 636f 6e64 6172 7929 293b 6f76 6572  secondary));over\n-0005d530: 666c 6f77 2d78 3a68 6964 6465 6e3b 7061  flow-x:hidden;pa\n-0005d540: 6464 696e 673a 7661 7228 2d2d 7078 2d38  dding:var(--px-8\n-0005d550: 2920 7661 7228 2d2d 7078 2d31 3229 3b74  ) var(--px-12);t\n-0005d560: 6578 742d 6f76 6572 666c 6f77 3a65 6c6c  ext-overflow:ell\n-0005d570: 6970 7369 733b 7768 6974 652d 7370 6163  ipsis;white-spac\n-0005d580: 653a 6e6f 7772 6170 3b63 7572 736f 723a  e:nowrap;cursor:\n-0005d590: 706f 696e 7465 727d 2e67 7261 7068 6971  pointer}.graphiq\n-0005d5a0: 6c2d 646f 632d 6578 706c 6f72 6572 2d73  l-doc-explorer-s\n-0005d5b0: 6561 7263 6820 5b72 6f6c 653d 6f70 7469  earch [role=opti\n-0005d5c0: 6f6e 5d5b 6461 7461 2d68 6561 646c 6573  on][data-headles\n-0005d5d0: 7375 692d 7374 6174 653d 6163 7469 7665  sui-state=active\n-0005d5e0: 5d7b 6261 636b 6772 6f75 6e64 2d63 6f6c  ]{background-col\n-0005d5f0: 6f72 3a68 736c 6128 7661 7228 2d2d 636f  or:hsla(var(--co\n-0005d600: 6c6f 722d 6e65 7574 7261 6c29 2c76 6172  lor-neutral),var\n-0005d610: 282d 2d61 6c70 6861 2d62 6163 6b67 726f  (--alpha-backgro\n-0005d620: 756e 642d 6c69 6768 7429 297d 2e67 7261  und-light))}.gra\n-0005d630: 7068 6971 6c2d 646f 632d 6578 706c 6f72  phiql-doc-explor\n-0005d640: 6572 2d73 6561 7263 6820 5b72 6f6c 653d  er-search [role=\n-0005d650: 6f70 7469 6f6e 5d3a 686f 7665 727b 6261  option]:hover{ba\n-0005d660: 636b 6772 6f75 6e64 2d63 6f6c 6f72 3a68  ckground-color:h\n-0005d670: 736c 6128 7661 7228 2d2d 636f 6c6f 722d  sla(var(--color-\n-0005d680: 6e65 7574 7261 6c29 2c76 6172 282d 2d61  neutral),var(--a\n-0005d690: 6c70 6861 2d62 6163 6b67 726f 756e 642d  lpha-background-\n-0005d6a0: 6d65 6469 756d 2929 7d2e 6772 6170 6869  medium))}.graphi\n-0005d6b0: 716c 2d64 6f63 2d65 7870 6c6f 7265 722d  ql-doc-explorer-\n-0005d6c0: 7365 6172 6368 205b 726f 6c65 3d6f 7074  search [role=opt\n-0005d6d0: 696f 6e5d 5b64 6174 612d 6865 6164 6c65  ion][data-headle\n-0005d6e0: 7373 7569 2d73 7461 7465 3d61 6374 6976  ssui-state=activ\n-0005d6f0: 655d 3a68 6f76 6572 7b62 6163 6b67 726f  e]:hover{backgro\n-0005d700: 756e 642d 636f 6c6f 723a 6873 6c61 2876  und-color:hsla(v\n-0005d710: 6172 282d 2d63 6f6c 6f72 2d6e 6575 7472  ar(--color-neutr\n-0005d720: 616c 292c 7661 7228 2d2d 616c 7068 612d  al),var(--alpha-\n-0005d730: 6261 636b 6772 6f75 6e64 2d68 6561 7679  background-heavy\n-0005d740: 2929 7d3a 6973 282e 6772 6170 6869 716c  ))}:is(.graphiql\n-0005d750: 2d64 6f63 2d65 7870 6c6f 7265 722d 7365  -doc-explorer-se\n-0005d760: 6172 6368 205b 726f 6c65 3d22 6f70 7469  arch [role=\"opti\n-0005d770: 6f6e 225d 292b 3a69 7328 2e67 7261 7068  on\"])+:is(.graph\n-0005d780: 6971 6c2d 646f 632d 6578 706c 6f72 6572  iql-doc-explorer\n-0005d790: 2d73 6561 7263 6820 5b72 6f6c 653d 226f  -search [role=\"o\n-0005d7a0: 7074 696f 6e22 5d29 7b6d 6172 6769 6e2d  ption\"]){margin-\n-0005d7b0: 746f 703a 7661 7228 2d2d 7078 2d34 297d  top:var(--px-4)}\n-0005d7c0: 2e67 7261 7068 6971 6c2d 646f 632d 6578  .graphiql-doc-ex\n-0005d7d0: 706c 6f72 6572 2d73 6561 7263 682d 7479  plorer-search-ty\n-0005d7e0: 7065 7b63 6f6c 6f72 3a68 736c 2876 6172  pe{color:hsl(var\n-0005d7f0: 282d 2d63 6f6c 6f72 2d69 6e66 6f29 297d  (--color-info))}\n-0005d800: 2e67 7261 7068 6971 6c2d 646f 632d 6578  .graphiql-doc-ex\n-0005d810: 706c 6f72 6572 2d73 6561 7263 682d 6669  plorer-search-fi\n-0005d820: 656c 647b 636f 6c6f 723a 6873 6c28 7661  eld{color:hsl(va\n-0005d830: 7228 2d2d 636f 6c6f 722d 7761 726e 696e  r(--color-warnin\n-0005d840: 6729 297d 2e67 7261 7068 6971 6c2d 646f  g))}.graphiql-do\n-0005d850: 632d 6578 706c 6f72 6572 2d73 6561 7263  c-explorer-searc\n-0005d860: 682d 6172 6775 6d65 6e74 7b63 6f6c 6f72  h-argument{color\n-0005d870: 3a68 736c 2876 6172 282d 2d63 6f6c 6f72  :hsl(var(--color\n-0005d880: 2d73 6563 6f6e 6461 7279 2929 7d2e 6772  -secondary))}.gr\n-0005d890: 6170 6869 716c 2d64 6f63 2d65 7870 6c6f  aphiql-doc-explo\n-0005d8a0: 7265 722d 7365 6172 6368 2d64 6976 6964  rer-search-divid\n-0005d8b0: 6572 7b63 6f6c 6f72 3a68 736c 6128 7661  er{color:hsla(va\n-0005d8c0: 7228 2d2d 636f 6c6f 722d 6e65 7574 7261  r(--color-neutra\n-0005d8d0: 6c29 2c76 6172 282d 2d61 6c70 6861 2d73  l),var(--alpha-s\n-0005d8e0: 6563 6f6e 6461 7279 2929 3b66 6f6e 742d  econdary));font-\n-0005d8f0: 7369 7a65 3a76 6172 282d 2d66 6f6e 742d  size:var(--font-\n-0005d900: 7369 7a65 2d68 696e 7429 3b66 6f6e 742d  size-hint);font-\n-0005d910: 7765 6967 6874 3a76 6172 282d 2d66 6f6e  weight:var(--fon\n-0005d920: 742d 7765 6967 6874 2d6d 6564 6975 6d29  t-weight-medium)\n-0005d930: 3b6d 6172 6769 6e2d 746f 703a 7661 7228  ;margin-top:var(\n-0005d940: 2d2d 7078 2d38 293b 7061 6464 696e 673a  --px-8);padding:\n-0005d950: 7661 7228 2d2d 7078 2d38 2920 7661 7228  var(--px-8) var(\n-0005d960: 2d2d 7078 2d31 3229 7d2e 6772 6170 6869  --px-12)}.graphi\n-0005d970: 716c 2d64 6f63 2d65 7870 6c6f 7265 722d  ql-doc-explorer-\n-0005d980: 7365 6172 6368 2d65 6d70 7479 7b63 6f6c  search-empty{col\n-0005d990: 6f72 3a68 736c 6128 7661 7228 2d2d 636f  or:hsla(var(--co\n-0005d9a0: 6c6f 722d 6e65 7574 7261 6c29 2c76 6172  lor-neutral),var\n-0005d9b0: 282d 2d61 6c70 6861 2d73 6563 6f6e 6461  (--alpha-seconda\n-0005d9c0: 7279 2929 3b70 6164 6469 6e67 3a76 6172  ry));padding:var\n-0005d9d0: 282d 2d70 782d 3829 2076 6172 282d 2d70  (--px-8) var(--p\n-0005d9e0: 782d 3132 297d 612e 6772 6170 6869 716c  x-12)}a.graphiql\n-0005d9f0: 2d64 6f63 2d65 7870 6c6f 7265 722d 6669  -doc-explorer-fi\n-0005da00: 656c 642d 6e61 6d65 7b63 6f6c 6f72 3a68  eld-name{color:h\n-0005da10: 736c 2876 6172 282d 2d63 6f6c 6f72 2d69  sl(var(--color-i\n-0005da20: 6e66 6f29 293b 7465 7874 2d64 6563 6f72  nfo));text-decor\n-0005da30: 6174 696f 6e3a 6e6f 6e65 7d61 2e67 7261  ation:none}a.gra\n-0005da40: 7068 6971 6c2d 646f 632d 6578 706c 6f72  phiql-doc-explor\n-0005da50: 6572 2d66 6965 6c64 2d6e 616d 653a 686f  er-field-name:ho\n-0005da60: 7665 727b 7465 7874 2d64 6563 6f72 6174  ver{text-decorat\n-0005da70: 696f 6e3a 756e 6465 726c 696e 657d 612e  ion:underline}a.\n-0005da80: 6772 6170 6869 716c 2d64 6f63 2d65 7870  graphiql-doc-exp\n-0005da90: 6c6f 7265 722d 6669 656c 642d 6e61 6d65  lorer-field-name\n-0005daa0: 3a66 6f63 7573 7b6f 7574 6c69 6e65 3a68  :focus{outline:h\n-0005dab0: 736c 2876 6172 282d 2d63 6f6c 6f72 2d69  sl(var(--color-i\n-0005dac0: 6e66 6f29 2920 6175 746f 2031 7078 7d2e  nfo)) auto 1px}.\n-0005dad0: 6772 6170 6869 716c 2d64 6f63 2d65 7870  graphiql-doc-exp\n-0005dae0: 6c6f 7265 722d 6974 656d 3e3a 6e6f 7428  lorer-item>:not(\n-0005daf0: 3a66 6972 7374 2d63 6869 6c64 297b 6d61  :first-child){ma\n-0005db00: 7267 696e 2d74 6f70 3a76 6172 282d 2d70  rgin-top:var(--p\n-0005db10: 782d 3132 297d 2e67 7261 7068 6971 6c2d  x-12)}.graphiql-\n-0005db20: 646f 632d 6578 706c 6f72 6572 2d61 7267  doc-explorer-arg\n-0005db30: 756d 656e 742d 6d75 6c74 6970 6c65 7b6d  ument-multiple{m\n-0005db40: 6172 6769 6e2d 6c65 6674 3a76 6172 282d  argin-left:var(-\n-0005db50: 2d70 782d 3829 7d2e 6772 6170 6869 716c  -px-8)}.graphiql\n-0005db60: 2d64 6f63 2d65 7870 6c6f 7265 722d 656e  -doc-explorer-en\n-0005db70: 756d 2d76 616c 7565 7b63 6f6c 6f72 3a68  um-value{color:h\n-0005db80: 736c 2876 6172 282d 2d63 6f6c 6f72 2d69  sl(var(--color-i\n-0005db90: 6e66 6f29 297d 2e67 7261 7068 6971 6c2d  nfo))}.graphiql-\n-0005dba0: 646f 632d 6578 706c 6f72 6572 2d68 6561  doc-explorer-hea\n-0005dbb0: 6465 727b 6469 7370 6c61 793a 666c 6578  der{display:flex\n-0005dbc0: 3b6a 7573 7469 6679 2d63 6f6e 7465 6e74  ;justify-content\n-0005dbd0: 3a73 7061 6365 2d62 6574 7765 656e 3b70  :space-between;p\n-0005dbe0: 6f73 6974 696f 6e3a 7265 6c61 7469 7665  osition:relative\n-0005dbf0: 7d2e 6772 6170 6869 716c 2d64 6f63 2d65  }.graphiql-doc-e\n-0005dc00: 7870 6c6f 7265 722d 6865 6164 6572 3a66  xplorer-header:f\n-0005dc10: 6f63 7573 2d77 6974 6869 6e20 2e67 7261  ocus-within .gra\n-0005dc20: 7068 6971 6c2d 646f 632d 6578 706c 6f72  phiql-doc-explor\n-0005dc30: 6572 2d74 6974 6c65 7b76 6973 6962 696c  er-title{visibil\n-0005dc40: 6974 793a 6869 6464 656e 7d2e 6772 6170  ity:hidden}.grap\n-0005dc50: 6869 716c 2d64 6f63 2d65 7870 6c6f 7265  hiql-doc-explore\n-0005dc60: 722d 6865 6164 6572 3a66 6f63 7573 2d77  r-header:focus-w\n-0005dc70: 6974 6869 6e20 2e67 7261 7068 6971 6c2d  ithin .graphiql-\n-0005dc80: 646f 632d 6578 706c 6f72 6572 2d62 6163  doc-explorer-bac\n-0005dc90: 6b3a 6e6f 7428 3a66 6f63 7573 297b 636f  k:not(:focus){co\n-0005dca0: 6c6f 723a 7472 616e 7370 6172 656e 747d  lor:transparent}\n-0005dcb0: 2e67 7261 7068 6971 6c2d 646f 632d 6578  .graphiql-doc-ex\n-0005dcc0: 706c 6f72 6572 2d68 6561 6465 722d 636f  plorer-header-co\n-0005dcd0: 6e74 656e 747b 6469 7370 6c61 793a 666c  ntent{display:fl\n-0005dce0: 6578 3b66 6c65 782d 6469 7265 6374 696f  ex;flex-directio\n-0005dcf0: 6e3a 636f 6c75 6d6e 3b6d 696e 2d77 6964  n:column;min-wid\n-0005dd00: 7468 3a30 7d2e 6772 6170 6869 716c 2d64  th:0}.graphiql-d\n-0005dd10: 6f63 2d65 7870 6c6f 7265 722d 7365 6172  oc-explorer-sear\n-0005dd20: 6368 7b70 6f73 6974 696f 6e3a 6162 736f  ch{position:abso\n-0005dd30: 6c75 7465 3b72 6967 6874 3a30 3b74 6f70  lute;right:0;top\n-0005dd40: 3a30 7d2e 6772 6170 6869 716c 2d64 6f63  :0}.graphiql-doc\n-0005dd50: 2d65 7870 6c6f 7265 722d 7365 6172 6368  -explorer-search\n-0005dd60: 3a66 6f63 7573 2d77 6974 6869 6e7b 6c65  :focus-within{le\n-0005dd70: 6674 3a30 7d2e 6772 6170 6869 716c 2d64  ft:0}.graphiql-d\n-0005dd80: 6f63 2d65 7870 6c6f 7265 722d 7365 6172  oc-explorer-sear\n-0005dd90: 6368 205b 726f 6c65 3d63 6f6d 626f 626f  ch [role=combobo\n-0005dda0: 785d 7b68 6569 6768 743a 3234 7078 3b77  x]{height:24px;w\n-0005ddb0: 6964 7468 3a34 6368 7d2e 6772 6170 6869  idth:4ch}.graphi\n-0005ddc0: 716c 2d64 6f63 2d65 7870 6c6f 7265 722d  ql-doc-explorer-\n-0005ddd0: 7365 6172 6368 205b 726f 6c65 3d63 6f6d  search [role=com\n-0005dde0: 626f 626f 785d 3a66 6f63 7573 7b77 6964  bobox]:focus{wid\n-0005ddf0: 7468 3a31 3030 257d 612e 6772 6170 6869  th:100%}a.graphi\n-0005de00: 716c 2d64 6f63 2d65 7870 6c6f 7265 722d  ql-doc-explorer-\n-0005de10: 6261 636b 7b61 6c69 676e 2d69 7465 6d73  back{align-items\n-0005de20: 3a63 656e 7465 723b 636f 6c6f 723a 6873  :center;color:hs\n-0005de30: 6c61 2876 6172 282d 2d63 6f6c 6f72 2d6e  la(var(--color-n\n-0005de40: 6575 7472 616c 292c 7661 7228 2d2d 616c  eutral),var(--al\n-0005de50: 7068 612d 7365 636f 6e64 6172 7929 293b  pha-secondary));\n-0005de60: 6469 7370 6c61 793a 666c 6578 3b74 6578  display:flex;tex\n-0005de70: 742d 6465 636f 7261 7469 6f6e 3a6e 6f6e  t-decoration:non\n-0005de80: 657d 612e 6772 6170 6869 716c 2d64 6f63  e}a.graphiql-doc\n-0005de90: 2d65 7870 6c6f 7265 722d 6261 636b 3a68  -explorer-back:h\n-0005dea0: 6f76 6572 7b74 6578 742d 6465 636f 7261  over{text-decora\n-0005deb0: 7469 6f6e 3a75 6e64 6572 6c69 6e65 7d61  tion:underline}a\n-0005dec0: 2e67 7261 7068 6971 6c2d 646f 632d 6578  .graphiql-doc-ex\n-0005ded0: 706c 6f72 6572 2d62 6163 6b3a 666f 6375  plorer-back:focu\n-0005dee0: 737b 6f75 746c 696e 653a 6873 6c61 2876  s{outline:hsla(v\n-0005def0: 6172 282d 2d63 6f6c 6f72 2d6e 6575 7472  ar(--color-neutr\n-0005df00: 616c 292c 7661 7228 2d2d 616c 7068 612d  al),var(--alpha-\n-0005df10: 7365 636f 6e64 6172 7929 2920 6175 746f  secondary)) auto\n-0005df20: 2031 7078 7d61 2e67 7261 7068 6971 6c2d   1px}a.graphiql-\n-0005df30: 646f 632d 6578 706c 6f72 6572 2d62 6163  doc-explorer-bac\n-0005df40: 6b3a 666f 6375 732b 2e67 7261 7068 6971  k:focus+.graphiq\n-0005df50: 6c2d 646f 632d 6578 706c 6f72 6572 2d74  l-doc-explorer-t\n-0005df60: 6974 6c65 7b76 6973 6962 696c 6974 793a  itle{visibility:\n-0005df70: 756e 7365 747d 612e 6772 6170 6869 716c  unset}a.graphiql\n-0005df80: 2d64 6f63 2d65 7870 6c6f 7265 722d 6261  -doc-explorer-ba\n-0005df90: 636b 3e73 7667 7b68 6569 6768 743a 7661  ck>svg{height:va\n-0005dfa0: 7228 2d2d 7078 2d38 293b 6d61 7267 696e  r(--px-8);margin\n-0005dfb0: 2d72 6967 6874 3a76 6172 282d 2d70 782d  -right:var(--px-\n-0005dfc0: 3829 3b77 6964 7468 3a76 6172 282d 2d70  8);width:var(--p\n-0005dfd0: 782d 3829 7d2e 6772 6170 6869 716c 2d64  x-8)}.graphiql-d\n-0005dfe0: 6f63 2d65 7870 6c6f 7265 722d 7469 746c  oc-explorer-titl\n-0005dff0: 657b 666f 6e74 2d77 6569 6768 743a 7661  e{font-weight:va\n-0005e000: 7228 2d2d 666f 6e74 2d77 6569 6768 742d  r(--font-weight-\n-0005e010: 6d65 6469 756d 293b 666f 6e74 2d73 697a  medium);font-siz\n-0005e020: 653a 7661 7228 2d2d 666f 6e74 2d73 697a  e:var(--font-siz\n-0005e030: 652d 6832 293b 6f76 6572 666c 6f77 2d78  e-h2);overflow-x\n-0005e040: 3a68 6964 6465 6e3b 7465 7874 2d6f 7665  :hidden;text-ove\n-0005e050: 7266 6c6f 773a 656c 6c69 7073 6973 3b77  rflow:ellipsis;w\n-0005e060: 6869 7465 2d73 7061 6365 3a6e 6f77 7261  hite-space:nowra\n-0005e070: 707d 2e67 7261 7068 6971 6c2d 646f 632d  p}.graphiql-doc-\n-0005e080: 6578 706c 6f72 6572 2d74 6974 6c65 3a6e  explorer-title:n\n-0005e090: 6f74 283a 6669 7273 742d 6368 696c 6429  ot(:first-child)\n-0005e0a0: 7b66 6f6e 742d 7369 7a65 3a76 6172 282d  {font-size:var(-\n-0005e0b0: 2d66 6f6e 742d 7369 7a65 2d68 3329 3b6d  -font-size-h3);m\n-0005e0c0: 6172 6769 6e2d 746f 703a 7661 7228 2d2d  argin-top:var(--\n-0005e0d0: 7078 2d38 297d 2e67 7261 7068 6971 6c2d  px-8)}.graphiql-\n-0005e0e0: 646f 632d 6578 706c 6f72 6572 2d63 6f6e  doc-explorer-con\n-0005e0f0: 7465 6e74 3e2a 7b63 6f6c 6f72 3a68 736c  tent>*{color:hsl\n-0005e100: 6128 7661 7228 2d2d 636f 6c6f 722d 6e65  a(var(--color-ne\n-0005e110: 7574 7261 6c29 2c76 6172 282d 2d61 6c70  utral),var(--alp\n-0005e120: 6861 2d73 6563 6f6e 6461 7279 2929 3b6d  ha-secondary));m\n-0005e130: 6172 6769 6e2d 746f 703a 7661 7228 2d2d  argin-top:var(--\n-0005e140: 7078 2d32 3029 7d2e 6772 6170 6869 716c  px-20)}.graphiql\n-0005e150: 2d64 6f63 2d65 7870 6c6f 7265 722d 6572  -doc-explorer-er\n-0005e160: 726f 727b 6261 636b 6772 6f75 6e64 2d63  ror{background-c\n-0005e170: 6f6c 6f72 3a68 736c 6128 7661 7228 2d2d  olor:hsla(var(--\n-0005e180: 636f 6c6f 722d 6572 726f 7229 2c76 6172  color-error),var\n-0005e190: 282d 2d61 6c70 6861 2d62 6163 6b67 726f  (--alpha-backgro\n-0005e1a0: 756e 642d 6865 6176 7929 293b 626f 7264  und-heavy));bord\n-0005e1b0: 6572 3a31 7078 2073 6f6c 6964 2068 736c  er:1px solid hsl\n-0005e1c0: 2876 6172 282d 2d63 6f6c 6f72 2d65 7272  (var(--color-err\n-0005e1d0: 6f72 2929 3b62 6f72 6465 722d 7261 6469  or));border-radi\n-0005e1e0: 7573 3a76 6172 282d 2d62 6f72 6465 722d  us:var(--border-\n-0005e1f0: 7261 6469 7573 2d38 293b 636f 6c6f 723a  radius-8);color:\n-0005e200: 6873 6c28 7661 7228 2d2d 636f 6c6f 722d  hsl(var(--color-\n-0005e210: 6572 726f 7229 293b 7061 6464 696e 673a  error));padding:\n-0005e220: 7661 7228 2d2d 7078 2d38 2920 7661 7228  var(--px-8) var(\n-0005e230: 2d2d 7078 2d31 3229 7d2e 436f 6465 4d69  --px-12)}.CodeMi\n-0005e240: 7272 6f72 7b66 6f6e 742d 6661 6d69 6c79  rror{font-family\n-0005e250: 3a6d 6f6e 6f73 7061 6365 3b68 6569 6768  :monospace;heigh\n-0005e260: 743a 3330 3070 783b 636f 6c6f 723a 2330  t:300px;color:#0\n-0005e270: 3030 3b64 6972 6563 7469 6f6e 3a6c 7472  00;direction:ltr\n-0005e280: 7d2e 436f 6465 4d69 7272 6f72 2d6c 696e  }.CodeMirror-lin\n-0005e290: 6573 7b70 6164 6469 6e67 3a34 7078 2030  es{padding:4px 0\n-0005e2a0: 7d2e 436f 6465 4d69 7272 6f72 2070 7265  }.CodeMirror pre\n-0005e2b0: 2e43 6f64 654d 6972 726f 722d 6c69 6e65  .CodeMirror-line\n-0005e2c0: 2c2e 436f 6465 4d69 7272 6f72 2070 7265  ,.CodeMirror pre\n-0005e2d0: 2e43 6f64 654d 6972 726f 722d 6c69 6e65  .CodeMirror-line\n-0005e2e0: 2d6c 696b 657b 7061 6464 696e 673a 3020  -like{padding:0 \n-0005e2f0: 3470 787d 2e43 6f64 654d 6972 726f 722d  4px}.CodeMirror-\n-0005e300: 7363 726f 6c6c 6261 722d 6669 6c6c 6572  scrollbar-filler\n-0005e310: 2c2e 436f 6465 4d69 7272 6f72 2d67 7574  ,.CodeMirror-gut\n-0005e320: 7465 722d 6669 6c6c 6572 7b62 6163 6b67  ter-filler{backg\n-0005e330: 726f 756e 642d 636f 6c6f 723a 2366 6666  round-color:#fff\n-0005e340: 7d2e 436f 6465 4d69 7272 6f72 2d67 7574  }.CodeMirror-gut\n-0005e350: 7465 7273 7b62 6f72 6465 722d 7269 6768  ters{border-righ\n-0005e360: 743a 3170 7820 736f 6c69 6420 2364 6464  t:1px solid #ddd\n-0005e370: 3b62 6163 6b67 726f 756e 642d 636f 6c6f  ;background-colo\n-0005e380: 723a 2366 3766 3766 373b 7768 6974 652d  r:#f7f7f7;white-\n-0005e390: 7370 6163 653a 6e6f 7772 6170 7d2e 436f  space:nowrap}.Co\n-0005e3a0: 6465 4d69 7272 6f72 2d6c 696e 656e 756d  deMirror-linenum\n-0005e3b0: 6265 727b 7061 6464 696e 673a 3020 3370  ber{padding:0 3p\n-0005e3c0: 7820 3020 3570 783b 6d69 6e2d 7769 6474  x 0 5px;min-widt\n-0005e3d0: 683a 3230 7078 3b74 6578 742d 616c 6967  h:20px;text-alig\n-0005e3e0: 6e3a 7269 6768 743b 636f 6c6f 723a 2339  n:right;color:#9\n-0005e3f0: 3939 3b77 6869 7465 2d73 7061 6365 3a6e  99;white-space:n\n-0005e400: 6f77 7261 707d 2e43 6f64 654d 6972 726f  owrap}.CodeMirro\n-0005e410: 722d 6775 7474 6572 6d61 726b 6572 7b63  r-guttermarker{c\n-0005e420: 6f6c 6f72 3a23 3030 307d 2e43 6f64 654d  olor:#000}.CodeM\n-0005e430: 6972 726f 722d 6775 7474 6572 6d61 726b  irror-guttermark\n-0005e440: 6572 2d73 7562 746c 657b 636f 6c6f 723a  er-subtle{color:\n-0005e450: 2339 3939 7d2e 436f 6465 4d69 7272 6f72  #999}.CodeMirror\n-0005e460: 2d63 7572 736f 727b 626f 7264 6572 2d6c  -cursor{border-l\n-0005e470: 6566 743a 3170 7820 736f 6c69 6420 626c  eft:1px solid bl\n-0005e480: 6163 6b3b 626f 7264 6572 2d72 6967 6874  ack;border-right\n-0005e490: 3a6e 6f6e 653b 7769 6474 683a 307d 2e43  :none;width:0}.C\n-0005e4a0: 6f64 654d 6972 726f 7220 6469 762e 436f  odeMirror div.Co\n-0005e4b0: 6465 4d69 7272 6f72 2d73 6563 6f6e 6461  deMirror-seconda\n-0005e4c0: 7279 6375 7273 6f72 7b62 6f72 6465 722d  rycursor{border-\n-0005e4d0: 6c65 6674 3a31 7078 2073 6f6c 6964 2073  left:1px solid s\n-0005e4e0: 696c 7665 727d 2e63 6d2d 6661 742d 6375  ilver}.cm-fat-cu\n-0005e4f0: 7273 6f72 202e 436f 6465 4d69 7272 6f72  rsor .CodeMirror\n-0005e500: 2d63 7572 736f 727b 7769 6474 683a 6175  -cursor{width:au\n-0005e510: 746f 3b62 6f72 6465 723a 3021 696d 706f  to;border:0!impo\n-0005e520: 7274 616e 743b 6261 636b 6772 6f75 6e64  rtant;background\n-0005e530: 3a23 3765 377d 2e63 6d2d 6661 742d 6375  :#7e7}.cm-fat-cu\n-0005e540: 7273 6f72 2064 6976 2e43 6f64 654d 6972  rsor div.CodeMir\n-0005e550: 726f 722d 6375 7273 6f72 737b 7a2d 696e  ror-cursors{z-in\n-0005e560: 6465 783a 317d 2e63 6d2d 6661 742d 6375  dex:1}.cm-fat-cu\n-0005e570: 7273 6f72 202e 436f 6465 4d69 7272 6f72  rsor .CodeMirror\n-0005e580: 2d6c 696e 653a 3a73 656c 6563 7469 6f6e  -line::selection\n-0005e590: 2c2e 636d 2d66 6174 2d63 7572 736f 7220  ,.cm-fat-cursor \n-0005e5a0: 2e43 6f64 654d 6972 726f 722d 6c69 6e65  .CodeMirror-line\n-0005e5b0: 3e73 7061 6e3a 3a73 656c 6563 7469 6f6e  >span::selection\n-0005e5c0: 2c2e 636d 2d66 6174 2d63 7572 736f 7220  ,.cm-fat-cursor \n-0005e5d0: 2e43 6f64 654d 6972 726f 722d 6c69 6e65  .CodeMirror-line\n-0005e5e0: 3e73 7061 6e3e 7370 616e 3a3a 7365 6c65  >span>span::sele\n-0005e5f0: 6374 696f 6e7b 6261 636b 6772 6f75 6e64  ction{background\n-0005e600: 3a74 7261 6e73 7061 7265 6e74 7d2e 636d  :transparent}.cm\n-0005e610: 2d66 6174 2d63 7572 736f 7220 2e43 6f64  -fat-cursor .Cod\n-0005e620: 654d 6972 726f 722d 6c69 6e65 3a3a 2d6d  eMirror-line::-m\n-0005e630: 6f7a 2d73 656c 6563 7469 6f6e 2c2e 636d  oz-selection,.cm\n-0005e640: 2d66 6174 2d63 7572 736f 7220 2e43 6f64  -fat-cursor .Cod\n-0005e650: 654d 6972 726f 722d 6c69 6e65 3e73 7061  eMirror-line>spa\n-0005e660: 6e3a 3a2d 6d6f 7a2d 7365 6c65 6374 696f  n::-moz-selectio\n-0005e670: 6e2c 2e63 6d2d 6661 742d 6375 7273 6f72  n,.cm-fat-cursor\n-0005e680: 202e 436f 6465 4d69 7272 6f72 2d6c 696e   .CodeMirror-lin\n-0005e690: 653e 7370 616e 3e73 7061 6e3a 3a2d 6d6f  e>span>span::-mo\n-0005e6a0: 7a2d 7365 6c65 6374 696f 6e7b 6261 636b  z-selection{back\n-0005e6b0: 6772 6f75 6e64 3a74 7261 6e73 7061 7265  ground:transpare\n-0005e6c0: 6e74 7d2e 636d 2d66 6174 2d63 7572 736f  nt}.cm-fat-curso\n-0005e6d0: 727b 6361 7265 742d 636f 6c6f 723a 7472  r{caret-color:tr\n-0005e6e0: 616e 7370 6172 656e 747d 402d 6d6f 7a2d  ansparent}@-moz-\n-0005e6f0: 6b65 7966 7261 6d65 7320 626c 696e 6b7b  keyframes blink{\n-0005e700: 3530 257b 6261 636b 6772 6f75 6e64 2d63  50%{background-c\n-0005e710: 6f6c 6f72 3a74 7261 6e73 7061 7265 6e74  olor:transparent\n-0005e720: 7d7d 402d 7765 626b 6974 2d6b 6579 6672  }}@-webkit-keyfr\n-0005e730: 616d 6573 2062 6c69 6e6b 7b35 3025 7b62  ames blink{50%{b\n-0005e740: 6163 6b67 726f 756e 642d 636f 6c6f 723a  ackground-color:\n-0005e750: 7472 616e 7370 6172 656e 747d 7d40 6b65  transparent}}@ke\n-0005e760: 7966 7261 6d65 7320 626c 696e 6b7b 3530  yframes blink{50\n-0005e770: 257b 6261 636b 6772 6f75 6e64 2d63 6f6c  %{background-col\n-0005e780: 6f72 3a74 7261 6e73 7061 7265 6e74 7d7d  or:transparent}}\n-0005e790: 2e63 6d2d 7461 627b 6469 7370 6c61 793a  .cm-tab{display:\n-0005e7a0: 696e 6c69 6e65 2d62 6c6f 636b 3b74 6578  inline-block;tex\n-0005e7b0: 742d 6465 636f 7261 7469 6f6e 3a69 6e68  t-decoration:inh\n-0005e7c0: 6572 6974 7d2e 436f 6465 4d69 7272 6f72  erit}.CodeMirror\n-0005e7d0: 2d72 756c 6572 737b 706f 7369 7469 6f6e  -rulers{position\n-0005e7e0: 3a61 6273 6f6c 7574 653b 6c65 6674 3a30  :absolute;left:0\n-0005e7f0: 3b72 6967 6874 3a30 3b74 6f70 3a2d 3530  ;right:0;top:-50\n-0005e800: 7078 3b62 6f74 746f 6d3a 303b 6f76 6572  px;bottom:0;over\n-0005e810: 666c 6f77 3a68 6964 6465 6e7d 2e43 6f64  flow:hidden}.Cod\n-0005e820: 654d 6972 726f 722d 7275 6c65 727b 626f  eMirror-ruler{bo\n-0005e830: 7264 6572 2d6c 6566 743a 3170 7820 736f  rder-left:1px so\n-0005e840: 6c69 6420 2363 6363 3b74 6f70 3a30 3b62  lid #ccc;top:0;b\n-0005e850: 6f74 746f 6d3a 303b 706f 7369 7469 6f6e  ottom:0;position\n-0005e860: 3a61 6273 6f6c 7574 657d 2e63 6d2d 732d  :absolute}.cm-s-\n-0005e870: 6465 6661 756c 7420 2e63 6d2d 6865 6164  default .cm-head\n-0005e880: 6572 7b63 6f6c 6f72 3a23 3030 667d 2e63  er{color:#00f}.c\n-0005e890: 6d2d 732d 6465 6661 756c 7420 2e63 6d2d  m-s-default .cm-\n-0005e8a0: 7175 6f74 657b 636f 6c6f 723a 2330 3930  quote{color:#090\n-0005e8b0: 7d2e 636d 2d6e 6567 6174 6976 657b 636f  }.cm-negative{co\n-0005e8c0: 6c6f 723a 2364 3434 7d2e 636d 2d70 6f73  lor:#d44}.cm-pos\n-0005e8d0: 6974 6976 657b 636f 6c6f 723a 2332 3932  itive{color:#292\n-0005e8e0: 7d2e 636d 2d68 6561 6465 722c 2e63 6d2d  }.cm-header,.cm-\n-0005e8f0: 7374 726f 6e67 7b66 6f6e 742d 7765 6967  strong{font-weig\n-0005e900: 6874 3a37 3030 7d2e 636d 2d65 6d7b 666f  ht:700}.cm-em{fo\n-0005e910: 6e74 2d73 7479 6c65 3a69 7461 6c69 637d  nt-style:italic}\n-0005e920: 2e63 6d2d 6c69 6e6b 7b74 6578 742d 6465  .cm-link{text-de\n-0005e930: 636f 7261 7469 6f6e 3a75 6e64 6572 6c69  coration:underli\n-0005e940: 6e65 7d2e 636d 2d73 7472 696b 6574 6872  ne}.cm-strikethr\n-0005e950: 6f75 6768 7b74 6578 742d 6465 636f 7261  ough{text-decora\n-0005e960: 7469 6f6e 3a6c 696e 652d 7468 726f 7567  tion:line-throug\n-0005e970: 687d 2e63 6d2d 732d 6465 6661 756c 7420  h}.cm-s-default \n-0005e980: 2e63 6d2d 6b65 7977 6f72 647b 636f 6c6f  .cm-keyword{colo\n-0005e990: 723a 2337 3038 7d2e 636d 2d73 2d64 6566  r:#708}.cm-s-def\n-0005e9a0: 6175 6c74 202e 636d 2d61 746f 6d7b 636f  ault .cm-atom{co\n-0005e9b0: 6c6f 723a 2332 3139 7d2e 636d 2d73 2d64  lor:#219}.cm-s-d\n-0005e9c0: 6566 6175 6c74 202e 636d 2d6e 756d 6265  efault .cm-numbe\n-0005e9d0: 727b 636f 6c6f 723a 2331 3634 7d2e 636d  r{color:#164}.cm\n-0005e9e0: 2d73 2d64 6566 6175 6c74 202e 636d 2d64  -s-default .cm-d\n-0005e9f0: 6566 7b63 6f6c 6f72 3a23 3030 667d 2e63  ef{color:#00f}.c\n-0005ea00: 6d2d 732d 6465 6661 756c 7420 2e63 6d2d  m-s-default .cm-\n-0005ea10: 7661 7269 6162 6c65 2d32 7b63 6f6c 6f72  variable-2{color\n-0005ea20: 3a23 3035 617d 2e63 6d2d 732d 6465 6661  :#05a}.cm-s-defa\n-0005ea30: 756c 7420 2e63 6d2d 7661 7269 6162 6c65  ult .cm-variable\n-0005ea40: 2d33 2c2e 636d 2d73 2d64 6566 6175 6c74  -3,.cm-s-default\n-0005ea50: 202e 636d 2d74 7970 657b 636f 6c6f 723a   .cm-type{color:\n-0005ea60: 2330 3835 7d2e 636d 2d73 2d64 6566 6175  #085}.cm-s-defau\n-0005ea70: 6c74 202e 636d 2d63 6f6d 6d65 6e74 7b63  lt .cm-comment{c\n-0005ea80: 6f6c 6f72 3a23 6135 307d 2e63 6d2d 732d  olor:#a50}.cm-s-\n-0005ea90: 6465 6661 756c 7420 2e63 6d2d 7374 7269  default .cm-stri\n-0005eaa0: 6e67 7b63 6f6c 6f72 3a23 6131 317d 2e63  ng{color:#a11}.c\n-0005eab0: 6d2d 732d 6465 6661 756c 7420 2e63 6d2d  m-s-default .cm-\n-0005eac0: 7374 7269 6e67 2d32 7b63 6f6c 6f72 3a23  string-2{color:#\n-0005ead0: 6635 307d 2e63 6d2d 732d 6465 6661 756c  f50}.cm-s-defaul\n-0005eae0: 7420 2e63 6d2d 6d65 7461 2c2e 636d 2d73  t .cm-meta,.cm-s\n-0005eaf0: 2d64 6566 6175 6c74 202e 636d 2d71 7561  -default .cm-qua\n-0005eb00: 6c69 6669 6572 7b63 6f6c 6f72 3a23 3535  lifier{color:#55\n-0005eb10: 357d 2e63 6d2d 732d 6465 6661 756c 7420  5}.cm-s-default \n-0005eb20: 2e63 6d2d 6275 696c 7469 6e7b 636f 6c6f  .cm-builtin{colo\n-0005eb30: 723a 2333 3061 7d2e 636d 2d73 2d64 6566  r:#30a}.cm-s-def\n-0005eb40: 6175 6c74 202e 636d 2d62 7261 636b 6574  ault .cm-bracket\n-0005eb50: 7b63 6f6c 6f72 3a23 3939 377d 2e63 6d2d  {color:#997}.cm-\n-0005eb60: 732d 6465 6661 756c 7420 2e63 6d2d 7461  s-default .cm-ta\n-0005eb70: 677b 636f 6c6f 723a 2331 3730 7d2e 636d  g{color:#170}.cm\n-0005eb80: 2d73 2d64 6566 6175 6c74 202e 636d 2d61  -s-default .cm-a\n-0005eb90: 7474 7269 6275 7465 7b63 6f6c 6f72 3a23  ttribute{color:#\n-0005eba0: 3030 637d 2e63 6d2d 732d 6465 6661 756c  00c}.cm-s-defaul\n-0005ebb0: 7420 2e63 6d2d 6872 7b63 6f6c 6f72 3a23  t .cm-hr{color:#\n-0005ebc0: 3939 397d 2e63 6d2d 732d 6465 6661 756c  999}.cm-s-defaul\n-0005ebd0: 7420 2e63 6d2d 6c69 6e6b 7b63 6f6c 6f72  t .cm-link{color\n-0005ebe0: 3a23 3030 637d 2e63 6d2d 732d 6465 6661  :#00c}.cm-s-defa\n-0005ebf0: 756c 7420 2e63 6d2d 6572 726f 722c 2e63  ult .cm-error,.c\n-0005ec00: 6d2d 696e 7661 6c69 6463 6861 727b 636f  m-invalidchar{co\n-0005ec10: 6c6f 723a 7265 647d 2e43 6f64 654d 6972  lor:red}.CodeMir\n-0005ec20: 726f 722d 636f 6d70 6f73 696e 677b 626f  ror-composing{bo\n-0005ec30: 7264 6572 2d62 6f74 746f 6d3a 3270 7820  rder-bottom:2px \n-0005ec40: 736f 6c69 647d 6469 762e 436f 6465 4d69  solid}div.CodeMi\n-0005ec50: 7272 6f72 2073 7061 6e2e 436f 6465 4d69  rror span.CodeMi\n-0005ec60: 7272 6f72 2d6d 6174 6368 696e 6762 7261  rror-matchingbra\n-0005ec70: 636b 6574 7b63 6f6c 6f72 3a23 3062 307d  cket{color:#0b0}\n-0005ec80: 6469 762e 436f 6465 4d69 7272 6f72 2073  div.CodeMirror s\n-0005ec90: 7061 6e2e 436f 6465 4d69 7272 6f72 2d6e  pan.CodeMirror-n\n-0005eca0: 6f6e 6d61 7463 6869 6e67 6272 6163 6b65  onmatchingbracke\n-0005ecb0: 747b 636f 6c6f 723a 2361 3232 7d2e 436f  t{color:#a22}.Co\n-0005ecc0: 6465 4d69 7272 6f72 2d6d 6174 6368 696e  deMirror-matchin\n-0005ecd0: 6774 6167 7b62 6163 6b67 726f 756e 643a  gtag{background:\n-0005ece0: 7267 6261 2832 3535 2c31 3530 2c30 2c2e  rgba(255,150,0,.\n-0005ecf0: 3329 7d2e 436f 6465 4d69 7272 6f72 2d61  3)}.CodeMirror-a\n-0005ed00: 6374 6976 656c 696e 652d 6261 636b 6772  ctiveline-backgr\n-0005ed10: 6f75 6e64 7b62 6163 6b67 726f 756e 643a  ound{background:\n-0005ed20: 2365 3866 3266 667d 2e43 6f64 654d 6972  #e8f2ff}.CodeMir\n-0005ed30: 726f 727b 706f 7369 7469 6f6e 3a72 656c  ror{position:rel\n-0005ed40: 6174 6976 653b 6f76 6572 666c 6f77 3a68  ative;overflow:h\n-0005ed50: 6964 6465 6e3b 6261 636b 6772 6f75 6e64  idden;background\n-0005ed60: 3a77 6869 7465 7d2e 436f 6465 4d69 7272  :white}.CodeMirr\n-0005ed70: 6f72 2d73 6372 6f6c 6c7b 6f76 6572 666c  or-scroll{overfl\n-0005ed80: 6f77 3a73 6372 6f6c 6c21 696d 706f 7274  ow:scroll!import\n-0005ed90: 616e 743b 6d61 7267 696e 2d62 6f74 746f  ant;margin-botto\n-0005eda0: 6d3a 2d35 3070 783b 6d61 7267 696e 2d72  m:-50px;margin-r\n-0005edb0: 6967 6874 3a2d 3530 7078 3b70 6164 6469  ight:-50px;paddi\n-0005edc0: 6e67 2d62 6f74 746f 6d3a 3530 7078 3b68  ng-bottom:50px;h\n-0005edd0: 6569 6768 743a 3130 3025 3b6f 7574 6c69  eight:100%;outli\n-0005ede0: 6e65 3a6e 6f6e 653b 706f 7369 7469 6f6e  ne:none;position\n-0005edf0: 3a72 656c 6174 6976 653b 7a2d 696e 6465  :relative;z-inde\n-0005ee00: 783a 307d 2e43 6f64 654d 6972 726f 722d  x:0}.CodeMirror-\n-0005ee10: 7369 7a65 727b 706f 7369 7469 6f6e 3a72  sizer{position:r\n-0005ee20: 656c 6174 6976 653b 626f 7264 6572 2d72  elative;border-r\n-0005ee30: 6967 6874 3a35 3070 7820 736f 6c69 6420  ight:50px solid \n-0005ee40: 7472 616e 7370 6172 656e 747d 2e43 6f64  transparent}.Cod\n-0005ee50: 654d 6972 726f 722d 7673 6372 6f6c 6c62  eMirror-vscrollb\n-0005ee60: 6172 2c2e 436f 6465 4d69 7272 6f72 2d68  ar,.CodeMirror-h\n-0005ee70: 7363 726f 6c6c 6261 722c 2e43 6f64 654d  scrollbar,.CodeM\n-0005ee80: 6972 726f 722d 7363 726f 6c6c 6261 722d  irror-scrollbar-\n-0005ee90: 6669 6c6c 6572 2c2e 436f 6465 4d69 7272  filler,.CodeMirr\n-0005eea0: 6f72 2d67 7574 7465 722d 6669 6c6c 6572  or-gutter-filler\n-0005eeb0: 7b70 6f73 6974 696f 6e3a 6162 736f 6c75  {position:absolu\n-0005eec0: 7465 3b7a 2d69 6e64 6578 3a36 3b64 6973  te;z-index:6;dis\n-0005eed0: 706c 6179 3a6e 6f6e 653b 6f75 746c 696e  play:none;outlin\n-0005eee0: 653a 6e6f 6e65 7d2e 436f 6465 4d69 7272  e:none}.CodeMirr\n-0005eef0: 6f72 2d76 7363 726f 6c6c 6261 727b 7269  or-vscrollbar{ri\n-0005ef00: 6768 743a 303b 746f 703a 303b 6f76 6572  ght:0;top:0;over\n-0005ef10: 666c 6f77 2d78 3a68 6964 6465 6e3b 6f76  flow-x:hidden;ov\n-0005ef20: 6572 666c 6f77 2d79 3a73 6372 6f6c 6c7d  erflow-y:scroll}\n-0005ef30: 2e43 6f64 654d 6972 726f 722d 6873 6372  .CodeMirror-hscr\n-0005ef40: 6f6c 6c62 6172 7b62 6f74 746f 6d3a 303b  ollbar{bottom:0;\n-0005ef50: 6c65 6674 3a30 3b6f 7665 7266 6c6f 772d  left:0;overflow-\n-0005ef60: 793a 6869 6464 656e 3b6f 7665 7266 6c6f  y:hidden;overflo\n-0005ef70: 772d 783a 7363 726f 6c6c 7d2e 436f 6465  w-x:scroll}.Code\n-0005ef80: 4d69 7272 6f72 2d73 6372 6f6c 6c62 6172  Mirror-scrollbar\n-0005ef90: 2d66 696c 6c65 727b 7269 6768 743a 303b  -filler{right:0;\n-0005efa0: 626f 7474 6f6d 3a30 7d2e 436f 6465 4d69  bottom:0}.CodeMi\n-0005efb0: 7272 6f72 2d67 7574 7465 722d 6669 6c6c  rror-gutter-fill\n-0005efc0: 6572 7b6c 6566 743a 303b 626f 7474 6f6d  er{left:0;bottom\n-0005efd0: 3a30 7d2e 436f 6465 4d69 7272 6f72 2d67  :0}.CodeMirror-g\n-0005efe0: 7574 7465 7273 7b70 6f73 6974 696f 6e3a  utters{position:\n-0005eff0: 6162 736f 6c75 7465 3b6c 6566 743a 303b  absolute;left:0;\n-0005f000: 746f 703a 303b 6d69 6e2d 6865 6967 6874  top:0;min-height\n-0005f010: 3a31 3030 253b 7a2d 696e 6465 783a 337d  :100%;z-index:3}\n-0005f020: 2e43 6f64 654d 6972 726f 722d 6775 7474  .CodeMirror-gutt\n-0005f030: 6572 7b77 6869 7465 2d73 7061 6365 3a6e  er{white-space:n\n-0005f040: 6f72 6d61 6c3b 6865 6967 6874 3a31 3030  ormal;height:100\n-0005f050: 253b 6469 7370 6c61 793a 696e 6c69 6e65  %;display:inline\n-0005f060: 2d62 6c6f 636b 3b76 6572 7469 6361 6c2d  -block;vertical-\n-0005f070: 616c 6967 6e3a 746f 703b 6d61 7267 696e  align:top;margin\n-0005f080: 2d62 6f74 746f 6d3a 2d35 3070 787d 2e43  -bottom:-50px}.C\n-0005f090: 6f64 654d 6972 726f 722d 6775 7474 6572  odeMirror-gutter\n-0005f0a0: 2d77 7261 7070 6572 7b70 6f73 6974 696f  -wrapper{positio\n-0005f0b0: 6e3a 6162 736f 6c75 7465 3b7a 2d69 6e64  n:absolute;z-ind\n-0005f0c0: 6578 3a34 3b62 6163 6b67 726f 756e 643a  ex:4;background:\n-0005f0d0: 6e6f 6e65 2169 6d70 6f72 7461 6e74 3b62  none!important;b\n-0005f0e0: 6f72 6465 723a 6e6f 6e65 2169 6d70 6f72  order:none!impor\n-0005f0f0: 7461 6e74 7d2e 436f 6465 4d69 7272 6f72  tant}.CodeMirror\n-0005f100: 2d67 7574 7465 722d 6261 636b 6772 6f75  -gutter-backgrou\n-0005f110: 6e64 7b70 6f73 6974 696f 6e3a 6162 736f  nd{position:abso\n-0005f120: 6c75 7465 3b74 6f70 3a30 3b62 6f74 746f  lute;top:0;botto\n-0005f130: 6d3a 303b 7a2d 696e 6465 783a 347d 2e43  m:0;z-index:4}.C\n-0005f140: 6f64 654d 6972 726f 722d 6775 7474 6572  odeMirror-gutter\n-0005f150: 2d65 6c74 7b70 6f73 6974 696f 6e3a 6162  -elt{position:ab\n-0005f160: 736f 6c75 7465 3b63 7572 736f 723a 6465  solute;cursor:de\n-0005f170: 6661 756c 743b 7a2d 696e 6465 783a 347d  fault;z-index:4}\n-0005f180: 2e43 6f64 654d 6972 726f 722d 6775 7474  .CodeMirror-gutt\n-0005f190: 6572 2d77 7261 7070 6572 203a 3a73 656c  er-wrapper ::sel\n-0005f1a0: 6563 7469 6f6e 7b62 6163 6b67 726f 756e  ection{backgroun\n-0005f1b0: 642d 636f 6c6f 723a 7472 616e 7370 6172  d-color:transpar\n-0005f1c0: 656e 747d 2e43 6f64 654d 6972 726f 722d  ent}.CodeMirror-\n-0005f1d0: 6775 7474 6572 2d77 7261 7070 6572 203a  gutter-wrapper :\n-0005f1e0: 3a2d 6d6f 7a2d 7365 6c65 6374 696f 6e7b  :-moz-selection{\n-0005f1f0: 6261 636b 6772 6f75 6e64 2d63 6f6c 6f72  background-color\n-0005f200: 3a74 7261 6e73 7061 7265 6e74 7d2e 436f  :transparent}.Co\n-0005f210: 6465 4d69 7272 6f72 2d6c 696e 6573 7b63  deMirror-lines{c\n-0005f220: 7572 736f 723a 7465 7874 3b6d 696e 2d68  ursor:text;min-h\n-0005f230: 6569 6768 743a 3170 787d 2e43 6f64 654d  eight:1px}.CodeM\n-0005f240: 6972 726f 7220 7072 652e 436f 6465 4d69  irror pre.CodeMi\n-0005f250: 7272 6f72 2d6c 696e 652c 2e43 6f64 654d  rror-line,.CodeM\n-0005f260: 6972 726f 7220 7072 652e 436f 6465 4d69  irror pre.CodeMi\n-0005f270: 7272 6f72 2d6c 696e 652d 6c69 6b65 7b2d  rror-line-like{-\n-0005f280: 6d6f 7a2d 626f 7264 6572 2d72 6164 6975  moz-border-radiu\n-0005f290: 733a 303b 2d77 6562 6b69 742d 626f 7264  s:0;-webkit-bord\n-0005f2a0: 6572 2d72 6164 6975 733a 303b 626f 7264  er-radius:0;bord\n-0005f2b0: 6572 2d72 6164 6975 733a 303b 626f 7264  er-radius:0;bord\n-0005f2c0: 6572 2d77 6964 7468 3a30 3b62 6163 6b67  er-width:0;backg\n-0005f2d0: 726f 756e 643a 7472 616e 7370 6172 656e  round:transparen\n-0005f2e0: 743b 666f 6e74 2d66 616d 696c 793a 696e  t;font-family:in\n-0005f2f0: 6865 7269 743b 666f 6e74 2d73 697a 653a  herit;font-size:\n-0005f300: 696e 6865 7269 743b 6d61 7267 696e 3a30  inherit;margin:0\n-0005f310: 3b77 6869 7465 2d73 7061 6365 3a70 7265  ;white-space:pre\n-0005f320: 3b77 6f72 642d 7772 6170 3a6e 6f72 6d61  ;word-wrap:norma\n-0005f330: 6c3b 6c69 6e65 2d68 6569 6768 743a 696e  l;line-height:in\n-0005f340: 6865 7269 743b 636f 6c6f 723a 696e 6865  herit;color:inhe\n-0005f350: 7269 743b 7a2d 696e 6465 783a 323b 706f  rit;z-index:2;po\n-0005f360: 7369 7469 6f6e 3a72 656c 6174 6976 653b  sition:relative;\n-0005f370: 6f76 6572 666c 6f77 3a76 6973 6962 6c65  overflow:visible\n-0005f380: 3b2d 7765 626b 6974 2d74 6170 2d68 6967  ;-webkit-tap-hig\n-0005f390: 686c 6967 6874 2d63 6f6c 6f72 3a74 7261  hlight-color:tra\n-0005f3a0: 6e73 7061 7265 6e74 3b2d 7765 626b 6974  nsparent;-webkit\n-0005f3b0: 2d66 6f6e 742d 7661 7269 616e 742d 6c69  -font-variant-li\n-0005f3c0: 6761 7475 7265 733a 636f 6e74 6578 7475  gatures:contextu\n-0005f3d0: 616c 3b66 6f6e 742d 7661 7269 616e 742d  al;font-variant-\n-0005f3e0: 6c69 6761 7475 7265 733a 636f 6e74 6578  ligatures:contex\n-0005f3f0: 7475 616c 7d2e 436f 6465 4d69 7272 6f72  tual}.CodeMirror\n-0005f400: 2d77 7261 7020 7072 652e 436f 6465 4d69  -wrap pre.CodeMi\n-0005f410: 7272 6f72 2d6c 696e 652c 2e43 6f64 654d  rror-line,.CodeM\n-0005f420: 6972 726f 722d 7772 6170 2070 7265 2e43  irror-wrap pre.C\n-0005f430: 6f64 654d 6972 726f 722d 6c69 6e65 2d6c  odeMirror-line-l\n-0005f440: 696b 657b 776f 7264 2d77 7261 703a 6272  ike{word-wrap:br\n-0005f450: 6561 6b2d 776f 7264 3b77 6869 7465 2d73  eak-word;white-s\n-0005f460: 7061 6365 3a70 7265 2d77 7261 703b 776f  pace:pre-wrap;wo\n-0005f470: 7264 2d62 7265 616b 3a6e 6f72 6d61 6c7d  rd-break:normal}\n-0005f480: 2e43 6f64 654d 6972 726f 722d 6c69 6e65  .CodeMirror-line\n-0005f490: 6261 636b 6772 6f75 6e64 7b70 6f73 6974  background{posit\n-0005f4a0: 696f 6e3a 6162 736f 6c75 7465 3b6c 6566  ion:absolute;lef\n-0005f4b0: 743a 303b 7269 6768 743a 303b 746f 703a  t:0;right:0;top:\n-0005f4c0: 303b 626f 7474 6f6d 3a30 3b7a 2d69 6e64  0;bottom:0;z-ind\n-0005f4d0: 6578 3a30 7d2e 436f 6465 4d69 7272 6f72  ex:0}.CodeMirror\n-0005f4e0: 2d6c 696e 6577 6964 6765 747b 706f 7369  -linewidget{posi\n-0005f4f0: 7469 6f6e 3a72 656c 6174 6976 653b 7a2d  tion:relative;z-\n-0005f500: 696e 6465 783a 323b 7061 6464 696e 673a  index:2;padding:\n-0005f510: 2e31 7078 7d2e 436f 6465 4d69 7272 6f72  .1px}.CodeMirror\n-0005f520: 2d72 746c 2070 7265 7b64 6972 6563 7469  -rtl pre{directi\n-0005f530: 6f6e 3a72 746c 7d2e 436f 6465 4d69 7272  on:rtl}.CodeMirr\n-0005f540: 6f72 2d63 6f64 657b 6f75 746c 696e 653a  or-code{outline:\n-0005f550: 6e6f 6e65 7d2e 436f 6465 4d69 7272 6f72  none}.CodeMirror\n-0005f560: 2d73 6372 6f6c 6c2c 2e43 6f64 654d 6972  -scroll,.CodeMir\n-0005f570: 726f 722d 7369 7a65 722c 2e43 6f64 654d  ror-sizer,.CodeM\n-0005f580: 6972 726f 722d 6775 7474 6572 2c2e 436f  irror-gutter,.Co\n-0005f590: 6465 4d69 7272 6f72 2d67 7574 7465 7273  deMirror-gutters\n-0005f5a0: 2c2e 436f 6465 4d69 7272 6f72 2d6c 696e  ,.CodeMirror-lin\n-0005f5b0: 656e 756d 6265 727b 2d6d 6f7a 2d62 6f78  enumber{-moz-box\n-0005f5c0: 2d73 697a 696e 673a 636f 6e74 656e 742d  -sizing:content-\n-0005f5d0: 626f 783b 626f 782d 7369 7a69 6e67 3a63  box;box-sizing:c\n-0005f5e0: 6f6e 7465 6e74 2d62 6f78 7d2e 436f 6465  ontent-box}.Code\n-0005f5f0: 4d69 7272 6f72 2d6d 6561 7375 7265 7b70  Mirror-measure{p\n-0005f600: 6f73 6974 696f 6e3a 6162 736f 6c75 7465  osition:absolute\n-0005f610: 3b77 6964 7468 3a31 3030 253b 6865 6967  ;width:100%;heig\n-0005f620: 6874 3a30 3b6f 7665 7266 6c6f 773a 6869  ht:0;overflow:hi\n-0005f630: 6464 656e 3b76 6973 6962 696c 6974 793a  dden;visibility:\n-0005f640: 6869 6464 656e 7d2e 436f 6465 4d69 7272  hidden}.CodeMirr\n-0005f650: 6f72 2d63 7572 736f 727b 706f 7369 7469  or-cursor{positi\n-0005f660: 6f6e 3a61 6273 6f6c 7574 653b 706f 696e  on:absolute;poin\n-0005f670: 7465 722d 6576 656e 7473 3a6e 6f6e 657d  ter-events:none}\n-0005f680: 2e43 6f64 654d 6972 726f 722d 6d65 6173  .CodeMirror-meas\n-0005f690: 7572 6520 7072 657b 706f 7369 7469 6f6e  ure pre{position\n-0005f6a0: 3a73 7461 7469 637d 6469 762e 436f 6465  :static}div.Code\n-0005f6b0: 4d69 7272 6f72 2d63 7572 736f 7273 7b76  Mirror-cursors{v\n-0005f6c0: 6973 6962 696c 6974 793a 6869 6464 656e  isibility:hidden\n-0005f6d0: 3b70 6f73 6974 696f 6e3a 7265 6c61 7469  ;position:relati\n-0005f6e0: 7665 3b7a 2d69 6e64 6578 3a33 7d64 6976  ve;z-index:3}div\n-0005f6f0: 2e43 6f64 654d 6972 726f 722d 6472 6167  .CodeMirror-drag\n-0005f700: 6375 7273 6f72 732c 2e43 6f64 654d 6972  cursors,.CodeMir\n-0005f710: 726f 722d 666f 6375 7365 6420 6469 762e  ror-focused div.\n-0005f720: 436f 6465 4d69 7272 6f72 2d63 7572 736f  CodeMirror-curso\n-0005f730: 7273 7b76 6973 6962 696c 6974 793a 7669  rs{visibility:vi\n-0005f740: 7369 626c 657d 2e43 6f64 654d 6972 726f  sible}.CodeMirro\n-0005f750: 722d 7365 6c65 6374 6564 7b62 6163 6b67  r-selected{backg\n-0005f760: 726f 756e 643a 2364 3964 3964 397d 2e43  round:#d9d9d9}.C\n-0005f770: 6f64 654d 6972 726f 722d 666f 6375 7365  odeMirror-focuse\n-0005f780: 6420 2e43 6f64 654d 6972 726f 722d 7365  d .CodeMirror-se\n-0005f790: 6c65 6374 6564 7b62 6163 6b67 726f 756e  lected{backgroun\n-0005f7a0: 643a 2364 3764 3466 307d 2e43 6f64 654d  d:#d7d4f0}.CodeM\n-0005f7b0: 6972 726f 722d 6372 6f73 7368 6169 727b  irror-crosshair{\n-0005f7c0: 6375 7273 6f72 3a63 726f 7373 6861 6972  cursor:crosshair\n-0005f7d0: 7d2e 436f 6465 4d69 7272 6f72 2d6c 696e  }.CodeMirror-lin\n-0005f7e0: 653a 3a73 656c 6563 7469 6f6e 2c2e 436f  e::selection,.Co\n-0005f7f0: 6465 4d69 7272 6f72 2d6c 696e 653e 7370  deMirror-line>sp\n-0005f800: 616e 3a3a 7365 6c65 6374 696f 6e2c 2e43  an::selection,.C\n-0005f810: 6f64 654d 6972 726f 722d 6c69 6e65 3e73  odeMirror-line>s\n-0005f820: 7061 6e3e 7370 616e 3a3a 7365 6c65 6374  pan>span::select\n-0005f830: 696f 6e7b 6261 636b 6772 6f75 6e64 3a23  ion{background:#\n-0005f840: 6437 6434 6630 7d2e 436f 6465 4d69 7272  d7d4f0}.CodeMirr\n-0005f850: 6f72 2d6c 696e 653a 3a2d 6d6f 7a2d 7365  or-line::-moz-se\n-0005f860: 6c65 6374 696f 6e2c 2e43 6f64 654d 6972  lection,.CodeMir\n-0005f870: 726f 722d 6c69 6e65 3e73 7061 6e3a 3a2d  ror-line>span::-\n-0005f880: 6d6f 7a2d 7365 6c65 6374 696f 6e2c 2e43  moz-selection,.C\n-0005f890: 6f64 654d 6972 726f 722d 6c69 6e65 3e73  odeMirror-line>s\n-0005f8a0: 7061 6e3e 7370 616e 3a3a 2d6d 6f7a 2d73  pan>span::-moz-s\n-0005f8b0: 656c 6563 7469 6f6e 7b62 6163 6b67 726f  election{backgro\n-0005f8c0: 756e 643a 2364 3764 3466 307d 2e63 6d2d  und:#d7d4f0}.cm-\n-0005f8d0: 7365 6172 6368 696e 677b 6261 636b 6772  searching{backgr\n-0005f8e0: 6f75 6e64 2d63 6f6c 6f72 3a23 6666 613b  ound-color:#ffa;\n-0005f8f0: 6261 636b 6772 6f75 6e64 2d63 6f6c 6f72  background-color\n-0005f900: 3a23 6666 3036 7d2e 636d 2d66 6f72 6365  :#ff06}.cm-force\n-0005f910: 2d62 6f72 6465 727b 7061 6464 696e 672d  -border{padding-\n-0005f920: 7269 6768 743a 2e31 7078 7d40 6d65 6469  right:.1px}@medi\n-0005f930: 6120 7072 696e 747b 2e43 6f64 654d 6972  a print{.CodeMir\n-0005f940: 726f 7220 6469 762e 436f 6465 4d69 7272  ror div.CodeMirr\n-0005f950: 6f72 2d63 7572 736f 7273 7b76 6973 6962  or-cursors{visib\n-0005f960: 696c 6974 793a 6869 6464 656e 7d7d 2e63  ility:hidden}}.c\n-0005f970: 6d2d 7461 622d 7772 6170 2d68 6163 6b3a  m-tab-wrap-hack:\n-0005f980: 6166 7465 727b 636f 6e74 656e 743a 2222  after{content:\"\"\n-0005f990: 7d73 7061 6e2e 436f 6465 4d69 7272 6f72  }span.CodeMirror\n-0005f9a0: 2d73 656c 6563 7465 6474 6578 747b 6261  -selectedtext{ba\n-0005f9b0: 636b 6772 6f75 6e64 3a6e 6f6e 657d 2e67  ckground:none}.g\n-0005f9c0: 7261 7068 6971 6c2d 636f 6e74 6169 6e65  raphiql-containe\n-0005f9d0: 7220 2e43 6f64 654d 6972 726f 727b 6865  r .CodeMirror{he\n-0005f9e0: 6967 6874 3a31 3030 253b 706f 7369 7469  ight:100%;positi\n-0005f9f0: 6f6e 3a61 6273 6f6c 7574 653b 7769 6474  on:absolute;widt\n-0005fa00: 683a 3130 3025 7d2e 6772 6170 6869 716c  h:100%}.graphiql\n-0005fa10: 2d63 6f6e 7461 696e 6572 202e 436f 6465  -container .Code\n-0005fa20: 4d69 7272 6f72 7b66 6f6e 742d 6661 6d69  Mirror{font-fami\n-0005fa30: 6c79 3a76 6172 282d 2d66 6f6e 742d 6661  ly:var(--font-fa\n-0005fa40: 6d69 6c79 2d6d 6f6e 6f29 7d2e 6772 6170  mily-mono)}.grap\n-0005fa50: 6869 716c 2d63 6f6e 7461 696e 6572 202e  hiql-container .\n-0005fa60: 436f 6465 4d69 7272 6f72 2c2e 6772 6170  CodeMirror,.grap\n-0005fa70: 6869 716c 2d63 6f6e 7461 696e 6572 202e  hiql-container .\n-0005fa80: 436f 6465 4d69 7272 6f72 2d67 7574 7465  CodeMirror-gutte\n-0005fa90: 7273 7b62 6163 6b67 726f 756e 643a 6e6f  rs{background:no\n-0005faa0: 6e65 3b62 6163 6b67 726f 756e 642d 636f  ne;background-co\n-0005fab0: 6c6f 723a 7661 7228 2d2d 6564 6974 6f72  lor:var(--editor\n-0005fac0: 2d62 6163 6b67 726f 756e 642c 2068 736c  -background, hsl\n-0005fad0: 2876 6172 282d 2d63 6f6c 6f72 2d62 6173  (var(--color-bas\n-0005fae0: 6529 2929 7d2e 6772 6170 6869 716c 2d63  e)))}.graphiql-c\n-0005faf0: 6f6e 7461 696e 6572 202e 436f 6465 4d69  ontainer .CodeMi\n-0005fb00: 7272 6f72 2d6c 696e 656e 756d 6265 727b  rror-linenumber{\n-0005fb10: 7061 6464 696e 673a 307d 2e67 7261 7068  padding:0}.graph\n-0005fb20: 6971 6c2d 636f 6e74 6169 6e65 7220 2e43  iql-container .C\n-0005fb30: 6f64 654d 6972 726f 722d 6775 7474 6572  odeMirror-gutter\n-0005fb40: 737b 626f 7264 6572 3a6e 6f6e 657d 2e63  s{border:none}.c\n-0005fb50: 6d2d 732d 6772 6170 6869 716c 7b63 6f6c  m-s-graphiql{col\n-0005fb60: 6f72 3a68 736c 6128 7661 7228 2d2d 636f  or:hsla(var(--co\n-0005fb70: 6c6f 722d 6e65 7574 7261 6c29 2c76 6172  lor-neutral),var\n-0005fb80: 282d 2d61 6c70 6861 2d74 6572 7469 6172  (--alpha-tertiar\n-0005fb90: 7929 297d 2e63 6d2d 732d 6772 6170 6869  y))}.cm-s-graphi\n-0005fba0: 716c 202e 636d 2d6b 6579 776f 7264 7b63  ql .cm-keyword{c\n-0005fbb0: 6f6c 6f72 3a68 736c 2876 6172 282d 2d63  olor:hsl(var(--c\n-0005fbc0: 6f6c 6f72 2d70 7269 6d61 7279 2929 7d2e  olor-primary))}.\n-0005fbd0: 636d 2d73 2d67 7261 7068 6971 6c20 2e63  cm-s-graphiql .c\n-0005fbe0: 6d2d 6465 667b 636f 6c6f 723a 6873 6c28  m-def{color:hsl(\n-0005fbf0: 7661 7228 2d2d 636f 6c6f 722d 7465 7274  var(--color-tert\n-0005fc00: 6961 7279 2929 7d2e 636d 2d73 2d67 7261  iary))}.cm-s-gra\n-0005fc10: 7068 6971 6c20 2e63 6d2d 7075 6e63 7475  phiql .cm-punctu\n-0005fc20: 6174 696f 6e7b 636f 6c6f 723a 6873 6c61  ation{color:hsla\n-0005fc30: 2876 6172 282d 2d63 6f6c 6f72 2d6e 6575  (var(--color-neu\n-0005fc40: 7472 616c 292c 7661 7228 2d2d 616c 7068  tral),var(--alph\n-0005fc50: 612d 7465 7274 6961 7279 2929 7d2e 636d  a-tertiary))}.cm\n-0005fc60: 2d73 2d67 7261 7068 6971 6c20 2e63 6d2d  -s-graphiql .cm-\n-0005fc70: 7661 7269 6162 6c65 7b63 6f6c 6f72 3a68  variable{color:h\n-0005fc80: 736c 2876 6172 282d 2d63 6f6c 6f72 2d73  sl(var(--color-s\n-0005fc90: 6563 6f6e 6461 7279 2929 7d2e 636d 2d73  econdary))}.cm-s\n-0005fca0: 2d67 7261 7068 6971 6c20 2e63 6d2d 6174  -graphiql .cm-at\n-0005fcb0: 6f6d 7b63 6f6c 6f72 3a68 736c 2876 6172  om{color:hsl(var\n-0005fcc0: 282d 2d63 6f6c 6f72 2d74 6572 7469 6172  (--color-tertiar\n-0005fcd0: 7929 297d 2e63 6d2d 732d 6772 6170 6869  y))}.cm-s-graphi\n-0005fce0: 716c 202e 636d 2d6e 756d 6265 727b 636f  ql .cm-number{co\n-0005fcf0: 6c6f 723a 6873 6c28 7661 7228 2d2d 636f  lor:hsl(var(--co\n-0005fd00: 6c6f 722d 7375 6363 6573 7329 297d 2e63  lor-success))}.c\n-0005fd10: 6d2d 732d 6772 6170 6869 716c 202e 636d  m-s-graphiql .cm\n-0005fd20: 2d73 7472 696e 677b 636f 6c6f 723a 6873  -string{color:hs\n-0005fd30: 6c28 7661 7228 2d2d 636f 6c6f 722d 7761  l(var(--color-wa\n-0005fd40: 726e 696e 6729 297d 2e63 6d2d 732d 6772  rning))}.cm-s-gr\n-0005fd50: 6170 6869 716c 202e 636d 2d62 7569 6c74  aphiql .cm-built\n-0005fd60: 696e 7b63 6f6c 6f72 3a68 736c 2876 6172  in{color:hsl(var\n-0005fd70: 282d 2d63 6f6c 6f72 2d73 7563 6365 7373  (--color-success\n-0005fd80: 2929 7d2e 636d 2d73 2d67 7261 7068 6971  ))}.cm-s-graphiq\n-0005fd90: 6c20 2e63 6d2d 7374 7269 6e67 2d32 7b63  l .cm-string-2{c\n-0005fda0: 6f6c 6f72 3a68 736c 2876 6172 282d 2d63  olor:hsl(var(--c\n-0005fdb0: 6f6c 6f72 2d73 6563 6f6e 6461 7279 2929  olor-secondary))\n-0005fdc0: 7d2e 636d 2d73 2d67 7261 7068 6971 6c20  }.cm-s-graphiql \n-0005fdd0: 2e63 6d2d 6174 7472 6962 7574 652c 2e63  .cm-attribute,.c\n-0005fde0: 6d2d 732d 6772 6170 6869 716c 202e 636d  m-s-graphiql .cm\n-0005fdf0: 2d6d 6574 617b 636f 6c6f 723a 6873 6c28  -meta{color:hsl(\n-0005fe00: 7661 7228 2d2d 636f 6c6f 722d 7465 7274  var(--color-tert\n-0005fe10: 6961 7279 2929 7d2e 636d 2d73 2d67 7261  iary))}.cm-s-gra\n-0005fe20: 7068 6971 6c20 2e63 6d2d 7072 6f70 6572  phiql .cm-proper\n-0005fe30: 7479 7b63 6f6c 6f72 3a68 736c 2876 6172  ty{color:hsl(var\n-0005fe40: 282d 2d63 6f6c 6f72 2d69 6e66 6f29 297d  (--color-info))}\n-0005fe50: 2e63 6d2d 732d 6772 6170 6869 716c 202e  .cm-s-graphiql .\n-0005fe60: 636d 2d71 7561 6c69 6669 6572 7b63 6f6c  cm-qualifier{col\n-0005fe70: 6f72 3a68 736c 2876 6172 282d 2d63 6f6c  or:hsl(var(--col\n-0005fe80: 6f72 2d73 6563 6f6e 6461 7279 2929 7d2e  or-secondary))}.\n-0005fe90: 636d 2d73 2d67 7261 7068 6971 6c20 2e63  cm-s-graphiql .c\n-0005fea0: 6d2d 636f 6d6d 656e 747b 636f 6c6f 723a  m-comment{color:\n-0005feb0: 6873 6c61 2876 6172 282d 2d63 6f6c 6f72  hsla(var(--color\n-0005fec0: 2d6e 6575 7472 616c 292c 7661 7228 2d2d  -neutral),var(--\n-0005fed0: 616c 7068 612d 7365 636f 6e64 6172 7929  alpha-secondary)\n-0005fee0: 297d 2e63 6d2d 732d 6772 6170 6869 716c  )}.cm-s-graphiql\n-0005fef0: 202e 636d 2d77 737b 636f 6c6f 723a 6873   .cm-ws{color:hs\n-0005ff00: 6c61 2876 6172 282d 2d63 6f6c 6f72 2d6e  la(var(--color-n\n-0005ff10: 6575 7472 616c 292c 7661 7228 2d2d 616c  eutral),var(--al\n-0005ff20: 7068 612d 7465 7274 6961 7279 2929 7d2e  pha-tertiary))}.\n-0005ff30: 636d 2d73 2d67 7261 7068 6971 6c20 2e63  cm-s-graphiql .c\n-0005ff40: 6d2d 696e 7661 6c69 6463 6861 727b 636f  m-invalidchar{co\n-0005ff50: 6c6f 723a 6873 6c28 7661 7228 2d2d 636f  lor:hsl(var(--co\n-0005ff60: 6c6f 722d 6572 726f 7229 297d 2e63 6d2d  lor-error))}.cm-\n-0005ff70: 732d 6772 6170 6869 716c 202e 436f 6465  s-graphiql .Code\n-0005ff80: 4d69 7272 6f72 2d63 7572 736f 727b 626f  Mirror-cursor{bo\n-0005ff90: 7264 6572 2d6c 6566 743a 3270 7820 736f  rder-left:2px so\n-0005ffa0: 6c69 6420 6873 6c61 2876 6172 282d 2d63  lid hsla(var(--c\n-0005ffb0: 6f6c 6f72 2d6e 6575 7472 616c 292c 7661  olor-neutral),va\n-0005ffc0: 7228 2d2d 616c 7068 612d 7365 636f 6e64  r(--alpha-second\n-0005ffd0: 6172 7929 297d 2e63 6d2d 732d 6772 6170  ary))}.cm-s-grap\n-0005ffe0: 6869 716c 202e 436f 6465 4d69 7272 6f72  hiql .CodeMirror\n-0005fff0: 2d6c 696e 656e 756d 6265 727b 636f 6c6f  -linenumber{colo\n-00060000: 723a 6873 6c61 2876 6172 282d 2d63 6f6c  r:hsla(var(--col\n-00060010: 6f72 2d6e 6575 7472 616c 292c 7661 7228  or-neutral),var(\n-00060020: 2d2d 616c 7068 612d 7465 7274 6961 7279  --alpha-tertiary\n-00060030: 2929 7d2e 6772 6170 6869 716c 2d63 6f6e  ))}.graphiql-con\n-00060040: 7461 696e 6572 2064 6976 2e43 6f64 654d  tainer div.CodeM\n-00060050: 6972 726f 7220 7370 616e 2e43 6f64 654d  irror span.CodeM\n-00060060: 6972 726f 722d 6d61 7463 6869 6e67 6272  irror-matchingbr\n-00060070: 6163 6b65 742c 2e67 7261 7068 6971 6c2d  acket,.graphiql-\n-00060080: 636f 6e74 6169 6e65 7220 6469 762e 436f  container div.Co\n-00060090: 6465 4d69 7272 6f72 2073 7061 6e2e 436f  deMirror span.Co\n-000600a0: 6465 4d69 7272 6f72 2d6e 6f6e 6d61 7463  deMirror-nonmatc\n-000600b0: 6869 6e67 6272 6163 6b65 747b 636f 6c6f  hingbracket{colo\n-000600c0: 723a 6873 6c28 7661 7228 2d2d 636f 6c6f  r:hsl(var(--colo\n-000600d0: 722d 7761 726e 696e 6729 297d 2e67 7261  r-warning))}.gra\n-000600e0: 7068 6971 6c2d 636f 6e74 6169 6e65 7220  phiql-container \n-000600f0: 2e43 6f64 654d 6972 726f 722d 7365 6c65  .CodeMirror-sele\n-00060100: 6374 6564 2c2e 6772 6170 6869 716c 2d63  cted,.graphiql-c\n-00060110: 6f6e 7461 696e 6572 202e 436f 6465 4d69  ontainer .CodeMi\n-00060120: 7272 6f72 2d66 6f63 7573 6564 202e 436f  rror-focused .Co\n-00060130: 6465 4d69 7272 6f72 2d73 656c 6563 7465  deMirror-selecte\n-00060140: 647b 6261 636b 6772 6f75 6e64 3a68 736c  d{background:hsl\n-00060150: 6128 7661 7228 2d2d 636f 6c6f 722d 6e65  a(var(--color-ne\n-00060160: 7574 7261 6c29 2c76 6172 282d 2d61 6c70  utral),var(--alp\n-00060170: 6861 2d62 6163 6b67 726f 756e 642d 6865  ha-background-he\n-00060180: 6176 7929 297d 2e67 7261 7068 6971 6c2d  avy))}.graphiql-\n-00060190: 636f 6e74 6169 6e65 7220 2e43 6f64 654d  container .CodeM\n-000601a0: 6972 726f 722d 6469 616c 6f67 7b62 6163  irror-dialog{bac\n-000601b0: 6b67 726f 756e 643a 696e 6865 7269 743b  kground:inherit;\n-000601c0: 636f 6c6f 723a 696e 6865 7269 743b 6c65  color:inherit;le\n-000601d0: 6674 3a30 3b72 6967 6874 3a30 3b6f 7665  ft:0;right:0;ove\n-000601e0: 7266 6c6f 773a 6869 6464 656e 3b70 6164  rflow:hidden;pad\n-000601f0: 6469 6e67 3a76 6172 282d 2d70 782d 3229  ding:var(--px-2)\n-00060200: 2076 6172 282d 2d70 782d 3629 3b70 6f73   var(--px-6);pos\n-00060210: 6974 696f 6e3a 6162 736f 6c75 7465 3b7a  ition:absolute;z\n-00060220: 2d69 6e64 6578 3a36 7d2e 6772 6170 6869  -index:6}.graphi\n-00060230: 716c 2d63 6f6e 7461 696e 6572 202e 436f  ql-container .Co\n-00060240: 6465 4d69 7272 6f72 2d64 6961 6c6f 672d  deMirror-dialog-\n-00060250: 746f 707b 626f 7264 6572 2d62 6f74 746f  top{border-botto\n-00060260: 6d3a 3170 7820 736f 6c69 6420 6873 6c61  m:1px solid hsla\n-00060270: 2876 6172 282d 2d63 6f6c 6f72 2d6e 6575  (var(--color-neu\n-00060280: 7472 616c 292c 7661 7228 2d2d 616c 7068  tral),var(--alph\n-00060290: 612d 6261 636b 6772 6f75 6e64 2d68 6561  a-background-hea\n-000602a0: 7679 2929 3b70 6164 6469 6e67 2d62 6f74  vy));padding-bot\n-000602b0: 746f 6d3a 7661 7228 2d2d 7078 2d31 3229  tom:var(--px-12)\n-000602c0: 3b74 6f70 3a30 7d2e 6772 6170 6869 716c  ;top:0}.graphiql\n-000602d0: 2d63 6f6e 7461 696e 6572 202e 436f 6465  -container .Code\n-000602e0: 4d69 7272 6f72 2d64 6961 6c6f 672d 626f  Mirror-dialog-bo\n-000602f0: 7474 6f6d 7b62 6f72 6465 722d 746f 703a  ttom{border-top:\n-00060300: 3170 7820 736f 6c69 6420 6873 6c61 2876  1px solid hsla(v\n-00060310: 6172 282d 2d63 6f6c 6f72 2d6e 6575 7472  ar(--color-neutr\n-00060320: 616c 292c 7661 7228 2d2d 616c 7068 612d  al),var(--alpha-\n-00060330: 6261 636b 6772 6f75 6e64 2d68 6561 7679  background-heavy\n-00060340: 2929 3b62 6f74 746f 6d3a 303b 7061 6464  ));bottom:0;padd\n-00060350: 696e 672d 746f 703a 7661 7228 2d2d 7078  ing-top:var(--px\n-00060360: 2d31 3229 7d2e 6772 6170 6869 716c 2d63  -12)}.graphiql-c\n-00060370: 6f6e 7461 696e 6572 202e 436f 6465 4d69  ontainer .CodeMi\n-00060380: 7272 6f72 2d73 6561 7263 682d 6869 6e74  rror-search-hint\n-00060390: 7b64 6973 706c 6179 3a6e 6f6e 657d 2e67  {display:none}.g\n-000603a0: 7261 7068 6971 6c2d 636f 6e74 6169 6e65  raphiql-containe\n-000603b0: 7220 2e43 6f64 654d 6972 726f 722d 6469  r .CodeMirror-di\n-000603c0: 616c 6f67 2069 6e70 7574 7b62 6f72 6465  alog input{borde\n-000603d0: 723a 3170 7820 736f 6c69 6420 6873 6c61  r:1px solid hsla\n-000603e0: 2876 6172 282d 2d63 6f6c 6f72 2d6e 6575  (var(--color-neu\n-000603f0: 7472 616c 292c 7661 7228 2d2d 616c 7068  tral),var(--alph\n-00060400: 612d 6261 636b 6772 6f75 6e64 2d68 6561  a-background-hea\n-00060410: 7679 2929 3b62 6f72 6465 722d 7261 6469  vy));border-radi\n-00060420: 7573 3a76 6172 282d 2d62 6f72 6465 722d  us:var(--border-\n-00060430: 7261 6469 7573 2d34 293b 7061 6464 696e  radius-4);paddin\n-00060440: 673a 7661 7228 2d2d 7078 2d34 297d 2e67  g:var(--px-4)}.g\n-00060450: 7261 7068 6971 6c2d 636f 6e74 6169 6e65  raphiql-containe\n-00060460: 7220 2e43 6f64 654d 6972 726f 722d 6469  r .CodeMirror-di\n-00060470: 616c 6f67 2069 6e70 7574 3a66 6f63 7573  alog input:focus\n-00060480: 7b6f 7574 6c69 6e65 3a68 736c 2876 6172  {outline:hsl(var\n-00060490: 282d 2d63 6f6c 6f72 2d70 7269 6d61 7279  (--color-primary\n-000604a0: 2929 2073 6f6c 6964 2032 7078 7d2e 6772  )) solid 2px}.gr\n-000604b0: 6170 6869 716c 2d63 6f6e 7461 696e 6572  aphiql-container\n-000604c0: 202e 636d 2d73 6561 7263 6869 6e67 7b62   .cm-searching{b\n-000604d0: 6163 6b67 726f 756e 642d 636f 6c6f 723a  ackground-color:\n-000604e0: 6873 6c61 2876 6172 282d 2d63 6f6c 6f72  hsla(var(--color\n-000604f0: 2d77 6172 6e69 6e67 292c 7661 7228 2d2d  -warning),var(--\n-00060500: 616c 7068 612d 6261 636b 6772 6f75 6e64  alpha-background\n-00060510: 2d6c 6967 6874 2929 3b70 6164 6469 6e67  -light));padding\n-00060520: 2d62 6f74 746f 6d3a 312e 3570 783b 7061  -bottom:1.5px;pa\n-00060530: 6464 696e 672d 746f 703a 2e35 7078 7d2e  dding-top:.5px}.\n-00060540: 436f 6465 4d69 7272 6f72 2d66 6f6c 646d  CodeMirror-foldm\n-00060550: 6172 6b65 727b 636f 6c6f 723a 2330 3066  arker{color:#00f\n-00060560: 3b74 6578 742d 7368 6164 6f77 3a23 6239  ;text-shadow:#b9\n-00060570: 6620 3170 7820 3170 7820 3270 782c 2362  f 1px 1px 2px,#b\n-00060580: 3966 202d 3170 7820 2d31 7078 2032 7078  9f -1px -1px 2px\n-00060590: 2c23 6239 6620 3170 7820 2d31 7078 2032  ,#b9f 1px -1px 2\n-000605a0: 7078 2c23 6239 6620 2d31 7078 2031 7078  px,#b9f -1px 1px\n-000605b0: 2032 7078 3b66 6f6e 742d 6661 6d69 6c79   2px;font-family\n-000605c0: 3a61 7269 616c 3b6c 696e 652d 6865 6967  :arial;line-heig\n-000605d0: 6874 3a2e 333b 6375 7273 6f72 3a70 6f69  ht:.3;cursor:poi\n-000605e0: 6e74 6572 7d2e 436f 6465 4d69 7272 6f72  nter}.CodeMirror\n-000605f0: 2d66 6f6c 6467 7574 7465 727b 7769 6474  -foldgutter{widt\n-00060600: 683a 2e37 656d 7d2e 436f 6465 4d69 7272  h:.7em}.CodeMirr\n-00060610: 6f72 2d66 6f6c 6467 7574 7465 722d 6f70  or-foldgutter-op\n-00060620: 656e 2c2e 436f 6465 4d69 7272 6f72 2d66  en,.CodeMirror-f\n-00060630: 6f6c 6467 7574 7465 722d 666f 6c64 6564  oldgutter-folded\n-00060640: 7b63 7572 736f 723a 706f 696e 7465 727d  {cursor:pointer}\n-00060650: 2e43 6f64 654d 6972 726f 722d 666f 6c64  .CodeMirror-fold\n-00060660: 6775 7474 6572 2d6f 7065 6e3a 6166 7465  gutter-open:afte\n-00060670: 727b 636f 6e74 656e 743a 22e2 96be 227d  r{content:\"...\"}\n-00060680: 2e43 6f64 654d 6972 726f 722d 666f 6c64  .CodeMirror-fold\n-00060690: 6775 7474 6572 2d66 6f6c 6465 643a 6166  gutter-folded:af\n-000606a0: 7465 727b 636f 6e74 656e 743a 22e2 96b8  ter{content:\"...\n-000606b0: 227d 2e43 6f64 654d 6972 726f 722d 666f  \"}.CodeMirror-fo\n-000606c0: 6c64 6775 7474 6572 7b77 6964 7468 3a76  ldgutter{width:v\n-000606d0: 6172 282d 2d70 782d 3132 297d 2e43 6f64  ar(--px-12)}.Cod\n-000606e0: 654d 6972 726f 722d 666f 6c64 6d61 726b  eMirror-foldmark\n-000606f0: 6572 7b62 6163 6b67 726f 756e 642d 636f  er{background-co\n-00060700: 6c6f 723a 6873 6c28 7661 7228 2d2d 636f  lor:hsl(var(--co\n-00060710: 6c6f 722d 696e 666f 2929 3b62 6f72 6465  lor-info));borde\n-00060720: 722d 7261 6469 7573 3a76 6172 282d 2d62  r-radius:var(--b\n-00060730: 6f72 6465 722d 7261 6469 7573 2d34 293b  order-radius-4);\n-00060740: 636f 6c6f 723a 6873 6c28 7661 7228 2d2d  color:hsl(var(--\n-00060750: 636f 6c6f 722d 6261 7365 2929 3b66 6f6e  color-base));fon\n-00060760: 742d 6661 6d69 6c79 3a69 6e68 6572 6974  t-family:inherit\n-00060770: 3b6d 6172 6769 6e3a 3020 7661 7228 2d2d  ;margin:0 var(--\n-00060780: 7078 2d34 293b 7061 6464 696e 673a 3020  px-4);padding:0 \n-00060790: 7661 7228 2d2d 7078 2d38 293b 7465 7874  var(--px-8);text\n-000607a0: 2d73 6861 646f 773a 6e6f 6e65 7d2e 436f  -shadow:none}.Co\n-000607b0: 6465 4d69 7272 6f72 2d66 6f6c 6467 7574  deMirror-foldgut\n-000607c0: 7465 722d 6f70 656e 2c2e 436f 6465 4d69  ter-open,.CodeMi\n-000607d0: 7272 6f72 2d66 6f6c 6467 7574 7465 722d  rror-foldgutter-\n-000607e0: 666f 6c64 6564 7b63 6f6c 6f72 3a68 736c  folded{color:hsl\n-000607f0: 6128 7661 7228 2d2d 636f 6c6f 722d 6e65  a(var(--color-ne\n-00060800: 7574 7261 6c29 2c76 6172 282d 2d61 6c70  utral),var(--alp\n-00060810: 6861 2d74 6572 7469 6172 7929 297d 2e43  ha-tertiary))}.C\n-00060820: 6f64 654d 6972 726f 722d 666f 6c64 6775  odeMirror-foldgu\n-00060830: 7474 6572 2d6f 7065 6e3a 6166 7465 722c  tter-open:after,\n-00060840: 2e43 6f64 654d 6972 726f 722d 666f 6c64  .CodeMirror-fold\n-00060850: 6775 7474 6572 2d66 6f6c 6465 643a 6166  gutter-folded:af\n-00060860: 7465 727b 6d61 7267 696e 3a30 2076 6172  ter{margin:0 var\n-00060870: 282d 2d70 782d 3229 7d2e 6772 6170 6869  (--px-2)}.graphi\n-00060880: 716c 2d65 6469 746f 727b 6865 6967 6874  ql-editor{height\n-00060890: 3a31 3030 253b 706f 7369 7469 6f6e 3a72  :100%;position:r\n-000608a0: 656c 6174 6976 653b 7769 6474 683a 3130  elative;width:10\n-000608b0: 3025 7d2e 6772 6170 6869 716c 2d65 6469  0%}.graphiql-edi\n-000608c0: 746f 722e 6869 6464 656e 7b6c 6566 743a  tor.hidden{left:\n-000608d0: 2d39 3939 3970 783b 706f 7369 7469 6f6e  -9999px;position\n-000608e0: 3a61 6273 6f6c 7574 653b 746f 703a 2d39  :absolute;top:-9\n-000608f0: 3939 3970 783b 7669 7369 6269 6c69 7479  999px;visibility\n-00060900: 3a68 6964 6465 6e7d 2e43 6f64 654d 6972  :hidden}.CodeMir\n-00060910: 726f 722d 6c69 6e74 2d6d 6172 6b65 7273  ror-lint-markers\n-00060920: 7b77 6964 7468 3a31 3670 787d 2e43 6f64  {width:16px}.Cod\n-00060930: 654d 6972 726f 722d 6c69 6e74 2d74 6f6f  eMirror-lint-too\n-00060940: 6c74 6970 7b62 6163 6b67 726f 756e 642d  ltip{background-\n-00060950: 636f 6c6f 723a 2366 6664 3b62 6f72 6465  color:#ffd;borde\n-00060960: 723a 3170 7820 736f 6c69 6420 626c 6163  r:1px solid blac\n-00060970: 6b3b 626f 7264 6572 2d72 6164 6975 733a  k;border-radius:\n-00060980: 3470 783b 636f 6c6f 723a 2330 3030 3b66  4px;color:#000;f\n-00060990: 6f6e 742d 6661 6d69 6c79 3a6d 6f6e 6f73  ont-family:monos\n-000609a0: 7061 6365 3b66 6f6e 742d 7369 7a65 3a31  pace;font-size:1\n-000609b0: 3070 743b 6f76 6572 666c 6f77 3a68 6964  0pt;overflow:hid\n-000609c0: 6465 6e3b 7061 6464 696e 673a 3270 7820  den;padding:2px \n-000609d0: 3570 783b 706f 7369 7469 6f6e 3a66 6978  5px;position:fix\n-000609e0: 6564 3b77 6869 7465 2d73 7061 6365 3a70  ed;white-space:p\n-000609f0: 7265 3b77 6869 7465 2d73 7061 6365 3a70  re;white-space:p\n-00060a00: 7265 2d77 7261 703b 7a2d 696e 6465 783a  re-wrap;z-index:\n-00060a10: 3130 303b 6d61 782d 7769 6474 683a 3630  100;max-width:60\n-00060a20: 3070 783b 6f70 6163 6974 793a 303b 7472  0px;opacity:0;tr\n-00060a30: 616e 7369 7469 6f6e 3a6f 7061 6369 7479  ansition:opacity\n-00060a40: 202e 3473 3b2d 6d6f 7a2d 7472 616e 7369   .4s;-moz-transi\n-00060a50: 7469 6f6e 3a6f 7061 6369 7479 202e 3473  tion:opacity .4s\n-00060a60: 3b2d 7765 626b 6974 2d74 7261 6e73 6974  ;-webkit-transit\n-00060a70: 696f 6e3a 6f70 6163 6974 7920 2e34 733b  ion:opacity .4s;\n-00060a80: 2d6f 2d74 7261 6e73 6974 696f 6e3a 6f70  -o-transition:op\n-00060a90: 6163 6974 7920 2e34 733b 2d6d 732d 7472  acity .4s;-ms-tr\n-00060aa0: 616e 7369 7469 6f6e 3a6f 7061 6369 7479  ansition:opacity\n-00060ab0: 202e 3473 7d2e 436f 6465 4d69 7272 6f72   .4s}.CodeMirror\n-00060ac0: 2d6c 696e 742d 6d61 726b 7b62 6163 6b67  -lint-mark{backg\n-00060ad0: 726f 756e 642d 706f 7369 7469 6f6e 3a6c  round-position:l\n-00060ae0: 6566 7420 626f 7474 6f6d 3b62 6163 6b67  eft bottom;backg\n-00060af0: 726f 756e 642d 7265 7065 6174 3a72 6570  round-repeat:rep\n-00060b00: 6561 742d 787d 2e43 6f64 654d 6972 726f  eat-x}.CodeMirro\n-00060b10: 722d 6c69 6e74 2d6d 6172 6b2d 7761 726e  r-lint-mark-warn\n-00060b20: 696e 677b 6261 636b 6772 6f75 6e64 2d69  ing{background-i\n-00060b30: 6d61 6765 3a75 726c 2864 6174 613a 696d  mage:url(data:im\n-00060b40: 6167 652f 706e 673b 6261 7365 3634 2c69  age/png;base64,i\n-00060b50: 5642 4f52 7730 4b47 676f 4141 4141 4e53  VBORw0KGgoAAAANS\n-00060b60: 5568 4555 6741 4141 4151 4141 4141 4443  UhEUgAAAAQAAAADC\n-00060b70: 4159 4141 4143 3039 4b37 4741 4141 4141  AYAAAC09K7GAAAAA\n-00060b80: 584e 5352 3049 4172 7334 6336 5141 4141  XNSR0IArs4c6QAAA\n-00060b90: 415a 6953 3064 4541 5038 412f 7744 2f6f  AZiS0dEAP8A/wD/o\n-00060ba0: 4c32 6e6b 7741 4141 416c 7753 466c 7a41  L2nkwAAAAlwSFlzA\n-00060bb0: 4141 4c45 7741 4143 784d 4241 4a71 6347  AALEwAACxMBAJqcG\n-00060bc0: 4141 4141 4164 3053 5531 4642 3973 4a46  AAAAAd0SU1FB9sJF\n-00060bd0: 6851 5845 6268 5467 3759 4141 4141 5a64  hQXEbhTg7YAAAAZd\n-00060be0: 4556 5964 454e 7662 5731 6c62 6e51 4151  EVYdENvbW1lbnQAQ\n-00060bf0: 334a 6c59 5852 6c5a 4342 3361 5852 6f49  3JlYXRlZCB3aXRoI\n-00060c00: 4564 4a54 5642 5867 5134 5841 4141 414d  EdJTVBXgQ4XAAAAM\n-00060c10: 6b6c 4551 5651 4931 324e 6b67 4949 764a  klEQVQI12NkgIIvJ\n-00060c20: 3351 584d 6a41 7764 444e 2b4f 6145 6279  3QXMjAwdDN+OaEby\n-00060c30: 7344 4134 4d50 4177 4e44 4e77 4d43 7769  sDA4MPAwNDNwMCwi\n-00060c40: 4f48 4c43 6431 7a58 3037 6f36 6b42 5647  OHLCd1zX07o6kBVG\n-00060c50: 5145 414b 4241 4e74 6f62 736b 4e4d 4141  QEAKBANtobskNMAA\n-00060c60: 4141 4153 5556 4f52 4b35 4359 4949 3d29  AAASUVORK5CYII=)\n-00060c70: 7d2e 436f 6465 4d69 7272 6f72 2d6c 696e  }.CodeMirror-lin\n-00060c80: 742d 6d61 726b 2d65 7272 6f72 7b62 6163  t-mark-error{bac\n-00060c90: 6b67 726f 756e 642d 696d 6167 653a 7572  kground-image:ur\n-00060ca0: 6c28 6461 7461 3a69 6d61 6765 2f70 6e67  l(data:image/png\n-00060cb0: 3b62 6173 6536 342c 6956 424f 5277 304b  ;base64,iVBORw0K\n-00060cc0: 4767 6f41 4141 414e 5355 6845 5567 4141  GgoAAAANSUhEUgAA\n-00060cd0: 4141 5141 4141 4144 4341 5941 4141 4330  AAQAAAADCAYAAAC0\n-00060ce0: 394b 3747 4141 4141 4158 4e53 5230 4941  9K7GAAAAAXNSR0IA\n-00060cf0: 7273 3463 3651 4141 4141 5a69 5330 6445  rs4c6QAAAAZiS0dE\n-00060d00: 4150 3841 2f77 442f 6f4c 326e 6b77 4141  AP8A/wD/oL2nkwAA\n-00060d10: 4141 6c77 5346 6c7a 4141 414c 4577 4141  AAlwSFlzAAALEwAA\n-00060d20: 4378 4d42 414a 7163 4741 4141 4141 6430  CxMBAJqcGAAAAAd0\n-00060d30: 5355 3146 4239 734a 4477 3463 4f43 5731  SU1FB9sJDw4cOCW1\n-00060d40: 2f4b 4941 4141 415a 6445 5659 6445 4e76  /KIAAAAZdEVYdENv\n-00060d50: 6257 316c 626e 5141 5133 4a6c 5958 526c  bW1lbnQAQ3JlYXRl\n-00060d60: 5a43 4233 6158 526f 4945 644a 5456 4258  ZCB3aXRoIEdJTVBX\n-00060d70: 6751 3458 4141 4141 4845 6c45 5156 5149  gQ4XAAAAHElEQVQI\n-00060d80: 3132 4e67 6749 4c2f 4441 7a2f 4764 4135  12NggIL/DAz/GdA5\n-00060d90: 2f78 6b59 2f71 504b 4d44 4177 4141 444c  /xkY/qPKMDAwAADL\n-00060da0: 5a77 6635 7276 6d2b 4c51 4141 4141 424a  Zwf5rvm+LQAAAABJ\n-00060db0: 5255 3545 726b 4a67 6767 3d3d 297d 2e43  RU5ErkJggg==)}.C\n-00060dc0: 6f64 654d 6972 726f 722d 6c69 6e74 2d6d  odeMirror-lint-m\n-00060dd0: 6172 6b65 727b 6261 636b 6772 6f75 6e64  arker{background\n-00060de0: 2d70 6f73 6974 696f 6e3a 6365 6e74 6572  -position:center\n-00060df0: 2063 656e 7465 723b 6261 636b 6772 6f75   center;backgrou\n-00060e00: 6e64 2d72 6570 6561 743a 6e6f 2d72 6570  nd-repeat:no-rep\n-00060e10: 6561 743b 6375 7273 6f72 3a70 6f69 6e74  eat;cursor:point\n-00060e20: 6572 3b64 6973 706c 6179 3a69 6e6c 696e  er;display:inlin\n-00060e30: 652d 626c 6f63 6b3b 6865 6967 6874 3a31  e-block;height:1\n-00060e40: 3670 783b 7769 6474 683a 3136 7078 3b76  6px;width:16px;v\n-00060e50: 6572 7469 6361 6c2d 616c 6967 6e3a 6d69  ertical-align:mi\n-00060e60: 6464 6c65 3b70 6f73 6974 696f 6e3a 7265  ddle;position:re\n-00060e70: 6c61 7469 7665 7d2e 436f 6465 4d69 7272  lative}.CodeMirr\n-00060e80: 6f72 2d6c 696e 742d 6d65 7373 6167 657b  or-lint-message{\n-00060e90: 7061 6464 696e 672d 6c65 6674 3a31 3870  padding-left:18p\n-00060ea0: 783b 6261 636b 6772 6f75 6e64 2d70 6f73  x;background-pos\n-00060eb0: 6974 696f 6e3a 746f 7020 6c65 6674 3b62  ition:top left;b\n-00060ec0: 6163 6b67 726f 756e 642d 7265 7065 6174  ackground-repeat\n-00060ed0: 3a6e 6f2d 7265 7065 6174 7d2e 436f 6465  :no-repeat}.Code\n-00060ee0: 4d69 7272 6f72 2d6c 696e 742d 6d61 726b  Mirror-lint-mark\n-00060ef0: 6572 2d77 6172 6e69 6e67 2c2e 436f 6465  er-warning,.Code\n-00060f00: 4d69 7272 6f72 2d6c 696e 742d 6d65 7373  Mirror-lint-mess\n-00060f10: 6167 652d 7761 726e 696e 677b 6261 636b  age-warning{back\n-00060f20: 6772 6f75 6e64 2d69 6d61 6765 3a75 726c  ground-image:url\n-00060f30: 2864 6174 613a 696d 6167 652f 706e 673b  (data:image/png;\n-00060f40: 6261 7365 3634 2c69 5642 4f52 7730 4b47  base64,iVBORw0KG\n-00060f50: 676f 4141 4141 4e53 5568 4555 6741 4141  goAAAANSUhEUgAAA\n-00060f60: 4241 4141 4141 5143 414d 4141 4141 6f4c  BAAAAAQCAMAAAAoL\n-00060f70: 5139 5441 4141 414e 6c42 4d56 4558 2f75  Q9TAAAANlBMVEX/u\n-00060f80: 7744 7672 7744 2f75 7744 2f75 7744 2f75  wDvrwD/uwD/uwD/u\n-00060f90: 7744 2f75 7744 2f75 7744 2f75 7744 2f75  wD/uwD/uwD/uwD/u\n-00060fa0: 7744 3674 7744 2f75 7741 4141 4144 7572  wD6twD/uwAAAADur\n-00060fb0: 7744 3274 5144 3775 4144 2b75 6741 4141  wD2tQD7uAD+ugAAA\n-00060fc0: 4144 2f75 7744 686d 6554 5241 4141 4144  AD/uwDhmeTRAAAAD\n-00060fd0: 4852 5354 6c4d 4a38 6d4e 3145 5963 626d  HRSTlMJ8mN1EYcbm\n-00060fe0: 6969 7867 4143 6d37 5762 7541 4141 4156  iixgACm7WbuAAAAV\n-00060ff0: 6b6c 4551 5652 3432 6e33 5055 5171 4149  klEQVR42n3PUQqAI\n-00061000: 4242 4655 5531 4c4c 6333 752f 6a64 624f  BBFUU1LLc3u/jdbO\n-00061010: 4a6f 5731 5030 3844 4139 4762 6138 2b59  JoW1P08DA9Gba8+Y\n-00061020: 574a 3667 4e4a 6f4e 5949 427a 4141 3263  WJ6gNJoNYIBzAA2c\n-00061030: 6842 7468 356b 4c6d 4739 5955 6f47 304e  hBth5kLmG9YUoG0N\n-00061040: 4841 5577 4658 774f 394c 7542 514c 3167  HAUwFXwO9LuBQL1g\n-00061050: 6943 5162 3867 4339 4f72 6f32 7670 3572  iCQb8gC9Oro2vp5r\n-00061060: 6e63 4349 5938 4c38 7545 7835 5a6b 4141  ncCIY8L8uEx5ZkAA\n-00061070: 4141 4153 5556 4f52 4b35 4359 4949 3d29  AAASUVORK5CYII=)\n-00061080: 7d2e 436f 6465 4d69 7272 6f72 2d6c 696e  }.CodeMirror-lin\n-00061090: 742d 6d61 726b 6572 2d65 7272 6f72 2c2e  t-marker-error,.\n-000610a0: 436f 6465 4d69 7272 6f72 2d6c 696e 742d  CodeMirror-lint-\n-000610b0: 6d65 7373 6167 652d 6572 726f 727b 6261  message-error{ba\n-000610c0: 636b 6772 6f75 6e64 2d69 6d61 6765 3a75  ckground-image:u\n-000610d0: 726c 2864 6174 613a 696d 6167 652f 706e  rl(data:image/pn\n-000610e0: 673b 6261 7365 3634 2c69 5642 4f52 7730  g;base64,iVBORw0\n-000610f0: 4b47 676f 4141 4141 4e53 5568 4555 6741  KGgoAAAANSUhEUgA\n-00061100: 4141 4241 4141 4141 5143 414d 4141 4141  AABAAAAAQCAMAAAA\n-00061110: 6f4c 5139 5441 4141 4148 6c42 4d56 4557  oLQ9TAAAAHlBMVEW\n-00061120: 3741 4143 3741 4143 7841 4143 3741 4143  7AAC7AACxAAC7AAC\n-00061130: 3741 4141 4141 4143 3441 4143 3541 4144  7AAAAAAC4AAC5AAD\n-00061140: 2f2f 2f2b 3741 4141 5564 636c 7041 4141  ///+7AAAUdclpAAA\n-00061150: 4142 6e52 5354 6c4d 586e 4f52 5369 7743  ABnRSTlMXnORSiwC\n-00061160: 4b30 5a4b 5341 4141 4154 556c 4551 5652  K0ZKSAAAATUlEQVR\n-00061170: 3432 6d57 504f 5137 4151 4167 4475 514c  42mWPOQ7AQAgDuQL\n-00061180: 782f 7a38 6373 5952 6d50 5249 4649 7752  x/z8csYRmPRIFIwR\n-00061190: 476e 6f73 5272 7061 6d76 6b4b 6930 4654  GnosRrpamvkKi0FT\n-000611a0: 4969 4d41 5352 3368 684b 572b 6841 4e36  IiMASR3hhKW+hAN6\n-000611b0: 2f74 4957 6875 3950 4457 6954 474e 456b  /tIWhu9PDWiTGNEk\n-000611c0: 5474 494f 7563 4135 4f79 7239 636b 5067  TtIOucA5Oyr9ckPg\n-000611d0: 4157 6d30 4750 426f 6736 7634 4141 4141  AWm0GPBog6v4AAAA\n-000611e0: 4153 5556 4f52 4b35 4359 4949 3d29 7d2e  ASUVORK5CYII=)}.\n-000611f0: 436f 6465 4d69 7272 6f72 2d6c 696e 742d  CodeMirror-lint-\n-00061200: 6d61 726b 6572 2d6d 756c 7469 706c 657b  marker-multiple{\n-00061210: 6261 636b 6772 6f75 6e64 2d69 6d61 6765  background-image\n-00061220: 3a75 726c 2864 6174 613a 696d 6167 652f  :url(data:image/\n-00061230: 706e 673b 6261 7365 3634 2c69 5642 4f52  png;base64,iVBOR\n-00061240: 7730 4b47 676f 4141 4141 4e53 5568 4555  w0KGgoAAAANSUhEU\n-00061250: 6741 4141 4163 4141 4141 4843 414d 4141  gAAAAcAAAAHCAMAA\n-00061260: 4144 7a6a 4b66 6841 4141 4143 5642 4d56  ADzjKfhAAAACVBMV\n-00061270: 4555 4141 4141 4141 4143 2f76 3739 3134  EUAAAAAAAC/v7914\n-00061280: 6b79 4841 4141 4141 5852 5354 6c4d 4151  kyHAAAAAXRSTlMAQ\n-00061290: 4f62 595a 6741 4141 434e 4a52 4546 5565  ObYZgAAACNJREFUe\n-000612a0: 4e6f 3169 6f45 4a41 4141 4977 6d7a 2f48  No1ioEJAAAIwmz/H\n-000612b0: 3930 6946 4653 474a 6746 4d65 3367 614c  90iFFSGJgFMe3gaL\n-000612c0: 5a30 6f64 2b39 2f41 515a 3041 446f 7362  Z0od+9/AQZ0ADosb\n-000612d0: 5972 6141 4141 4141 456c 4654 6b53 7551  YraAAAAAElFTkSuQ\n-000612e0: 6d43 4329 3b62 6163 6b67 726f 756e 642d  mCC);background-\n-000612f0: 7265 7065 6174 3a6e 6f2d 7265 7065 6174  repeat:no-repeat\n-00061300: 3b62 6163 6b67 726f 756e 642d 706f 7369  ;background-posi\n-00061310: 7469 6f6e 3a72 6967 6874 2062 6f74 746f  tion:right botto\n-00061320: 6d3b 7769 6474 683a 3130 3025 3b68 6569  m;width:100%;hei\n-00061330: 6768 743a 3130 3025 7d2e 436f 6465 4d69  ght:100%}.CodeMi\n-00061340: 7272 6f72 2d6c 696e 742d 6c69 6e65 2d65  rror-lint-line-e\n-00061350: 7272 6f72 7b62 6163 6b67 726f 756e 642d  rror{background-\n-00061360: 636f 6c6f 723a 2362 3734 6335 3131 347d  color:#b74c5114}\n-00061370: 2e43 6f64 654d 6972 726f 722d 6c69 6e74  .CodeMirror-lint\n-00061380: 2d6c 696e 652d 7761 726e 696e 677b 6261  -line-warning{ba\n-00061390: 636b 6772 6f75 6e64 2d63 6f6c 6f72 3a23  ckground-color:#\n-000613a0: 6666 6433 3030 3161 7d2e 436f 6465 4d69  ffd3001a}.CodeMi\n-000613b0: 7272 6f72 2d6c 696e 742d 6d61 726b 2d65  rror-lint-mark-e\n-000613c0: 7272 6f72 2c2e 436f 6465 4d69 7272 6f72  rror,.CodeMirror\n-000613d0: 2d6c 696e 742d 6d61 726b 2d77 6172 6e69  -lint-mark-warni\n-000613e0: 6e67 7b62 6163 6b67 726f 756e 642d 7265  ng{background-re\n-000613f0: 7065 6174 3a72 6570 6561 742d 783b 6261  peat:repeat-x;ba\n-00061400: 636b 6772 6f75 6e64 2d73 697a 653a 3130  ckground-size:10\n-00061410: 7078 2033 7078 3b62 6163 6b67 726f 756e  px 3px;backgroun\n-00061420: 642d 706f 7369 7469 6f6e 3a30 2039 3525  d-position:0 95%\n-00061430: 7d2e 636d 2d73 2d67 7261 7068 6971 6c20  }.cm-s-graphiql \n-00061440: 2e43 6f64 654d 6972 726f 722d 6c69 6e74  .CodeMirror-lint\n-00061450: 2d6d 6172 6b2d 6572 726f 727b 636f 6c6f  -mark-error{colo\n-00061460: 723a 6873 6c28 7661 7228 2d2d 636f 6c6f  r:hsl(var(--colo\n-00061470: 722d 6572 726f 7229 297d 2e43 6f64 654d  r-error))}.CodeM\n-00061480: 6972 726f 722d 6c69 6e74 2d6d 6172 6b2d  irror-lint-mark-\n-00061490: 6572 726f 727b 6261 636b 6772 6f75 6e64  error{background\n-000614a0: 2d69 6d61 6765 3a6c 696e 6561 722d 6772  -image:linear-gr\n-000614b0: 6164 6965 6e74 2834 3564 6567 2c74 7261  adient(45deg,tra\n-000614c0: 6e73 7061 7265 6e74 2036 3525 2c68 736c  nsparent 65%,hsl\n-000614d0: 2876 6172 282d 2d63 6f6c 6f72 2d65 7272  (var(--color-err\n-000614e0: 6f72 2929 2038 3025 2c74 7261 6e73 7061  or)) 80%,transpa\n-000614f0: 7265 6e74 2039 3025 292c 6c69 6e65 6172  rent 90%),linear\n-00061500: 2d67 7261 6469 656e 7428 3133 3564 6567  -gradient(135deg\n-00061510: 2c74 7261 6e73 7061 7265 6e74 2035 252c  ,transparent 5%,\n-00061520: 6873 6c28 7661 7228 2d2d 636f 6c6f 722d  hsl(var(--color-\n-00061530: 6572 726f 7229 2920 3135 252c 7472 616e  error)) 15%,tran\n-00061540: 7370 6172 656e 7420 3235 2529 2c6c 696e  sparent 25%),lin\n-00061550: 6561 722d 6772 6164 6965 6e74 2831 3335  ear-gradient(135\n-00061560: 6465 672c 7472 616e 7370 6172 656e 7420  deg,transparent \n-00061570: 3435 252c 6873 6c28 7661 7228 2d2d 636f  45%,hsl(var(--co\n-00061580: 6c6f 722d 6572 726f 7229 2920 3535 252c  lor-error)) 55%,\n-00061590: 7472 616e 7370 6172 656e 7420 3635 2529  transparent 65%)\n-000615a0: 2c6c 696e 6561 722d 6772 6164 6965 6e74  ,linear-gradient\n-000615b0: 2834 3564 6567 2c74 7261 6e73 7061 7265  (45deg,transpare\n-000615c0: 6e74 2032 3525 2c68 736c 2876 6172 282d  nt 25%,hsl(var(-\n-000615d0: 2d63 6f6c 6f72 2d65 7272 6f72 2929 2033  -color-error)) 3\n-000615e0: 3525 2c74 7261 6e73 7061 7265 6e74 2035  5%,transparent 5\n-000615f0: 3025 297d 2e63 6d2d 732d 6772 6170 6869  0%)}.cm-s-graphi\n-00061600: 716c 202e 436f 6465 4d69 7272 6f72 2d6c  ql .CodeMirror-l\n-00061610: 696e 742d 6d61 726b 2d77 6172 6e69 6e67  int-mark-warning\n-00061620: 7b63 6f6c 6f72 3a68 736c 2876 6172 282d  {color:hsl(var(-\n-00061630: 2d63 6f6c 6f72 2d77 6172 6e69 6e67 2929  -color-warning))\n-00061640: 7d2e 436f 6465 4d69 7272 6f72 2d6c 696e  }.CodeMirror-lin\n-00061650: 742d 6d61 726b 2d77 6172 6e69 6e67 7b62  t-mark-warning{b\n-00061660: 6163 6b67 726f 756e 642d 696d 6167 653a  ackground-image:\n-00061670: 6c69 6e65 6172 2d67 7261 6469 656e 7428  linear-gradient(\n-00061680: 3435 6465 672c 7472 616e 7370 6172 656e  45deg,transparen\n-00061690: 7420 3635 252c 6873 6c28 7661 7228 2d2d  t 65%,hsl(var(--\n-000616a0: 636f 6c6f 722d 7761 726e 696e 6729 2920  color-warning)) \n-000616b0: 3830 252c 7472 616e 7370 6172 656e 7420  80%,transparent \n-000616c0: 3930 2529 2c6c 696e 6561 722d 6772 6164  90%),linear-grad\n-000616d0: 6965 6e74 2831 3335 6465 672c 7472 616e  ient(135deg,tran\n-000616e0: 7370 6172 656e 7420 3525 2c68 736c 2876  sparent 5%,hsl(v\n-000616f0: 6172 282d 2d63 6f6c 6f72 2d77 6172 6e69  ar(--color-warni\n-00061700: 6e67 2929 2031 3525 2c74 7261 6e73 7061  ng)) 15%,transpa\n-00061710: 7265 6e74 2032 3525 292c 6c69 6e65 6172  rent 25%),linear\n-00061720: 2d67 7261 6469 656e 7428 3133 3564 6567  -gradient(135deg\n-00061730: 2c74 7261 6e73 7061 7265 6e74 2034 3525  ,transparent 45%\n-00061740: 2c68 736c 2876 6172 282d 2d63 6f6c 6f72  ,hsl(var(--color\n-00061750: 2d77 6172 6e69 6e67 2929 2035 3525 2c74  -warning)) 55%,t\n-00061760: 7261 6e73 7061 7265 6e74 2036 3525 292c  ransparent 65%),\n-00061770: 6c69 6e65 6172 2d67 7261 6469 656e 7428  linear-gradient(\n-00061780: 3435 6465 672c 7472 616e 7370 6172 656e  45deg,transparen\n-00061790: 7420 3235 252c 6873 6c28 7661 7228 2d2d  t 25%,hsl(var(--\n-000617a0: 636f 6c6f 722d 7761 726e 696e 6729 2920  color-warning)) \n-000617b0: 3335 252c 7472 616e 7370 6172 656e 7420  35%,transparent \n-000617c0: 3530 2529 7d2e 436f 6465 4d69 7272 6f72  50%)}.CodeMirror\n-000617d0: 2d6c 696e 742d 746f 6f6c 7469 707b 6261  -lint-tooltip{ba\n-000617e0: 636b 6772 6f75 6e64 2d63 6f6c 6f72 3a68  ckground-color:h\n-000617f0: 736c 2876 6172 282d 2d63 6f6c 6f72 2d62  sl(var(--color-b\n-00061800: 6173 6529 293b 626f 7264 6572 3a76 6172  ase));border:var\n-00061810: 282d 2d70 6f70 6f76 6572 2d62 6f72 6465  (--popover-borde\n-00061820: 7229 3b62 6f72 6465 722d 7261 6469 7573  r);border-radius\n-00061830: 3a76 6172 282d 2d62 6f72 6465 722d 7261  :var(--border-ra\n-00061840: 6469 7573 2d38 293b 626f 782d 7368 6164  dius-8);box-shad\n-00061850: 6f77 3a76 6172 282d 2d70 6f70 6f76 6572  ow:var(--popover\n-00061860: 2d62 6f78 2d73 6861 646f 7729 3b66 6f6e  -box-shadow);fon\n-00061870: 742d 7369 7a65 3a76 6172 282d 2d66 6f6e  t-size:var(--fon\n-00061880: 742d 7369 7a65 2d62 6f64 7929 3b66 6f6e  t-size-body);fon\n-00061890: 742d 6661 6d69 6c79 3a76 6172 282d 2d66  t-family:var(--f\n-000618a0: 6f6e 742d 6661 6d69 6c79 293b 6d61 782d  ont-family);max-\n-000618b0: 7769 6474 683a 3630 3070 783b 6f76 6572  width:600px;over\n-000618c0: 666c 6f77 3a68 6964 6465 6e3b 7061 6464  flow:hidden;padd\n-000618d0: 696e 673a 7661 7228 2d2d 7078 2d31 3229  ing:var(--px-12)\n-000618e0: 7d2e 436f 6465 4d69 7272 6f72 2d6c 696e  }.CodeMirror-lin\n-000618f0: 742d 6d65 7373 6167 652d 6572 726f 722c  t-message-error,\n-00061900: 2e43 6f64 654d 6972 726f 722d 6c69 6e74  .CodeMirror-lint\n-00061910: 2d6d 6573 7361 6765 2d77 6172 6e69 6e67  -message-warning\n-00061920: 7b62 6163 6b67 726f 756e 642d 696d 6167  {background-imag\n-00061930: 653a 6e6f 6e65 3b70 6164 6469 6e67 3a30  e:none;padding:0\n-00061940: 7d2e 436f 6465 4d69 7272 6f72 2d6c 696e  }.CodeMirror-lin\n-00061950: 742d 6d65 7373 6167 652d 6572 726f 727b  t-message-error{\n-00061960: 636f 6c6f 723a 6873 6c28 7661 7228 2d2d  color:hsl(var(--\n-00061970: 636f 6c6f 722d 6572 726f 7229 297d 2e43  color-error))}.C\n-00061980: 6f64 654d 6972 726f 722d 6c69 6e74 2d6d  odeMirror-lint-m\n-00061990: 6573 7361 6765 2d77 6172 6e69 6e67 7b63  essage-warning{c\n-000619a0: 6f6c 6f72 3a68 736c 2876 6172 282d 2d63  olor:hsl(var(--c\n-000619b0: 6f6c 6f72 2d77 6172 6e69 6e67 2929 7d2e  olor-warning))}.\n-000619c0: 436f 6465 4d69 7272 6f72 2d68 696e 7473  CodeMirror-hints\n-000619d0: 7b70 6f73 6974 696f 6e3a 6162 736f 6c75  {position:absolu\n-000619e0: 7465 3b7a 2d69 6e64 6578 3a31 303b 6f76  te;z-index:10;ov\n-000619f0: 6572 666c 6f77 3a68 6964 6465 6e3b 6c69  erflow:hidden;li\n-00061a00: 7374 2d73 7479 6c65 3a6e 6f6e 653b 6d61  st-style:none;ma\n-00061a10: 7267 696e 3a30 3b70 6164 6469 6e67 3a32  rgin:0;padding:2\n-00061a20: 7078 3b2d 7765 626b 6974 2d62 6f78 2d73  px;-webkit-box-s\n-00061a30: 6861 646f 773a 3270 7820 3370 7820 3570  hadow:2px 3px 5p\n-00061a40: 7820 7267 6261 2830 2c30 2c30 2c2e 3229  x rgba(0,0,0,.2)\n-00061a50: 3b2d 6d6f 7a2d 626f 782d 7368 6164 6f77  ;-moz-box-shadow\n-00061a60: 3a32 7078 2033 7078 2035 7078 2072 6762  :2px 3px 5px rgb\n-00061a70: 6128 302c 302c 302c 2e32 293b 626f 782d  a(0,0,0,.2);box-\n-00061a80: 7368 6164 6f77 3a32 7078 2033 7078 2035  shadow:2px 3px 5\n-00061a90: 7078 2023 3030 3033 3b62 6f72 6465 722d  px #0003;border-\n-00061aa0: 7261 6469 7573 3a33 7078 3b62 6f72 6465  radius:3px;borde\n-00061ab0: 723a 3170 7820 736f 6c69 6420 7369 6c76  r:1px solid silv\n-00061ac0: 6572 3b62 6163 6b67 726f 756e 643a 7768  er;background:wh\n-00061ad0: 6974 653b 666f 6e74 2d73 697a 653a 3930  ite;font-size:90\n-00061ae0: 253b 666f 6e74 2d66 616d 696c 793a 6d6f  %;font-family:mo\n-00061af0: 6e6f 7370 6163 653b 6d61 782d 6865 6967  nospace;max-heig\n-00061b00: 6874 3a32 3065 6d3b 6f76 6572 666c 6f77  ht:20em;overflow\n-00061b10: 2d79 3a61 7574 6f7d 2e43 6f64 654d 6972  -y:auto}.CodeMir\n-00061b20: 726f 722d 6869 6e74 7b6d 6172 6769 6e3a  ror-hint{margin:\n-00061b30: 303b 7061 6464 696e 673a 3020 3470 783b  0;padding:0 4px;\n-00061b40: 626f 7264 6572 2d72 6164 6975 733a 3270  border-radius:2p\n-00061b50: 783b 7768 6974 652d 7370 6163 653a 7072  x;white-space:pr\n-00061b60: 653b 636f 6c6f 723a 2330 3030 3b63 7572  e;color:#000;cur\n-00061b70: 736f 723a 706f 696e 7465 727d 6c69 2e43  sor:pointer}li.C\n-00061b80: 6f64 654d 6972 726f 722d 6869 6e74 2d61  odeMirror-hint-a\n-00061b90: 6374 6976 657b 6261 636b 6772 6f75 6e64  ctive{background\n-00061ba0: 3a23 3038 663b 636f 6c6f 723a 2366 6666  :#08f;color:#fff\n-00061bb0: 7d2e 436f 6465 4d69 7272 6f72 2d68 696e  }.CodeMirror-hin\n-00061bc0: 7473 7b62 6163 6b67 726f 756e 643a 6873  ts{background:hs\n-00061bd0: 6c28 7661 7228 2d2d 636f 6c6f 722d 6261  l(var(--color-ba\n-00061be0: 7365 2929 3b62 6f72 6465 723a 7661 7228  se));border:var(\n-00061bf0: 2d2d 706f 706f 7665 722d 626f 7264 6572  --popover-border\n-00061c00: 293b 626f 7264 6572 2d72 6164 6975 733a  );border-radius:\n-00061c10: 7661 7228 2d2d 626f 7264 6572 2d72 6164  var(--border-rad\n-00061c20: 6975 732d 3829 3b62 6f78 2d73 6861 646f  ius-8);box-shado\n-00061c30: 773a 7661 7228 2d2d 706f 706f 7665 722d  w:var(--popover-\n-00061c40: 626f 782d 7368 6164 6f77 293b 6469 7370  box-shadow);disp\n-00061c50: 6c61 793a 6772 6964 3b66 6f6e 742d 6661  lay:grid;font-fa\n-00061c60: 6d69 6c79 3a76 6172 282d 2d66 6f6e 742d  mily:var(--font-\n-00061c70: 6661 6d69 6c79 293b 666f 6e74 2d73 697a  family);font-siz\n-00061c80: 653a 7661 7228 2d2d 666f 6e74 2d73 697a  e:var(--font-siz\n-00061c90: 652d 626f 6479 293b 6772 6964 2d74 656d  e-body);grid-tem\n-00061ca0: 706c 6174 652d 636f 6c75 6d6e 733a 6175  plate-columns:au\n-00061cb0: 746f 2066 6974 2d63 6f6e 7465 6e74 2833  to fit-content(3\n-00061cc0: 3030 7078 293b 6d61 782d 6865 6967 6874  00px);max-height\n-00061cd0: 3a32 3634 7078 3b70 6164 6469 6e67 3a30  :264px;padding:0\n-00061ce0: 7d2e 436f 6465 4d69 7272 6f72 2d68 696e  }.CodeMirror-hin\n-00061cf0: 747b 626f 7264 6572 2d72 6164 6975 733a  t{border-radius:\n-00061d00: 7661 7228 2d2d 626f 7264 6572 2d72 6164  var(--border-rad\n-00061d10: 6975 732d 3429 3b63 6f6c 6f72 3a68 736c  ius-4);color:hsl\n-00061d20: 6128 7661 7228 2d2d 636f 6c6f 722d 6e65  a(var(--color-ne\n-00061d30: 7574 7261 6c29 2c76 6172 282d 2d61 6c70  utral),var(--alp\n-00061d40: 6861 2d73 6563 6f6e 6461 7279 2929 3b67  ha-secondary));g\n-00061d50: 7269 642d 636f 6c75 6d6e 3a31 202f 2032  rid-column:1 / 2\n-00061d60: 3b6d 6172 6769 6e3a 7661 7228 2d2d 7078  ;margin:var(--px\n-00061d70: 2d34 293b 7061 6464 696e 673a 7661 7228  -4);padding:var(\n-00061d80: 2d2d 7078 2d36 2920 7661 7228 2d2d 7078  --px-6) var(--px\n-00061d90: 2d38 2921 696d 706f 7274 616e 747d 2e43  -8)!important}.C\n-00061da0: 6f64 654d 6972 726f 722d 6869 6e74 3a6e  odeMirror-hint:n\n-00061db0: 6f74 283a 6669 7273 742d 6368 696c 6429  ot(:first-child)\n-00061dc0: 7b6d 6172 6769 6e2d 746f 703a 307d 6c69  {margin-top:0}li\n-00061dd0: 2e43 6f64 654d 6972 726f 722d 6869 6e74  .CodeMirror-hint\n-00061de0: 2d61 6374 6976 657b 6261 636b 6772 6f75  -active{backgrou\n-00061df0: 6e64 3a68 736c 6128 7661 7228 2d2d 636f  nd:hsla(var(--co\n-00061e00: 6c6f 722d 7072 696d 6172 7929 2c76 6172  lor-primary),var\n-00061e10: 282d 2d61 6c70 6861 2d62 6163 6b67 726f  (--alpha-backgro\n-00061e20: 756e 642d 6d65 6469 756d 2929 3b63 6f6c  und-medium));col\n-00061e30: 6f72 3a68 736c 2876 6172 282d 2d63 6f6c  or:hsl(var(--col\n-00061e40: 6f72 2d70 7269 6d61 7279 2929 7d2e 436f  or-primary))}.Co\n-00061e50: 6465 4d69 7272 6f72 2d68 696e 742d 696e  deMirror-hint-in\n-00061e60: 666f 726d 6174 696f 6e7b 626f 7264 6572  formation{border\n-00061e70: 2d6c 6566 743a 3170 7820 736f 6c69 6420  -left:1px solid \n-00061e80: 6873 6c61 2876 6172 282d 2d63 6f6c 6f72  hsla(var(--color\n-00061e90: 2d6e 6575 7472 616c 292c 7661 7228 2d2d  -neutral),var(--\n-00061ea0: 616c 7068 612d 6261 636b 6772 6f75 6e64  alpha-background\n-00061eb0: 2d68 6561 7679 2929 3b67 7269 642d 636f  -heavy));grid-co\n-00061ec0: 6c75 6d6e 3a32 202f 2033 3b67 7269 642d  lumn:2 / 3;grid-\n-00061ed0: 726f 773a 3120 2f20 3939 3939 393b 6d61  row:1 / 99999;ma\n-00061ee0: 782d 6865 6967 6874 3a32 3634 7078 3b6f  x-height:264px;o\n-00061ef0: 7665 7266 6c6f 773a 6175 746f 3b70 6164  verflow:auto;pad\n-00061f00: 6469 6e67 3a76 6172 282d 2d70 782d 3132  ding:var(--px-12\n-00061f10: 297d 2e43 6f64 654d 6972 726f 722d 6869  )}.CodeMirror-hi\n-00061f20: 6e74 2d69 6e66 6f72 6d61 7469 6f6e 2d68  nt-information-h\n-00061f30: 6561 6465 727b 6469 7370 6c61 793a 666c  eader{display:fl\n-00061f40: 6578 3b61 6c69 676e 2d69 7465 6d73 3a62  ex;align-items:b\n-00061f50: 6173 656c 696e 657d 2e43 6f64 654d 6972  aseline}.CodeMir\n-00061f60: 726f 722d 6869 6e74 2d69 6e66 6f72 6d61  ror-hint-informa\n-00061f70: 7469 6f6e 2d66 6965 6c64 2d6e 616d 657b  tion-field-name{\n-00061f80: 666f 6e74 2d73 697a 653a 7661 7228 2d2d  font-size:var(--\n-00061f90: 666f 6e74 2d73 697a 652d 6834 293b 666f  font-size-h4);fo\n-00061fa0: 6e74 2d77 6569 6768 743a 7661 7228 2d2d  nt-weight:var(--\n-00061fb0: 666f 6e74 2d77 6569 6768 742d 6d65 6469  font-weight-medi\n-00061fc0: 756d 297d 2e43 6f64 654d 6972 726f 722d  um)}.CodeMirror-\n-00061fd0: 6869 6e74 2d69 6e66 6f72 6d61 7469 6f6e  hint-information\n-00061fe0: 2d74 7970 652d 6e61 6d65 2d70 696c 6c7b  -type-name-pill{\n-00061ff0: 626f 7264 6572 3a31 7078 2073 6f6c 6964  border:1px solid\n-00062000: 2068 736c 6128 7661 7228 2d2d 636f 6c6f   hsla(var(--colo\n-00062010: 722d 6e65 7574 7261 6c29 2c76 6172 282d  r-neutral),var(-\n-00062020: 2d61 6c70 6861 2d74 6572 7469 6172 7929  -alpha-tertiary)\n-00062030: 293b 626f 7264 6572 2d72 6164 6975 733a  );border-radius:\n-00062040: 7661 7228 2d2d 626f 7264 6572 2d72 6164  var(--border-rad\n-00062050: 6975 732d 3429 3b63 6f6c 6f72 3a68 736c  ius-4);color:hsl\n-00062060: 6128 7661 7228 2d2d 636f 6c6f 722d 6e65  a(var(--color-ne\n-00062070: 7574 7261 6c29 2c76 6172 282d 2d61 6c70  utral),var(--alp\n-00062080: 6861 2d73 6563 6f6e 6461 7279 2929 3b6d  ha-secondary));m\n-00062090: 6172 6769 6e2d 6c65 6674 3a76 6172 282d  argin-left:var(-\n-000620a0: 2d70 782d 3629 3b70 6164 6469 6e67 3a76  -px-6);padding:v\n-000620b0: 6172 282d 2d70 782d 3429 7d2e 436f 6465  ar(--px-4)}.Code\n-000620c0: 4d69 7272 6f72 2d68 696e 742d 696e 666f  Mirror-hint-info\n-000620d0: 726d 6174 696f 6e2d 7479 7065 2d6e 616d  rmation-type-nam\n-000620e0: 657b 636f 6c6f 723a 696e 6865 7269 743b  e{color:inherit;\n-000620f0: 7465 7874 2d64 6563 6f72 6174 696f 6e3a  text-decoration:\n-00062100: 6e6f 6e65 7d2e 436f 6465 4d69 7272 6f72  none}.CodeMirror\n-00062110: 2d68 696e 742d 696e 666f 726d 6174 696f  -hint-informatio\n-00062120: 6e2d 7479 7065 2d6e 616d 653a 686f 7665  n-type-name:hove\n-00062130: 727b 7465 7874 2d64 6563 6f72 6174 696f  r{text-decoratio\n-00062140: 6e3a 756e 6465 726c 696e 6520 646f 7474  n:underline dott\n-00062150: 6564 7d2e 436f 6465 4d69 7272 6f72 2d68  ed}.CodeMirror-h\n-00062160: 696e 742d 696e 666f 726d 6174 696f 6e2d  int-information-\n-00062170: 6465 7363 7269 7074 696f 6e7b 636f 6c6f  description{colo\n-00062180: 723a 6873 6c61 2876 6172 282d 2d63 6f6c  r:hsla(var(--col\n-00062190: 6f72 2d6e 6575 7472 616c 292c 7661 7228  or-neutral),var(\n-000621a0: 2d2d 616c 7068 612d 7365 636f 6e64 6172  --alpha-secondar\n-000621b0: 7929 293b 6d61 7267 696e 2d74 6f70 3a76  y));margin-top:v\n-000621c0: 6172 282d 2d70 782d 3132 297d 2e43 6f64  ar(--px-12)}.Cod\n-000621d0: 654d 6972 726f 722d 696e 666f 7b62 6163  eMirror-info{bac\n-000621e0: 6b67 726f 756e 642d 636f 6c6f 723a 6873  kground-color:hs\n-000621f0: 6c28 7661 7228 2d2d 636f 6c6f 722d 6261  l(var(--color-ba\n-00062200: 7365 2929 3b62 6f72 6465 723a 7661 7228  se));border:var(\n-00062210: 2d2d 706f 706f 7665 722d 626f 7264 6572  --popover-border\n-00062220: 293b 626f 7264 6572 2d72 6164 6975 733a  );border-radius:\n-00062230: 7661 7228 2d2d 626f 7264 6572 2d72 6164  var(--border-rad\n-00062240: 6975 732d 3829 3b62 6f78 2d73 6861 646f  ius-8);box-shado\n-00062250: 773a 7661 7228 2d2d 706f 706f 7665 722d  w:var(--popover-\n-00062260: 626f 782d 7368 6164 6f77 293b 636f 6c6f  box-shadow);colo\n-00062270: 723a 6873 6c61 2876 6172 282d 2d63 6f6c  r:hsla(var(--col\n-00062280: 6f72 2d6e 6575 7472 616c 292c 3129 3b6d  or-neutral),1);m\n-00062290: 6178 2d68 6569 6768 743a 3330 3070 783b  ax-height:300px;\n-000622a0: 6d61 782d 7769 6474 683a 3430 3070 783b  max-width:400px;\n-000622b0: 6f70 6163 6974 793a 303b 6f76 6572 666c  opacity:0;overfl\n-000622c0: 6f77 3a61 7574 6f3b 7061 6464 696e 673a  ow:auto;padding:\n-000622d0: 7661 7228 2d2d 7078 2d31 3229 3b70 6f73  var(--px-12);pos\n-000622e0: 6974 696f 6e3a 6669 7865 643b 7472 616e  ition:fixed;tran\n-000622f0: 7369 7469 6f6e 3a6f 7061 6369 7479 202e  sition:opacity .\n-00062300: 3135 733b 7a2d 696e 6465 783a 3130 7d2e  15s;z-index:10}.\n-00062310: 436f 6465 4d69 7272 6f72 2d69 6e66 6f20  CodeMirror-info \n-00062320: 617b 636f 6c6f 723a 696e 6865 7269 743b  a{color:inherit;\n-00062330: 7465 7874 2d64 6563 6f72 6174 696f 6e3a  text-decoration:\n-00062340: 6e6f 6e65 7d2e 436f 6465 4d69 7272 6f72  none}.CodeMirror\n-00062350: 2d69 6e66 6f20 613a 686f 7665 727b 7465  -info a:hover{te\n-00062360: 7874 2d64 6563 6f72 6174 696f 6e3a 756e  xt-decoration:un\n-00062370: 6465 726c 696e 6520 646f 7474 6564 7d2e  derline dotted}.\n-00062380: 436f 6465 4d69 7272 6f72 2d69 6e66 6f20  CodeMirror-info \n-00062390: 2e43 6f64 654d 6972 726f 722d 696e 666f  .CodeMirror-info\n-000623a0: 2d68 6561 6465 727b 6469 7370 6c61 793a  -header{display:\n-000623b0: 666c 6578 3b61 6c69 676e 2d69 7465 6d73  flex;align-items\n-000623c0: 3a62 6173 656c 696e 657d 2e43 6f64 654d  :baseline}.CodeM\n-000623d0: 6972 726f 722d 696e 666f 202e 436f 6465  irror-info .Code\n-000623e0: 4d69 7272 6f72 2d69 6e66 6f2d 6865 6164  Mirror-info-head\n-000623f0: 6572 3e2e 7479 7065 2d6e 616d 652c 2e43  er>.type-name,.C\n-00062400: 6f64 654d 6972 726f 722d 696e 666f 202e  odeMirror-info .\n-00062410: 436f 6465 4d69 7272 6f72 2d69 6e66 6f2d  CodeMirror-info-\n-00062420: 6865 6164 6572 3e2e 6669 656c 642d 6e61  header>.field-na\n-00062430: 6d65 2c2e 436f 6465 4d69 7272 6f72 2d69  me,.CodeMirror-i\n-00062440: 6e66 6f20 2e43 6f64 654d 6972 726f 722d  nfo .CodeMirror-\n-00062450: 696e 666f 2d68 6561 6465 723e 2e61 7267  info-header>.arg\n-00062460: 2d6e 616d 652c 2e43 6f64 654d 6972 726f  -name,.CodeMirro\n-00062470: 722d 696e 666f 202e 436f 6465 4d69 7272  r-info .CodeMirr\n-00062480: 6f72 2d69 6e66 6f2d 6865 6164 6572 3e2e  or-info-header>.\n-00062490: 6469 7265 6374 6976 652d 6e61 6d65 2c2e  directive-name,.\n-000624a0: 436f 6465 4d69 7272 6f72 2d69 6e66 6f20  CodeMirror-info \n-000624b0: 2e43 6f64 654d 6972 726f 722d 696e 666f  .CodeMirror-info\n-000624c0: 2d68 6561 6465 723e 2e65 6e75 6d2d 7661  -header>.enum-va\n-000624d0: 6c75 657b 666f 6e74 2d73 697a 653a 7661  lue{font-size:va\n-000624e0: 7228 2d2d 666f 6e74 2d73 697a 652d 6834  r(--font-size-h4\n-000624f0: 293b 666f 6e74 2d77 6569 6768 743a 7661  );font-weight:va\n-00062500: 7228 2d2d 666f 6e74 2d77 6569 6768 742d  r(--font-weight-\n-00062510: 6d65 6469 756d 297d 2e43 6f64 654d 6972  medium)}.CodeMir\n-00062520: 726f 722d 696e 666f 202e 7479 7065 2d6e  ror-info .type-n\n-00062530: 616d 652d 7069 6c6c 7b62 6f72 6465 723a  ame-pill{border:\n-00062540: 3170 7820 736f 6c69 6420 6873 6c61 2876  1px solid hsla(v\n-00062550: 6172 282d 2d63 6f6c 6f72 2d6e 6575 7472  ar(--color-neutr\n-00062560: 616c 292c 7661 7228 2d2d 616c 7068 612d  al),var(--alpha-\n-00062570: 7465 7274 6961 7279 2929 3b62 6f72 6465  tertiary));borde\n-00062580: 722d 7261 6469 7573 3a76 6172 282d 2d62  r-radius:var(--b\n-00062590: 6f72 6465 722d 7261 6469 7573 2d34 293b  order-radius-4);\n-000625a0: 636f 6c6f 723a 6873 6c61 2876 6172 282d  color:hsla(var(-\n-000625b0: 2d63 6f6c 6f72 2d6e 6575 7472 616c 292c  -color-neutral),\n-000625c0: 7661 7228 2d2d 616c 7068 612d 7365 636f  var(--alpha-seco\n-000625d0: 6e64 6172 7929 293b 6d61 7267 696e 2d6c  ndary));margin-l\n-000625e0: 6566 743a 7661 7228 2d2d 7078 2d36 293b  eft:var(--px-6);\n-000625f0: 7061 6464 696e 673a 7661 7228 2d2d 7078  padding:var(--px\n-00062600: 2d34 297d 2e43 6f64 654d 6972 726f 722d  -4)}.CodeMirror-\n-00062610: 696e 666f 202e 696e 666f 2d64 6573 6372  info .info-descr\n-00062620: 6970 7469 6f6e 7b63 6f6c 6f72 3a68 736c  iption{color:hsl\n-00062630: 6128 7661 7228 2d2d 636f 6c6f 722d 6e65  a(var(--color-ne\n-00062640: 7574 7261 6c29 2c76 6172 282d 2d61 6c70  utral),var(--alp\n-00062650: 6861 2d73 6563 6f6e 6461 7279 2929 3b6d  ha-secondary));m\n-00062660: 6172 6769 6e2d 746f 703a 7661 7228 2d2d  argin-top:var(--\n-00062670: 7078 2d31 3229 3b6f 7665 7266 6c6f 773a  px-12);overflow:\n-00062680: 6869 6464 656e 7d2e 436f 6465 4d69 7272  hidden}.CodeMirr\n-00062690: 6f72 2d6a 756d 702d 746f 6b65 6e7b 7465  or-jump-token{te\n-000626a0: 7874 2d64 6563 6f72 6174 696f 6e3a 756e  xt-decoration:un\n-000626b0: 6465 726c 696e 6520 646f 7474 6564 3b63  derline dotted;c\n-000626c0: 7572 736f 723a 706f 696e 7465 727d 2e61  ursor:pointer}.a\n-000626d0: 7574 6f2d 696e 7365 7274 6564 2d6c 6561  uto-inserted-lea\n-000626e0: 662e 636d 2d70 726f 7065 7274 797b 616e  f.cm-property{an\n-000626f0: 696d 6174 696f 6e2d 6475 7261 7469 6f6e  imation-duration\n-00062700: 3a36 733b 616e 696d 6174 696f 6e2d 6e61  :6s;animation-na\n-00062710: 6d65 3a69 6e73 6572 7469 6f6e 4661 6465  me:insertionFade\n-00062720: 3b62 6f72 6465 722d 7261 6469 7573 3a76  ;border-radius:v\n-00062730: 6172 282d 2d62 6f72 6465 722d 7261 6469  ar(--border-radi\n-00062740: 7573 2d34 293b 7061 6464 696e 673a 7661  us-4);padding:va\n-00062750: 7228 2d2d 7078 2d32 297d 406b 6579 6672  r(--px-2)}@keyfr\n-00062760: 616d 6573 2069 6e73 6572 7469 6f6e 4661  ames insertionFa\n-00062770: 6465 7b30 252c 746f 7b62 6163 6b67 726f  de{0%,to{backgro\n-00062780: 756e 642d 636f 6c6f 723a 6e6f 6e65 7d31  und-color:none}1\n-00062790: 3525 2c38 3525 7b62 6163 6b67 726f 756e  5%,85%{backgroun\n-000627a0: 642d 636f 6c6f 723a 6873 6c61 2876 6172  d-color:hsla(var\n-000627b0: 282d 2d63 6f6c 6f72 2d77 6172 6e69 6e67  (--color-warning\n-000627c0: 292c 7661 7228 2d2d 616c 7068 612d 6261  ),var(--alpha-ba\n-000627d0: 636b 6772 6f75 6e64 2d6c 6967 6874 2929  ckground-light))\n-000627e0: 7d7d 6275 7474 6f6e 2e67 7261 7068 6971  }}button.graphiq\n-000627f0: 6c2d 746f 6f6c 6261 722d 6275 7474 6f6e  l-toolbar-button\n-00062800: 7b64 6973 706c 6179 3a66 6c65 783b 616c  {display:flex;al\n-00062810: 6967 6e2d 6974 656d 733a 6365 6e74 6572  ign-items:center\n-00062820: 3b6a 7573 7469 6679 2d63 6f6e 7465 6e74  ;justify-content\n-00062830: 3a63 656e 7465 723b 6865 6967 6874 3a76  :center;height:v\n-00062840: 6172 282d 2d74 6f6f 6c62 6172 2d77 6964  ar(--toolbar-wid\n-00062850: 7468 293b 7769 6474 683a 7661 7228 2d2d  th);width:var(--\n-00062860: 746f 6f6c 6261 722d 7769 6474 6829 7d62  toolbar-width)}b\n-00062870: 7574 746f 6e2e 6772 6170 6869 716c 2d74  utton.graphiql-t\n-00062880: 6f6f 6c62 6172 2d62 7574 746f 6e2e 6572  oolbar-button.er\n-00062890: 726f 727b 6261 636b 6772 6f75 6e64 3a68  ror{background:h\n-000628a0: 736c 6128 7661 7228 2d2d 636f 6c6f 722d  sla(var(--color-\n-000628b0: 6572 726f 7229 2c76 6172 282d 2d61 6c70  error),var(--alp\n-000628c0: 6861 2d62 6163 6b67 726f 756e 642d 6865  ha-background-he\n-000628d0: 6176 7929 297d 2e67 7261 7068 6971 6c2d  avy))}.graphiql-\n-000628e0: 6578 6563 7574 652d 6275 7474 6f6e 2d77  execute-button-w\n-000628f0: 7261 7070 6572 7b70 6f73 6974 696f 6e3a  rapper{position:\n-00062900: 7265 6c61 7469 7665 7d62 7574 746f 6e2e  relative}button.\n-00062910: 6772 6170 6869 716c 2d65 7865 6375 7465  graphiql-execute\n-00062920: 2d62 7574 746f 6e7b 6261 636b 6772 6f75  -button{backgrou\n-00062930: 6e64 2d63 6f6c 6f72 3a68 736c 2876 6172  nd-color:hsl(var\n-00062940: 282d 2d63 6f6c 6f72 2d70 7269 6d61 7279  (--color-primary\n-00062950: 2929 3b62 6f72 6465 723a 6e6f 6e65 3b62  ));border:none;b\n-00062960: 6f72 6465 722d 7261 6469 7573 3a76 6172  order-radius:var\n-00062970: 282d 2d62 6f72 6465 722d 7261 6469 7573  (--border-radius\n-00062980: 2d38 293b 6375 7273 6f72 3a70 6f69 6e74  -8);cursor:point\n-00062990: 6572 3b68 6569 6768 743a 7661 7228 2d2d  er;height:var(--\n-000629a0: 746f 6f6c 6261 722d 7769 6474 6829 3b70  toolbar-width);p\n-000629b0: 6164 6469 6e67 3a30 3b77 6964 7468 3a76  adding:0;width:v\n-000629c0: 6172 282d 2d74 6f6f 6c62 6172 2d77 6964  ar(--toolbar-wid\n-000629d0: 7468 297d 6275 7474 6f6e 2e67 7261 7068  th)}button.graph\n-000629e0: 6971 6c2d 6578 6563 7574 652d 6275 7474  iql-execute-butt\n-000629f0: 6f6e 3a68 6f76 6572 7b62 6163 6b67 726f  on:hover{backgro\n-00062a00: 756e 642d 636f 6c6f 723a 6873 6c61 2876  und-color:hsla(v\n-00062a10: 6172 282d 2d63 6f6c 6f72 2d70 7269 6d61  ar(--color-prima\n-00062a20: 7279 292c 2e39 297d 6275 7474 6f6e 2e67  ry),.9)}button.g\n-00062a30: 7261 7068 6971 6c2d 6578 6563 7574 652d  raphiql-execute-\n-00062a40: 6275 7474 6f6e 3a61 6374 6976 657b 6261  button:active{ba\n-00062a50: 636b 6772 6f75 6e64 2d63 6f6c 6f72 3a68  ckground-color:h\n-00062a60: 736c 6128 7661 7228 2d2d 636f 6c6f 722d  sla(var(--color-\n-00062a70: 7072 696d 6172 7929 2c2e 3829 7d62 7574  primary),.8)}but\n-00062a80: 746f 6e2e 6772 6170 6869 716c 2d65 7865  ton.graphiql-exe\n-00062a90: 6375 7465 2d62 7574 746f 6e3a 666f 6375  cute-button:focu\n-00062aa0: 737b 6f75 746c 696e 653a 6873 6c61 2876  s{outline:hsla(v\n-00062ab0: 6172 282d 2d63 6f6c 6f72 2d70 7269 6d61  ar(--color-prima\n-00062ac0: 7279 292c 2e38 2920 6175 746f 2031 7078  ry),.8) auto 1px\n-00062ad0: 7d62 7574 746f 6e2e 6772 6170 6869 716c  }button.graphiql\n-00062ae0: 2d65 7865 6375 7465 2d62 7574 746f 6e3e  -execute-button>\n-00062af0: 7376 677b 636f 6c6f 723a 2366 6666 3b64  svg{color:#fff;d\n-00062b00: 6973 706c 6179 3a62 6c6f 636b 3b68 6569  isplay:block;hei\n-00062b10: 6768 743a 7661 7228 2d2d 7078 2d31 3629  ght:var(--px-16)\n-00062b20: 3b6d 6172 6769 6e3a 6175 746f 3b77 6964  ;margin:auto;wid\n-00062b30: 7468 3a76 6172 282d 2d70 782d 3136 297d  th:var(--px-16)}\n-00062b40: 6275 7474 6f6e 2e67 7261 7068 6971 6c2d  button.graphiql-\n-00062b50: 746f 6f6c 6261 722d 6d65 6e75 7b64 6973  toolbar-menu{dis\n-00062b60: 706c 6179 3a62 6c6f 636b 3b68 6569 6768  play:block;heigh\n-00062b70: 743a 7661 7228 2d2d 746f 6f6c 6261 722d  t:var(--toolbar-\n-00062b80: 7769 6474 6829 3b77 6964 7468 3a76 6172  width);width:var\n-00062b90: 282d 2d74 6f6f 6c62 6172 2d77 6964 7468  (--toolbar-width\n-00062ba0: 297d 0a0a 2f2a 212a 2a2a 2a2a 2a2a 2a2a  )}../*!*********\n-00062bb0: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n-00062bc0: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n-00062bd0: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n-00062be0: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n-00062bf0: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n-00062c00: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n-00062c10: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 212a 5c0a  ************!*\\.\n-00062c20: 2020 212a 2a2a 2063 7373 202e 2e2f 2e2e    !*** css ../..\n-00062c30: 2f2e 2e2f 6e6f 6465 5f6d 6f64 756c 6573  /../node_modules\n-00062c40: 2f63 7373 2d6c 6f61 6465 722f 6469 7374  /css-loader/dist\n-00062c50: 2f63 6a73 2e6a 7321 2e2e 2f2e 2e2f 2e2e  /cjs.js!../../..\n-00062c60: 2f6e 6f64 655f 6d6f 6475 6c65 732f 706f  /node_modules/po\n-00062c70: 7374 6373 732d 6c6f 6164 6572 2f64 6973  stcss-loader/dis\n-00062c80: 742f 636a 732e 6a73 212e 2f73 7479 6c65  t/cjs.js!./style\n-00062c90: 2e63 7373 202a 2a2a 210a 2020 5c2a 2a2a  .css ***!.  \\***\n-00062ca0: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n-00062cb0: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n-00062cc0: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n-00062cd0: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n-00062ce0: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n-00062cf0: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n-00062d00: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n-00062d10: 2a2a 2f0a 2f2a 2045 7665 7279 7468 696e  **/./* Everythin\n-00062d20: 6720 2a2f 0a2e 6772 6170 6869 716c 2d63  g */..graphiql-c\n-00062d30: 6f6e 7461 696e 6572 207b 0a20 2062 6163  ontainer {.  bac\n-00062d40: 6b67 726f 756e 642d 636f 6c6f 723a 2068  kground-color: h\n-00062d50: 736c 2876 6172 282d 2d63 6f6c 6f72 2d62  sl(var(--color-b\n-00062d60: 6173 6529 293b 0a20 2064 6973 706c 6179  ase));.  display\n-00062d70: 3a20 666c 6578 3b0a 2020 6865 6967 6874  : flex;.  height\n-00062d80: 3a20 3130 3025 3b0a 2020 6d61 7267 696e  : 100%;.  margin\n-00062d90: 3a20 303b 0a20 206f 7665 7266 6c6f 773a  : 0;.  overflow:\n-00062da0: 2068 6964 6465 6e3b 0a20 2077 6964 7468   hidden;.  width\n-00062db0: 3a20 3130 3025 3b0a 7d0a 2f2a 2054 6865  : 100%;.}./* The\n-00062dc0: 2073 6964 6562 6172 202a 2f0a 2e67 7261   sidebar */..gra\n-00062dd0: 7068 6971 6c2d 636f 6e74 6169 6e65 7220  phiql-container \n-00062de0: 2e67 7261 7068 6971 6c2d 7369 6465 6261  .graphiql-sideba\n-00062df0: 7220 7b0a 2020 6469 7370 6c61 793a 2066  r {.  display: f\n-00062e00: 6c65 783b 0a20 2066 6c65 782d 6469 7265  lex;.  flex-dire\n-00062e10: 6374 696f 6e3a 2063 6f6c 756d 6e3b 0a20  ction: column;. \n-00062e20: 206a 7573 7469 6679 2d63 6f6e 7465 6e74   justify-content\n-00062e30: 3a20 7370 6163 652d 6265 7477 6565 6e3b  : space-between;\n-00062e40: 0a20 2070 6164 6469 6e67 3a20 7661 7228  .  padding: var(\n-00062e50: 2d2d 7078 2d38 293b 0a20 2077 6964 7468  --px-8);.  width\n-00062e60: 3a20 7661 7228 2d2d 7369 6465 6261 722d  : var(--sidebar-\n-00062e70: 7769 6474 6829 3b0a 7d0a 2e67 7261 7068  width);.}..graph\n-00062e80: 6971 6c2d 636f 6e74 6169 6e65 7220 2e67  iql-container .g\n-00062e90: 7261 7068 6971 6c2d 7369 6465 6261 7220  raphiql-sidebar \n-00062ea0: 2e67 7261 7068 6971 6c2d 7369 6465 6261  .graphiql-sideba\n-00062eb0: 722d 7365 6374 696f 6e20 7b0a 2020 6469  r-section {.  di\n-00062ec0: 7370 6c61 793a 2066 6c65 783b 0a20 2066  splay: flex;.  f\n-00062ed0: 6c65 782d 6469 7265 6374 696f 6e3a 2063  lex-direction: c\n-00062ee0: 6f6c 756d 6e3b 0a20 2067 6170 3a20 7661  olumn;.  gap: va\n-00062ef0: 7228 2d2d 7078 2d38 293b 0a7d 0a2e 6772  r(--px-8);.}..gr\n-00062f00: 6170 6869 716c 2d63 6f6e 7461 696e 6572  aphiql-container\n-00062f10: 202e 6772 6170 6869 716c 2d73 6964 6562   .graphiql-sideb\n-00062f20: 6172 2062 7574 746f 6e20 7b0a 2020 6469  ar button {.  di\n-00062f30: 7370 6c61 793a 2066 6c65 783b 0a20 2061  splay: flex;.  a\n-00062f40: 6c69 676e 2d69 7465 6d73 3a20 6365 6e74  lign-items: cent\n-00062f50: 6572 3b0a 2020 6a75 7374 6966 792d 636f  er;.  justify-co\n-00062f60: 6e74 656e 743a 2063 656e 7465 723b 0a20  ntent: center;. \n-00062f70: 2063 6f6c 6f72 3a20 6873 6c61 2876 6172   color: hsla(var\n-00062f80: 282d 2d63 6f6c 6f72 2d6e 6575 7472 616c  (--color-neutral\n-00062f90: 292c 2076 6172 282d 2d61 6c70 6861 2d73  ), var(--alpha-s\n-00062fa0: 6563 6f6e 6461 7279 2929 3b0a 2020 6865  econdary));.  he\n-00062fb0: 6967 6874 3a20 6361 6c63 2876 6172 282d  ight: calc(var(-\n-00062fc0: 2d73 6964 6562 6172 2d77 6964 7468 2920  -sidebar-width) \n-00062fd0: 2d20 2832 202a 2076 6172 282d 2d70 782d  - (2 * var(--px-\n-00062fe0: 3829 2929 3b0a 2020 7769 6474 683a 2063  8)));.  width: c\n-00062ff0: 616c 6328 7661 7228 2d2d 7369 6465 6261  alc(var(--sideba\n-00063000: 722d 7769 6474 6829 202d 2028 3220 2a20  r-width) - (2 * \n-00063010: 7661 7228 2d2d 7078 2d38 2929 293b 0a7d  var(--px-8)));.}\n-00063020: 0a2e 6772 6170 6869 716c 2d63 6f6e 7461  ..graphiql-conta\n-00063030: 696e 6572 202e 6772 6170 6869 716c 2d73  iner .graphiql-s\n-00063040: 6964 6562 6172 2062 7574 746f 6e2e 6163  idebar button.ac\n-00063050: 7469 7665 207b 0a20 2063 6f6c 6f72 3a20  tive {.  color: \n-00063060: 6873 6c61 2876 6172 282d 2d63 6f6c 6f72  hsla(var(--color\n-00063070: 2d6e 6575 7472 616c 292c 2031 293b 0a7d  -neutral), 1);.}\n-00063080: 0a2e 6772 6170 6869 716c 2d63 6f6e 7461  ..graphiql-conta\n-00063090: 696e 6572 202e 6772 6170 6869 716c 2d73  iner .graphiql-s\n-000630a0: 6964 6562 6172 2062 7574 746f 6e3a 6e6f  idebar button:no\n-000630b0: 7428 3a66 6972 7374 2d63 6869 6c64 2920  t(:first-child) \n-000630c0: 7b0a 2020 6d61 7267 696e 2d74 6f70 3a20  {.  margin-top: \n-000630d0: 7661 7228 2d2d 7078 2d34 293b 0a7d 0a2e  var(--px-4);.}..\n-000630e0: 6772 6170 6869 716c 2d63 6f6e 7461 696e  graphiql-contain\n-000630f0: 6572 202e 6772 6170 6869 716c 2d73 6964  er .graphiql-sid\n-00063100: 6562 6172 2062 7574 746f 6e20 3e20 7376  ebar button > sv\n-00063110: 6720 7b0a 2020 6865 6967 6874 3a20 7661  g {.  height: va\n-00063120: 7228 2d2d 7078 2d32 3029 3b0a 2020 7769  r(--px-20);.  wi\n-00063130: 6474 683a 2076 6172 282d 2d70 782d 3230  dth: var(--px-20\n-00063140: 293b 0a7d 0a2f 2a20 5468 6520 6d61 696e  );.}./* The main\n-00063150: 2063 6f6e 7465 6e74 2c20 692e 652e 2065   content, i.e. e\n-00063160: 7665 7279 7468 696e 6720 6578 6365 7074  verything except\n-00063170: 2074 6865 2073 6964 6562 6172 202a 2f0a   the sidebar */.\n-00063180: 2e67 7261 7068 6971 6c2d 636f 6e74 6169  .graphiql-contai\n-00063190: 6e65 7220 2e67 7261 7068 6971 6c2d 6d61  ner .graphiql-ma\n-000631a0: 696e 207b 0a20 2064 6973 706c 6179 3a20  in {.  display: \n-000631b0: 666c 6578 3b0a 2020 666c 6578 3a20 313b  flex;.  flex: 1;\n-000631c0: 0a20 206d 696e 2d77 6964 7468 3a20 303b  .  min-width: 0;\n-000631d0: 0a7d 0a2f 2a20 5468 6520 6375 7272 656e  .}./* The curren\n-000631e0: 7420 7365 7373 696f 6e20 616e 6420 7461  t session and ta\n-000631f0: 6273 202a 2f0a 2e67 7261 7068 6971 6c2d  bs */..graphiql-\n-00063200: 636f 6e74 6169 6e65 7220 2e67 7261 7068  container .graph\n-00063210: 6971 6c2d 7365 7373 696f 6e73 207b 0a20  iql-sessions {. \n-00063220: 2062 6163 6b67 726f 756e 642d 636f 6c6f   background-colo\n-00063230: 723a 2068 736c 6128 7661 7228 2d2d 636f  r: hsla(var(--co\n-00063240: 6c6f 722d 6e65 7574 7261 6c29 2c20 7661  lor-neutral), va\n-00063250: 7228 2d2d 616c 7068 612d 6261 636b 6772  r(--alpha-backgr\n-00063260: 6f75 6e64 2d6c 6967 6874 2929 3b0a 2020  ound-light));.  \n-00063270: 2f2a 2041 6464 696e 6720 7468 6520 3870  /* Adding the 8p\n-00063280: 7820 6f66 2070 6164 6469 6e67 2074 6f20  x of padding to \n-00063290: 7468 6520 696e 6e65 7220 626f 7264 6572  the inner border\n-000632a0: 2072 6164 6975 7320 6f66 2074 6865 2071   radius of the q\n-000632b0: 7565 7279 2065 6469 746f 7220 2a2f 0a20  uery editor */. \n-000632c0: 2062 6f72 6465 722d 7261 6469 7573 3a20   border-radius: \n-000632d0: 6361 6c63 2876 6172 282d 2d62 6f72 6465  calc(var(--borde\n-000632e0: 722d 7261 6469 7573 2d31 3229 202b 2076  r-radius-12) + v\n-000632f0: 6172 282d 2d70 782d 3829 293b 0a20 2064  ar(--px-8));.  d\n-00063300: 6973 706c 6179 3a20 666c 6578 3b0a 2020  isplay: flex;.  \n-00063310: 666c 6578 2d64 6972 6563 7469 6f6e 3a20  flex-direction: \n-00063320: 636f 6c75 6d6e 3b0a 2020 666c 6578 3a20  column;.  flex: \n-00063330: 313b 0a20 206d 6178 2d68 6569 6768 743a  1;.  max-height:\n-00063340: 2031 3030 253b 0a20 206d 6172 6769 6e3a   100%;.  margin:\n-00063350: 2076 6172 282d 2d70 782d 3136 293b 0a20   var(--px-16);. \n-00063360: 206d 6172 6769 6e2d 6c65 6674 3a20 303b   margin-left: 0;\n-00063370: 0a20 206d 696e 2d77 6964 7468 3a20 303b  .  min-width: 0;\n-00063380: 0a7d 0a2f 2a20 5468 6520 7365 7373 696f  .}./* The sessio\n-00063390: 6e20 6865 6164 6572 2063 6f6e 7461 696e  n header contain\n-000633a0: 696e 6720 7461 6273 2061 6e64 2074 6865  ing tabs and the\n-000633b0: 206c 6f67 6f20 2a2f 0a2e 6772 6170 6869   logo */..graphi\n-000633c0: 716c 2d63 6f6e 7461 696e 6572 202e 6772  ql-container .gr\n-000633d0: 6170 6869 716c 2d73 6573 7369 6f6e 2d68  aphiql-session-h\n-000633e0: 6561 6465 7220 7b0a 2020 616c 6967 6e2d  eader {.  align-\n-000633f0: 6974 656d 733a 2063 656e 7465 723b 0a20  items: center;. \n-00063400: 2064 6973 706c 6179 3a20 666c 6578 3b0a   display: flex;.\n-00063410: 2020 6a75 7374 6966 792d 636f 6e74 656e    justify-conten\n-00063420: 743a 2073 7061 6365 2d62 6574 7765 656e  t: space-between\n-00063430: 3b0a 2020 6865 6967 6874 3a20 7661 7228  ;.  height: var(\n-00063440: 2d2d 7365 7373 696f 6e2d 6865 6164 6572  --session-header\n-00063450: 2d68 6569 6768 7429 3b0a 7d0a 2f2a 2054  -height);.}./* T\n-00063460: 6865 2062 7574 746f 6e20 746f 2061 6464  he button to add\n-00063470: 2061 206e 6577 2074 6162 202a 2f0a 6275   a new tab */.bu\n-00063480: 7474 6f6e 2e67 7261 7068 6971 6c2d 7461  tton.graphiql-ta\n-00063490: 622d 6164 6420 7b0a 2020 6865 6967 6874  b-add {.  height\n-000634a0: 3a20 3130 3025 3b0a 2020 7061 6464 696e  : 100%;.  paddin\n-000634b0: 673a 2076 6172 282d 2d70 782d 3429 3b0a  g: var(--px-4);.\n-000634c0: 7d0a 6275 7474 6f6e 2e67 7261 7068 6971  }.button.graphiq\n-000634d0: 6c2d 7461 622d 6164 6420 3e20 7376 6720  l-tab-add > svg \n-000634e0: 7b0a 2020 636f 6c6f 723a 2068 736c 6128  {.  color: hsla(\n-000634f0: 7661 7228 2d2d 636f 6c6f 722d 6e65 7574  var(--color-neut\n-00063500: 7261 6c29 2c20 7661 7228 2d2d 616c 7068  ral), var(--alph\n-00063510: 612d 7365 636f 6e64 6172 7929 293b 0a20  a-secondary));. \n-00063520: 2064 6973 706c 6179 3a20 626c 6f63 6b3b   display: block;\n-00063530: 0a20 2068 6569 6768 743a 2076 6172 282d  .  height: var(-\n-00063540: 2d70 782d 3136 293b 0a20 2077 6964 7468  -px-16);.  width\n-00063550: 3a20 7661 7228 2d2d 7078 2d31 3629 3b0a  : var(--px-16);.\n-00063560: 7d0a 2f2a 2054 6865 2072 6967 6874 2d68  }./* The right-h\n-00063570: 616e 642d 7369 6465 206f 6620 7468 6520  and-side of the \n-00063580: 7365 7373 696f 6e20 6865 6164 6572 202a  session header *\n-00063590: 2f0a 2e67 7261 7068 6971 6c2d 636f 6e74  /..graphiql-cont\n-000635a0: 6169 6e65 7220 2e67 7261 7068 6971 6c2d  ainer .graphiql-\n-000635b0: 7365 7373 696f 6e2d 6865 6164 6572 2d72  session-header-r\n-000635c0: 6967 6874 207b 0a20 2061 6c69 676e 2d69  ight {.  align-i\n-000635d0: 7465 6d73 3a20 6365 6e74 6572 3b0a 2020  tems: center;.  \n-000635e0: 6469 7370 6c61 793a 2066 6c65 783b 0a7d  display: flex;.}\n-000635f0: 0a2f 2a20 5468 6520 4772 6170 6869 514c  ./* The GraphiQL\n-00063600: 206c 6f67 6f20 2a2f 0a2e 6772 6170 6869   logo */..graphi\n-00063610: 716c 2d63 6f6e 7461 696e 6572 202e 6772  ql-container .gr\n-00063620: 6170 6869 716c 2d6c 6f67 6f20 7b0a 2020  aphiql-logo {.  \n-00063630: 636f 6c6f 723a 2068 736c 6128 7661 7228  color: hsla(var(\n-00063640: 2d2d 636f 6c6f 722d 6e65 7574 7261 6c29  --color-neutral)\n-00063650: 2c20 7661 7228 2d2d 616c 7068 612d 7365  , var(--alpha-se\n-00063660: 636f 6e64 6172 7929 293b 0a20 2066 6f6e  condary));.  fon\n-00063670: 742d 7369 7a65 3a20 7661 7228 2d2d 666f  t-size: var(--fo\n-00063680: 6e74 2d73 697a 652d 6834 293b 0a20 2066  nt-size-h4);.  f\n-00063690: 6f6e 742d 7765 6967 6874 3a20 7661 7228  ont-weight: var(\n-000636a0: 2d2d 666f 6e74 2d77 6569 6768 742d 6d65  --font-weight-me\n-000636b0: 6469 756d 293b 0a20 2070 6164 6469 6e67  dium);.  padding\n-000636c0: 3a20 7661 7228 2d2d 7078 2d31 3229 2076  : var(--px-12) v\n-000636d0: 6172 282d 2d70 782d 3136 293b 0a7d 0a2f  ar(--px-16);.}./\n-000636e0: 2a20 556e 646f 2064 6566 6175 6c74 206c  * Undo default l\n-000636f0: 696e 6b20 7374 796c 696e 6720 666f 7220  ink styling for \n-00063700: 7468 6520 6465 6661 756c 7420 4772 6170  the default Grap\n-00063710: 6869 514c 206c 6f67 6f20 6c69 6e6b 202a  hiQL logo link *\n-00063720: 2f0a 2e67 7261 7068 6971 6c2d 636f 6e74  /..graphiql-cont\n-00063730: 6169 6e65 7220 2e67 7261 7068 6971 6c2d  ainer .graphiql-\n-00063740: 6c6f 676f 202e 6772 6170 6869 716c 2d6c  logo .graphiql-l\n-00063750: 6f67 6f2d 6c69 6e6b 207b 0a20 2063 6f6c  ogo-link {.  col\n-00063760: 6f72 3a20 6873 6c61 2876 6172 282d 2d63  or: hsla(var(--c\n-00063770: 6f6c 6f72 2d6e 6575 7472 616c 292c 2076  olor-neutral), v\n-00063780: 6172 282d 2d61 6c70 6861 2d73 6563 6f6e  ar(--alpha-secon\n-00063790: 6461 7279 2929 3b0a 2020 7465 7874 2d64  dary));.  text-d\n-000637a0: 6563 6f72 6174 696f 6e3a 206e 6f6e 653b  ecoration: none;\n-000637b0: 0a7d 0a2f 2a20 5468 6520 6564 6974 6f72  .}./* The editor\n-000637c0: 206f 6620 7468 6520 7365 7373 696f 6e20   of the session \n-000637d0: 2a2f 0a2e 6772 6170 6869 716c 2d63 6f6e  */..graphiql-con\n-000637e0: 7461 696e 6572 202e 6772 6170 6869 716c  tainer .graphiql\n-000637f0: 2d73 6573 7369 6f6e 207b 0a20 2064 6973  -session {.  dis\n-00063800: 706c 6179 3a20 666c 6578 3b0a 2020 666c  play: flex;.  fl\n-00063810: 6578 3a20 313b 0a20 2070 6164 6469 6e67  ex: 1;.  padding\n-00063820: 3a20 3020 7661 7228 2d2d 7078 2d38 2920  : 0 var(--px-8) \n-00063830: 7661 7228 2d2d 7078 2d38 293b 0a7d 0a2f  var(--px-8);.}./\n-00063840: 2a20 416c 6c20 6564 6974 6f72 7320 2871  * All editors (q\n-00063850: 7565 7279 2c20 7661 7269 6162 6c65 2c20  uery, variable, \n-00063860: 6865 6164 6572 7329 202a 2f0a 2e67 7261  headers) */..gra\n-00063870: 7068 6971 6c2d 636f 6e74 6169 6e65 7220  phiql-container \n-00063880: 2e67 7261 7068 6971 6c2d 6564 6974 6f72  .graphiql-editor\n-00063890: 7320 7b0a 2020 6261 636b 6772 6f75 6e64  s {.  background\n-000638a0: 2d63 6f6c 6f72 3a20 6873 6c28 7661 7228  -color: hsl(var(\n-000638b0: 2d2d 636f 6c6f 722d 6261 7365 2929 3b0a  --color-base));.\n-000638c0: 2020 626f 7264 6572 2d72 6164 6975 733a    border-radius:\n-000638d0: 2063 616c 6328 7661 7228 2d2d 626f 7264   calc(var(--bord\n-000638e0: 6572 2d72 6164 6975 732d 3132 2929 3b0a  er-radius-12));.\n-000638f0: 2020 626f 782d 7368 6164 6f77 3a20 7661    box-shadow: va\n-00063900: 7228 2d2d 706f 706f 7665 722d 626f 782d  r(--popover-box-\n-00063910: 7368 6164 6f77 293b 0a20 2064 6973 706c  shadow);.  displ\n-00063920: 6179 3a20 666c 6578 3b0a 2020 666c 6578  ay: flex;.  flex\n-00063930: 3a20 313b 0a20 2066 6c65 782d 6469 7265  : 1;.  flex-dire\n-00063940: 6374 696f 6e3a 2063 6f6c 756d 6e3b 0a7d  ction: column;.}\n-00063950: 0a2e 6772 6170 6869 716c 2d63 6f6e 7461  ..graphiql-conta\n-00063960: 696e 6572 202e 6772 6170 6869 716c 2d65  iner .graphiql-e\n-00063970: 6469 746f 7273 2e66 756c 6c2d 6865 6967  ditors.full-heig\n-00063980: 6874 207b 0a20 206d 6172 6769 6e2d 746f  ht {.  margin-to\n-00063990: 703a 2063 616c 6328 7661 7228 2d2d 7078  p: calc(var(--px\n-000639a0: 2d38 2920 2d20 7661 7228 2d2d 7365 7373  -8) - var(--sess\n-000639b0: 696f 6e2d 6865 6164 6572 2d68 6569 6768  ion-header-heigh\n-000639c0: 7429 293b 0a7d 0a2f 2a20 5468 6520 7175  t));.}./* The qu\n-000639d0: 6572 7920 6564 6974 6f72 2061 6e64 2074  ery editor and t\n-000639e0: 6865 2074 6f6f 6c62 6172 202a 2f0a 2e67  he toolbar */..g\n-000639f0: 7261 7068 6971 6c2d 636f 6e74 6169 6e65  raphiql-containe\n-00063a00: 7220 2e67 7261 7068 6971 6c2d 7175 6572  r .graphiql-quer\n-00063a10: 792d 6564 6974 6f72 207b 0a20 2062 6f72  y-editor {.  bor\n-00063a20: 6465 722d 626f 7474 6f6d 3a20 3170 7820  der-bottom: 1px \n-00063a30: 736f 6c69 640a 2020 2020 6873 6c61 2876  solid.    hsla(v\n-00063a40: 6172 282d 2d63 6f6c 6f72 2d6e 6575 7472  ar(--color-neutr\n-00063a50: 616c 292c 2076 6172 282d 2d61 6c70 6861  al), var(--alpha\n-00063a60: 2d62 6163 6b67 726f 756e 642d 6865 6176  -background-heav\n-00063a70: 7929 293b 0a20 2070 6164 6469 6e67 3a20  y));.  padding: \n-00063a80: 7661 7228 2d2d 7078 2d31 3629 3b0a 2020  var(--px-16);.  \n-00063a90: 636f 6c75 6d6e 2d67 6170 3a20 7661 7228  column-gap: var(\n-00063aa0: 2d2d 7078 2d31 3629 3b0a 2020 6469 7370  --px-16);.  disp\n-00063ab0: 6c61 793a 2066 6c65 783b 0a20 2077 6964  lay: flex;.  wid\n-00063ac0: 7468 3a20 3130 3025 3b0a 7d0a 2f2a 2054  th: 100%;.}./* T\n-00063ad0: 6865 2076 6572 7469 6361 6c20 746f 6f6c  he vertical tool\n-00063ae0: 6261 7220 6e65 7874 2074 6f20 7468 6520  bar next to the \n-00063af0: 7175 6572 7920 6564 6974 6f72 202a 2f0a  query editor */.\n-00063b00: 2e67 7261 7068 6971 6c2d 636f 6e74 6169  .graphiql-contai\n-00063b10: 6e65 7220 2e67 7261 7068 6971 6c2d 746f  ner .graphiql-to\n-00063b20: 6f6c 6261 7220 7b0a 2020 7769 6474 683a  olbar {.  width:\n-00063b30: 2076 6172 282d 2d74 6f6f 6c62 6172 2d77   var(--toolbar-w\n-00063b40: 6964 7468 293b 0a7d 0a2e 6772 6170 6869  idth);.}..graphi\n-00063b50: 716c 2d63 6f6e 7461 696e 6572 202e 6772  ql-container .gr\n-00063b60: 6170 6869 716c 2d74 6f6f 6c62 6172 203e  aphiql-toolbar >\n-00063b70: 202a 202b 202a 207b 0a20 206d 6172 6769   * + * {.  margi\n-00063b80: 6e2d 746f 703a 2076 6172 282d 2d70 782d  n-top: var(--px-\n-00063b90: 3829 3b0a 7d0a 2f2a 2054 6865 2074 6f6f  8);.}./* The too\n-00063ba0: 6c62 6172 2069 636f 6e73 202a 2f0a 2e67  lbar icons */..g\n-00063bb0: 7261 7068 6971 6c2d 746f 6f6c 6261 722d  raphiql-toolbar-\n-00063bc0: 6963 6f6e 207b 0a20 2063 6f6c 6f72 3a20  icon {.  color: \n-00063bd0: 6873 6c61 2876 6172 282d 2d63 6f6c 6f72  hsla(var(--color\n-00063be0: 2d6e 6575 7472 616c 292c 2076 6172 282d  -neutral), var(-\n-00063bf0: 2d61 6c70 6861 2d74 6572 7469 6172 7929  -alpha-tertiary)\n-00063c00: 293b 0a20 2064 6973 706c 6179 3a20 626c  );.  display: bl\n-00063c10: 6f63 6b3b 0a20 2068 6569 6768 743a 2063  ock;.  height: c\n-00063c20: 616c 6328 7661 7228 2d2d 746f 6f6c 6261  alc(var(--toolba\n-00063c30: 722d 7769 6474 6829 202d 2028 7661 7228  r-width) - (var(\n-00063c40: 2d2d 7078 2d38 2920 2a20 3229 293b 0a20  --px-8) * 2));. \n-00063c50: 2077 6964 7468 3a20 6361 6c63 2876 6172   width: calc(var\n-00063c60: 282d 2d74 6f6f 6c62 6172 2d77 6964 7468  (--toolbar-width\n-00063c70: 2920 2d20 2876 6172 282d 2d70 782d 3829  ) - (var(--px-8)\n-00063c80: 202a 2032 2929 3b0a 7d0a 2f2a 2054 6865   * 2));.}./* The\n-00063c90: 2074 6162 2062 6172 2066 6f72 2065 6469   tab bar for edi\n-00063ca0: 746f 7220 746f 6f6c 7320 2a2f 0a2e 6772  tor tools */..gr\n-00063cb0: 6170 6869 716c 2d63 6f6e 7461 696e 6572  aphiql-container\n-00063cc0: 202e 6772 6170 6869 716c 2d65 6469 746f   .graphiql-edito\n-00063cd0: 722d 746f 6f6c 7320 7b0a 2020 6375 7273  r-tools {.  curs\n-00063ce0: 6f72 3a20 726f 772d 7265 7369 7a65 3b0a  or: row-resize;.\n-00063cf0: 2020 6469 7370 6c61 793a 2066 6c65 783b    display: flex;\n-00063d00: 0a20 2077 6964 7468 3a20 3130 3025 3b0a  .  width: 100%;.\n-00063d10: 2020 636f 6c75 6d6e 2d67 6170 3a20 7661    column-gap: va\n-00063d20: 7228 2d2d 7078 2d38 293b 0a20 2070 6164  r(--px-8);.  pad\n-00063d30: 6469 6e67 3a20 7661 7228 2d2d 7078 2d38  ding: var(--px-8\n-00063d40: 293b 0a7d 0a2e 6772 6170 6869 716c 2d63  );.}..graphiql-c\n-00063d50: 6f6e 7461 696e 6572 202e 6772 6170 6869  ontainer .graphi\n-00063d60: 716c 2d65 6469 746f 722d 746f 6f6c 7320  ql-editor-tools \n-00063d70: 6275 7474 6f6e 207b 0a20 2063 6f6c 6f72  button {.  color\n-00063d80: 3a20 6873 6c61 2876 6172 282d 2d63 6f6c  : hsla(var(--col\n-00063d90: 6f72 2d6e 6575 7472 616c 292c 2076 6172  or-neutral), var\n-00063da0: 282d 2d61 6c70 6861 2d73 6563 6f6e 6461  (--alpha-seconda\n-00063db0: 7279 2929 3b0a 7d0a 2e67 7261 7068 6971  ry));.}..graphiq\n-00063dc0: 6c2d 636f 6e74 6169 6e65 7220 2e67 7261  l-container .gra\n-00063dd0: 7068 6971 6c2d 6564 6974 6f72 2d74 6f6f  phiql-editor-too\n-00063de0: 6c73 2062 7574 746f 6e2e 6163 7469 7665  ls button.active\n-00063df0: 207b 0a20 2063 6f6c 6f72 3a20 6873 6c61   {.  color: hsla\n-00063e00: 2876 6172 282d 2d63 6f6c 6f72 2d6e 6575  (var(--color-neu\n-00063e10: 7472 616c 292c 2031 293b 0a7d 0a2f 2a20  tral), 1);.}./* \n-00063e20: 5468 6520 7461 6220 6275 7474 6f6e 7320  The tab buttons \n-00063e30: 746f 2073 7769 7463 6820 6265 7477 6565  to switch betwee\n-00063e40: 6e20 6564 6974 6f72 2074 6f6f 6c73 202a  n editor tools *\n-00063e50: 2f0a 2e67 7261 7068 6971 6c2d 636f 6e74  /..graphiql-cont\n-00063e60: 6169 6e65 720a 2020 2e67 7261 7068 6971  ainer.  .graphiq\n-00063e70: 6c2d 6564 6974 6f72 2d74 6f6f 6c73 0a20  l-editor-tools. \n-00063e80: 203e 2062 7574 746f 6e3a 6e6f 7428 2e67   > button:not(.g\n-00063e90: 7261 7068 6971 6c2d 746f 6767 6c65 2d65  raphiql-toggle-e\n-00063ea0: 6469 746f 722d 746f 6f6c 7329 207b 0a20  ditor-tools) {. \n-00063eb0: 2070 6164 6469 6e67 3a20 7661 7228 2d2d   padding: var(--\n-00063ec0: 7078 2d38 2920 7661 7228 2d2d 7078 2d31  px-8) var(--px-1\n-00063ed0: 3229 3b0a 7d0a 2e67 7261 7068 6971 6c2d  2);.}..graphiql-\n-00063ee0: 636f 6e74 6169 6e65 7220 2e67 7261 7068  container .graph\n-00063ef0: 6971 6c2d 6564 6974 6f72 2d74 6f6f 6c73  iql-editor-tools\n-00063f00: 202e 6772 6170 6869 716c 2d74 6f67 676c   .graphiql-toggl\n-00063f10: 652d 6564 6974 6f72 2d74 6f6f 6c73 207b  e-editor-tools {\n-00063f20: 0a20 206d 6172 6769 6e2d 6c65 6674 3a20  .  margin-left: \n-00063f30: 6175 746f 3b0a 7d0a 2f2a 2041 6e20 6564  auto;.}./* An ed\n-00063f40: 6974 6f72 2074 6f6f 6c2c 2065 2e67 2e20  itor tool, e.g. \n-00063f50: 7661 7269 6162 6c65 206f 7220 6865 6164  variable or head\n-00063f60: 6572 2065 6469 746f 7220 2a2f 0a2e 6772  er editor */..gr\n-00063f70: 6170 6869 716c 2d63 6f6e 7461 696e 6572  aphiql-container\n-00063f80: 202e 6772 6170 6869 716c 2d65 6469 746f   .graphiql-edito\n-00063f90: 722d 746f 6f6c 207b 0a20 2066 6c65 783a  r-tool {.  flex:\n-00063fa0: 2031 3b0a 2020 7061 6464 696e 673a 2076   1;.  padding: v\n-00063fb0: 6172 282d 2d70 782d 3136 293b 0a7d 0a2f  ar(--px-16);.}./\n-00063fc0: 2a2a 0a20 2020 2a20 5468 6520 7761 7920  **.   * The way \n-00063fd0: 436f 6465 4d69 7272 6f72 2065 6469 746f  CodeMirror edito\n-00063fe0: 7273 2061 7265 2073 7479 6c65 6420 7468  rs are styled th\n-00063ff0: 6579 206f 7665 7266 6c6f 7720 7468 6569  ey overflow thei\n-00064000: 7220 636f 6e74 6169 6e69 6e67 0a20 2020  r containing.   \n-00064010: 2a20 656c 656d 656e 742e 2046 6f72 2073  * element. For s\n-00064020: 6f6d 6520 4f53 2d62 726f 7773 6572 2d63  ome OS-browser-c\n-00064030: 6f6d 6269 6e61 7469 6f6e 7320 7468 6973  ombinations this\n-00064040: 206d 6967 6874 2063 6175 7365 206f 7665   might cause ove\n-00064050: 726c 6170 2069 7373 7565 732c 0a20 2020  rlap issues,.   \n-00064060: 2a20 7365 7474 696e 6720 7468 6520 706f  * setting the po\n-00064070: 7369 7469 6f6e 206f 6620 7468 6973 2074  sition of this t\n-00064080: 6f20 6072 656c 6174 6976 6560 206d 616b  o `relative` mak\n-00064090: 6573 2073 7572 6520 7468 6973 2065 6c65  es sure this ele\n-000640a0: 6d65 6e74 2077 696c 6c0a 2020 202a 2061  ment will.   * a\n-000640b0: 6c77 6179 7320 6265 206f 6e20 746f 7020  lways be on top \n-000640c0: 6f66 2061 6e79 2065 6469 746f 7273 2e0a  of any editors..\n-000640d0: 2020 202a 2f0a 2e67 7261 7068 6971 6c2d     */..graphiql-\n-000640e0: 636f 6e74 6169 6e65 7220 2e67 7261 7068  container .graph\n-000640f0: 6971 6c2d 746f 6f6c 6261 722c 0a2e 6772  iql-toolbar,..gr\n-00064100: 6170 6869 716c 2d63 6f6e 7461 696e 6572  aphiql-container\n-00064110: 202e 6772 6170 6869 716c 2d65 6469 746f   .graphiql-edito\n-00064120: 722d 746f 6f6c 732c 0a2e 6772 6170 6869  r-tools,..graphi\n-00064130: 716c 2d63 6f6e 7461 696e 6572 202e 6772  ql-container .gr\n-00064140: 6170 6869 716c 2d65 6469 746f 722d 746f  aphiql-editor-to\n-00064150: 6f6c 207b 0a20 2070 6f73 6974 696f 6e3a  ol {.  position:\n-00064160: 2072 656c 6174 6976 653b 0a7d 0a2f 2a20   relative;.}./* \n-00064170: 5468 6520 7265 7370 6f6e 7365 2076 6965  The response vie\n-00064180: 7720 2a2f 0a2e 6772 6170 6869 716c 2d63  w */..graphiql-c\n-00064190: 6f6e 7461 696e 6572 202e 6772 6170 6869  ontainer .graphi\n-000641a0: 716c 2d72 6573 706f 6e73 6520 7b0a 2020  ql-response {.  \n-000641b0: 2d2d 6564 6974 6f72 2d62 6163 6b67 726f  --editor-backgro\n-000641c0: 756e 643a 2074 7261 6e73 7061 7265 6e74  und: transparent\n-000641d0: 3b0a 2020 6469 7370 6c61 793a 2066 6c65  ;.  display: fle\n-000641e0: 783b 0a20 2077 6964 7468 3a20 3130 3025  x;.  width: 100%\n-000641f0: 3b0a 2020 666c 6578 2d64 6972 6563 7469  ;.  flex-directi\n-00064200: 6f6e 3a20 636f 6c75 6d6e 3b0a 7d0a 2f2a  on: column;.}./*\n-00064210: 2054 6865 2072 6573 756c 7473 2065 6469   The results edi\n-00064220: 746f 7220 7772 6170 7069 6e67 2063 6f6e  tor wrapping con\n-00064230: 7461 696e 6572 202a 2f0a 2e67 7261 7068  tainer */..graph\n-00064240: 6971 6c2d 636f 6e74 6169 6e65 7220 2e67  iql-container .g\n-00064250: 7261 7068 6971 6c2d 7265 7370 6f6e 7365  raphiql-response\n-00064260: 202e 7265 7375 6c74 2d77 696e 646f 7720   .result-window \n-00064270: 7b0a 2020 706f 7369 7469 6f6e 3a20 7265  {.  position: re\n-00064280: 6c61 7469 7665 3b0a 2020 666c 6578 3a20  lative;.  flex: \n-00064290: 313b 0a7d 0a2f 2a20 5468 6520 666f 6f74  1;.}./* The foot\n-000642a0: 6572 2062 656c 6f77 2074 6865 2072 6573  er below the res\n-000642b0: 706f 6e73 6520 7669 6577 202a 2f0a 2e67  ponse view */..g\n-000642c0: 7261 7068 6971 6c2d 636f 6e74 6169 6e65  raphiql-containe\n-000642d0: 7220 2e67 7261 7068 6971 6c2d 666f 6f74  r .graphiql-foot\n-000642e0: 6572 207b 0a20 2062 6f72 6465 722d 746f  er {.  border-to\n-000642f0: 703a 2031 7078 2073 6f6c 6964 0a20 2020  p: 1px solid.   \n-00064300: 2068 736c 6128 7661 7228 2d2d 636f 6c6f   hsla(var(--colo\n-00064310: 722d 6e65 7574 7261 6c29 2c20 7661 7228  r-neutral), var(\n-00064320: 2d2d 616c 7068 612d 6261 636b 6772 6f75  --alpha-backgrou\n-00064330: 6e64 2d68 6561 7679 2929 3b0a 7d0a 2f2a  nd-heavy));.}./*\n-00064340: 2054 6865 2070 6c75 6769 6e20 636f 6e74   The plugin cont\n-00064350: 6169 6e65 7220 2a2f 0a2e 6772 6170 6869  ainer */..graphi\n-00064360: 716c 2d63 6f6e 7461 696e 6572 202e 6772  ql-container .gr\n-00064370: 6170 6869 716c 2d70 6c75 6769 6e20 7b0a  aphiql-plugin {.\n-00064380: 2020 626f 7264 6572 2d6c 6566 743a 2031    border-left: 1\n-00064390: 7078 2073 6f6c 6964 0a20 2020 2068 736c  px solid.    hsl\n-000643a0: 6128 7661 7228 2d2d 636f 6c6f 722d 6e65  a(var(--color-ne\n-000643b0: 7574 7261 6c29 2c20 7661 7228 2d2d 616c  utral), var(--al\n-000643c0: 7068 612d 6261 636b 6772 6f75 6e64 2d68  pha-background-h\n-000643d0: 6561 7679 2929 3b0a 2020 666c 6578 3a20  eavy));.  flex: \n-000643e0: 313b 0a20 206f 7665 7266 6c6f 772d 793a  1;.  overflow-y:\n-000643f0: 2061 7574 6f3b 0a20 2070 6164 6469 6e67   auto;.  padding\n-00064400: 3a20 7661 7228 2d2d 7078 2d31 3629 3b0a  : var(--px-16);.\n-00064410: 7d0a 2f2a 2047 656e 6572 6963 2064 7261  }./* Generic dra\n-00064420: 6720 6261 7220 666f 7220 686f 7269 7a6f  g bar for horizo\n-00064430: 6e74 616c 2072 6573 697a 696e 6720 2a2f  ntal resizing */\n-00064440: 0a2e 6772 6170 6869 716c 2d68 6f72 697a  ..graphiql-horiz\n-00064450: 6f6e 7461 6c2d 6472 6167 2d62 6172 207b  ontal-drag-bar {\n-00064460: 0a20 2077 6964 7468 3a20 7661 7228 2d2d  .  width: var(--\n-00064470: 7078 2d31 3229 3b0a 2020 6375 7273 6f72  px-12);.  cursor\n-00064480: 3a20 636f 6c2d 7265 7369 7a65 3b0a 7d0a  : col-resize;.}.\n-00064490: 2e67 7261 7068 6971 6c2d 686f 7269 7a6f  .graphiql-horizo\n-000644a0: 6e74 616c 2d64 7261 672d 6261 723a 686f  ntal-drag-bar:ho\n-000644b0: 7665 723a 3a61 6674 6572 207b 0a20 2062  ver::after {.  b\n-000644c0: 6f72 6465 723a 2076 6172 282d 2d70 782d  order: var(--px-\n-000644d0: 3229 2073 6f6c 6964 0a20 2020 2068 736c  2) solid.    hsl\n-000644e0: 6128 7661 7228 2d2d 636f 6c6f 722d 6e65  a(var(--color-ne\n-000644f0: 7574 7261 6c29 2c20 7661 7228 2d2d 616c  utral), var(--al\n-00064500: 7068 612d 6261 636b 6772 6f75 6e64 2d68  pha-background-h\n-00064510: 6561 7679 2929 3b0a 2020 626f 7264 6572  eavy));.  border\n-00064520: 2d72 6164 6975 733a 2076 6172 282d 2d62  -radius: var(--b\n-00064530: 6f72 6465 722d 7261 6469 7573 2d32 293b  order-radius-2);\n-00064540: 0a20 2063 6f6e 7465 6e74 3a20 2727 3b0a  .  content: '';.\n-00064550: 2020 6469 7370 6c61 793a 2062 6c6f 636b    display: block\n-00064560: 3b0a 2020 6865 6967 6874 3a20 3235 253b  ;.  height: 25%;\n-00064570: 0a20 206d 6172 6769 6e3a 2030 2061 7574  .  margin: 0 aut\n-00064580: 6f3b 0a20 2070 6f73 6974 696f 6e3a 2072  o;.  position: r\n-00064590: 656c 6174 6976 653b 0a20 202f 2a20 2831  elative;.  /* (1\n-000645a0: 3030 2520 2d20 3235 2529 202f 2032 203d  00% - 25%) / 2 =\n-000645b0: 2033 372e 3525 202a 2f0a 2020 746f 703a   37.5% */.  top:\n-000645c0: 2033 372e 3525 3b0a 2020 7769 6474 683a   37.5%;.  width:\n-000645d0: 2030 3b0a 7d0a 2e67 7261 7068 6971 6c2d   0;.}..graphiql-\n-000645e0: 636f 6e74 6169 6e65 7220 2e67 7261 7068  container .graph\n-000645f0: 6971 6c2d 6368 6576 726f 6e2d 6963 6f6e  iql-chevron-icon\n-00064600: 207b 0a20 2063 6f6c 6f72 3a20 6873 6c61   {.  color: hsla\n-00064610: 2876 6172 282d 2d63 6f6c 6f72 2d6e 6575  (var(--color-neu\n-00064620: 7472 616c 292c 2076 6172 282d 2d61 6c70  tral), var(--alp\n-00064630: 6861 2d74 6572 7469 6172 7929 293b 0a20  ha-tertiary));. \n-00064640: 2064 6973 706c 6179 3a20 626c 6f63 6b3b   display: block;\n-00064650: 0a20 2068 6569 6768 743a 2076 6172 282d  .  height: var(-\n-00064660: 2d70 782d 3132 293b 0a20 206d 6172 6769  -px-12);.  margi\n-00064670: 6e3a 2076 6172 282d 2d70 782d 3132 293b  n: var(--px-12);\n-00064680: 0a20 2077 6964 7468 3a20 7661 7228 2d2d  .  width: var(--\n-00064690: 7078 2d31 3229 3b0a 7d0a 2f2a 2047 656e  px-12);.}./* Gen\n-000646a0: 6572 6963 2073 7069 6e20 616e 696d 6174  eric spin animat\n-000646b0: 696f 6e20 2a2f 0a2e 6772 6170 6869 716c  ion */..graphiql\n-000646c0: 2d73 7069 6e20 7b0a 2020 616e 696d 6174  -spin {.  animat\n-000646d0: 696f 6e3a 2073 7069 6e20 302e 3873 206c  ion: spin 0.8s l\n-000646e0: 696e 6561 7220 3073 2069 6e66 696e 6974  inear 0s infinit\n-000646f0: 653b 0a7d 0a40 6b65 7966 7261 6d65 7320  e;.}.@keyframes \n-00064700: 7370 696e 207b 0a20 2066 726f 6d20 7b0a  spin {.  from {.\n-00064710: 2020 2020 7472 616e 7366 6f72 6d3a 2072      transform: r\n-00064720: 6f74 6174 6528 3064 6567 293b 0a20 207d  otate(0deg);.  }\n-00064730: 0a20 2074 6f20 7b0a 2020 2020 7472 616e  .  to {.    tran\n-00064740: 7366 6f72 6d3a 2072 6f74 6174 6528 3336  sform: rotate(36\n-00064750: 3064 6567 293b 0a20 207d 0a7d 0a2f 2a20  0deg);.  }.}./* \n-00064760: 5468 6520 6865 6164 6572 206f 6620 7468  The header of th\n-00064770: 6520 7365 7474 696e 6773 2064 6961 6c6f  e settings dialo\n-00064780: 6720 2a2f 0a2e 6772 6170 6869 716c 2d64  g */..graphiql-d\n-00064790: 6961 6c6f 6720 2e67 7261 7068 6971 6c2d  ialog .graphiql-\n-000647a0: 6469 616c 6f67 2d68 6561 6465 7220 7b0a  dialog-header {.\n-000647b0: 2020 616c 6967 6e2d 6974 656d 733a 2063    align-items: c\n-000647c0: 656e 7465 723b 0a20 2064 6973 706c 6179  enter;.  display\n-000647d0: 3a20 666c 6578 3b0a 2020 6a75 7374 6966  : flex;.  justif\n-000647e0: 792d 636f 6e74 656e 743a 2073 7061 6365  y-content: space\n-000647f0: 2d62 6574 7765 656e 3b0a 2020 7061 6464  -between;.  padd\n-00064800: 696e 673a 2076 6172 282d 2d70 782d 3234  ing: var(--px-24\n-00064810: 293b 0a7d 0a2f 2a20 5468 6520 7469 746c  );.}./* The titl\n-00064820: 6520 6f66 2074 6865 2073 6574 7469 6e67  e of the setting\n-00064830: 7320 6469 616c 6f67 202a 2f0a 2e67 7261  s dialog */..gra\n-00064840: 7068 6971 6c2d 6469 616c 6f67 202e 6772  phiql-dialog .gr\n-00064850: 6170 6869 716c 2d64 6961 6c6f 672d 7469  aphiql-dialog-ti\n-00064860: 746c 6520 7b0a 2020 666f 6e74 2d73 697a  tle {.  font-siz\n-00064870: 653a 2076 6172 282d 2d66 6f6e 742d 7369  e: var(--font-si\n-00064880: 7a65 2d68 3329 3b0a 2020 666f 6e74 2d77  ze-h3);.  font-w\n-00064890: 6569 6768 743a 2076 6172 282d 2d66 6f6e  eight: var(--fon\n-000648a0: 742d 7765 6967 6874 2d6d 6564 6975 6d29  t-weight-medium)\n-000648b0: 3b0a 2020 6d61 7267 696e 3a20 303b 0a7d  ;.  margin: 0;.}\n-000648c0: 0a2f 2a20 4120 7365 6374 696f 6e20 696e  ./* A section in\n-000648d0: 7369 6465 2074 6865 2073 6574 7469 6e67  side the setting\n-000648e0: 7320 6469 616c 6f67 202a 2f0a 2e67 7261  s dialog */..gra\n-000648f0: 7068 6971 6c2d 6469 616c 6f67 202e 6772  phiql-dialog .gr\n-00064900: 6170 6869 716c 2d64 6961 6c6f 672d 7365  aphiql-dialog-se\n-00064910: 6374 696f 6e20 7b0a 2020 616c 6967 6e2d  ction {.  align-\n-00064920: 6974 656d 733a 2063 656e 7465 723b 0a20  items: center;. \n-00064930: 2062 6f72 6465 722d 746f 703a 2031 7078   border-top: 1px\n-00064940: 2073 6f6c 6964 0a20 2020 2068 736c 6128   solid.    hsla(\n-00064950: 7661 7228 2d2d 636f 6c6f 722d 6e65 7574  var(--color-neut\n-00064960: 7261 6c29 2c20 7661 7228 2d2d 616c 7068  ral), var(--alph\n-00064970: 612d 6261 636b 6772 6f75 6e64 2d68 6561  a-background-hea\n-00064980: 7679 2929 3b0a 2020 6469 7370 6c61 793a  vy));.  display:\n-00064990: 2066 6c65 783b 0a20 206a 7573 7469 6679   flex;.  justify\n-000649a0: 2d63 6f6e 7465 6e74 3a20 7370 6163 652d  -content: space-\n-000649b0: 6265 7477 6565 6e3b 0a20 2070 6164 6469  between;.  paddi\n-000649c0: 6e67 3a20 7661 7228 2d2d 7078 2d32 3429  ng: var(--px-24)\n-000649d0: 3b0a 7d0a 2e67 7261 7068 6971 6c2d 6469  ;.}..graphiql-di\n-000649e0: 616c 6f67 202e 6772 6170 6869 716c 2d64  alog .graphiql-d\n-000649f0: 6961 6c6f 672d 7365 6374 696f 6e20 3e20  ialog-section > \n-00064a00: 3a6e 6f74 283a 6669 7273 742d 6368 696c  :not(:first-chil\n-00064a10: 6429 207b 0a20 206d 6172 6769 6e2d 6c65  d) {.  margin-le\n-00064a20: 6674 3a20 7661 7228 2d2d 7078 2d32 3429  ft: var(--px-24)\n-00064a30: 3b0a 7d0a 2f2a 2054 6865 2073 6563 7469  ;.}./* The secti\n-00064a40: 6f6e 2074 6974 6c65 2069 6e20 7468 6520  on title in the \n-00064a50: 7365 7474 696e 6773 2064 6961 6c6f 6720  settings dialog \n-00064a60: 2a2f 0a2e 6772 6170 6869 716c 2d64 6961  */..graphiql-dia\n-00064a70: 6c6f 6720 2e67 7261 7068 6971 6c2d 6469  log .graphiql-di\n-00064a80: 616c 6f67 2d73 6563 7469 6f6e 2d74 6974  alog-section-tit\n-00064a90: 6c65 207b 0a20 2066 6f6e 742d 7369 7a65  le {.  font-size\n-00064aa0: 3a20 7661 7228 2d2d 666f 6e74 2d73 697a  : var(--font-siz\n-00064ab0: 652d 6834 293b 0a20 2066 6f6e 742d 7765  e-h4);.  font-we\n-00064ac0: 6967 6874 3a20 7661 7228 2d2d 666f 6e74  ight: var(--font\n-00064ad0: 2d77 6569 6768 742d 6d65 6469 756d 293b  -weight-medium);\n-00064ae0: 0a7d 0a2f 2a20 5468 6520 7365 6374 696f  .}./* The sectio\n-00064af0: 6e20 6361 7074 696f 6e20 696e 2074 6865  n caption in the\n-00064b00: 2073 6574 7469 6e67 7320 6469 616c 6f67   settings dialog\n-00064b10: 202a 2f0a 2e67 7261 7068 6971 6c2d 6469   */..graphiql-di\n-00064b20: 616c 6f67 202e 6772 6170 6869 716c 2d64  alog .graphiql-d\n-00064b30: 6961 6c6f 672d 7365 6374 696f 6e2d 6361  ialog-section-ca\n-00064b40: 7074 696f 6e20 7b0a 2020 636f 6c6f 723a  ption {.  color:\n-00064b50: 2068 736c 6128 7661 7228 2d2d 636f 6c6f   hsla(var(--colo\n-00064b60: 722d 6e65 7574 7261 6c29 2c20 7661 7228  r-neutral), var(\n-00064b70: 2d2d 616c 7068 612d 7365 636f 6e64 6172  --alpha-secondar\n-00064b80: 7929 293b 0a7d 0a2e 6772 6170 6869 716c  y));.}..graphiql\n-00064b90: 2d64 6961 6c6f 6720 2e67 7261 7068 6971  -dialog .graphiq\n-00064ba0: 6c2d 7761 726e 696e 672d 7465 7874 207b  l-warning-text {\n-00064bb0: 0a20 2063 6f6c 6f72 3a20 6873 6c28 7661  .  color: hsl(va\n-00064bc0: 7228 2d2d 636f 6c6f 722d 7761 726e 696e  r(--color-warnin\n-00064bd0: 6729 293b 0a20 2066 6f6e 742d 7765 6967  g));.  font-weig\n-00064be0: 6874 3a20 7661 7228 2d2d 666f 6e74 2d77  ht: var(--font-w\n-00064bf0: 6569 6768 742d 6d65 6469 756d 293b 0a7d  eight-medium);.}\n-00064c00: 0a2e 6772 6170 6869 716c 2d64 6961 6c6f  ..graphiql-dialo\n-00064c10: 6720 2e67 7261 7068 6971 6c2d 7461 626c  g .graphiql-tabl\n-00064c20: 6520 7b0a 2020 626f 7264 6572 2d63 6f6c  e {.  border-col\n-00064c30: 6c61 7073 653a 2063 6f6c 6c61 7073 653b  lapse: collapse;\n-00064c40: 0a20 2077 6964 7468 3a20 3130 3025 3b0a  .  width: 100%;.\n-00064c50: 7d0a 2e67 7261 7068 6971 6c2d 6469 616c  }..graphiql-dial\n-00064c60: 6f67 202e 6772 6170 6869 716c 2d74 6162  og .graphiql-tab\n-00064c70: 6c65 203a 6973 2874 682c 2074 6429 207b  le :is(th, td) {\n-00064c80: 0a20 2062 6f72 6465 723a 2031 7078 2073  .  border: 1px s\n-00064c90: 6f6c 6964 2068 736c 6128 7661 7228 2d2d  olid hsla(var(--\n-00064ca0: 636f 6c6f 722d 6e65 7574 7261 6c29 2c20  color-neutral), \n-00064cb0: 7661 7228 2d2d 616c 7068 612d 6261 636b  var(--alpha-back\n-00064cc0: 6772 6f75 6e64 2d68 6561 7679 2929 3b0a  ground-heavy));.\n-00064cd0: 2020 7061 6464 696e 673a 2076 6172 282d    padding: var(-\n-00064ce0: 2d70 782d 3829 2076 6172 282d 2d70 782d  -px-8) var(--px-\n-00064cf0: 3132 293b 0a7d 0a2f 2a20 4120 7369 6e67  12);.}./* A sing\n-00064d00: 6c65 206b 6579 2074 6865 2073 686f 7274  le key the short\n-00064d10: 2d6b 6579 2064 6961 6c6f 6720 2a2f 0a2e  -key dialog */..\n-00064d20: 6772 6170 6869 716c 2d64 6961 6c6f 6720  graphiql-dialog \n-00064d30: 2e67 7261 7068 6971 6c2d 6b65 7920 7b0a  .graphiql-key {.\n-00064d40: 2020 6261 636b 6772 6f75 6e64 2d63 6f6c    background-col\n-00064d50: 6f72 3a20 6873 6c61 2876 6172 282d 2d63  or: hsla(var(--c\n-00064d60: 6f6c 6f72 2d6e 6575 7472 616c 292c 2076  olor-neutral), v\n-00064d70: 6172 282d 2d61 6c70 6861 2d62 6163 6b67  ar(--alpha-backg\n-00064d80: 726f 756e 642d 6d65 6469 756d 2929 3b0a  round-medium));.\n-00064d90: 2020 626f 7264 6572 2d72 6164 6975 733a    border-radius:\n-00064da0: 2076 6172 282d 2d62 6f72 6465 722d 7261   var(--border-ra\n-00064db0: 6469 7573 2d34 293b 0a20 2070 6164 6469  dius-4);.  paddi\n-00064dc0: 6e67 3a20 7661 7228 2d2d 7078 2d34 293b  ng: var(--px-4);\n-00064dd0: 0a7d 0a2f 2a20 4176 6f69 6420 7368 6f77  .}./* Avoid show\n-00064de0: 696e 6720 6e61 7469 7665 2074 6f6f 6c74  ing native toolt\n-00064df0: 6970 7320 666f 7220 6963 6f6e 7320 7769  ips for icons wi\n-00064e00: 7468 2074 6974 6c65 7320 2a2f 0a2e 6772  th titles */..gr\n-00064e10: 6170 6869 716c 2d63 6f6e 7461 696e 6572  aphiql-container\n-00064e20: 2073 7667 207b 0a20 2070 6f69 6e74 6572   svg {.  pointer\n-00064e30: 2d65 7665 6e74 733a 206e 6f6e 653b 0a7d  -events: none;.}\n-00064e40: 0a0a 0a2f 2a23 2073 6f75 7263 654d 6170  .../*# sourceMap\n-00064e50: 7069 6e67 5552 4c3d 6772 6170 6869 716c  pingURL=graphiql\n-00064e60: 2e63 7373 2e6d 6170 2a2f                 .css.map*/\n+00058820: 2f0a 2f2a 2061 2076 6572 7920 7369 6d70  /./* a very simp\n+00058830: 6c65 2062 6f78 2d6d 6f64 656c 2072 6573  le box-model res\n+00058840: 6574 2c20 696e 7465 6e74 696f 6e61 6c6c  et, intentionall\n+00058850: 7920 646f 6573 206e 6f74 2069 6e63 6c75  y does not inclu\n+00058860: 6465 2070 7365 7564 6f20 656c 656d 656e  de pseudo elemen\n+00058870: 7473 202a 2f0a 2e67 7261 7068 6971 6c2d  ts */..graphiql-\n+00058880: 636f 6e74 6169 6e65 7220 2a20 7b0a 2020  container * {.  \n+00058890: 626f 782d 7369 7a69 6e67 3a20 626f 7264  box-sizing: bord\n+000588a0: 6572 2d62 6f78 3b0a 2020 666f 6e74 2d76  er-box;.  font-v\n+000588b0: 6172 6961 6e74 2d6c 6967 6174 7572 6573  ariant-ligatures\n+000588c0: 3a20 6e6f 6e65 3b0a 7d0a 0a2e 6772 6170  : none;.}...grap\n+000588d0: 6869 716c 2d63 6f6e 7461 696e 6572 2c0a  hiql-container,.\n+000588e0: 2e43 6f64 654d 6972 726f 722d 696e 666f  .CodeMirror-info\n+000588f0: 2c0a 2e43 6f64 654d 6972 726f 722d 6c69  ,..CodeMirror-li\n+00058900: 6e74 2d74 6f6f 6c74 6970 2c0a 2e67 7261  nt-tooltip,..gra\n+00058910: 7068 6971 6c2d 6469 616c 6f67 2c0a 2e67  phiql-dialog,..g\n+00058920: 7261 7068 6971 6c2d 6469 616c 6f67 2d6f  raphiql-dialog-o\n+00058930: 7665 726c 6179 2c0a 2e67 7261 7068 6971  verlay,..graphiq\n+00058940: 6c2d 746f 6f6c 7469 702c 0a5b 6461 7461  l-tooltip,.[data\n+00058950: 2d72 6164 6978 2d70 6f70 7065 722d 636f  -radix-popper-co\n+00058960: 6e74 656e 742d 7772 6170 7065 725d 207b  ntent-wrapper] {\n+00058970: 0a20 202f 2a20 436f 6c6f 7273 202a 2f0a  .  /* Colors */.\n+00058980: 2020 2d2d 636f 6c6f 722d 7072 696d 6172    --color-primar\n+00058990: 793a 2033 3230 2c20 3935 252c 2034 3325  y: 320, 95%, 43%\n+000589a0: 3b0a 2020 2d2d 636f 6c6f 722d 7365 636f  ;.  --color-seco\n+000589b0: 6e64 6172 793a 2032 3432 2c20 3531 252c  ndary: 242, 51%,\n+000589c0: 2036 3125 3b0a 2020 2d2d 636f 6c6f 722d   61%;.  --color-\n+000589d0: 7465 7274 6961 7279 3a20 3138 382c 2031  tertiary: 188, 1\n+000589e0: 3030 252c 2033 3625 3b0a 2020 2d2d 636f  00%, 36%;.  --co\n+000589f0: 6c6f 722d 696e 666f 3a20 3230 382c 2031  lor-info: 208, 1\n+00058a00: 3030 252c 2034 3625 3b0a 2020 2d2d 636f  00%, 46%;.  --co\n+00058a10: 6c6f 722d 7375 6363 6573 733a 2031 3538  lor-success: 158\n+00058a20: 2c20 3630 252c 2034 3225 3b0a 2020 2d2d  , 60%, 42%;.  --\n+00058a30: 636f 6c6f 722d 7761 726e 696e 673a 2033  color-warning: 3\n+00058a40: 362c 2031 3030 252c 2034 3125 3b0a 2020  6, 100%, 41%;.  \n+00058a50: 2d2d 636f 6c6f 722d 6572 726f 723a 2031  --color-error: 1\n+00058a60: 332c 2039 3325 2c20 3538 253b 0a20 202d  3, 93%, 58%;.  -\n+00058a70: 2d63 6f6c 6f72 2d6e 6575 7472 616c 3a20  -color-neutral: \n+00058a80: 3231 392c 2032 3825 2c20 3332 253b 0a20  219, 28%, 32%;. \n+00058a90: 202d 2d63 6f6c 6f72 2d62 6173 653a 2032   --color-base: 2\n+00058aa0: 3139 2c20 3238 252c 2031 3030 253b 0a0a  19, 28%, 100%;..\n+00058ab0: 2020 2f2a 2043 6f6c 6f72 2061 6c70 6861    /* Color alpha\n+00058ac0: 2076 616c 7565 7320 2a2f 0a20 202d 2d61   values */.  --a\n+00058ad0: 6c70 6861 2d73 6563 6f6e 6461 7279 3a20  lpha-secondary: \n+00058ae0: 302e 3736 3b0a 2020 2d2d 616c 7068 612d  0.76;.  --alpha-\n+00058af0: 7465 7274 6961 7279 3a20 302e 353b 0a20  tertiary: 0.5;. \n+00058b00: 202d 2d61 6c70 6861 2d62 6163 6b67 726f   --alpha-backgro\n+00058b10: 756e 642d 6865 6176 793a 2030 2e31 353b  und-heavy: 0.15;\n+00058b20: 0a20 202d 2d61 6c70 6861 2d62 6163 6b67  .  --alpha-backg\n+00058b30: 726f 756e 642d 6d65 6469 756d 3a20 302e  round-medium: 0.\n+00058b40: 313b 0a20 202d 2d61 6c70 6861 2d62 6163  1;.  --alpha-bac\n+00058b50: 6b67 726f 756e 642d 6c69 6768 743a 2030  kground-light: 0\n+00058b60: 2e30 373b 0a0a 2020 2f2a 2046 6f6e 7420  .07;..  /* Font \n+00058b70: 2a2f 0a20 202d 2d66 6f6e 742d 6661 6d69  */.  --font-fami\n+00058b80: 6c79 3a20 2752 6f62 6f74 6f27 2c20 7361  ly: 'Roboto', sa\n+00058b90: 6e73 2d73 6572 6966 3b0a 2020 2d2d 666f  ns-serif;.  --fo\n+00058ba0: 6e74 2d66 616d 696c 792d 6d6f 6e6f 3a20  nt-family-mono: \n+00058bb0: 2746 6972 6120 436f 6465 272c 206d 6f6e  'Fira Code', mon\n+00058bc0: 6f73 7061 6365 3b0a 2020 2d2d 666f 6e74  ospace;.  --font\n+00058bd0: 2d73 697a 652d 6869 6e74 3a20 6361 6c63  -size-hint: calc\n+00058be0: 2831 3272 656d 202f 2031 3629 3b0a 2020  (12rem / 16);.  \n+00058bf0: 2d2d 666f 6e74 2d73 697a 652d 696e 6c69  --font-size-inli\n+00058c00: 6e65 2d63 6f64 653a 2063 616c 6328 3133  ne-code: calc(13\n+00058c10: 7265 6d20 2f20 3136 293b 0a20 202d 2d66  rem / 16);.  --f\n+00058c20: 6f6e 742d 7369 7a65 2d62 6f64 793a 2063  ont-size-body: c\n+00058c30: 616c 6328 3135 7265 6d20 2f20 3136 293b  alc(15rem / 16);\n+00058c40: 0a20 202d 2d66 6f6e 742d 7369 7a65 2d68  .  --font-size-h\n+00058c50: 343a 2063 616c 6328 3138 7265 6d20 2f20  4: calc(18rem / \n+00058c60: 3136 293b 0a20 202d 2d66 6f6e 742d 7369  16);.  --font-si\n+00058c70: 7a65 2d68 333a 2063 616c 6328 3232 7265  ze-h3: calc(22re\n+00058c80: 6d20 2f20 3136 293b 0a20 202d 2d66 6f6e  m / 16);.  --fon\n+00058c90: 742d 7369 7a65 2d68 323a 2063 616c 6328  t-size-h2: calc(\n+00058ca0: 3239 7265 6d20 2f20 3136 293b 0a20 202d  29rem / 16);.  -\n+00058cb0: 2d66 6f6e 742d 7765 6967 6874 2d72 6567  -font-weight-reg\n+00058cc0: 756c 6172 3a20 3430 303b 0a20 202d 2d66  ular: 400;.  --f\n+00058cd0: 6f6e 742d 7765 6967 6874 2d6d 6564 6975  ont-weight-mediu\n+00058ce0: 6d3a 2035 3030 3b0a 2020 2d2d 6c69 6e65  m: 500;.  --line\n+00058cf0: 2d68 6569 6768 743a 2031 2e35 3b0a 0a20  -height: 1.5;.. \n+00058d00: 202f 2a20 5370 6163 696e 6720 2a2f 0a20   /* Spacing */. \n+00058d10: 202d 2d70 782d 323a 2032 7078 3b0a 2020   --px-2: 2px;.  \n+00058d20: 2d2d 7078 2d34 3a20 3470 783b 0a20 202d  --px-4: 4px;.  -\n+00058d30: 2d70 782d 363a 2036 7078 3b0a 2020 2d2d  -px-6: 6px;.  --\n+00058d40: 7078 2d38 3a20 3870 783b 0a20 202d 2d70  px-8: 8px;.  --p\n+00058d50: 782d 3130 3a20 3130 7078 3b0a 2020 2d2d  x-10: 10px;.  --\n+00058d60: 7078 2d31 323a 2031 3270 783b 0a20 202d  px-12: 12px;.  -\n+00058d70: 2d70 782d 3136 3a20 3136 7078 3b0a 2020  -px-16: 16px;.  \n+00058d80: 2d2d 7078 2d32 303a 2032 3070 783b 0a20  --px-20: 20px;. \n+00058d90: 202d 2d70 782d 3234 3a20 3234 7078 3b0a   --px-24: 24px;.\n+00058da0: 0a20 202f 2a20 426f 7264 6572 2072 6164  .  /* Border rad\n+00058db0: 6975 7320 2a2f 0a20 202d 2d62 6f72 6465  ius */.  --borde\n+00058dc0: 722d 7261 6469 7573 2d32 3a20 3270 783b  r-radius-2: 2px;\n+00058dd0: 0a20 202d 2d62 6f72 6465 722d 7261 6469  .  --border-radi\n+00058de0: 7573 2d34 3a20 3470 783b 0a20 202d 2d62  us-4: 4px;.  --b\n+00058df0: 6f72 6465 722d 7261 6469 7573 2d38 3a20  order-radius-8: \n+00058e00: 3870 783b 0a20 202d 2d62 6f72 6465 722d  8px;.  --border-\n+00058e10: 7261 6469 7573 2d31 323a 2031 3270 783b  radius-12: 12px;\n+00058e20: 0a0a 2020 2f2a 2050 6f70 6f76 6572 2073  ..  /* Popover s\n+00058e30: 7479 6c65 7320 2874 6f6f 6c74 6970 2c20  tyles (tooltip, \n+00058e40: 6469 616c 6f67 2c20 6574 6329 202a 2f0a  dialog, etc) */.\n+00058e50: 2020 2d2d 706f 706f 7665 722d 626f 782d    --popover-box-\n+00058e60: 7368 6164 6f77 3a20 3070 7820 3670 7820  shadow: 0px 6px \n+00058e70: 3230 7078 2072 6762 6128 3539 2c20 3736  20px rgba(59, 76\n+00058e80: 2c20 3130 362c 2030 2e31 3329 2c0a 2020  , 106, 0.13),.  \n+00058e90: 2020 3070 7820 312e 3334 3031 3870 7820    0px 1.34018px \n+00058ea0: 342e 3436 3732 3670 7820 7267 6261 2835  4.46726px rgba(5\n+00058eb0: 392c 2037 362c 2031 3036 2c20 302e 3037  9, 76, 106, 0.07\n+00058ec0: 3734 3933 3929 2c0a 2020 2020 3070 7820  74939),.    0px \n+00058ed0: 302e 3339 3930 3036 7078 2031 2e33 3330  0.399006px 1.330\n+00058ee0: 3032 7078 2072 6762 6128 3539 2c20 3736  02px rgba(59, 76\n+00058ef0: 2c20 3130 362c 2030 2e30 3532 3530 3631  , 106, 0.0525061\n+00058f00: 293b 0a20 202d 2d70 6f70 6f76 6572 2d62  );.  --popover-b\n+00058f10: 6f72 6465 723a 206e 6f6e 653b 0a0a 2020  order: none;..  \n+00058f20: 2f2a 204c 6179 6f75 7420 2a2f 0a20 202d  /* Layout */.  -\n+00058f30: 2d73 6964 6562 6172 2d77 6964 7468 3a20  -sidebar-width: \n+00058f40: 3630 7078 3b0a 2020 2d2d 746f 6f6c 6261  60px;.  --toolba\n+00058f50: 722d 7769 6474 683a 2034 3070 783b 0a20  r-width: 40px;. \n+00058f60: 202d 2d73 6573 7369 6f6e 2d68 6561 6465   --session-heade\n+00058f70: 722d 6865 6967 6874 3a20 3531 7078 3b0a  r-height: 51px;.\n+00058f80: 7d0a 0a40 6d65 6469 6120 2870 7265 6665  }..@media (prefe\n+00058f90: 7273 2d63 6f6c 6f72 2d73 6368 656d 653a  rs-color-scheme:\n+00058fa0: 2064 6172 6b29 207b 0a20 2062 6f64 793a   dark) {.  body:\n+00058fb0: 6e6f 7428 2e67 7261 7068 6971 6c2d 6c69  not(.graphiql-li\n+00058fc0: 6768 7429 202e 6772 6170 6869 716c 2d63  ght) .graphiql-c\n+00058fd0: 6f6e 7461 696e 6572 2c0a 2020 626f 6479  ontainer,.  body\n+00058fe0: 3a6e 6f74 282e 6772 6170 6869 716c 2d6c  :not(.graphiql-l\n+00058ff0: 6967 6874 2920 2e43 6f64 654d 6972 726f  ight) .CodeMirro\n+00059000: 722d 696e 666f 2c0a 2020 626f 6479 3a6e  r-info,.  body:n\n+00059010: 6f74 282e 6772 6170 6869 716c 2d6c 6967  ot(.graphiql-lig\n+00059020: 6874 2920 2e43 6f64 654d 6972 726f 722d  ht) .CodeMirror-\n+00059030: 6c69 6e74 2d74 6f6f 6c74 6970 2c0a 2020  lint-tooltip,.  \n+00059040: 626f 6479 3a6e 6f74 282e 6772 6170 6869  body:not(.graphi\n+00059050: 716c 2d6c 6967 6874 2920 2e67 7261 7068  ql-light) .graph\n+00059060: 6971 6c2d 6469 616c 6f67 2c0a 2020 626f  iql-dialog,.  bo\n+00059070: 6479 3a6e 6f74 282e 6772 6170 6869 716c  dy:not(.graphiql\n+00059080: 2d6c 6967 6874 2920 2e67 7261 7068 6971  -light) .graphiq\n+00059090: 6c2d 6469 616c 6f67 2d6f 7665 726c 6179  l-dialog-overlay\n+000590a0: 2c0a 2020 626f 6479 3a6e 6f74 282e 6772  ,.  body:not(.gr\n+000590b0: 6170 6869 716c 2d6c 6967 6874 2920 2e67  aphiql-light) .g\n+000590c0: 7261 7068 6971 6c2d 746f 6f6c 7469 702c  raphiql-tooltip,\n+000590d0: 0a20 2062 6f64 793a 6e6f 7428 2e67 7261  .  body:not(.gra\n+000590e0: 7068 6971 6c2d 6c69 6768 7429 205b 6461  phiql-light) [da\n+000590f0: 7461 2d72 6164 6978 2d70 6f70 7065 722d  ta-radix-popper-\n+00059100: 636f 6e74 656e 742d 7772 6170 7065 725d  content-wrapper]\n+00059110: 207b 0a20 2020 202d 2d63 6f6c 6f72 2d70   {.    --color-p\n+00059120: 7269 6d61 7279 3a20 3333 382c 2031 3030  rimary: 338, 100\n+00059130: 252c 2036 3725 3b0a 2020 2020 2d2d 636f  %, 67%;.    --co\n+00059140: 6c6f 722d 7365 636f 6e64 6172 793a 2032  lor-secondary: 2\n+00059150: 3433 2c20 3130 3025 2c20 3737 253b 0a20  43, 100%, 77%;. \n+00059160: 2020 202d 2d63 6f6c 6f72 2d74 6572 7469     --color-terti\n+00059170: 6172 793a 2031 3838 2c20 3130 3025 2c20  ary: 188, 100%, \n+00059180: 3434 253b 0a20 2020 202d 2d63 6f6c 6f72  44%;.    --color\n+00059190: 2d69 6e66 6f3a 2032 3038 2c20 3130 3025  -info: 208, 100%\n+000591a0: 2c20 3732 253b 0a20 2020 202d 2d63 6f6c  , 72%;.    --col\n+000591b0: 6f72 2d73 7563 6365 7373 3a20 3135 382c  or-success: 158,\n+000591c0: 2031 3030 252c 2034 3225 3b0a 2020 2020   100%, 42%;.    \n+000591d0: 2d2d 636f 6c6f 722d 7761 726e 696e 673a  --color-warning:\n+000591e0: 2033 302c 2031 3030 252c 2038 3025 3b0a   30, 100%, 80%;.\n+000591f0: 2020 2020 2d2d 636f 6c6f 722d 6572 726f      --color-erro\n+00059200: 723a 2031 332c 2031 3030 252c 2035 3825  r: 13, 100%, 58%\n+00059210: 3b0a 2020 2020 2d2d 636f 6c6f 722d 6e65  ;.    --color-ne\n+00059220: 7574 7261 6c3a 2032 3139 2c20 3239 252c  utral: 219, 29%,\n+00059230: 2037 3825 3b0a 2020 2020 2d2d 636f 6c6f   78%;.    --colo\n+00059240: 722d 6261 7365 3a20 3231 392c 2032 3925  r-base: 219, 29%\n+00059250: 2c20 3138 253b 0a0a 2020 2020 2d2d 706f  , 18%;..    --po\n+00059260: 706f 7665 722d 626f 782d 7368 6164 6f77  pover-box-shadow\n+00059270: 3a20 6e6f 6e65 3b0a 2020 2020 2d2d 706f  : none;.    --po\n+00059280: 706f 7665 722d 626f 7264 6572 3a20 3170  pover-border: 1p\n+00059290: 7820 736f 6c69 6420 6873 6c28 7661 7228  x solid hsl(var(\n+000592a0: 2d2d 636f 6c6f 722d 6e65 7574 7261 6c29  --color-neutral)\n+000592b0: 293b 0a20 207d 0a7d 0a0a 626f 6479 2e67  );.  }.}..body.g\n+000592c0: 7261 7068 6971 6c2d 6461 726b 202e 6772  raphiql-dark .gr\n+000592d0: 6170 6869 716c 2d63 6f6e 7461 696e 6572  aphiql-container\n+000592e0: 2c0a 626f 6479 2e67 7261 7068 6971 6c2d  ,.body.graphiql-\n+000592f0: 6461 726b 202e 436f 6465 4d69 7272 6f72  dark .CodeMirror\n+00059300: 2d69 6e66 6f2c 0a62 6f64 792e 6772 6170  -info,.body.grap\n+00059310: 6869 716c 2d64 6172 6b20 2e43 6f64 654d  hiql-dark .CodeM\n+00059320: 6972 726f 722d 6c69 6e74 2d74 6f6f 6c74  irror-lint-toolt\n+00059330: 6970 2c0a 626f 6479 2e67 7261 7068 6971  ip,.body.graphiq\n+00059340: 6c2d 6461 726b 202e 6772 6170 6869 716c  l-dark .graphiql\n+00059350: 2d64 6961 6c6f 672c 0a62 6f64 792e 6772  -dialog,.body.gr\n+00059360: 6170 6869 716c 2d64 6172 6b20 2e67 7261  aphiql-dark .gra\n+00059370: 7068 6971 6c2d 6469 616c 6f67 2d6f 7665  phiql-dialog-ove\n+00059380: 726c 6179 2c0a 626f 6479 2e67 7261 7068  rlay,.body.graph\n+00059390: 6971 6c2d 6461 726b 202e 6772 6170 6869  iql-dark .graphi\n+000593a0: 716c 2d74 6f6f 6c74 6970 2c0a 626f 6479  ql-tooltip,.body\n+000593b0: 2e67 7261 7068 6971 6c2d 6461 726b 205b  .graphiql-dark [\n+000593c0: 6461 7461 2d72 6164 6978 2d70 6f70 7065  data-radix-poppe\n+000593d0: 722d 636f 6e74 656e 742d 7772 6170 7065  r-content-wrappe\n+000593e0: 725d 207b 0a20 202d 2d63 6f6c 6f72 2d70  r] {.  --color-p\n+000593f0: 7269 6d61 7279 3a20 3333 382c 2031 3030  rimary: 338, 100\n+00059400: 252c 2036 3725 3b0a 2020 2d2d 636f 6c6f  %, 67%;.  --colo\n+00059410: 722d 7365 636f 6e64 6172 793a 2032 3433  r-secondary: 243\n+00059420: 2c20 3130 3025 2c20 3737 253b 0a20 202d  , 100%, 77%;.  -\n+00059430: 2d63 6f6c 6f72 2d74 6572 7469 6172 793a  -color-tertiary:\n+00059440: 2031 3838 2c20 3130 3025 2c20 3434 253b   188, 100%, 44%;\n+00059450: 0a20 202d 2d63 6f6c 6f72 2d69 6e66 6f3a  .  --color-info:\n+00059460: 2032 3038 2c20 3130 3025 2c20 3732 253b   208, 100%, 72%;\n+00059470: 0a20 202d 2d63 6f6c 6f72 2d73 7563 6365  .  --color-succe\n+00059480: 7373 3a20 3135 382c 2031 3030 252c 2034  ss: 158, 100%, 4\n+00059490: 3225 3b0a 2020 2d2d 636f 6c6f 722d 7761  2%;.  --color-wa\n+000594a0: 726e 696e 673a 2033 302c 2031 3030 252c  rning: 30, 100%,\n+000594b0: 2038 3025 3b0a 2020 2d2d 636f 6c6f 722d   80%;.  --color-\n+000594c0: 6572 726f 723a 2031 332c 2031 3030 252c  error: 13, 100%,\n+000594d0: 2035 3825 3b0a 2020 2d2d 636f 6c6f 722d   58%;.  --color-\n+000594e0: 6e65 7574 7261 6c3a 2032 3139 2c20 3239  neutral: 219, 29\n+000594f0: 252c 2037 3825 3b0a 2020 2d2d 636f 6c6f  %, 78%;.  --colo\n+00059500: 722d 6261 7365 3a20 3231 392c 2032 3925  r-base: 219, 29%\n+00059510: 2c20 3138 253b 0a0a 2020 2d2d 706f 706f  , 18%;..  --popo\n+00059520: 7665 722d 626f 782d 7368 6164 6f77 3a20  ver-box-shadow: \n+00059530: 6e6f 6e65 3b0a 2020 2d2d 706f 706f 7665  none;.  --popove\n+00059540: 722d 626f 7264 6572 3a20 3170 7820 736f  r-border: 1px so\n+00059550: 6c69 6420 6873 6c28 7661 7228 2d2d 636f  lid hsl(var(--co\n+00059560: 6c6f 722d 6e65 7574 7261 6c29 293b 0a7d  lor-neutral));.}\n+00059570: 0a0a 2e67 7261 7068 6971 6c2d 636f 6e74  ...graphiql-cont\n+00059580: 6169 6e65 722c 0a20 202e 436f 6465 4d69  ainer,.  .CodeMi\n+00059590: 7272 6f72 2d69 6e66 6f2c 0a20 202e 436f  rror-info,.  .Co\n+000595a0: 6465 4d69 7272 6f72 2d6c 696e 742d 746f  deMirror-lint-to\n+000595b0: 6f6c 7469 702c 0a20 202e 6772 6170 6869  oltip,.  .graphi\n+000595c0: 716c 2d64 6961 6c6f 672c 0a20 202e 6772  ql-dialog,.  .gr\n+000595d0: 6170 6869 716c 2d63 6f6e 7461 696e 6572  aphiql-container\n+000595e0: 3a69 7328 6275 7474 6f6e 292c 0a20 202e  :is(button),.  .\n+000595f0: 436f 6465 4d69 7272 6f72 2d69 6e66 6f3a  CodeMirror-info:\n+00059600: 6973 2862 7574 746f 6e29 2c0a 2020 2e43  is(button),.  .C\n+00059610: 6f64 654d 6972 726f 722d 6c69 6e74 2d74  odeMirror-lint-t\n+00059620: 6f6f 6c74 6970 3a69 7328 6275 7474 6f6e  ooltip:is(button\n+00059630: 292c 0a20 202e 6772 6170 6869 716c 2d64  ),.  .graphiql-d\n+00059640: 6961 6c6f 673a 6973 2862 7574 746f 6e29  ialog:is(button)\n+00059650: 207b 0a20 2020 2063 6f6c 6f72 3a20 6873   {.    color: hs\n+00059660: 6c28 7661 7228 2d2d 636f 6c6f 722d 6e65  l(var(--color-ne\n+00059670: 7574 7261 6c29 293b 0a20 2020 2066 6f6e  utral));.    fon\n+00059680: 742d 6661 6d69 6c79 3a20 7661 7228 2d2d  t-family: var(--\n+00059690: 666f 6e74 2d66 616d 696c 7929 3b0a 2020  font-family);.  \n+000596a0: 2020 666f 6e74 2d73 697a 653a 2076 6172    font-size: var\n+000596b0: 282d 2d66 6f6e 742d 7369 7a65 2d62 6f64  (--font-size-bod\n+000596c0: 7929 3b0a 2020 2020 666f 6e74 2d77 6569  y);.    font-wei\n+000596d0: 6768 743a 2076 6172 282d 2d66 6f6e 742d  ght: var(--font-\n+000596e0: 7765 6967 6874 2d72 6567 756c 6172 293b  weight-regular);\n+000596f0: 0a20 2020 206c 696e 652d 6865 6967 6874  .    line-height\n+00059700: 3a20 7661 7228 2d2d 6c69 6e65 2d68 6569  : var(--line-hei\n+00059710: 6768 7429 3b0a 2020 7d0a 0a2e 6772 6170  ght);.  }...grap\n+00059720: 6869 716c 2d63 6f6e 7461 696e 6572 2069  hiql-container i\n+00059730: 6e70 7574 2c20 2e43 6f64 654d 6972 726f  nput, .CodeMirro\n+00059740: 722d 696e 666f 2069 6e70 7574 2c20 2e43  r-info input, .C\n+00059750: 6f64 654d 6972 726f 722d 6c69 6e74 2d74  odeMirror-lint-t\n+00059760: 6f6f 6c74 6970 2069 6e70 7574 2c20 2e67  ooltip input, .g\n+00059770: 7261 7068 6971 6c2d 6469 616c 6f67 2069  raphiql-dialog i\n+00059780: 6e70 7574 207b 0a20 2020 2063 6f6c 6f72  nput {.    color\n+00059790: 3a20 6873 6c28 7661 7228 2d2d 636f 6c6f  : hsl(var(--colo\n+000597a0: 722d 6e65 7574 7261 6c29 293b 0a20 2020  r-neutral));.   \n+000597b0: 2066 6f6e 742d 6661 6d69 6c79 3a20 7661   font-family: va\n+000597c0: 7228 2d2d 666f 6e74 2d66 616d 696c 7929  r(--font-family)\n+000597d0: 3b0a 2020 2020 666f 6e74 2d73 697a 653a  ;.    font-size:\n+000597e0: 2076 6172 282d 2d66 6f6e 742d 7369 7a65   var(--font-size\n+000597f0: 2d63 6170 7469 6f6e 290a 2020 7d0a 0a2e  -caption).  }...\n+00059800: 6772 6170 6869 716c 2d63 6f6e 7461 696e  graphiql-contain\n+00059810: 6572 2069 6e70 7574 3a3a 706c 6163 6568  er input::placeh\n+00059820: 6f6c 6465 722c 202e 436f 6465 4d69 7272  older, .CodeMirr\n+00059830: 6f72 2d69 6e66 6f20 696e 7075 743a 3a70  or-info input::p\n+00059840: 6c61 6365 686f 6c64 6572 2c20 2e43 6f64  laceholder, .Cod\n+00059850: 654d 6972 726f 722d 6c69 6e74 2d74 6f6f  eMirror-lint-too\n+00059860: 6c74 6970 2069 6e70 7574 3a3a 706c 6163  ltip input::plac\n+00059870: 6568 6f6c 6465 722c 202e 6772 6170 6869  eholder, .graphi\n+00059880: 716c 2d64 6961 6c6f 6720 696e 7075 743a  ql-dialog input:\n+00059890: 3a70 6c61 6365 686f 6c64 6572 207b 0a20  :placeholder {. \n+000598a0: 2020 2020 2063 6f6c 6f72 3a20 6873 6c61       color: hsla\n+000598b0: 2876 6172 282d 2d63 6f6c 6f72 2d6e 6575  (var(--color-neu\n+000598c0: 7472 616c 292c 2076 6172 282d 2d61 6c70  tral), var(--alp\n+000598d0: 6861 2d73 6563 6f6e 6461 7279 2929 3b0a  ha-secondary));.\n+000598e0: 2020 2020 7d0a 0a2e 6772 6170 6869 716c      }...graphiql\n+000598f0: 2d63 6f6e 7461 696e 6572 2061 2c20 2e43  -container a, .C\n+00059900: 6f64 654d 6972 726f 722d 696e 666f 2061  odeMirror-info a\n+00059910: 2c20 2e43 6f64 654d 6972 726f 722d 6c69  , .CodeMirror-li\n+00059920: 6e74 2d74 6f6f 6c74 6970 2061 2c20 2e67  nt-tooltip a, .g\n+00059930: 7261 7068 6971 6c2d 6469 616c 6f67 2061  raphiql-dialog a\n+00059940: 207b 0a20 2020 2063 6f6c 6f72 3a20 6873   {.    color: hs\n+00059950: 6c28 7661 7228 2d2d 636f 6c6f 722d 7072  l(var(--color-pr\n+00059960: 696d 6172 7929 290a 2020 7d0a 0a2e 6772  imary)).  }...gr\n+00059970: 6170 6869 716c 2d63 6f6e 7461 696e 6572  aphiql-container\n+00059980: 2061 3a66 6f63 7573 2c20 2e43 6f64 654d   a:focus, .CodeM\n+00059990: 6972 726f 722d 696e 666f 2061 3a66 6f63  irror-info a:foc\n+000599a0: 7573 2c20 2e43 6f64 654d 6972 726f 722d  us, .CodeMirror-\n+000599b0: 6c69 6e74 2d74 6f6f 6c74 6970 2061 3a66  lint-tooltip a:f\n+000599c0: 6f63 7573 2c20 2e67 7261 7068 6971 6c2d  ocus, .graphiql-\n+000599d0: 6469 616c 6f67 2061 3a66 6f63 7573 207b  dialog a:focus {\n+000599e0: 0a20 2020 2020 206f 7574 6c69 6e65 3a20  .      outline: \n+000599f0: 6873 6c28 7661 7228 2d2d 636f 6c6f 722d  hsl(var(--color-\n+00059a00: 7072 696d 6172 7929 2920 6175 746f 2031  primary)) auto 1\n+00059a10: 7078 3b0a 2020 2020 7d0a 2e67 7261 7068  px;.    }..graph\n+00059a20: 6971 6c2d 756e 2d73 7479 6c65 642c 0a62  iql-un-styled,.b\n+00059a30: 7574 746f 6e2e 6772 6170 6869 716c 2d75  utton.graphiql-u\n+00059a40: 6e2d 7374 796c 6564 207b 0a20 2061 6c6c  n-styled {.  all\n+00059a50: 3a20 756e 7365 743b 0a20 2062 6f72 6465  : unset;.  borde\n+00059a60: 722d 7261 6469 7573 3a20 7661 7228 2d2d  r-radius: var(--\n+00059a70: 626f 7264 6572 2d72 6164 6975 732d 3429  border-radius-4)\n+00059a80: 3b0a 2020 6375 7273 6f72 3a20 706f 696e  ;.  cursor: poin\n+00059a90: 7465 720a 7d0a 0a3a 6973 282e 6772 6170  ter.}..:is(.grap\n+00059aa0: 6869 716c 2d75 6e2d 7374 796c 6564 2c62  hiql-un-styled,b\n+00059ab0: 7574 746f 6e2e 6772 6170 6869 716c 2d75  utton.graphiql-u\n+00059ac0: 6e2d 7374 796c 6564 293a 686f 7665 7220  n-styled):hover \n+00059ad0: 7b0a 2020 2020 6261 636b 6772 6f75 6e64  {.    background\n+00059ae0: 2d63 6f6c 6f72 3a20 6873 6c61 2876 6172  -color: hsla(var\n+00059af0: 282d 2d63 6f6c 6f72 2d6e 6575 7472 616c  (--color-neutral\n+00059b00: 292c 2076 6172 282d 2d61 6c70 6861 2d62  ), var(--alpha-b\n+00059b10: 6163 6b67 726f 756e 642d 6c69 6768 7429  ackground-light)\n+00059b20: 293b 0a20 207d 0a0a 3a69 7328 2e67 7261  );.  }..:is(.gra\n+00059b30: 7068 6971 6c2d 756e 2d73 7479 6c65 642c  phiql-un-styled,\n+00059b40: 6275 7474 6f6e 2e67 7261 7068 6971 6c2d  button.graphiql-\n+00059b50: 756e 2d73 7479 6c65 6429 3a61 6374 6976  un-styled):activ\n+00059b60: 6520 7b0a 2020 2020 6261 636b 6772 6f75  e {.    backgrou\n+00059b70: 6e64 2d63 6f6c 6f72 3a20 6873 6c61 280a  nd-color: hsla(.\n+00059b80: 2020 2020 2020 7661 7228 2d2d 636f 6c6f        var(--colo\n+00059b90: 722d 6e65 7574 7261 6c29 2c0a 2020 2020  r-neutral),.    \n+00059ba0: 2020 7661 7228 2d2d 616c 7068 612d 6261    var(--alpha-ba\n+00059bb0: 636b 6772 6f75 6e64 2d6d 6564 6975 6d29  ckground-medium)\n+00059bc0: 0a20 2020 2029 3b0a 2020 7d0a 0a3a 6973  .    );.  }..:is\n+00059bd0: 282e 6772 6170 6869 716c 2d75 6e2d 7374  (.graphiql-un-st\n+00059be0: 796c 6564 2c62 7574 746f 6e2e 6772 6170  yled,button.grap\n+00059bf0: 6869 716c 2d75 6e2d 7374 796c 6564 293a  hiql-un-styled):\n+00059c00: 666f 6375 7320 7b0a 2020 2020 6f75 746c  focus {.    outl\n+00059c10: 696e 653a 2068 736c 6128 7661 7228 2d2d  ine: hsla(var(--\n+00059c20: 636f 6c6f 722d 6e65 7574 7261 6c29 2c20  color-neutral), \n+00059c30: 7661 7228 2d2d 616c 7068 612d 6261 636b  var(--alpha-back\n+00059c40: 6772 6f75 6e64 2d68 6561 7679 2929 2061  ground-heavy)) a\n+00059c50: 7574 6f20 3170 783b 0a20 207d 0a0a 2e67  uto 1px;.  }...g\n+00059c60: 7261 7068 6971 6c2d 6275 7474 6f6e 2c0a  raphiql-button,.\n+00059c70: 6275 7474 6f6e 2e67 7261 7068 6971 6c2d  button.graphiql-\n+00059c80: 6275 7474 6f6e 207b 0a20 2062 6163 6b67  button {.  backg\n+00059c90: 726f 756e 642d 636f 6c6f 723a 2068 736c  round-color: hsl\n+00059ca0: 6128 7661 7228 2d2d 636f 6c6f 722d 6e65  a(var(--color-ne\n+00059cb0: 7574 7261 6c29 2c20 7661 7228 2d2d 616c  utral), var(--al\n+00059cc0: 7068 612d 6261 636b 6772 6f75 6e64 2d6c  pha-background-l\n+00059cd0: 6967 6874 2929 3b0a 2020 626f 7264 6572  ight));.  border\n+00059ce0: 3a20 6e6f 6e65 3b0a 2020 626f 7264 6572  : none;.  border\n+00059cf0: 2d72 6164 6975 733a 2076 6172 282d 2d62  -radius: var(--b\n+00059d00: 6f72 6465 722d 7261 6469 7573 2d34 293b  order-radius-4);\n+00059d10: 0a20 2063 6f6c 6f72 3a20 6873 6c28 7661  .  color: hsl(va\n+00059d20: 7228 2d2d 636f 6c6f 722d 6e65 7574 7261  r(--color-neutra\n+00059d30: 6c29 293b 0a20 2063 7572 736f 723a 2070  l));.  cursor: p\n+00059d40: 6f69 6e74 6572 3b0a 2020 666f 6e74 2d73  ointer;.  font-s\n+00059d50: 697a 653a 2076 6172 282d 2d66 6f6e 742d  ize: var(--font-\n+00059d60: 7369 7a65 2d62 6f64 7929 3b0a 2020 7061  size-body);.  pa\n+00059d70: 6464 696e 673a 2076 6172 282d 2d70 782d  dding: var(--px-\n+00059d80: 3829 2076 6172 282d 2d70 782d 3132 290a  8) var(--px-12).\n+00059d90: 7d0a 0a3a 6973 282e 6772 6170 6869 716c  }..:is(.graphiql\n+00059da0: 2d62 7574 746f 6e2c 6275 7474 6f6e 2e67  -button,button.g\n+00059db0: 7261 7068 6971 6c2d 6275 7474 6f6e 293a  raphiql-button):\n+00059dc0: 686f 7665 722c 0a20 203a 6973 282e 6772  hover,.  :is(.gr\n+00059dd0: 6170 6869 716c 2d62 7574 746f 6e2c 6275  aphiql-button,bu\n+00059de0: 7474 6f6e 2e67 7261 7068 6971 6c2d 6275  tton.graphiql-bu\n+00059df0: 7474 6f6e 293a 6163 7469 7665 207b 0a20  tton):active {. \n+00059e00: 2020 2062 6163 6b67 726f 756e 642d 636f     background-co\n+00059e10: 6c6f 723a 2068 736c 6128 0a20 2020 2020  lor: hsla(.     \n+00059e20: 2076 6172 282d 2d63 6f6c 6f72 2d6e 6575   var(--color-neu\n+00059e30: 7472 616c 292c 0a20 2020 2020 2076 6172  tral),.      var\n+00059e40: 282d 2d61 6c70 6861 2d62 6163 6b67 726f  (--alpha-backgro\n+00059e50: 756e 642d 6d65 6469 756d 290a 2020 2020  und-medium).    \n+00059e60: 293b 0a20 207d 0a0a 3a69 7328 2e67 7261  );.  }..:is(.gra\n+00059e70: 7068 6971 6c2d 6275 7474 6f6e 2c62 7574  phiql-button,but\n+00059e80: 746f 6e2e 6772 6170 6869 716c 2d62 7574  ton.graphiql-but\n+00059e90: 746f 6e29 3a66 6f63 7573 207b 0a20 2020  ton):focus {.   \n+00059ea0: 206f 7574 6c69 6e65 3a20 6873 6c61 2876   outline: hsla(v\n+00059eb0: 6172 282d 2d63 6f6c 6f72 2d6e 6575 7472  ar(--color-neutr\n+00059ec0: 616c 292c 2076 6172 282d 2d61 6c70 6861  al), var(--alpha\n+00059ed0: 2d62 6163 6b67 726f 756e 642d 6865 6176  -background-heav\n+00059ee0: 7929 2920 6175 746f 2031 7078 3b0a 2020  y)) auto 1px;.  \n+00059ef0: 7d0a 0a2e 6772 6170 6869 716c 2d62 7574  }...graphiql-but\n+00059f00: 746f 6e2d 7375 6363 6573 733a 6973 282e  ton-success:is(.\n+00059f10: 6772 6170 6869 716c 2d62 7574 746f 6e2c  graphiql-button,\n+00059f20: 6275 7474 6f6e 2e67 7261 7068 6971 6c2d  button.graphiql-\n+00059f30: 6275 7474 6f6e 2920 7b0a 2020 2020 6261  button) {.    ba\n+00059f40: 636b 6772 6f75 6e64 2d63 6f6c 6f72 3a20  ckground-color: \n+00059f50: 6873 6c61 2876 6172 282d 2d63 6f6c 6f72  hsla(var(--color\n+00059f60: 2d73 7563 6365 7373 292c 2076 6172 282d  -success), var(-\n+00059f70: 2d61 6c70 6861 2d62 6163 6b67 726f 756e  -alpha-backgroun\n+00059f80: 642d 6865 6176 7929 293b 0a20 207d 0a0a  d-heavy));.  }..\n+00059f90: 2e67 7261 7068 6971 6c2d 6275 7474 6f6e  .graphiql-button\n+00059fa0: 2d65 7272 6f72 3a69 7328 2e67 7261 7068  -error:is(.graph\n+00059fb0: 6971 6c2d 6275 7474 6f6e 2c62 7574 746f  iql-button,butto\n+00059fc0: 6e2e 6772 6170 6869 716c 2d62 7574 746f  n.graphiql-butto\n+00059fd0: 6e29 207b 0a20 2020 2062 6163 6b67 726f  n) {.    backgro\n+00059fe0: 756e 642d 636f 6c6f 723a 2068 736c 6128  und-color: hsla(\n+00059ff0: 7661 7228 2d2d 636f 6c6f 722d 6572 726f  var(--color-erro\n+0005a000: 7229 2c20 7661 7228 2d2d 616c 7068 612d  r), var(--alpha-\n+0005a010: 6261 636b 6772 6f75 6e64 2d68 6561 7679  background-heavy\n+0005a020: 2929 3b0a 2020 7d0a 2e67 7261 7068 6971  ));.  }..graphiq\n+0005a030: 6c2d 6275 7474 6f6e 2d67 726f 7570 207b  l-button-group {\n+0005a040: 0a20 2062 6163 6b67 726f 756e 642d 636f  .  background-co\n+0005a050: 6c6f 723a 2068 736c 6128 7661 7228 2d2d  lor: hsla(var(--\n+0005a060: 636f 6c6f 722d 6e65 7574 7261 6c29 2c20  color-neutral), \n+0005a070: 7661 7228 2d2d 616c 7068 612d 6261 636b  var(--alpha-back\n+0005a080: 6772 6f75 6e64 2d6c 6967 6874 2929 3b0a  ground-light));.\n+0005a090: 2020 2f2a 2042 6f72 6465 7220 7261 6469    /* Border radi\n+0005a0a0: 7573 206f 6620 6275 7474 6f6e 2070 6c75  us of button plu\n+0005a0b0: 7320 7061 6464 696e 6720 2a2f 0a20 2062  s padding */.  b\n+0005a0c0: 6f72 6465 722d 7261 6469 7573 3a20 6361  order-radius: ca\n+0005a0d0: 6c63 2876 6172 282d 2d62 6f72 6465 722d  lc(var(--border-\n+0005a0e0: 7261 6469 7573 2d34 2920 2b20 7661 7228  radius-4) + var(\n+0005a0f0: 2d2d 7078 2d34 2929 3b0a 2020 6469 7370  --px-4));.  disp\n+0005a100: 6c61 793a 2066 6c65 783b 0a20 2070 6164  lay: flex;.  pad\n+0005a110: 6469 6e67 3a20 7661 7228 2d2d 7078 2d34  ding: var(--px-4\n+0005a120: 290a 7d0a 2e67 7261 7068 6971 6c2d 6275  ).}..graphiql-bu\n+0005a130: 7474 6f6e 2d67 726f 7570 203e 2062 7574  tton-group > but\n+0005a140: 746f 6e2e 6772 6170 6869 716c 2d62 7574  ton.graphiql-but\n+0005a150: 746f 6e20 7b0a 2020 2020 6261 636b 6772  ton {.    backgr\n+0005a160: 6f75 6e64 2d63 6f6c 6f72 3a20 7472 616e  ound-color: tran\n+0005a170: 7370 6172 656e 740a 2020 7d0a 2e67 7261  sparent.  }..gra\n+0005a180: 7068 6971 6c2d 6275 7474 6f6e 2d67 726f  phiql-button-gro\n+0005a190: 7570 203e 2062 7574 746f 6e2e 6772 6170  up > button.grap\n+0005a1a0: 6869 716c 2d62 7574 746f 6e3a 686f 7665  hiql-button:hove\n+0005a1b0: 7220 7b0a 2020 2020 2020 6261 636b 6772  r {.      backgr\n+0005a1c0: 6f75 6e64 2d63 6f6c 6f72 3a20 6873 6c61  ound-color: hsla\n+0005a1d0: 280a 2020 2020 2020 2020 7661 7228 2d2d  (.        var(--\n+0005a1e0: 636f 6c6f 722d 6e65 7574 7261 6c29 2c0a  color-neutral),.\n+0005a1f0: 2020 2020 2020 2020 7661 7228 2d2d 616c          var(--al\n+0005a200: 7068 612d 6261 636b 6772 6f75 6e64 2d6c  pha-background-l\n+0005a210: 6967 6874 290a 2020 2020 2020 293b 0a20  ight).      );. \n+0005a220: 2020 207d 0a2e 6772 6170 6869 716c 2d62     }..graphiql-b\n+0005a230: 7574 746f 6e2d 6772 6f75 7020 3e20 6275  utton-group > bu\n+0005a240: 7474 6f6e 2e67 7261 7068 6971 6c2d 6275  tton.graphiql-bu\n+0005a250: 7474 6f6e 2e61 6374 6976 6520 7b0a 2020  tton.active {.  \n+0005a260: 2020 2020 6261 636b 6772 6f75 6e64 2d63      background-c\n+0005a270: 6f6c 6f72 3a20 6873 6c28 7661 7228 2d2d  olor: hsl(var(--\n+0005a280: 636f 6c6f 722d 6261 7365 2929 3b0a 2020  color-base));.  \n+0005a290: 2020 2020 6375 7273 6f72 3a20 6465 6661      cursor: defa\n+0005a2a0: 756c 743b 0a20 2020 207d 0a2e 6772 6170  ult;.    }..grap\n+0005a2b0: 6869 716c 2d62 7574 746f 6e2d 6772 6f75  hiql-button-grou\n+0005a2c0: 7020 3e20 2a20 2b20 2a20 7b0a 2020 2020  p > * + * {.    \n+0005a2d0: 6d61 7267 696e 2d6c 6566 743a 2076 6172  margin-left: var\n+0005a2e0: 282d 2d70 782d 3829 3b0a 2020 7d0a 2e67  (--px-8);.  }..g\n+0005a2f0: 7261 7068 6971 6c2d 6469 616c 6f67 2d6f  raphiql-dialog-o\n+0005a300: 7665 726c 6179 207b 0a20 2070 6f73 6974  verlay {.  posit\n+0005a310: 696f 6e3a 2066 6978 6564 3b0a 2020 696e  ion: fixed;.  in\n+0005a320: 7365 743a 2030 3b0a 2020 6261 636b 6772  set: 0;.  backgr\n+0005a330: 6f75 6e64 2d63 6f6c 6f72 3a20 6873 6c61  ound-color: hsla\n+0005a340: 2876 6172 282d 2d63 6f6c 6f72 2d6e 6575  (var(--color-neu\n+0005a350: 7472 616c 292c 2076 6172 282d 2d61 6c70  tral), var(--alp\n+0005a360: 6861 2d62 6163 6b67 726f 756e 642d 6865  ha-background-he\n+0005a370: 6176 7929 293b 0a20 202f 2a2a 0a20 2020  avy));.  /**.   \n+0005a380: 2a20 436f 6465 4d69 7272 6f72 2068 6173  * CodeMirror has\n+0005a390: 2061 2060 7a2d 696e 6465 7860 2073 6574   a `z-index` set\n+0005a3a0: 2066 6f72 2074 6865 2063 6f6e 7461 696e   for the contain\n+0005a3b0: 6572 206f 6620 7468 6520 7363 726f 6c6c  er of the scroll\n+0005a3c0: 6261 7220 6f66 2074 6865 0a20 2020 2a20  bar of the.   * \n+0005a3d0: 6564 6974 6f72 2c20 736f 2077 6520 6861  editor, so we ha\n+0005a3e0: 7665 2074 6f20 6164 6420 6f6e 6520 6865  ve to add one he\n+0005a3f0: 7265 2074 6f20 6d61 6b65 2073 7572 6520  re to make sure \n+0005a400: 7468 6174 2074 6865 2064 6961 6c6f 6720  that the dialog \n+0005a410: 6973 2073 686f 776e 0a20 2020 2a20 6162  is shown.   * ab\n+0005a420: 6f76 6520 7468 6520 6564 6974 6f72 2073  ove the editor s\n+0005a430: 6372 6f6c 6c62 6172 2028 6966 2074 6865  crollbar (if the\n+0005a440: 7920 6172 6520 7669 7369 626c 6529 2e0a  y are visible)..\n+0005a450: 2020 202a 2f0a 2020 7a2d 696e 6465 783a     */.  z-index:\n+0005a460: 2031 303b 0a7d 0a0a 2e67 7261 7068 6971   10;.}...graphiq\n+0005a470: 6c2d 6469 616c 6f67 207b 0a20 2062 6163  l-dialog {.  bac\n+0005a480: 6b67 726f 756e 642d 636f 6c6f 723a 2068  kground-color: h\n+0005a490: 736c 2876 6172 282d 2d63 6f6c 6f72 2d62  sl(var(--color-b\n+0005a4a0: 6173 6529 293b 0a20 2062 6f72 6465 723a  ase));.  border:\n+0005a4b0: 2076 6172 282d 2d70 6f70 6f76 6572 2d62   var(--popover-b\n+0005a4c0: 6f72 6465 7229 3b0a 2020 626f 7264 6572  order);.  border\n+0005a4d0: 2d72 6164 6975 733a 2076 6172 282d 2d62  -radius: var(--b\n+0005a4e0: 6f72 6465 722d 7261 6469 7573 2d31 3229  order-radius-12)\n+0005a4f0: 3b0a 2020 626f 782d 7368 6164 6f77 3a20  ;.  box-shadow: \n+0005a500: 7661 7228 2d2d 706f 706f 7665 722d 626f  var(--popover-bo\n+0005a510: 782d 7368 6164 6f77 293b 0a20 206d 6172  x-shadow);.  mar\n+0005a520: 6769 6e3a 2030 3b0a 2020 6d61 782d 6865  gin: 0;.  max-he\n+0005a530: 6967 6874 3a20 3830 7668 3b0a 2020 6d61  ight: 80vh;.  ma\n+0005a540: 782d 7769 6474 683a 2038 3076 773b 0a20  x-width: 80vw;. \n+0005a550: 206f 7665 7266 6c6f 773a 2061 7574 6f3b   overflow: auto;\n+0005a560: 0a20 2070 6164 6469 6e67 3a20 303b 0a20  .  padding: 0;. \n+0005a570: 2077 6964 7468 3a20 756e 7365 743b 0a20   width: unset;. \n+0005a580: 2074 7261 6e73 666f 726d 3a20 7472 616e   transform: tran\n+0005a590: 736c 6174 6528 2d35 3025 2c20 2d35 3025  slate(-50%, -50%\n+0005a5a0: 293b 0a20 2074 6f70 3a20 3530 253b 0a20  );.  top: 50%;. \n+0005a5b0: 206c 6566 743a 2035 3025 3b0a 2020 706f   left: 50%;.  po\n+0005a5c0: 7369 7469 6f6e 3a20 6669 7865 643b 0a20  sition: fixed;. \n+0005a5d0: 207a 2d69 6e64 6578 3a20 3130 3b0a 7d0a   z-index: 10;.}.\n+0005a5e0: 0a2e 6772 6170 6869 716c 2d64 6961 6c6f  ..graphiql-dialo\n+0005a5f0: 672d 636c 6f73 6520 3e20 7376 6720 7b0a  g-close > svg {.\n+0005a600: 2020 636f 6c6f 723a 2068 736c 6128 7661    color: hsla(va\n+0005a610: 7228 2d2d 636f 6c6f 722d 6e65 7574 7261  r(--color-neutra\n+0005a620: 6c29 2c20 7661 7228 2d2d 616c 7068 612d  l), var(--alpha-\n+0005a630: 7365 636f 6e64 6172 7929 293b 0a20 2064  secondary));.  d\n+0005a640: 6973 706c 6179 3a20 626c 6f63 6b3b 0a20  isplay: block;. \n+0005a650: 2068 6569 6768 743a 2076 6172 282d 2d70   height: var(--p\n+0005a660: 782d 3132 293b 0a20 2070 6164 6469 6e67  x-12);.  padding\n+0005a670: 3a20 7661 7228 2d2d 7078 2d31 3229 3b0a  : var(--px-12);.\n+0005a680: 2020 7769 6474 683a 2076 6172 282d 2d70    width: var(--p\n+0005a690: 782d 3132 293b 0a7d 0a2e 6772 6170 6869  x-12);.}..graphi\n+0005a6a0: 716c 2d64 726f 7064 6f77 6e2d 636f 6e74  ql-dropdown-cont\n+0005a6b0: 656e 7420 7b0a 2020 6261 636b 6772 6f75  ent {.  backgrou\n+0005a6c0: 6e64 2d63 6f6c 6f72 3a20 6873 6c28 7661  nd-color: hsl(va\n+0005a6d0: 7228 2d2d 636f 6c6f 722d 6261 7365 2929  r(--color-base))\n+0005a6e0: 3b0a 2020 626f 7264 6572 3a20 7661 7228  ;.  border: var(\n+0005a6f0: 2d2d 706f 706f 7665 722d 626f 7264 6572  --popover-border\n+0005a700: 293b 0a20 2062 6f72 6465 722d 7261 6469  );.  border-radi\n+0005a710: 7573 3a20 7661 7228 2d2d 626f 7264 6572  us: var(--border\n+0005a720: 2d72 6164 6975 732d 3829 3b0a 2020 626f  -radius-8);.  bo\n+0005a730: 782d 7368 6164 6f77 3a20 7661 7228 2d2d  x-shadow: var(--\n+0005a740: 706f 706f 7665 722d 626f 782d 7368 6164  popover-box-shad\n+0005a750: 6f77 293b 0a20 2066 6f6e 742d 7369 7a65  ow);.  font-size\n+0005a760: 3a20 696e 6865 7269 743b 0a20 206d 6178  : inherit;.  max\n+0005a770: 2d77 6964 7468 3a20 3235 3070 783b 0a20  -width: 250px;. \n+0005a780: 2070 6164 6469 6e67 3a20 7661 7228 2d2d   padding: var(--\n+0005a790: 7078 2d34 293b 0a20 2066 6f6e 742d 6661  px-4);.  font-fa\n+0005a7a0: 6d69 6c79 3a20 7661 7228 2d2d 666f 6e74  mily: var(--font\n+0005a7b0: 2d66 616d 696c 7929 3b0a 2020 636f 6c6f  -family);.  colo\n+0005a7c0: 723a 2068 736c 2876 6172 282d 2d63 6f6c  r: hsl(var(--col\n+0005a7d0: 6f72 2d6e 6575 7472 616c 2929 3b0a 2020  or-neutral));.  \n+0005a7e0: 6d61 782d 6865 6967 6874 3a20 6d69 6e28  max-height: min(\n+0005a7f0: 0a20 2020 2063 616c 6328 7661 7228 2d2d  .    calc(var(--\n+0005a800: 7261 6469 782d 6472 6f70 646f 776e 2d6d  radix-dropdown-m\n+0005a810: 656e 752d 636f 6e74 656e 742d 6176 6169  enu-content-avai\n+0005a820: 6c61 626c 652d 6865 6967 6874 2920 2d20  lable-height) - \n+0005a830: 3130 7078 292c 0a20 2020 2034 3030 7078  10px),.    400px\n+0005a840: 0a20 2029 3b0a 2020 6f76 6572 666c 6f77  .  );.  overflow\n+0005a850: 2d79 3a20 7363 726f 6c6c 3b0a 7d0a 0a2e  -y: scroll;.}...\n+0005a860: 6772 6170 6869 716c 2d64 726f 7064 6f77  graphiql-dropdow\n+0005a870: 6e2d 6974 656d 207b 0a20 2062 6f72 6465  n-item {.  borde\n+0005a880: 722d 7261 6469 7573 3a20 7661 7228 2d2d  r-radius: var(--\n+0005a890: 626f 7264 6572 2d72 6164 6975 732d 3429  border-radius-4)\n+0005a8a0: 3b0a 2020 666f 6e74 2d73 697a 653a 2069  ;.  font-size: i\n+0005a8b0: 6e68 6572 6974 3b0a 2020 6d61 7267 696e  nherit;.  margin\n+0005a8c0: 3a20 7661 7228 2d2d 7078 2d34 293b 0a20  : var(--px-4);. \n+0005a8d0: 206f 7665 7266 6c6f 773a 2068 6964 6465   overflow: hidde\n+0005a8e0: 6e3b 0a20 2070 6164 6469 6e67 3a20 7661  n;.  padding: va\n+0005a8f0: 7228 2d2d 7078 2d36 2920 7661 7228 2d2d  r(--px-6) var(--\n+0005a900: 7078 2d38 293b 0a20 2074 6578 742d 6f76  px-8);.  text-ov\n+0005a910: 6572 666c 6f77 3a20 656c 6c69 7073 6973  erflow: ellipsis\n+0005a920: 3b0a 2020 7768 6974 652d 7370 6163 653a  ;.  white-space:\n+0005a930: 206e 6f77 7261 703b 0a20 206f 7574 6c69   nowrap;.  outli\n+0005a940: 6e65 3a20 6e6f 6e65 3b0a 2020 6375 7273  ne: none;.  curs\n+0005a950: 6f72 3a20 706f 696e 7465 723b 0a20 206c  or: pointer;.  l\n+0005a960: 696e 652d 6865 6967 6874 3a20 7661 7228  ine-height: var(\n+0005a970: 2d2d 6c69 6e65 2d68 6569 6768 7429 0a7d  --line-height).}\n+0005a980: 0a0a 2e67 7261 7068 6971 6c2d 6472 6f70  ...graphiql-drop\n+0005a990: 646f 776e 2d69 7465 6d5b 6461 7461 2d73  down-item[data-s\n+0005a9a0: 656c 6563 7465 645d 2c0a 2020 2e67 7261  elected],.  .gra\n+0005a9b0: 7068 6971 6c2d 6472 6f70 646f 776e 2d69  phiql-dropdown-i\n+0005a9c0: 7465 6d5b 6461 7461 2d63 7572 7265 6e74  tem[data-current\n+0005a9d0: 2d6e 6176 5d2c 0a20 202e 6772 6170 6869  -nav],.  .graphi\n+0005a9e0: 716c 2d64 726f 7064 6f77 6e2d 6974 656d  ql-dropdown-item\n+0005a9f0: 3a68 6f76 6572 207b 0a20 2020 2062 6163  :hover {.    bac\n+0005aa00: 6b67 726f 756e 642d 636f 6c6f 723a 2068  kground-color: h\n+0005aa10: 736c 6128 7661 7228 2d2d 636f 6c6f 722d  sla(var(--color-\n+0005aa20: 6e65 7574 7261 6c29 2c20 7661 7228 2d2d  neutral), var(--\n+0005aa30: 616c 7068 612d 6261 636b 6772 6f75 6e64  alpha-background\n+0005aa40: 2d6c 6967 6874 2929 3b0a 2020 2020 636f  -light));.    co\n+0005aa50: 6c6f 723a 2069 6e68 6572 6974 3b0a 2020  lor: inherit;.  \n+0005aa60: 7d0a 0a2e 6772 6170 6869 716c 2d64 726f  }...graphiql-dro\n+0005aa70: 7064 6f77 6e2d 6974 656d 3a6e 6f74 283a  pdown-item:not(:\n+0005aa80: 6669 7273 742d 6368 696c 6429 207b 0a20  first-child) {. \n+0005aa90: 2020 206d 6172 6769 6e2d 746f 703a 2030     margin-top: 0\n+0005aaa0: 3b0a 2020 7d0a 2f2a 2a0a 202a 2057 6520  ;.  }./**. * We \n+0005aab0: 7265 6e64 6572 206d 6172 6b64 6f77 6e20  render markdown \n+0005aac0: 696e 2074 6865 2066 6f6c 6c6f 7769 6e67  in the following\n+0005aad0: 2070 6c61 6365 733a 0a20 2a20 2d20 496e   places:. * - In\n+0005aae0: 2074 6865 2068 696e 7420 746f 6f6c 7469   the hint toolti\n+0005aaf0: 7020 7768 656e 2074 7970 696e 6720 696e  p when typing in\n+0005ab00: 2074 6865 2071 7565 7279 2065 6469 746f   the query edito\n+0005ab10: 7220 2866 6965 6c64 2064 6573 6372 6970  r (field descrip\n+0005ab20: 7469 6f6e 0a20 2a20 2020 616e 642c 206f  tion. *   and, o\n+0005ab30: 7074 696f 6e61 6c6c 792c 2064 6570 7265  ptionally, depre\n+0005ab40: 6361 7469 6f6e 2072 6561 736f 6e29 2e0a  cation reason)..\n+0005ab50: 202a 202d 2049 6e20 7468 6520 696e 666f   * - In the info\n+0005ab60: 2074 6f6f 6c74 6970 2077 6865 6e20 686f   tooltip when ho\n+0005ab70: 7665 7269 6e67 206f 7665 7220 6120 6669  vering over a fi\n+0005ab80: 656c 6420 696e 2074 6865 2071 7565 7279  eld in the query\n+0005ab90: 2065 6469 746f 720a 202a 2020 2028 6669   editor. *   (fi\n+0005aba0: 656c 6420 6465 7363 7269 7074 696f 6e20  eld description \n+0005abb0: 616e 642c 206f 7074 696f 6e61 6c6c 792c  and, optionally,\n+0005abc0: 2064 6570 7265 6361 7469 6f6e 2072 6561   deprecation rea\n+0005abd0: 736f 6e29 2e0a 202a 2f0a 0a3a 6973 282e  son).. */..:is(.\n+0005abe0: 6772 6170 6869 716c 2d6d 6172 6b64 6f77  graphiql-markdow\n+0005abf0: 6e2d 6465 7363 7269 7074 696f 6e2c 2e67  n-description,.g\n+0005ac00: 7261 7068 6971 6c2d 6d61 726b 646f 776e  raphiql-markdown\n+0005ac10: 2d64 6570 7265 6361 7469 6f6e 2c2e 436f  -deprecation,.Co\n+0005ac20: 6465 4d69 7272 6f72 2d68 696e 742d 696e  deMirror-hint-in\n+0005ac30: 666f 726d 6174 696f 6e2d 6465 7363 7269  formation-descri\n+0005ac40: 7074 696f 6e2c 2e43 6f64 654d 6972 726f  ption,.CodeMirro\n+0005ac50: 722d 6869 6e74 2d69 6e66 6f72 6d61 7469  r-hint-informati\n+0005ac60: 6f6e 2d64 6570 7265 6361 7469 6f6e 2d72  on-deprecation-r\n+0005ac70: 6561 736f 6e2c 2e43 6f64 654d 6972 726f  eason,.CodeMirro\n+0005ac80: 722d 696e 666f 202e 696e 666f 2d64 6573  r-info .info-des\n+0005ac90: 6372 6970 7469 6f6e 2c2e 436f 6465 4d69  cription,.CodeMi\n+0005aca0: 7272 6f72 2d69 6e66 6f20 2e69 6e66 6f2d  rror-info .info-\n+0005acb0: 6465 7072 6563 6174 696f 6e29 2062 6c6f  deprecation) blo\n+0005acc0: 636b 7175 6f74 6520 7b0a 2020 2020 6d61  ckquote {.    ma\n+0005acd0: 7267 696e 2d6c 6566 743a 2030 3b0a 2020  rgin-left: 0;.  \n+0005ace0: 2020 6d61 7267 696e 2d72 6967 6874 3a20    margin-right: \n+0005acf0: 303b 0a20 2020 2070 6164 6469 6e67 2d6c  0;.    padding-l\n+0005ad00: 6566 743a 2076 6172 282d 2d70 782d 3829  eft: var(--px-8)\n+0005ad10: 3b0a 2020 7d0a 0a3a 6973 282e 6772 6170  ;.  }..:is(.grap\n+0005ad20: 6869 716c 2d6d 6172 6b64 6f77 6e2d 6465  hiql-markdown-de\n+0005ad30: 7363 7269 7074 696f 6e2c 2e67 7261 7068  scription,.graph\n+0005ad40: 6971 6c2d 6d61 726b 646f 776e 2d64 6570  iql-markdown-dep\n+0005ad50: 7265 6361 7469 6f6e 2c2e 436f 6465 4d69  recation,.CodeMi\n+0005ad60: 7272 6f72 2d68 696e 742d 696e 666f 726d  rror-hint-inform\n+0005ad70: 6174 696f 6e2d 6465 7363 7269 7074 696f  ation-descriptio\n+0005ad80: 6e2c 2e43 6f64 654d 6972 726f 722d 6869  n,.CodeMirror-hi\n+0005ad90: 6e74 2d69 6e66 6f72 6d61 7469 6f6e 2d64  nt-information-d\n+0005ada0: 6570 7265 6361 7469 6f6e 2d72 6561 736f  eprecation-reaso\n+0005adb0: 6e2c 2e43 6f64 654d 6972 726f 722d 696e  n,.CodeMirror-in\n+0005adc0: 666f 202e 696e 666f 2d64 6573 6372 6970  fo .info-descrip\n+0005add0: 7469 6f6e 2c2e 436f 6465 4d69 7272 6f72  tion,.CodeMirror\n+0005ade0: 2d69 6e66 6f20 2e69 6e66 6f2d 6465 7072  -info .info-depr\n+0005adf0: 6563 6174 696f 6e29 2063 6f64 652c 0a20  ecation) code,. \n+0005ae00: 203a 6973 282e 6772 6170 6869 716c 2d6d   :is(.graphiql-m\n+0005ae10: 6172 6b64 6f77 6e2d 6465 7363 7269 7074  arkdown-descript\n+0005ae20: 696f 6e2c 2e67 7261 7068 6971 6c2d 6d61  ion,.graphiql-ma\n+0005ae30: 726b 646f 776e 2d64 6570 7265 6361 7469  rkdown-deprecati\n+0005ae40: 6f6e 2c2e 436f 6465 4d69 7272 6f72 2d68  on,.CodeMirror-h\n+0005ae50: 696e 742d 696e 666f 726d 6174 696f 6e2d  int-information-\n+0005ae60: 6465 7363 7269 7074 696f 6e2c 2e43 6f64  description,.Cod\n+0005ae70: 654d 6972 726f 722d 6869 6e74 2d69 6e66  eMirror-hint-inf\n+0005ae80: 6f72 6d61 7469 6f6e 2d64 6570 7265 6361  ormation-depreca\n+0005ae90: 7469 6f6e 2d72 6561 736f 6e2c 2e43 6f64  tion-reason,.Cod\n+0005aea0: 654d 6972 726f 722d 696e 666f 202e 696e  eMirror-info .in\n+0005aeb0: 666f 2d64 6573 6372 6970 7469 6f6e 2c2e  fo-description,.\n+0005aec0: 436f 6465 4d69 7272 6f72 2d69 6e66 6f20  CodeMirror-info \n+0005aed0: 2e69 6e66 6f2d 6465 7072 6563 6174 696f  .info-deprecatio\n+0005aee0: 6e29 2070 7265 207b 0a20 2020 2062 6f72  n) pre {.    bor\n+0005aef0: 6465 722d 7261 6469 7573 3a20 7661 7228  der-radius: var(\n+0005af00: 2d2d 626f 7264 6572 2d72 6164 6975 732d  --border-radius-\n+0005af10: 3429 3b0a 2020 2020 666f 6e74 2d66 616d  4);.    font-fam\n+0005af20: 696c 793a 2076 6172 282d 2d66 6f6e 742d  ily: var(--font-\n+0005af30: 6661 6d69 6c79 2d6d 6f6e 6f29 3b0a 2020  family-mono);.  \n+0005af40: 2020 666f 6e74 2d73 697a 653a 2076 6172    font-size: var\n+0005af50: 282d 2d66 6f6e 742d 7369 7a65 2d69 6e6c  (--font-size-inl\n+0005af60: 696e 652d 636f 6465 293b 0a20 207d 0a0a  ine-code);.  }..\n+0005af70: 3a69 7328 2e67 7261 7068 6971 6c2d 6d61  :is(.graphiql-ma\n+0005af80: 726b 646f 776e 2d64 6573 6372 6970 7469  rkdown-descripti\n+0005af90: 6f6e 2c2e 6772 6170 6869 716c 2d6d 6172  on,.graphiql-mar\n+0005afa0: 6b64 6f77 6e2d 6465 7072 6563 6174 696f  kdown-deprecatio\n+0005afb0: 6e2c 2e43 6f64 654d 6972 726f 722d 6869  n,.CodeMirror-hi\n+0005afc0: 6e74 2d69 6e66 6f72 6d61 7469 6f6e 2d64  nt-information-d\n+0005afd0: 6573 6372 6970 7469 6f6e 2c2e 436f 6465  escription,.Code\n+0005afe0: 4d69 7272 6f72 2d68 696e 742d 696e 666f  Mirror-hint-info\n+0005aff0: 726d 6174 696f 6e2d 6465 7072 6563 6174  rmation-deprecat\n+0005b000: 696f 6e2d 7265 6173 6f6e 2c2e 436f 6465  ion-reason,.Code\n+0005b010: 4d69 7272 6f72 2d69 6e66 6f20 2e69 6e66  Mirror-info .inf\n+0005b020: 6f2d 6465 7363 7269 7074 696f 6e2c 2e43  o-description,.C\n+0005b030: 6f64 654d 6972 726f 722d 696e 666f 202e  odeMirror-info .\n+0005b040: 696e 666f 2d64 6570 7265 6361 7469 6f6e  info-deprecation\n+0005b050: 2920 636f 6465 207b 0a20 2020 2070 6164  ) code {.    pad\n+0005b060: 6469 6e67 3a20 7661 7228 2d2d 7078 2d32  ding: var(--px-2\n+0005b070: 293b 0a20 207d 0a0a 3a69 7328 2e67 7261  );.  }..:is(.gra\n+0005b080: 7068 6971 6c2d 6d61 726b 646f 776e 2d64  phiql-markdown-d\n+0005b090: 6573 6372 6970 7469 6f6e 2c2e 6772 6170  escription,.grap\n+0005b0a0: 6869 716c 2d6d 6172 6b64 6f77 6e2d 6465  hiql-markdown-de\n+0005b0b0: 7072 6563 6174 696f 6e2c 2e43 6f64 654d  precation,.CodeM\n+0005b0c0: 6972 726f 722d 6869 6e74 2d69 6e66 6f72  irror-hint-infor\n+0005b0d0: 6d61 7469 6f6e 2d64 6573 6372 6970 7469  mation-descripti\n+0005b0e0: 6f6e 2c2e 436f 6465 4d69 7272 6f72 2d68  on,.CodeMirror-h\n+0005b0f0: 696e 742d 696e 666f 726d 6174 696f 6e2d  int-information-\n+0005b100: 6465 7072 6563 6174 696f 6e2d 7265 6173  deprecation-reas\n+0005b110: 6f6e 2c2e 436f 6465 4d69 7272 6f72 2d69  on,.CodeMirror-i\n+0005b120: 6e66 6f20 2e69 6e66 6f2d 6465 7363 7269  nfo .info-descri\n+0005b130: 7074 696f 6e2c 2e43 6f64 654d 6972 726f  ption,.CodeMirro\n+0005b140: 722d 696e 666f 202e 696e 666f 2d64 6570  r-info .info-dep\n+0005b150: 7265 6361 7469 6f6e 2920 7072 6520 7b0a  recation) pre {.\n+0005b160: 2020 2020 6f76 6572 666c 6f77 3a20 6175      overflow: au\n+0005b170: 746f 3b0a 2020 2020 7061 6464 696e 673a  to;.    padding:\n+0005b180: 2076 6172 282d 2d70 782d 3629 2076 6172   var(--px-6) var\n+0005b190: 282d 2d70 782d 3829 3b0a 2020 7d0a 0a3a  (--px-8);.  }..:\n+0005b1a0: 6973 282e 6772 6170 6869 716c 2d6d 6172  is(.graphiql-mar\n+0005b1b0: 6b64 6f77 6e2d 6465 7363 7269 7074 696f  kdown-descriptio\n+0005b1c0: 6e2c 2e67 7261 7068 6971 6c2d 6d61 726b  n,.graphiql-mark\n+0005b1d0: 646f 776e 2d64 6570 7265 6361 7469 6f6e  down-deprecation\n+0005b1e0: 2c2e 436f 6465 4d69 7272 6f72 2d68 696e  ,.CodeMirror-hin\n+0005b1f0: 742d 696e 666f 726d 6174 696f 6e2d 6465  t-information-de\n+0005b200: 7363 7269 7074 696f 6e2c 2e43 6f64 654d  scription,.CodeM\n+0005b210: 6972 726f 722d 6869 6e74 2d69 6e66 6f72  irror-hint-infor\n+0005b220: 6d61 7469 6f6e 2d64 6570 7265 6361 7469  mation-deprecati\n+0005b230: 6f6e 2d72 6561 736f 6e2c 2e43 6f64 654d  on-reason,.CodeM\n+0005b240: 6972 726f 722d 696e 666f 202e 696e 666f  irror-info .info\n+0005b250: 2d64 6573 6372 6970 7469 6f6e 2c2e 436f  -description,.Co\n+0005b260: 6465 4d69 7272 6f72 2d69 6e66 6f20 2e69  deMirror-info .i\n+0005b270: 6e66 6f2d 6465 7072 6563 6174 696f 6e29  nfo-deprecation)\n+0005b280: 2070 7265 2063 6f64 6520 7b0a 2020 2020   pre code {.    \n+0005b290: 6261 636b 6772 6f75 6e64 2d63 6f6c 6f72  background-color\n+0005b2a0: 3a20 696e 6974 6961 6c3b 0a20 2020 2062  : initial;.    b\n+0005b2b0: 6f72 6465 722d 7261 6469 7573 3a20 303b  order-radius: 0;\n+0005b2c0: 0a20 2020 2070 6164 6469 6e67 3a20 303b  .    padding: 0;\n+0005b2d0: 0a20 207d 0a0a 3a69 7328 2e67 7261 7068  .  }..:is(.graph\n+0005b2e0: 6971 6c2d 6d61 726b 646f 776e 2d64 6573  iql-markdown-des\n+0005b2f0: 6372 6970 7469 6f6e 2c2e 6772 6170 6869  cription,.graphi\n+0005b300: 716c 2d6d 6172 6b64 6f77 6e2d 6465 7072  ql-markdown-depr\n+0005b310: 6563 6174 696f 6e2c 2e43 6f64 654d 6972  ecation,.CodeMir\n+0005b320: 726f 722d 6869 6e74 2d69 6e66 6f72 6d61  ror-hint-informa\n+0005b330: 7469 6f6e 2d64 6573 6372 6970 7469 6f6e  tion-description\n+0005b340: 2c2e 436f 6465 4d69 7272 6f72 2d68 696e  ,.CodeMirror-hin\n+0005b350: 742d 696e 666f 726d 6174 696f 6e2d 6465  t-information-de\n+0005b360: 7072 6563 6174 696f 6e2d 7265 6173 6f6e  precation-reason\n+0005b370: 2c2e 436f 6465 4d69 7272 6f72 2d69 6e66  ,.CodeMirror-inf\n+0005b380: 6f20 2e69 6e66 6f2d 6465 7363 7269 7074  o .info-descript\n+0005b390: 696f 6e2c 2e43 6f64 654d 6972 726f 722d  ion,.CodeMirror-\n+0005b3a0: 696e 666f 202e 696e 666f 2d64 6570 7265  info .info-depre\n+0005b3b0: 6361 7469 6f6e 2920 6f6c 2c0a 2020 3a69  cation) ol,.  :i\n+0005b3c0: 7328 2e67 7261 7068 6971 6c2d 6d61 726b  s(.graphiql-mark\n+0005b3d0: 646f 776e 2d64 6573 6372 6970 7469 6f6e  down-description\n+0005b3e0: 2c2e 6772 6170 6869 716c 2d6d 6172 6b64  ,.graphiql-markd\n+0005b3f0: 6f77 6e2d 6465 7072 6563 6174 696f 6e2c  own-deprecation,\n+0005b400: 2e43 6f64 654d 6972 726f 722d 6869 6e74  .CodeMirror-hint\n+0005b410: 2d69 6e66 6f72 6d61 7469 6f6e 2d64 6573  -information-des\n+0005b420: 6372 6970 7469 6f6e 2c2e 436f 6465 4d69  cription,.CodeMi\n+0005b430: 7272 6f72 2d68 696e 742d 696e 666f 726d  rror-hint-inform\n+0005b440: 6174 696f 6e2d 6465 7072 6563 6174 696f  ation-deprecatio\n+0005b450: 6e2d 7265 6173 6f6e 2c2e 436f 6465 4d69  n-reason,.CodeMi\n+0005b460: 7272 6f72 2d69 6e66 6f20 2e69 6e66 6f2d  rror-info .info-\n+0005b470: 6465 7363 7269 7074 696f 6e2c 2e43 6f64  description,.Cod\n+0005b480: 654d 6972 726f 722d 696e 666f 202e 696e  eMirror-info .in\n+0005b490: 666f 2d64 6570 7265 6361 7469 6f6e 2920  fo-deprecation) \n+0005b4a0: 756c 207b 0a20 2020 2070 6164 6469 6e67  ul {.    padding\n+0005b4b0: 2d6c 6566 743a 2076 6172 282d 2d70 782d  -left: var(--px-\n+0005b4c0: 3136 293b 0a20 207d 0a0a 3a69 7328 2e67  16);.  }..:is(.g\n+0005b4d0: 7261 7068 6971 6c2d 6d61 726b 646f 776e  raphiql-markdown\n+0005b4e0: 2d64 6573 6372 6970 7469 6f6e 2c2e 6772  -description,.gr\n+0005b4f0: 6170 6869 716c 2d6d 6172 6b64 6f77 6e2d  aphiql-markdown-\n+0005b500: 6465 7072 6563 6174 696f 6e2c 2e43 6f64  deprecation,.Cod\n+0005b510: 654d 6972 726f 722d 6869 6e74 2d69 6e66  eMirror-hint-inf\n+0005b520: 6f72 6d61 7469 6f6e 2d64 6573 6372 6970  ormation-descrip\n+0005b530: 7469 6f6e 2c2e 436f 6465 4d69 7272 6f72  tion,.CodeMirror\n+0005b540: 2d68 696e 742d 696e 666f 726d 6174 696f  -hint-informatio\n+0005b550: 6e2d 6465 7072 6563 6174 696f 6e2d 7265  n-deprecation-re\n+0005b560: 6173 6f6e 2c2e 436f 6465 4d69 7272 6f72  ason,.CodeMirror\n+0005b570: 2d69 6e66 6f20 2e69 6e66 6f2d 6465 7363  -info .info-desc\n+0005b580: 7269 7074 696f 6e2c 2e43 6f64 654d 6972  ription,.CodeMir\n+0005b590: 726f 722d 696e 666f 202e 696e 666f 2d64  ror-info .info-d\n+0005b5a0: 6570 7265 6361 7469 6f6e 2920 6f6c 207b  eprecation) ol {\n+0005b5b0: 0a20 2020 206c 6973 742d 7374 796c 652d  .    list-style-\n+0005b5c0: 7479 7065 3a20 6465 6369 6d61 6c3b 0a20  type: decimal;. \n+0005b5d0: 207d 0a0a 3a69 7328 2e67 7261 7068 6971   }..:is(.graphiq\n+0005b5e0: 6c2d 6d61 726b 646f 776e 2d64 6573 6372  l-markdown-descr\n+0005b5f0: 6970 7469 6f6e 2c2e 6772 6170 6869 716c  iption,.graphiql\n+0005b600: 2d6d 6172 6b64 6f77 6e2d 6465 7072 6563  -markdown-deprec\n+0005b610: 6174 696f 6e2c 2e43 6f64 654d 6972 726f  ation,.CodeMirro\n+0005b620: 722d 6869 6e74 2d69 6e66 6f72 6d61 7469  r-hint-informati\n+0005b630: 6f6e 2d64 6573 6372 6970 7469 6f6e 2c2e  on-description,.\n+0005b640: 436f 6465 4d69 7272 6f72 2d68 696e 742d  CodeMirror-hint-\n+0005b650: 696e 666f 726d 6174 696f 6e2d 6465 7072  information-depr\n+0005b660: 6563 6174 696f 6e2d 7265 6173 6f6e 2c2e  ecation-reason,.\n+0005b670: 436f 6465 4d69 7272 6f72 2d69 6e66 6f20  CodeMirror-info \n+0005b680: 2e69 6e66 6f2d 6465 7363 7269 7074 696f  .info-descriptio\n+0005b690: 6e2c 2e43 6f64 654d 6972 726f 722d 696e  n,.CodeMirror-in\n+0005b6a0: 666f 202e 696e 666f 2d64 6570 7265 6361  fo .info-depreca\n+0005b6b0: 7469 6f6e 2920 756c 207b 0a20 2020 206c  tion) ul {.    l\n+0005b6c0: 6973 742d 7374 796c 652d 7479 7065 3a20  ist-style-type: \n+0005b6d0: 6469 7363 3b0a 2020 7d0a 0a3a 6973 282e  disc;.  }..:is(.\n+0005b6e0: 6772 6170 6869 716c 2d6d 6172 6b64 6f77  graphiql-markdow\n+0005b6f0: 6e2d 6465 7363 7269 7074 696f 6e2c 2e67  n-description,.g\n+0005b700: 7261 7068 6971 6c2d 6d61 726b 646f 776e  raphiql-markdown\n+0005b710: 2d64 6570 7265 6361 7469 6f6e 2c2e 436f  -deprecation,.Co\n+0005b720: 6465 4d69 7272 6f72 2d68 696e 742d 696e  deMirror-hint-in\n+0005b730: 666f 726d 6174 696f 6e2d 6465 7363 7269  formation-descri\n+0005b740: 7074 696f 6e2c 2e43 6f64 654d 6972 726f  ption,.CodeMirro\n+0005b750: 722d 6869 6e74 2d69 6e66 6f72 6d61 7469  r-hint-informati\n+0005b760: 6f6e 2d64 6570 7265 6361 7469 6f6e 2d72  on-deprecation-r\n+0005b770: 6561 736f 6e2c 2e43 6f64 654d 6972 726f  eason,.CodeMirro\n+0005b780: 722d 696e 666f 202e 696e 666f 2d64 6573  r-info .info-des\n+0005b790: 6372 6970 7469 6f6e 2c2e 436f 6465 4d69  cription,.CodeMi\n+0005b7a0: 7272 6f72 2d69 6e66 6f20 2e69 6e66 6f2d  rror-info .info-\n+0005b7b0: 6465 7072 6563 6174 696f 6e29 2069 6d67  deprecation) img\n+0005b7c0: 207b 0a20 2020 2062 6f72 6465 722d 7261   {.    border-ra\n+0005b7d0: 6469 7573 3a20 7661 7228 2d2d 626f 7264  dius: var(--bord\n+0005b7e0: 6572 2d72 6164 6975 732d 3429 3b0a 2020  er-radius-4);.  \n+0005b7f0: 2020 6d61 782d 6865 6967 6874 3a20 3132    max-height: 12\n+0005b800: 3070 783b 0a20 2020 206d 6178 2d77 6964  0px;.    max-wid\n+0005b810: 7468 3a20 3130 3025 3b0a 2020 7d0a 0a3a  th: 100%;.  }..:\n+0005b820: 6973 282e 6772 6170 6869 716c 2d6d 6172  is(.graphiql-mar\n+0005b830: 6b64 6f77 6e2d 6465 7363 7269 7074 696f  kdown-descriptio\n+0005b840: 6e2c 2e67 7261 7068 6971 6c2d 6d61 726b  n,.graphiql-mark\n+0005b850: 646f 776e 2d64 6570 7265 6361 7469 6f6e  down-deprecation\n+0005b860: 2c2e 436f 6465 4d69 7272 6f72 2d68 696e  ,.CodeMirror-hin\n+0005b870: 742d 696e 666f 726d 6174 696f 6e2d 6465  t-information-de\n+0005b880: 7363 7269 7074 696f 6e2c 2e43 6f64 654d  scription,.CodeM\n+0005b890: 6972 726f 722d 6869 6e74 2d69 6e66 6f72  irror-hint-infor\n+0005b8a0: 6d61 7469 6f6e 2d64 6570 7265 6361 7469  mation-deprecati\n+0005b8b0: 6f6e 2d72 6561 736f 6e2c 2e43 6f64 654d  on-reason,.CodeM\n+0005b8c0: 6972 726f 722d 696e 666f 202e 696e 666f  irror-info .info\n+0005b8d0: 2d64 6573 6372 6970 7469 6f6e 2c2e 436f  -description,.Co\n+0005b8e0: 6465 4d69 7272 6f72 2d69 6e66 6f20 2e69  deMirror-info .i\n+0005b8f0: 6e66 6f2d 6465 7072 6563 6174 696f 6e29  nfo-deprecation)\n+0005b900: 203e 203a 6669 7273 742d 6368 696c 6420   > :first-child \n+0005b910: 7b0a 2020 2020 6d61 7267 696e 2d74 6f70  {.    margin-top\n+0005b920: 3a20 303b 0a20 207d 0a0a 3a69 7328 2e67  : 0;.  }..:is(.g\n+0005b930: 7261 7068 6971 6c2d 6d61 726b 646f 776e  raphiql-markdown\n+0005b940: 2d64 6573 6372 6970 7469 6f6e 2c2e 6772  -description,.gr\n+0005b950: 6170 6869 716c 2d6d 6172 6b64 6f77 6e2d  aphiql-markdown-\n+0005b960: 6465 7072 6563 6174 696f 6e2c 2e43 6f64  deprecation,.Cod\n+0005b970: 654d 6972 726f 722d 6869 6e74 2d69 6e66  eMirror-hint-inf\n+0005b980: 6f72 6d61 7469 6f6e 2d64 6573 6372 6970  ormation-descrip\n+0005b990: 7469 6f6e 2c2e 436f 6465 4d69 7272 6f72  tion,.CodeMirror\n+0005b9a0: 2d68 696e 742d 696e 666f 726d 6174 696f  -hint-informatio\n+0005b9b0: 6e2d 6465 7072 6563 6174 696f 6e2d 7265  n-deprecation-re\n+0005b9c0: 6173 6f6e 2c2e 436f 6465 4d69 7272 6f72  ason,.CodeMirror\n+0005b9d0: 2d69 6e66 6f20 2e69 6e66 6f2d 6465 7363  -info .info-desc\n+0005b9e0: 7269 7074 696f 6e2c 2e43 6f64 654d 6972  ription,.CodeMir\n+0005b9f0: 726f 722d 696e 666f 202e 696e 666f 2d64  ror-info .info-d\n+0005ba00: 6570 7265 6361 7469 6f6e 2920 3e20 3a6c  eprecation) > :l\n+0005ba10: 6173 742d 6368 696c 6420 7b0a 2020 2020  ast-child {.    \n+0005ba20: 6d61 7267 696e 2d62 6f74 746f 6d3a 2030  margin-bottom: 0\n+0005ba30: 3b0a 2020 7d0a 0a3a 6973 282e 6772 6170  ;.  }..:is(.grap\n+0005ba40: 6869 716c 2d6d 6172 6b64 6f77 6e2d 6465  hiql-markdown-de\n+0005ba50: 7363 7269 7074 696f 6e2c 2e43 6f64 654d  scription,.CodeM\n+0005ba60: 6972 726f 722d 6869 6e74 2d69 6e66 6f72  irror-hint-infor\n+0005ba70: 6d61 7469 6f6e 2d64 6573 6372 6970 7469  mation-descripti\n+0005ba80: 6f6e 2c2e 436f 6465 4d69 7272 6f72 2d69  on,.CodeMirror-i\n+0005ba90: 6e66 6f20 2e69 6e66 6f2d 6465 7363 7269  nfo .info-descri\n+0005baa0: 7074 696f 6e29 2061 207b 0a20 2020 2063  ption) a {.    c\n+0005bab0: 6f6c 6f72 3a20 6873 6c28 7661 7228 2d2d  olor: hsl(var(--\n+0005bac0: 636f 6c6f 722d 7072 696d 6172 7929 293b  color-primary));\n+0005bad0: 0a20 2020 2074 6578 742d 6465 636f 7261  .    text-decora\n+0005bae0: 7469 6f6e 3a20 6e6f 6e65 0a20 207d 0a0a  tion: none.  }..\n+0005baf0: 3a69 7328 2e67 7261 7068 6971 6c2d 6d61  :is(.graphiql-ma\n+0005bb00: 726b 646f 776e 2d64 6573 6372 6970 7469  rkdown-descripti\n+0005bb10: 6f6e 2c2e 436f 6465 4d69 7272 6f72 2d68  on,.CodeMirror-h\n+0005bb20: 696e 742d 696e 666f 726d 6174 696f 6e2d  int-information-\n+0005bb30: 6465 7363 7269 7074 696f 6e2c 2e43 6f64  description,.Cod\n+0005bb40: 654d 6972 726f 722d 696e 666f 202e 696e  eMirror-info .in\n+0005bb50: 666f 2d64 6573 6372 6970 7469 6f6e 2920  fo-description) \n+0005bb60: 613a 686f 7665 7220 7b0a 2020 2020 2020  a:hover {.      \n+0005bb70: 7465 7874 2d64 6563 6f72 6174 696f 6e3a  text-decoration:\n+0005bb80: 2075 6e64 6572 6c69 6e65 3b0a 2020 2020   underline;.    \n+0005bb90: 7d0a 0a3a 6973 282e 6772 6170 6869 716c  }..:is(.graphiql\n+0005bba0: 2d6d 6172 6b64 6f77 6e2d 6465 7363 7269  -markdown-descri\n+0005bbb0: 7074 696f 6e2c 2e43 6f64 654d 6972 726f  ption,.CodeMirro\n+0005bbc0: 722d 6869 6e74 2d69 6e66 6f72 6d61 7469  r-hint-informati\n+0005bbd0: 6f6e 2d64 6573 6372 6970 7469 6f6e 2c2e  on-description,.\n+0005bbe0: 436f 6465 4d69 7272 6f72 2d69 6e66 6f20  CodeMirror-info \n+0005bbf0: 2e69 6e66 6f2d 6465 7363 7269 7074 696f  .info-descriptio\n+0005bc00: 6e29 2062 6c6f 636b 7175 6f74 6520 7b0a  n) blockquote {.\n+0005bc10: 2020 2020 626f 7264 6572 2d6c 6566 743a      border-left:\n+0005bc20: 2031 2e35 7078 2073 6f6c 6964 2068 736c   1.5px solid hsl\n+0005bc30: 6128 7661 7228 2d2d 636f 6c6f 722d 6e65  a(var(--color-ne\n+0005bc40: 7574 7261 6c29 2c20 7661 7228 2d2d 616c  utral), var(--al\n+0005bc50: 7068 612d 7465 7274 6961 7279 2929 3b0a  pha-tertiary));.\n+0005bc60: 2020 7d0a 0a3a 6973 282e 6772 6170 6869    }..:is(.graphi\n+0005bc70: 716c 2d6d 6172 6b64 6f77 6e2d 6465 7363  ql-markdown-desc\n+0005bc80: 7269 7074 696f 6e2c 2e43 6f64 654d 6972  ription,.CodeMir\n+0005bc90: 726f 722d 6869 6e74 2d69 6e66 6f72 6d61  ror-hint-informa\n+0005bca0: 7469 6f6e 2d64 6573 6372 6970 7469 6f6e  tion-description\n+0005bcb0: 2c2e 436f 6465 4d69 7272 6f72 2d69 6e66  ,.CodeMirror-inf\n+0005bcc0: 6f20 2e69 6e66 6f2d 6465 7363 7269 7074  o .info-descript\n+0005bcd0: 696f 6e29 2063 6f64 652c 0a20 203a 6973  ion) code,.  :is\n+0005bce0: 282e 6772 6170 6869 716c 2d6d 6172 6b64  (.graphiql-markd\n+0005bcf0: 6f77 6e2d 6465 7363 7269 7074 696f 6e2c  own-description,\n+0005bd00: 2e43 6f64 654d 6972 726f 722d 6869 6e74  .CodeMirror-hint\n+0005bd10: 2d69 6e66 6f72 6d61 7469 6f6e 2d64 6573  -information-des\n+0005bd20: 6372 6970 7469 6f6e 2c2e 436f 6465 4d69  cription,.CodeMi\n+0005bd30: 7272 6f72 2d69 6e66 6f20 2e69 6e66 6f2d  rror-info .info-\n+0005bd40: 6465 7363 7269 7074 696f 6e29 2070 7265  description) pre\n+0005bd50: 207b 0a20 2020 2062 6163 6b67 726f 756e   {.    backgroun\n+0005bd60: 642d 636f 6c6f 723a 2068 736c 6128 7661  d-color: hsla(va\n+0005bd70: 7228 2d2d 636f 6c6f 722d 6e65 7574 7261  r(--color-neutra\n+0005bd80: 6c29 2c20 7661 7228 2d2d 616c 7068 612d  l), var(--alpha-\n+0005bd90: 6261 636b 6772 6f75 6e64 2d6c 6967 6874  background-light\n+0005bda0: 2929 3b0a 2020 2020 636f 6c6f 723a 2068  ));.    color: h\n+0005bdb0: 736c 2876 6172 282d 2d63 6f6c 6f72 2d6e  sl(var(--color-n\n+0005bdc0: 6575 7472 616c 2929 3b0a 2020 7d0a 0a3a  eutral));.  }..:\n+0005bdd0: 6973 282e 6772 6170 6869 716c 2d6d 6172  is(.graphiql-mar\n+0005bde0: 6b64 6f77 6e2d 6465 7363 7269 7074 696f  kdown-descriptio\n+0005bdf0: 6e2c 2e43 6f64 654d 6972 726f 722d 6869  n,.CodeMirror-hi\n+0005be00: 6e74 2d69 6e66 6f72 6d61 7469 6f6e 2d64  nt-information-d\n+0005be10: 6573 6372 6970 7469 6f6e 2c2e 436f 6465  escription,.Code\n+0005be20: 4d69 7272 6f72 2d69 6e66 6f20 2e69 6e66  Mirror-info .inf\n+0005be30: 6f2d 6465 7363 7269 7074 696f 6e29 203e  o-description) >\n+0005be40: 202a 207b 0a20 2020 206d 6172 6769 6e3a   * {.    margin:\n+0005be50: 2076 6172 282d 2d70 782d 3132 2920 303b   var(--px-12) 0;\n+0005be60: 0a20 207d 0a0a 3a69 7328 2e67 7261 7068  .  }..:is(.graph\n+0005be70: 6971 6c2d 6d61 726b 646f 776e 2d64 6570  iql-markdown-dep\n+0005be80: 7265 6361 7469 6f6e 2c2e 436f 6465 4d69  recation,.CodeMi\n+0005be90: 7272 6f72 2d68 696e 742d 696e 666f 726d  rror-hint-inform\n+0005bea0: 6174 696f 6e2d 6465 7072 6563 6174 696f  ation-deprecatio\n+0005beb0: 6e2d 7265 6173 6f6e 2c2e 436f 6465 4d69  n-reason,.CodeMi\n+0005bec0: 7272 6f72 2d69 6e66 6f20 2e69 6e66 6f2d  rror-info .info-\n+0005bed0: 6465 7072 6563 6174 696f 6e29 2061 207b  deprecation) a {\n+0005bee0: 0a20 2020 2063 6f6c 6f72 3a20 6873 6c28  .    color: hsl(\n+0005bef0: 7661 7228 2d2d 636f 6c6f 722d 7761 726e  var(--color-warn\n+0005bf00: 696e 6729 293b 0a20 2020 2074 6578 742d  ing));.    text-\n+0005bf10: 6465 636f 7261 7469 6f6e 3a20 756e 6465  decoration: unde\n+0005bf20: 726c 696e 653b 0a20 207d 0a0a 3a69 7328  rline;.  }..:is(\n+0005bf30: 2e67 7261 7068 6971 6c2d 6d61 726b 646f  .graphiql-markdo\n+0005bf40: 776e 2d64 6570 7265 6361 7469 6f6e 2c2e  wn-deprecation,.\n+0005bf50: 436f 6465 4d69 7272 6f72 2d68 696e 742d  CodeMirror-hint-\n+0005bf60: 696e 666f 726d 6174 696f 6e2d 6465 7072  information-depr\n+0005bf70: 6563 6174 696f 6e2d 7265 6173 6f6e 2c2e  ecation-reason,.\n+0005bf80: 436f 6465 4d69 7272 6f72 2d69 6e66 6f20  CodeMirror-info \n+0005bf90: 2e69 6e66 6f2d 6465 7072 6563 6174 696f  .info-deprecatio\n+0005bfa0: 6e29 2062 6c6f 636b 7175 6f74 6520 7b0a  n) blockquote {.\n+0005bfb0: 2020 2020 626f 7264 6572 2d6c 6566 743a      border-left:\n+0005bfc0: 2031 2e35 7078 2073 6f6c 6964 2068 736c   1.5px solid hsl\n+0005bfd0: 2876 6172 282d 2d63 6f6c 6f72 2d77 6172  (var(--color-war\n+0005bfe0: 6e69 6e67 2929 3b0a 2020 7d0a 0a3a 6973  ning));.  }..:is\n+0005bff0: 282e 6772 6170 6869 716c 2d6d 6172 6b64  (.graphiql-markd\n+0005c000: 6f77 6e2d 6465 7072 6563 6174 696f 6e2c  own-deprecation,\n+0005c010: 2e43 6f64 654d 6972 726f 722d 6869 6e74  .CodeMirror-hint\n+0005c020: 2d69 6e66 6f72 6d61 7469 6f6e 2d64 6570  -information-dep\n+0005c030: 7265 6361 7469 6f6e 2d72 6561 736f 6e2c  recation-reason,\n+0005c040: 2e43 6f64 654d 6972 726f 722d 696e 666f  .CodeMirror-info\n+0005c050: 202e 696e 666f 2d64 6570 7265 6361 7469   .info-deprecati\n+0005c060: 6f6e 2920 636f 6465 2c0a 2020 3a69 7328  on) code,.  :is(\n+0005c070: 2e67 7261 7068 6971 6c2d 6d61 726b 646f  .graphiql-markdo\n+0005c080: 776e 2d64 6570 7265 6361 7469 6f6e 2c2e  wn-deprecation,.\n+0005c090: 436f 6465 4d69 7272 6f72 2d68 696e 742d  CodeMirror-hint-\n+0005c0a0: 696e 666f 726d 6174 696f 6e2d 6465 7072  information-depr\n+0005c0b0: 6563 6174 696f 6e2d 7265 6173 6f6e 2c2e  ecation-reason,.\n+0005c0c0: 436f 6465 4d69 7272 6f72 2d69 6e66 6f20  CodeMirror-info \n+0005c0d0: 2e69 6e66 6f2d 6465 7072 6563 6174 696f  .info-deprecatio\n+0005c0e0: 6e29 2070 7265 207b 0a20 2020 2062 6163  n) pre {.    bac\n+0005c0f0: 6b67 726f 756e 642d 636f 6c6f 723a 2068  kground-color: h\n+0005c100: 736c 6128 7661 7228 2d2d 636f 6c6f 722d  sla(var(--color-\n+0005c110: 7761 726e 696e 6729 2c20 7661 7228 2d2d  warning), var(--\n+0005c120: 616c 7068 612d 6261 636b 6772 6f75 6e64  alpha-background\n+0005c130: 2d68 6561 7679 2929 3b0a 2020 7d0a 0a3a  -heavy));.  }..:\n+0005c140: 6973 282e 6772 6170 6869 716c 2d6d 6172  is(.graphiql-mar\n+0005c150: 6b64 6f77 6e2d 6465 7072 6563 6174 696f  kdown-deprecatio\n+0005c160: 6e2c 2e43 6f64 654d 6972 726f 722d 6869  n,.CodeMirror-hi\n+0005c170: 6e74 2d69 6e66 6f72 6d61 7469 6f6e 2d64  nt-information-d\n+0005c180: 6570 7265 6361 7469 6f6e 2d72 6561 736f  eprecation-reaso\n+0005c190: 6e2c 2e43 6f64 654d 6972 726f 722d 696e  n,.CodeMirror-in\n+0005c1a0: 666f 202e 696e 666f 2d64 6570 7265 6361  fo .info-depreca\n+0005c1b0: 7469 6f6e 2920 3e20 2a20 7b0a 2020 2020  tion) > * {.    \n+0005c1c0: 6d61 7267 696e 3a20 7661 7228 2d2d 7078  margin: var(--px\n+0005c1d0: 2d38 2920 303b 0a20 207d 0a0a 2e67 7261  -8) 0;.  }...gra\n+0005c1e0: 7068 6971 6c2d 6d61 726b 646f 776e 2d70  phiql-markdown-p\n+0005c1f0: 7265 7669 6577 203e 203a 6e6f 7428 3a66  review > :not(:f\n+0005c200: 6972 7374 2d63 6869 6c64 2920 7b0a 2020  irst-child) {.  \n+0005c210: 6469 7370 6c61 793a 206e 6f6e 653b 0a7d  display: none;.}\n+0005c220: 0a0a 2f2a 2a0a 202a 2057 6520 7368 6f77  ../**. * We show\n+0005c230: 2064 6570 7265 6361 7469 6f6e 7320 696e   deprecations in\n+0005c240: 2074 6865 2066 6f6c 6c6f 7769 6e67 2070   the following p\n+0005c250: 6c61 6365 733a 0a20 2a20 2d20 496e 2074  laces:. * - In t\n+0005c260: 6865 2068 696e 7420 746f 6f6c 7469 7020  he hint tooltip \n+0005c270: 7768 656e 2074 7970 696e 6720 696e 2074  when typing in t\n+0005c280: 6865 2071 7565 7279 2065 6469 746f 722e  he query editor.\n+0005c290: 0a20 2a20 2d20 496e 2074 6865 2069 6e66  . * - In the inf\n+0005c2a0: 6f20 746f 6f6c 7469 7020 7768 656e 2068  o tooltip when h\n+0005c2b0: 6f76 6572 696e 6720 6f76 6572 2061 2066  overing over a f\n+0005c2c0: 6965 6c64 2069 6e20 7468 6520 7175 6572  ield in the quer\n+0005c2d0: 7920 6564 6974 6f72 2e0a 202a 2f0a 0a2e  y editor.. */...\n+0005c2e0: 436f 6465 4d69 7272 6f72 2d68 696e 742d  CodeMirror-hint-\n+0005c2f0: 696e 666f 726d 6174 696f 6e2d 6465 7072  information-depr\n+0005c300: 6563 6174 696f 6e2c 0a2e 436f 6465 4d69  ecation,..CodeMi\n+0005c310: 7272 6f72 2d69 6e66 6f20 2e69 6e66 6f2d  rror-info .info-\n+0005c320: 6465 7072 6563 6174 696f 6e20 7b0a 2020  deprecation {.  \n+0005c330: 6261 636b 6772 6f75 6e64 2d63 6f6c 6f72  background-color\n+0005c340: 3a20 6873 6c61 2876 6172 282d 2d63 6f6c  : hsla(var(--col\n+0005c350: 6f72 2d77 6172 6e69 6e67 292c 2076 6172  or-warning), var\n+0005c360: 282d 2d61 6c70 6861 2d62 6163 6b67 726f  (--alpha-backgro\n+0005c370: 756e 642d 6c69 6768 7429 293b 0a20 2062  und-light));.  b\n+0005c380: 6f72 6465 723a 2031 7078 2073 6f6c 6964  order: 1px solid\n+0005c390: 2068 736c 2876 6172 282d 2d63 6f6c 6f72   hsl(var(--color\n+0005c3a0: 2d77 6172 6e69 6e67 2929 3b0a 2020 626f  -warning));.  bo\n+0005c3b0: 7264 6572 2d72 6164 6975 733a 2076 6172  rder-radius: var\n+0005c3c0: 282d 2d62 6f72 6465 722d 7261 6469 7573  (--border-radius\n+0005c3d0: 2d34 293b 0a20 2063 6f6c 6f72 3a20 6873  -4);.  color: hs\n+0005c3e0: 6c28 7661 7228 2d2d 636f 6c6f 722d 7761  l(var(--color-wa\n+0005c3f0: 726e 696e 6729 293b 0a20 206d 6172 6769  rning));.  margi\n+0005c400: 6e2d 746f 703a 2076 6172 282d 2d70 782d  n-top: var(--px-\n+0005c410: 3132 293b 0a20 2070 6164 6469 6e67 3a20  12);.  padding: \n+0005c420: 7661 7228 2d2d 7078 2d36 2920 7661 7228  var(--px-6) var(\n+0005c430: 2d2d 7078 2d38 293b 0a7d 0a0a 2e43 6f64  --px-8);.}...Cod\n+0005c440: 654d 6972 726f 722d 6869 6e74 2d69 6e66  eMirror-hint-inf\n+0005c450: 6f72 6d61 7469 6f6e 2d64 6570 7265 6361  ormation-depreca\n+0005c460: 7469 6f6e 2d6c 6162 656c 2c0a 2e43 6f64  tion-label,..Cod\n+0005c470: 654d 6972 726f 722d 696e 666f 202e 696e  eMirror-info .in\n+0005c480: 666f 2d64 6570 7265 6361 7469 6f6e 2d6c  fo-deprecation-l\n+0005c490: 6162 656c 207b 0a20 2066 6f6e 742d 7369  abel {.  font-si\n+0005c4a0: 7a65 3a20 7661 7228 2d2d 666f 6e74 2d73  ze: var(--font-s\n+0005c4b0: 697a 652d 6869 6e74 293b 0a20 2066 6f6e  ize-hint);.  fon\n+0005c4c0: 742d 7765 6967 6874 3a20 7661 7228 2d2d  t-weight: var(--\n+0005c4d0: 666f 6e74 2d77 6569 6768 742d 6d65 6469  font-weight-medi\n+0005c4e0: 756d 293b 0a7d 0a0a 2e43 6f64 654d 6972  um);.}...CodeMir\n+0005c4f0: 726f 722d 6869 6e74 2d69 6e66 6f72 6d61  ror-hint-informa\n+0005c500: 7469 6f6e 2d64 6570 7265 6361 7469 6f6e  tion-deprecation\n+0005c510: 2d72 6561 736f 6e2c 0a2e 436f 6465 4d69  -reason,..CodeMi\n+0005c520: 7272 6f72 2d69 6e66 6f20 2e69 6e66 6f2d  rror-info .info-\n+0005c530: 6465 7072 6563 6174 696f 6e2d 7265 6173  deprecation-reas\n+0005c540: 6f6e 207b 0a20 206d 6172 6769 6e2d 746f  on {.  margin-to\n+0005c550: 703a 2076 6172 282d 2d70 782d 3629 3b0a  p: var(--px-6);.\n+0005c560: 7d0a 2e67 7261 7068 6971 6c2d 7370 696e  }..graphiql-spin\n+0005c570: 6e65 7220 7b0a 2020 6865 6967 6874 3a20  ner {.  height: \n+0005c580: 3536 7078 3b0a 2020 6d61 7267 696e 3a20  56px;.  margin: \n+0005c590: 6175 746f 3b0a 2020 6d61 7267 696e 2d74  auto;.  margin-t\n+0005c5a0: 6f70 3a20 7661 7228 2d2d 7078 2d31 3629  op: var(--px-16)\n+0005c5b0: 3b0a 2020 7769 6474 683a 2035 3670 780a  ;.  width: 56px.\n+0005c5c0: 7d0a 0a2e 6772 6170 6869 716c 2d73 7069  }...graphiql-spi\n+0005c5d0: 6e6e 6572 3a3a 6166 7465 7220 7b0a 2020  nner::after {.  \n+0005c5e0: 2020 616e 696d 6174 696f 6e3a 2072 6f74    animation: rot\n+0005c5f0: 6174 696f 6e20 302e 3873 206c 696e 6561  ation 0.8s linea\n+0005c600: 7220 3073 2069 6e66 696e 6974 653b 0a20  r 0s infinite;. \n+0005c610: 2020 2062 6f72 6465 723a 2034 7078 2073     border: 4px s\n+0005c620: 6f6c 6964 2074 7261 6e73 7061 7265 6e74  olid transparent\n+0005c630: 3b0a 2020 2020 626f 7264 6572 2d72 6164  ;.    border-rad\n+0005c640: 6975 733a 2031 3030 253b 0a20 2020 2062  ius: 100%;.    b\n+0005c650: 6f72 6465 722d 746f 703a 2034 7078 2073  order-top: 4px s\n+0005c660: 6f6c 6964 2068 736c 6128 7661 7228 2d2d  olid hsla(var(--\n+0005c670: 636f 6c6f 722d 6e65 7574 7261 6c29 2c20  color-neutral), \n+0005c680: 7661 7228 2d2d 616c 7068 612d 7465 7274  var(--alpha-tert\n+0005c690: 6961 7279 2929 3b0a 2020 2020 636f 6e74  iary));.    cont\n+0005c6a0: 656e 743a 2027 273b 0a20 2020 2064 6973  ent: '';.    dis\n+0005c6b0: 706c 6179 3a20 696e 6c69 6e65 2d62 6c6f  play: inline-blo\n+0005c6c0: 636b 3b0a 2020 2020 6865 6967 6874 3a20  ck;.    height: \n+0005c6d0: 3436 7078 3b0a 2020 2020 7665 7274 6963  46px;.    vertic\n+0005c6e0: 616c 2d61 6c69 676e 3a20 6d69 6464 6c65  al-align: middle\n+0005c6f0: 3b0a 2020 2020 7769 6474 683a 2034 3670  ;.    width: 46p\n+0005c700: 783b 0a20 207d 0a0a 406b 6579 6672 616d  x;.  }..@keyfram\n+0005c710: 6573 2072 6f74 6174 696f 6e20 7b0a 2020  es rotation {.  \n+0005c720: 6672 6f6d 207b 0a20 2020 2074 7261 6e73  from {.    trans\n+0005c730: 666f 726d 3a20 726f 7461 7465 2830 6465  form: rotate(0de\n+0005c740: 6729 3b0a 2020 7d0a 2020 746f 207b 0a20  g);.  }.  to {. \n+0005c750: 2020 2074 7261 6e73 666f 726d 3a20 726f     transform: ro\n+0005c760: 7461 7465 2833 3630 6465 6729 3b0a 2020  tate(360deg);.  \n+0005c770: 7d0a 7d0a 2e67 7261 7068 6971 6c2d 746f  }.}..graphiql-to\n+0005c780: 6f6c 7469 7020 7b0a 2020 6261 636b 6772  oltip {.  backgr\n+0005c790: 6f75 6e64 3a20 6873 6c28 7661 7228 2d2d  ound: hsl(var(--\n+0005c7a0: 636f 6c6f 722d 6261 7365 2929 3b0a 2020  color-base));.  \n+0005c7b0: 626f 7264 6572 3a20 7661 7228 2d2d 706f  border: var(--po\n+0005c7c0: 706f 7665 722d 626f 7264 6572 293b 0a20  pover-border);. \n+0005c7d0: 2062 6f72 6465 722d 7261 6469 7573 3a20   border-radius: \n+0005c7e0: 7661 7228 2d2d 626f 7264 6572 2d72 6164  var(--border-rad\n+0005c7f0: 6975 732d 3429 3b0a 2020 626f 782d 7368  ius-4);.  box-sh\n+0005c800: 6164 6f77 3a20 7661 7228 2d2d 706f 706f  adow: var(--popo\n+0005c810: 7665 722d 626f 782d 7368 6164 6f77 293b  ver-box-shadow);\n+0005c820: 0a20 2063 6f6c 6f72 3a20 6873 6c28 7661  .  color: hsl(va\n+0005c830: 7228 2d2d 636f 6c6f 722d 6e65 7574 7261  r(--color-neutra\n+0005c840: 6c29 293b 0a20 2066 6f6e 742d 7369 7a65  l));.  font-size\n+0005c850: 3a20 696e 6865 7269 743b 0a20 2070 6164  : inherit;.  pad\n+0005c860: 6469 6e67 3a20 7661 7228 2d2d 7078 2d34  ding: var(--px-4\n+0005c870: 2920 7661 7228 2d2d 7078 2d36 293b 0a20  ) var(--px-6);. \n+0005c880: 2066 6f6e 742d 6661 6d69 6c79 3a20 7661   font-family: va\n+0005c890: 7228 2d2d 666f 6e74 2d66 616d 696c 7929  r(--font-family)\n+0005c8a0: 3b0a 7d0a 2e67 7261 7068 6971 6c2d 7461  ;.}..graphiql-ta\n+0005c8b0: 6273 207b 0a20 2064 6973 706c 6179 3a20  bs {.  display: \n+0005c8c0: 666c 6578 3b0a 2020 616c 6967 6e2d 6974  flex;.  align-it\n+0005c8d0: 656d 733a 2063 656e 7465 723b 0a20 206f  ems: center;.  o\n+0005c8e0: 7665 7266 6c6f 772d 783a 2061 7574 6f3b  verflow-x: auto;\n+0005c8f0: 0a20 2070 6164 6469 6e67 3a20 7661 7228  .  padding: var(\n+0005c900: 2d2d 7078 2d31 3229 0a7d 0a0a 2e67 7261  --px-12).}...gra\n+0005c910: 7068 6971 6c2d 7461 6273 203e 203a 6e6f  phiql-tabs > :no\n+0005c920: 7428 3a66 6972 7374 2d63 6869 6c64 2920  t(:first-child) \n+0005c930: 7b0a 2020 2020 6d61 7267 696e 2d6c 6566  {.    margin-lef\n+0005c940: 743a 2076 6172 282d 2d70 782d 3132 293b  t: var(--px-12);\n+0005c950: 0a20 207d 0a0a 2e67 7261 7068 6971 6c2d  .  }...graphiql-\n+0005c960: 7461 6220 7b0a 2020 616c 6967 6e2d 6974  tab {.  align-it\n+0005c970: 656d 733a 2073 7472 6574 6368 3b0a 2020  ems: stretch;.  \n+0005c980: 626f 7264 6572 2d72 6164 6975 733a 2076  border-radius: v\n+0005c990: 6172 282d 2d62 6f72 6465 722d 7261 6469  ar(--border-radi\n+0005c9a0: 7573 2d38 293b 0a20 2063 6f6c 6f72 3a20  us-8);.  color: \n+0005c9b0: 6873 6c61 2876 6172 282d 2d63 6f6c 6f72  hsla(var(--color\n+0005c9c0: 2d6e 6575 7472 616c 292c 2076 6172 282d  -neutral), var(-\n+0005c9d0: 2d61 6c70 6861 2d73 6563 6f6e 6461 7279  -alpha-secondary\n+0005c9e0: 2929 3b0a 2020 6469 7370 6c61 793a 2066  ));.  display: f\n+0005c9f0: 6c65 780a 7d0a 0a2e 6772 6170 6869 716c  lex.}...graphiql\n+0005ca00: 2d74 6162 203e 2062 7574 746f 6e2e 6772  -tab > button.gr\n+0005ca10: 6170 6869 716c 2d74 6162 2d63 6c6f 7365  aphiql-tab-close\n+0005ca20: 207b 0a20 2020 2076 6973 6962 696c 6974   {.    visibilit\n+0005ca30: 793a 2068 6964 6465 6e3b 0a20 207d 0a0a  y: hidden;.  }..\n+0005ca40: 2e67 7261 7068 6971 6c2d 7461 622e 6772  .graphiql-tab.gr\n+0005ca50: 6170 6869 716c 2d74 6162 2d61 6374 6976  aphiql-tab-activ\n+0005ca60: 6520 3e20 6275 7474 6f6e 2e67 7261 7068  e > button.graph\n+0005ca70: 6971 6c2d 7461 622d 636c 6f73 652c 0a20  iql-tab-close,. \n+0005ca80: 202e 6772 6170 6869 716c 2d74 6162 3a68   .graphiql-tab:h\n+0005ca90: 6f76 6572 203e 2062 7574 746f 6e2e 6772  over > button.gr\n+0005caa0: 6170 6869 716c 2d74 6162 2d63 6c6f 7365  aphiql-tab-close\n+0005cab0: 2c0a 2020 2e67 7261 7068 6971 6c2d 7461  ,.  .graphiql-ta\n+0005cac0: 623a 666f 6375 732d 7769 7468 696e 203e  b:focus-within >\n+0005cad0: 2062 7574 746f 6e2e 6772 6170 6869 716c   button.graphiql\n+0005cae0: 2d74 6162 2d63 6c6f 7365 207b 0a20 2020  -tab-close {.   \n+0005caf0: 2076 6973 6962 696c 6974 793a 2075 6e73   visibility: uns\n+0005cb00: 6574 3b0a 2020 7d0a 0a2e 6772 6170 6869  et;.  }...graphi\n+0005cb10: 716c 2d74 6162 2e67 7261 7068 6971 6c2d  ql-tab.graphiql-\n+0005cb20: 7461 622d 6163 7469 7665 207b 0a20 2020  tab-active {.   \n+0005cb30: 2062 6163 6b67 726f 756e 642d 636f 6c6f   background-colo\n+0005cb40: 723a 2068 736c 6128 7661 7228 2d2d 636f  r: hsla(var(--co\n+0005cb50: 6c6f 722d 6e65 7574 7261 6c29 2c20 7661  lor-neutral), va\n+0005cb60: 7228 2d2d 616c 7068 612d 6261 636b 6772  r(--alpha-backgr\n+0005cb70: 6f75 6e64 2d68 6561 7679 2929 3b0a 2020  ound-heavy));.  \n+0005cb80: 2020 636f 6c6f 723a 2068 736c 6128 7661    color: hsla(va\n+0005cb90: 7228 2d2d 636f 6c6f 722d 6e65 7574 7261  r(--color-neutra\n+0005cba0: 6c29 2c20 3129 3b0a 2020 7d0a 0a62 7574  l), 1);.  }..but\n+0005cbb0: 746f 6e2e 6772 6170 6869 716c 2d74 6162  ton.graphiql-tab\n+0005cbc0: 2d62 7574 746f 6e20 7b0a 2020 7061 6464  -button {.  padd\n+0005cbd0: 696e 673a 2076 6172 282d 2d70 782d 3429  ing: var(--px-4)\n+0005cbe0: 2030 2076 6172 282d 2d70 782d 3429 2076   0 var(--px-4) v\n+0005cbf0: 6172 282d 2d70 782d 3829 3b0a 7d0a 0a62  ar(--px-8);.}..b\n+0005cc00: 7574 746f 6e2e 6772 6170 6869 716c 2d74  utton.graphiql-t\n+0005cc10: 6162 2d63 6c6f 7365 207b 0a20 2061 6c69  ab-close {.  ali\n+0005cc20: 676e 2d69 7465 6d73 3a20 6365 6e74 6572  gn-items: center\n+0005cc30: 3b0a 2020 6469 7370 6c61 793a 2066 6c65  ;.  display: fle\n+0005cc40: 783b 0a20 2070 6164 6469 6e67 3a20 7661  x;.  padding: va\n+0005cc50: 7228 2d2d 7078 2d34 2920 7661 7228 2d2d  r(--px-4) var(--\n+0005cc60: 7078 2d38 290a 7d0a 0a62 7574 746f 6e2e  px-8).}..button.\n+0005cc70: 6772 6170 6869 716c 2d74 6162 2d63 6c6f  graphiql-tab-clo\n+0005cc80: 7365 203e 2073 7667 207b 0a20 2020 2068  se > svg {.    h\n+0005cc90: 6569 6768 743a 2076 6172 282d 2d70 782d  eight: var(--px-\n+0005cca0: 3829 3b0a 2020 2020 7769 6474 683a 2076  8);.    width: v\n+0005ccb0: 6172 282d 2d70 782d 3829 3b0a 2020 7d0a  ar(--px-8);.  }.\n+0005ccc0: 2e67 7261 7068 6971 6c2d 6869 7374 6f72  .graphiql-histor\n+0005ccd0: 792d 6865 6164 6572 207b 0a20 2066 6f6e  y-header {.  fon\n+0005cce0: 742d 7369 7a65 3a20 7661 7228 2d2d 666f  t-size: var(--fo\n+0005ccf0: 6e74 2d73 697a 652d 6832 293b 0a20 2066  nt-size-h2);.  f\n+0005cd00: 6f6e 742d 7765 6967 6874 3a20 7661 7228  ont-weight: var(\n+0005cd10: 2d2d 666f 6e74 2d77 6569 6768 742d 6d65  --font-weight-me\n+0005cd20: 6469 756d 293b 0a20 2064 6973 706c 6179  dium);.  display\n+0005cd30: 3a20 666c 6578 3b0a 2020 6a75 7374 6966  : flex;.  justif\n+0005cd40: 792d 636f 6e74 656e 743a 2073 7061 6365  y-content: space\n+0005cd50: 2d62 6574 7765 656e 3b0a 2020 616c 6967  -between;.  alig\n+0005cd60: 6e2d 6974 656d 733a 2063 656e 7465 723b  n-items: center;\n+0005cd70: 0a7d 0a0a 2e67 7261 7068 6971 6c2d 6869  .}...graphiql-hi\n+0005cd80: 7374 6f72 792d 6865 6164 6572 2062 7574  story-header but\n+0005cd90: 746f 6e20 7b0a 2020 666f 6e74 2d73 697a  ton {.  font-siz\n+0005cda0: 653a 2076 6172 282d 2d66 6f6e 742d 7369  e: var(--font-si\n+0005cdb0: 7a65 2d69 6e6c 696e 652d 636f 6465 293b  ze-inline-code);\n+0005cdc0: 0a20 2070 6164 6469 6e67 3a20 7661 7228  .  padding: var(\n+0005cdd0: 2d2d 7078 2d36 2920 7661 7228 2d2d 7078  --px-6) var(--px\n+0005cde0: 2d31 3029 3b0a 7d0a 0a2e 6772 6170 6869  -10);.}...graphi\n+0005cdf0: 716c 2d68 6973 746f 7279 2d69 7465 6d73  ql-history-items\n+0005ce00: 207b 0a20 206d 6172 6769 6e3a 2076 6172   {.  margin: var\n+0005ce10: 282d 2d70 782d 3136 2920 3020 303b 0a20  (--px-16) 0 0;. \n+0005ce20: 206c 6973 742d 7374 796c 653a 206e 6f6e   list-style: non\n+0005ce30: 653b 0a20 2070 6164 6469 6e67 3a20 303b  e;.  padding: 0;\n+0005ce40: 0a7d 0a0a 2e67 7261 7068 6971 6c2d 6869  .}...graphiql-hi\n+0005ce50: 7374 6f72 792d 6974 656d 207b 0a20 2062  story-item {.  b\n+0005ce60: 6f72 6465 722d 7261 6469 7573 3a20 7661  order-radius: va\n+0005ce70: 7228 2d2d 626f 7264 6572 2d72 6164 6975  r(--border-radiu\n+0005ce80: 732d 3429 3b0a 2020 636f 6c6f 723a 2068  s-4);.  color: h\n+0005ce90: 736c 6128 7661 7228 2d2d 636f 6c6f 722d  sla(var(--color-\n+0005cea0: 6e65 7574 7261 6c29 2c20 7661 7228 2d2d  neutral), var(--\n+0005ceb0: 616c 7068 612d 7365 636f 6e64 6172 7929  alpha-secondary)\n+0005cec0: 293b 0a20 2064 6973 706c 6179 3a20 666c  );.  display: fl\n+0005ced0: 6578 3b0a 2020 666f 6e74 2d73 697a 653a  ex;.  font-size:\n+0005cee0: 2076 6172 282d 2d66 6f6e 742d 7369 7a65   var(--font-size\n+0005cef0: 2d69 6e6c 696e 652d 636f 6465 293b 0a20  -inline-code);. \n+0005cf00: 2066 6f6e 742d 6661 6d69 6c79 3a20 7661   font-family: va\n+0005cf10: 7228 2d2d 666f 6e74 2d66 616d 696c 792d  r(--font-family-\n+0005cf20: 6d6f 6e6f 293b 0a20 2068 6569 6768 743a  mono);.  height:\n+0005cf30: 2033 3470 780a 7d0a 0a2e 6772 6170 6869   34px.}...graphi\n+0005cf40: 716c 2d68 6973 746f 7279 2d69 7465 6d3a  ql-history-item:\n+0005cf50: 686f 7665 7220 7b0a 2020 2020 636f 6c6f  hover {.    colo\n+0005cf60: 723a 2068 736c 2876 6172 282d 2d63 6f6c  r: hsl(var(--col\n+0005cf70: 6f72 2d6e 6575 7472 616c 2929 3b0a 2020  or-neutral));.  \n+0005cf80: 2020 6261 636b 6772 6f75 6e64 2d63 6f6c    background-col\n+0005cf90: 6f72 3a20 6873 6c61 2876 6172 282d 2d63  or: hsla(var(--c\n+0005cfa0: 6f6c 6f72 2d6e 6575 7472 616c 292c 2076  olor-neutral), v\n+0005cfb0: 6172 282d 2d61 6c70 6861 2d62 6163 6b67  ar(--alpha-backg\n+0005cfc0: 726f 756e 642d 6c69 6768 7429 293b 0a20  round-light));. \n+0005cfd0: 207d 0a0a 2e67 7261 7068 6971 6c2d 6869   }...graphiql-hi\n+0005cfe0: 7374 6f72 792d 6974 656d 3a6e 6f74 283a  story-item:not(:\n+0005cff0: 6669 7273 742d 6368 696c 6429 207b 0a20  first-child) {. \n+0005d000: 2020 206d 6172 6769 6e2d 746f 703a 2076     margin-top: v\n+0005d010: 6172 282d 2d70 782d 3429 3b0a 2020 7d0a  ar(--px-4);.  }.\n+0005d020: 0a2e 6772 6170 6869 716c 2d68 6973 746f  ..graphiql-histo\n+0005d030: 7279 2d69 7465 6d2e 6564 6974 6162 6c65  ry-item.editable\n+0005d040: 207b 0a20 2020 2062 6163 6b67 726f 756e   {.    backgroun\n+0005d050: 642d 636f 6c6f 723a 2068 736c 6128 0a20  d-color: hsla(. \n+0005d060: 2020 2020 2076 6172 282d 2d63 6f6c 6f72       var(--color\n+0005d070: 2d70 7269 6d61 7279 292c 0a20 2020 2020  -primary),.     \n+0005d080: 2076 6172 282d 2d61 6c70 6861 2d62 6163   var(--alpha-bac\n+0005d090: 6b67 726f 756e 642d 6d65 6469 756d 290a  kground-medium).\n+0005d0a0: 2020 2020 290a 2020 7d0a 0a2e 6772 6170      ).  }...grap\n+0005d0b0: 6869 716c 2d68 6973 746f 7279 2d69 7465  hiql-history-ite\n+0005d0c0: 6d2e 6564 6974 6162 6c65 203e 2069 6e70  m.editable > inp\n+0005d0d0: 7574 207b 0a20 2020 2020 2062 6163 6b67  ut {.      backg\n+0005d0e0: 726f 756e 643a 2074 7261 6e73 7061 7265  round: transpare\n+0005d0f0: 6e74 3b0a 2020 2020 2020 626f 7264 6572  nt;.      border\n+0005d100: 3a20 6e6f 6e65 3b0a 2020 2020 2020 666c  : none;.      fl\n+0005d110: 6578 3a20 313b 0a20 2020 2020 206d 6172  ex: 1;.      mar\n+0005d120: 6769 6e3a 2030 3b0a 2020 2020 2020 6f75  gin: 0;.      ou\n+0005d130: 746c 696e 653a 206e 6f6e 653b 0a20 2020  tline: none;.   \n+0005d140: 2020 2070 6164 6469 6e67 3a20 3020 7661     padding: 0 va\n+0005d150: 7228 2d2d 7078 2d31 3029 3b0a 2020 2020  r(--px-10);.    \n+0005d160: 2020 7769 6474 683a 2031 3030 250a 2020    width: 100%.  \n+0005d170: 2020 7d0a 0a2e 6772 6170 6869 716c 2d68    }...graphiql-h\n+0005d180: 6973 746f 7279 2d69 7465 6d2e 6564 6974  istory-item.edit\n+0005d190: 6162 6c65 203e 2069 6e70 7574 3a3a 706c  able > input::pl\n+0005d1a0: 6163 6568 6f6c 6465 7220 7b0a 2020 2020  aceholder {.    \n+0005d1b0: 2020 2020 636f 6c6f 723a 2068 736c 6128      color: hsla(\n+0005d1c0: 7661 7228 2d2d 636f 6c6f 722d 6e65 7574  var(--color-neut\n+0005d1d0: 7261 6c29 2c20 7661 7228 2d2d 616c 7068  ral), var(--alph\n+0005d1e0: 612d 7365 636f 6e64 6172 7929 293b 0a20  a-secondary));. \n+0005d1f0: 2020 2020 207d 0a0a 2e67 7261 7068 6971       }...graphiq\n+0005d200: 6c2d 6869 7374 6f72 792d 6974 656d 2e65  l-history-item.e\n+0005d210: 6469 7461 626c 6520 3e20 6275 7474 6f6e  ditable > button\n+0005d220: 207b 0a20 2020 2020 2063 6f6c 6f72 3a20   {.      color: \n+0005d230: 6873 6c28 7661 7228 2d2d 636f 6c6f 722d  hsl(var(--color-\n+0005d240: 7072 696d 6172 7929 293b 0a20 2020 2020  primary));.     \n+0005d250: 2070 6164 6469 6e67 3a20 3020 7661 7228   padding: 0 var(\n+0005d260: 2d2d 7078 2d31 3029 0a20 2020 207d 0a0a  --px-10).    }..\n+0005d270: 2e67 7261 7068 6971 6c2d 6869 7374 6f72  .graphiql-histor\n+0005d280: 792d 6974 656d 2e65 6469 7461 626c 6520  y-item.editable \n+0005d290: 3e20 6275 7474 6f6e 3a61 6374 6976 6520  > button:active \n+0005d2a0: 7b0a 2020 2020 2020 2020 6261 636b 6772  {.        backgr\n+0005d2b0: 6f75 6e64 2d63 6f6c 6f72 3a20 6873 6c61  ound-color: hsla\n+0005d2c0: 280a 2020 2020 2020 2020 2020 7661 7228  (.          var(\n+0005d2d0: 2d2d 636f 6c6f 722d 7072 696d 6172 7929  --color-primary)\n+0005d2e0: 2c0a 2020 2020 2020 2020 2020 7661 7228  ,.          var(\n+0005d2f0: 2d2d 616c 7068 612d 6261 636b 6772 6f75  --alpha-backgrou\n+0005d300: 6e64 2d68 6561 7679 290a 2020 2020 2020  nd-heavy).      \n+0005d310: 2020 293b 0a20 2020 2020 207d 0a0a 2e67    );.      }...g\n+0005d320: 7261 7068 6971 6c2d 6869 7374 6f72 792d  raphiql-history-\n+0005d330: 6974 656d 2e65 6469 7461 626c 6520 3e20  item.editable > \n+0005d340: 6275 7474 6f6e 3a66 6f63 7573 207b 0a20  button:focus {. \n+0005d350: 2020 2020 2020 206f 7574 6c69 6e65 3a20         outline: \n+0005d360: 6873 6c28 7661 7228 2d2d 636f 6c6f 722d  hsl(var(--color-\n+0005d370: 7072 696d 6172 7929 2920 6175 746f 2031  primary)) auto 1\n+0005d380: 7078 3b0a 2020 2020 2020 7d0a 0a2e 6772  px;.      }...gr\n+0005d390: 6170 6869 716c 2d68 6973 746f 7279 2d69  aphiql-history-i\n+0005d3a0: 7465 6d2e 6564 6974 6162 6c65 203e 2062  tem.editable > b\n+0005d3b0: 7574 746f 6e20 3e20 7376 6720 7b0a 2020  utton > svg {.  \n+0005d3c0: 2020 2020 2020 6469 7370 6c61 793a 2062        display: b\n+0005d3d0: 6c6f 636b 3b0a 2020 2020 2020 7d0a 0a62  lock;.      }..b\n+0005d3e0: 7574 746f 6e2e 6772 6170 6869 716c 2d68  utton.graphiql-h\n+0005d3f0: 6973 746f 7279 2d69 7465 6d2d 6c61 6265  istory-item-labe\n+0005d400: 6c20 7b0a 2020 666c 6578 3a20 313b 0a20  l {.  flex: 1;. \n+0005d410: 2070 6164 6469 6e67 3a20 7661 7228 2d2d   padding: var(--\n+0005d420: 7078 2d38 2920 7661 7228 2d2d 7078 2d31  px-8) var(--px-1\n+0005d430: 3029 3b0a 2020 6f76 6572 666c 6f77 3a20  0);.  overflow: \n+0005d440: 6869 6464 656e 3b0a 2020 7465 7874 2d6f  hidden;.  text-o\n+0005d450: 7665 7266 6c6f 773a 2065 6c6c 6970 7369  verflow: ellipsi\n+0005d460: 733b 0a20 2077 6869 7465 2d73 7061 6365  s;.  white-space\n+0005d470: 3a20 6e6f 7772 6170 3b0a 7d0a 0a62 7574  : nowrap;.}..but\n+0005d480: 746f 6e2e 6772 6170 6869 716c 2d68 6973  ton.graphiql-his\n+0005d490: 746f 7279 2d69 7465 6d2d 6163 7469 6f6e  tory-item-action\n+0005d4a0: 207b 0a20 2061 6c69 676e 2d69 7465 6d73   {.  align-items\n+0005d4b0: 3a20 6365 6e74 6572 3b0a 2020 636f 6c6f  : center;.  colo\n+0005d4c0: 723a 2068 736c 6128 7661 7228 2d2d 636f  r: hsla(var(--co\n+0005d4d0: 6c6f 722d 6e65 7574 7261 6c29 2c20 7661  lor-neutral), va\n+0005d4e0: 7228 2d2d 616c 7068 612d 7365 636f 6e64  r(--alpha-second\n+0005d4f0: 6172 7929 293b 0a20 2064 6973 706c 6179  ary));.  display\n+0005d500: 3a20 666c 6578 3b0a 2020 7061 6464 696e  : flex;.  paddin\n+0005d510: 673a 2076 6172 282d 2d70 782d 3829 2076  g: var(--px-8) v\n+0005d520: 6172 282d 2d70 782d 3629 0a7d 0a0a 6275  ar(--px-6).}..bu\n+0005d530: 7474 6f6e 2e67 7261 7068 6971 6c2d 6869  tton.graphiql-hi\n+0005d540: 7374 6f72 792d 6974 656d 2d61 6374 696f  story-item-actio\n+0005d550: 6e3a 686f 7665 7220 7b0a 2020 2020 636f  n:hover {.    co\n+0005d560: 6c6f 723a 2068 736c 2876 6172 282d 2d63  lor: hsl(var(--c\n+0005d570: 6f6c 6f72 2d6e 6575 7472 616c 2929 3b0a  olor-neutral));.\n+0005d580: 2020 7d0a 0a62 7574 746f 6e2e 6772 6170    }..button.grap\n+0005d590: 6869 716c 2d68 6973 746f 7279 2d69 7465  hiql-history-ite\n+0005d5a0: 6d2d 6163 7469 6f6e 203e 2073 7667 207b  m-action > svg {\n+0005d5b0: 0a20 2020 2068 6569 6768 743a 2031 3470  .    height: 14p\n+0005d5c0: 783b 0a20 2020 2077 6964 7468 3a20 3134  x;.    width: 14\n+0005d5d0: 7078 3b0a 2020 7d0a 0a2e 6772 6170 6869  px;.  }...graphi\n+0005d5e0: 716c 2d68 6973 746f 7279 2d69 7465 6d2d  ql-history-item-\n+0005d5f0: 7370 6163 6572 207b 0a20 2068 6569 6768  spacer {.  heigh\n+0005d600: 743a 2076 6172 282d 2d70 782d 3136 293b  t: var(--px-16);\n+0005d610: 0a7d 0a2e 6772 6170 6869 716c 2d64 6f63  .}..graphiql-doc\n+0005d620: 2d65 7870 6c6f 7265 722d 6465 6661 756c  -explorer-defaul\n+0005d630: 742d 7661 6c75 6520 7b0a 2020 636f 6c6f  t-value {.  colo\n+0005d640: 723a 2068 736c 2876 6172 282d 2d63 6f6c  r: hsl(var(--col\n+0005d650: 6f72 2d73 7563 6365 7373 2929 3b0a 7d0a  or-success));.}.\n+0005d660: 612e 6772 6170 6869 716c 2d64 6f63 2d65  a.graphiql-doc-e\n+0005d670: 7870 6c6f 7265 722d 7479 7065 2d6e 616d  xplorer-type-nam\n+0005d680: 6520 7b0a 2020 636f 6c6f 723a 2068 736c  e {.  color: hsl\n+0005d690: 2876 6172 282d 2d63 6f6c 6f72 2d77 6172  (var(--color-war\n+0005d6a0: 6e69 6e67 2929 3b0a 2020 7465 7874 2d64  ning));.  text-d\n+0005d6b0: 6563 6f72 6174 696f 6e3a 206e 6f6e 650a  ecoration: none.\n+0005d6c0: 7d0a 612e 6772 6170 6869 716c 2d64 6f63  }.a.graphiql-doc\n+0005d6d0: 2d65 7870 6c6f 7265 722d 7479 7065 2d6e  -explorer-type-n\n+0005d6e0: 616d 653a 686f 7665 7220 7b0a 2020 2020  ame:hover {.    \n+0005d6f0: 7465 7874 2d64 6563 6f72 6174 696f 6e3a  text-decoration:\n+0005d700: 2075 6e64 6572 6c69 6e65 3b0a 2020 7d0a   underline;.  }.\n+0005d710: 612e 6772 6170 6869 716c 2d64 6f63 2d65  a.graphiql-doc-e\n+0005d720: 7870 6c6f 7265 722d 7479 7065 2d6e 616d  xplorer-type-nam\n+0005d730: 653a 666f 6375 7320 7b0a 2020 2020 6f75  e:focus {.    ou\n+0005d740: 746c 696e 653a 2068 736c 2876 6172 282d  tline: hsl(var(-\n+0005d750: 2d63 6f6c 6f72 2d77 6172 6e69 6e67 2929  -color-warning))\n+0005d760: 2061 7574 6f20 3170 783b 0a20 207d 0a0a   auto 1px;.  }..\n+0005d770: 2020 2e67 7261 7068 6971 6c2d 646f 632d    .graphiql-doc-\n+0005d780: 6578 706c 6f72 6572 2d61 7267 756d 656e  explorer-argumen\n+0005d790: 7420 3e20 2a20 2b20 2a20 7b0a 2020 2020  t > * + * {.    \n+0005d7a0: 6d61 7267 696e 2d74 6f70 3a20 7661 7228  margin-top: var(\n+0005d7b0: 2d2d 7078 2d31 3229 3b0a 2020 7d0a 0a2e  --px-12);.  }...\n+0005d7c0: 6772 6170 6869 716c 2d64 6f63 2d65 7870  graphiql-doc-exp\n+0005d7d0: 6c6f 7265 722d 6172 6775 6d65 6e74 2d6e  lorer-argument-n\n+0005d7e0: 616d 6520 7b0a 2020 636f 6c6f 723a 2068  ame {.  color: h\n+0005d7f0: 736c 2876 6172 282d 2d63 6f6c 6f72 2d73  sl(var(--color-s\n+0005d800: 6563 6f6e 6461 7279 2929 3b0a 7d0a 0a2e  econdary));.}...\n+0005d810: 6772 6170 6869 716c 2d64 6f63 2d65 7870  graphiql-doc-exp\n+0005d820: 6c6f 7265 722d 6172 6775 6d65 6e74 2d64  lorer-argument-d\n+0005d830: 6570 7265 6361 7469 6f6e 207b 0a20 2062  eprecation {.  b\n+0005d840: 6163 6b67 726f 756e 642d 636f 6c6f 723a  ackground-color:\n+0005d850: 2068 736c 6128 7661 7228 2d2d 636f 6c6f   hsla(var(--colo\n+0005d860: 722d 7761 726e 696e 6729 2c20 7661 7228  r-warning), var(\n+0005d870: 2d2d 616c 7068 612d 6261 636b 6772 6f75  --alpha-backgrou\n+0005d880: 6e64 2d6c 6967 6874 2929 3b0a 2020 626f  nd-light));.  bo\n+0005d890: 7264 6572 3a20 3170 7820 736f 6c69 6420  rder: 1px solid \n+0005d8a0: 6873 6c28 7661 7228 2d2d 636f 6c6f 722d  hsl(var(--color-\n+0005d8b0: 7761 726e 696e 6729 293b 0a20 2062 6f72  warning));.  bor\n+0005d8c0: 6465 722d 7261 6469 7573 3a20 7661 7228  der-radius: var(\n+0005d8d0: 2d2d 626f 7264 6572 2d72 6164 6975 732d  --border-radius-\n+0005d8e0: 3429 3b0a 2020 636f 6c6f 723a 2068 736c  4);.  color: hsl\n+0005d8f0: 2876 6172 282d 2d63 6f6c 6f72 2d77 6172  (var(--color-war\n+0005d900: 6e69 6e67 2929 3b0a 2020 7061 6464 696e  ning));.  paddin\n+0005d910: 673a 2076 6172 282d 2d70 782d 3829 3b0a  g: var(--px-8);.\n+0005d920: 7d0a 0a2e 6772 6170 6869 716c 2d64 6f63  }...graphiql-doc\n+0005d930: 2d65 7870 6c6f 7265 722d 6172 6775 6d65  -explorer-argume\n+0005d940: 6e74 2d64 6570 7265 6361 7469 6f6e 2d6c  nt-deprecation-l\n+0005d950: 6162 656c 207b 0a20 2066 6f6e 742d 7369  abel {.  font-si\n+0005d960: 7a65 3a20 7661 7228 2d2d 666f 6e74 2d73  ze: var(--font-s\n+0005d970: 697a 652d 6869 6e74 293b 0a20 2066 6f6e  ize-hint);.  fon\n+0005d980: 742d 7765 6967 6874 3a20 7661 7228 2d2d  t-weight: var(--\n+0005d990: 666f 6e74 2d77 6569 6768 742d 6d65 6469  font-weight-medi\n+0005d9a0: 756d 293b 0a7d 0a2e 6772 6170 6869 716c  um);.}..graphiql\n+0005d9b0: 2d64 6f63 2d65 7870 6c6f 7265 722d 6465  -doc-explorer-de\n+0005d9c0: 7072 6563 6174 696f 6e20 7b0a 2020 6261  precation {.  ba\n+0005d9d0: 636b 6772 6f75 6e64 2d63 6f6c 6f72 3a20  ckground-color: \n+0005d9e0: 6873 6c61 2876 6172 282d 2d63 6f6c 6f72  hsla(var(--color\n+0005d9f0: 2d77 6172 6e69 6e67 292c 2076 6172 282d  -warning), var(-\n+0005da00: 2d61 6c70 6861 2d62 6163 6b67 726f 756e  -alpha-backgroun\n+0005da10: 642d 6c69 6768 7429 293b 0a20 2062 6f72  d-light));.  bor\n+0005da20: 6465 723a 2031 7078 2073 6f6c 6964 2068  der: 1px solid h\n+0005da30: 736c 2876 6172 282d 2d63 6f6c 6f72 2d77  sl(var(--color-w\n+0005da40: 6172 6e69 6e67 2929 3b0a 2020 626f 7264  arning));.  bord\n+0005da50: 6572 2d72 6164 6975 733a 2076 6172 282d  er-radius: var(-\n+0005da60: 2d70 782d 3429 3b0a 2020 636f 6c6f 723a  -px-4);.  color:\n+0005da70: 2068 736c 2876 6172 282d 2d63 6f6c 6f72   hsl(var(--color\n+0005da80: 2d77 6172 6e69 6e67 2929 3b0a 2020 7061  -warning));.  pa\n+0005da90: 6464 696e 673a 2076 6172 282d 2d70 782d  dding: var(--px-\n+0005daa0: 3829 3b0a 7d0a 0a2e 6772 6170 6869 716c  8);.}...graphiql\n+0005dab0: 2d64 6f63 2d65 7870 6c6f 7265 722d 6465  -doc-explorer-de\n+0005dac0: 7072 6563 6174 696f 6e2d 6c61 6265 6c20  precation-label \n+0005dad0: 7b0a 2020 666f 6e74 2d73 697a 653a 2076  {.  font-size: v\n+0005dae0: 6172 282d 2d66 6f6e 742d 7369 7a65 2d68  ar(--font-size-h\n+0005daf0: 696e 7429 3b0a 2020 666f 6e74 2d77 6569  int);.  font-wei\n+0005db00: 6768 743a 2076 6172 282d 2d66 6f6e 742d  ght: var(--font-\n+0005db10: 7765 6967 6874 2d6d 6564 6975 6d29 3b0a  weight-medium);.\n+0005db20: 7d0a 2e67 7261 7068 6971 6c2d 646f 632d  }..graphiql-doc-\n+0005db30: 6578 706c 6f72 6572 2d64 6972 6563 7469  explorer-directi\n+0005db40: 7665 207b 0a20 2063 6f6c 6f72 3a20 6873  ve {.  color: hs\n+0005db50: 6c28 7661 7228 2d2d 636f 6c6f 722d 7365  l(var(--color-se\n+0005db60: 636f 6e64 6172 7929 293b 0a7d 0a2e 6772  condary));.}..gr\n+0005db70: 6170 6869 716c 2d64 6f63 2d65 7870 6c6f  aphiql-doc-explo\n+0005db80: 7265 722d 7365 6374 696f 6e2d 7469 746c  rer-section-titl\n+0005db90: 6520 7b0a 2020 616c 6967 6e2d 6974 656d  e {.  align-item\n+0005dba0: 733a 2063 656e 7465 723b 0a20 2064 6973  s: center;.  dis\n+0005dbb0: 706c 6179 3a20 666c 6578 3b0a 2020 666f  play: flex;.  fo\n+0005dbc0: 6e74 2d73 697a 653a 2076 6172 282d 2d66  nt-size: var(--f\n+0005dbd0: 6f6e 742d 7369 7a65 2d68 696e 7429 3b0a  ont-size-hint);.\n+0005dbe0: 2020 666f 6e74 2d77 6569 6768 743a 2076    font-weight: v\n+0005dbf0: 6172 282d 2d66 6f6e 742d 7765 6967 6874  ar(--font-weight\n+0005dc00: 2d6d 6564 6975 6d29 3b0a 2020 6c69 6e65  -medium);.  line\n+0005dc10: 2d68 6569 6768 743a 2031 0a7d 0a0a 2e67  -height: 1.}...g\n+0005dc20: 7261 7068 6971 6c2d 646f 632d 6578 706c  raphiql-doc-expl\n+0005dc30: 6f72 6572 2d73 6563 7469 6f6e 2d74 6974  orer-section-tit\n+0005dc40: 6c65 203e 2073 7667 207b 0a20 2020 2068  le > svg {.    h\n+0005dc50: 6569 6768 743a 2076 6172 282d 2d70 782d  eight: var(--px-\n+0005dc60: 3136 293b 0a20 2020 206d 6172 6769 6e2d  16);.    margin-\n+0005dc70: 7269 6768 743a 2076 6172 282d 2d70 782d  right: var(--px-\n+0005dc80: 3829 3b0a 2020 2020 7769 6474 683a 2076  8);.    width: v\n+0005dc90: 6172 282d 2d70 782d 3136 293b 0a20 207d  ar(--px-16);.  }\n+0005dca0: 0a0a 2e67 7261 7068 6971 6c2d 646f 632d  ...graphiql-doc-\n+0005dcb0: 6578 706c 6f72 6572 2d73 6563 7469 6f6e  explorer-section\n+0005dcc0: 2d63 6f6e 7465 6e74 207b 0a20 206d 6172  -content {.  mar\n+0005dcd0: 6769 6e2d 6c65 6674 3a20 7661 7228 2d2d  gin-left: var(--\n+0005dce0: 7078 2d38 293b 0a20 206d 6172 6769 6e2d  px-8);.  margin-\n+0005dcf0: 746f 703a 2076 6172 282d 2d70 782d 3136  top: var(--px-16\n+0005dd00: 290a 7d0a 0a2e 6772 6170 6869 716c 2d64  ).}...graphiql-d\n+0005dd10: 6f63 2d65 7870 6c6f 7265 722d 7365 6374  oc-explorer-sect\n+0005dd20: 696f 6e2d 636f 6e74 656e 7420 3e20 2a20  ion-content > * \n+0005dd30: 2b20 2a20 7b0a 2020 2020 6d61 7267 696e  + * {.    margin\n+0005dd40: 2d74 6f70 3a20 7661 7228 2d2d 7078 2d31  -top: var(--px-1\n+0005dd50: 3629 3b0a 2020 7d0a 2e67 7261 7068 6971  6);.  }..graphiq\n+0005dd60: 6c2d 646f 632d 6578 706c 6f72 6572 2d72  l-doc-explorer-r\n+0005dd70: 6f6f 742d 7479 7065 207b 0a20 2063 6f6c  oot-type {.  col\n+0005dd80: 6f72 3a20 6873 6c28 7661 7228 2d2d 636f  or: hsl(var(--co\n+0005dd90: 6c6f 722d 696e 666f 2929 3b0a 7d0a 2e67  lor-info));.}..g\n+0005dda0: 7261 7068 6971 6c2d 646f 632d 6578 706c  raphiql-doc-expl\n+0005ddb0: 6f72 6572 2d73 6561 7263 6820 7b0a 2020  orer-search {.  \n+0005ddc0: 636f 6c6f 723a 2068 736c 6128 7661 7228  color: hsla(var(\n+0005ddd0: 2d2d 636f 6c6f 722d 6e65 7574 7261 6c29  --color-neutral)\n+0005dde0: 2c20 7661 7228 2d2d 616c 7068 612d 7365  , var(--alpha-se\n+0005ddf0: 636f 6e64 6172 7929 290a 7d0a 0a2e 6772  condary)).}...gr\n+0005de00: 6170 6869 716c 2d64 6f63 2d65 7870 6c6f  aphiql-doc-explo\n+0005de10: 7265 722d 7365 6172 6368 3a6e 6f74 285b  rer-search:not([\n+0005de20: 6461 7461 2d73 7461 7465 3d27 6964 6c65  data-state='idle\n+0005de30: 275d 2920 7b0a 2020 2020 626f 7264 6572  ']) {.    border\n+0005de40: 3a20 7661 7228 2d2d 706f 706f 7665 722d  : var(--popover-\n+0005de50: 626f 7264 6572 293b 0a20 2020 2062 6f72  border);.    bor\n+0005de60: 6465 722d 7261 6469 7573 3a20 7661 7228  der-radius: var(\n+0005de70: 2d2d 626f 7264 6572 2d72 6164 6975 732d  --border-radius-\n+0005de80: 3429 3b0a 2020 2020 626f 782d 7368 6164  4);.    box-shad\n+0005de90: 6f77 3a20 7661 7228 2d2d 706f 706f 7665  ow: var(--popove\n+0005dea0: 722d 626f 782d 7368 6164 6f77 293b 0a20  r-box-shadow);. \n+0005deb0: 2020 2063 6f6c 6f72 3a20 6873 6c28 7661     color: hsl(va\n+0005dec0: 7228 2d2d 636f 6c6f 722d 6e65 7574 7261  r(--color-neutra\n+0005ded0: 6c29 290a 2020 7d0a 0a2e 6772 6170 6869  l)).  }...graphi\n+0005dee0: 716c 2d64 6f63 2d65 7870 6c6f 7265 722d  ql-doc-explorer-\n+0005def0: 7365 6172 6368 3a6e 6f74 285b 6461 7461  search:not([data\n+0005df00: 2d73 7461 7465 3d27 6964 6c65 275d 2920  -state='idle']) \n+0005df10: 2e67 7261 7068 6971 6c2d 646f 632d 6578  .graphiql-doc-ex\n+0005df20: 706c 6f72 6572 2d73 6561 7263 682d 696e  plorer-search-in\n+0005df30: 7075 7420 7b0a 2020 2020 2020 6261 636b  put {.      back\n+0005df40: 6772 6f75 6e64 3a20 6873 6c28 7661 7228  ground: hsl(var(\n+0005df50: 2d2d 636f 6c6f 722d 6261 7365 2929 3b0a  --color-base));.\n+0005df60: 2020 2020 7d0a 0a2e 6772 6170 6869 716c      }...graphiql\n+0005df70: 2d64 6f63 2d65 7870 6c6f 7265 722d 7365  -doc-explorer-se\n+0005df80: 6172 6368 2d69 6e70 7574 207b 0a20 2061  arch-input {.  a\n+0005df90: 6c69 676e 2d69 7465 6d73 3a20 6365 6e74  lign-items: cent\n+0005dfa0: 6572 3b0a 2020 6261 636b 6772 6f75 6e64  er;.  background\n+0005dfb0: 2d63 6f6c 6f72 3a20 6873 6c61 2876 6172  -color: hsla(var\n+0005dfc0: 282d 2d63 6f6c 6f72 2d6e 6575 7472 616c  (--color-neutral\n+0005dfd0: 292c 2076 6172 282d 2d61 6c70 6861 2d62  ), var(--alpha-b\n+0005dfe0: 6163 6b67 726f 756e 642d 6c69 6768 7429  ackground-light)\n+0005dff0: 293b 0a20 2062 6f72 6465 722d 7261 6469  );.  border-radi\n+0005e000: 7573 3a20 7661 7228 2d2d 626f 7264 6572  us: var(--border\n+0005e010: 2d72 6164 6975 732d 3429 3b0a 2020 6469  -radius-4);.  di\n+0005e020: 7370 6c61 793a 2066 6c65 783b 0a20 2070  splay: flex;.  p\n+0005e030: 6164 6469 6e67 3a20 7661 7228 2d2d 7078  adding: var(--px\n+0005e040: 2d38 2920 7661 7228 2d2d 7078 2d31 3229  -8) var(--px-12)\n+0005e050: 3b0a 7d0a 0a2e 6772 6170 6869 716c 2d64  ;.}...graphiql-d\n+0005e060: 6f63 2d65 7870 6c6f 7265 722d 7365 6172  oc-explorer-sear\n+0005e070: 6368 205b 726f 6c65 3d27 636f 6d62 6f62  ch [role='combob\n+0005e080: 6f78 275d 207b 0a20 2062 6f72 6465 723a  ox'] {.  border:\n+0005e090: 206e 6f6e 653b 0a20 2062 6163 6b67 726f   none;.  backgro\n+0005e0a0: 756e 642d 636f 6c6f 723a 2074 7261 6e73  und-color: trans\n+0005e0b0: 7061 7265 6e74 3b0a 2020 6d61 7267 696e  parent;.  margin\n+0005e0c0: 2d6c 6566 743a 2076 6172 282d 2d70 782d  -left: var(--px-\n+0005e0d0: 3429 3b0a 2020 7769 6474 683a 2031 3030  4);.  width: 100\n+0005e0e0: 250a 7d0a 0a2e 6772 6170 6869 716c 2d64  %.}...graphiql-d\n+0005e0f0: 6f63 2d65 7870 6c6f 7265 722d 7365 6172  oc-explorer-sear\n+0005e100: 6368 205b 726f 6c65 3d27 636f 6d62 6f62  ch [role='combob\n+0005e110: 6f78 275d 3a66 6f63 7573 207b 0a20 2020  ox']:focus {.   \n+0005e120: 206f 7574 6c69 6e65 3a20 6e6f 6e65 3b0a   outline: none;.\n+0005e130: 2020 7d0a 0a2e 6772 6170 6869 716c 2d64    }...graphiql-d\n+0005e140: 6f63 2d65 7870 6c6f 7265 722d 7365 6172  oc-explorer-sear\n+0005e150: 6368 205b 726f 6c65 3d27 6c69 7374 626f  ch [role='listbo\n+0005e160: 7827 5d20 7b0a 2020 6261 636b 6772 6f75  x'] {.  backgrou\n+0005e170: 6e64 2d63 6f6c 6f72 3a20 6873 6c28 7661  nd-color: hsl(va\n+0005e180: 7228 2d2d 636f 6c6f 722d 6261 7365 2929  r(--color-base))\n+0005e190: 3b0a 2020 626f 7264 6572 3a20 6e6f 6e65  ;.  border: none\n+0005e1a0: 3b0a 2020 626f 7264 6572 2d62 6f74 746f  ;.  border-botto\n+0005e1b0: 6d2d 6c65 6674 2d72 6164 6975 733a 2076  m-left-radius: v\n+0005e1c0: 6172 282d 2d62 6f72 6465 722d 7261 6469  ar(--border-radi\n+0005e1d0: 7573 2d34 293b 0a20 2062 6f72 6465 722d  us-4);.  border-\n+0005e1e0: 626f 7474 6f6d 2d72 6967 6874 2d72 6164  bottom-right-rad\n+0005e1f0: 6975 733a 2076 6172 282d 2d62 6f72 6465  ius: var(--borde\n+0005e200: 722d 7261 6469 7573 2d34 293b 0a20 2062  r-radius-4);.  b\n+0005e210: 6f72 6465 722d 746f 703a 2031 7078 2073  order-top: 1px s\n+0005e220: 6f6c 6964 0a20 2020 2068 736c 6128 7661  olid.    hsla(va\n+0005e230: 7228 2d2d 636f 6c6f 722d 6e65 7574 7261  r(--color-neutra\n+0005e240: 6c29 2c20 7661 7228 2d2d 616c 7068 612d  l), var(--alpha-\n+0005e250: 6261 636b 6772 6f75 6e64 2d68 6561 7679  background-heavy\n+0005e260: 2929 3b0a 2020 6d61 782d 6865 6967 6874  ));.  max-height\n+0005e270: 3a20 3430 3070 783b 0a20 206f 7665 7266  : 400px;.  overf\n+0005e280: 6c6f 772d 793a 2061 7574 6f3b 0a20 206d  low-y: auto;.  m\n+0005e290: 6172 6769 6e3a 2030 3b0a 2020 666f 6e74  argin: 0;.  font\n+0005e2a0: 2d73 697a 653a 2076 6172 282d 2d66 6f6e  -size: var(--fon\n+0005e2b0: 742d 7369 7a65 2d62 6f64 7929 3b0a 2020  t-size-body);.  \n+0005e2c0: 7061 6464 696e 673a 2076 6172 282d 2d70  padding: var(--p\n+0005e2d0: 782d 3429 3b0a 2020 2f2a 2a0a 2020 202a  x-4);.  /**.   *\n+0005e2e0: 2054 6869 7320 6d61 6b65 7320 7375 7265   This makes sure\n+0005e2f0: 2074 6861 7420 7468 6520 6c6f 6769 6320   that the logic \n+0005e300: 666f 7220 6175 746f 2d73 6372 6f6c 6c69  for auto-scrolli\n+0005e310: 6e67 2074 6865 2073 6561 7263 6820 7265  ng the search re\n+0005e320: 7375 6c74 7320 7768 656e 0a20 2020 2a20  sults when.   * \n+0005e330: 7573 696e 6720 6b65 7962 6f61 7264 206e  using keyboard n\n+0005e340: 6176 6967 6174 696f 6e20 776f 726b 7320  avigation works \n+0005e350: 7072 6f70 6572 6c79 2028 7765 2075 7365  properly (we use\n+0005e360: 2060 6f66 6673 6574 546f 7060 2074 6865   `offsetTop` the\n+0005e370: 7265 292e 0a20 2020 2a2f 0a20 2070 6f73  re)..   */.  pos\n+0005e380: 6974 696f 6e3a 2072 656c 6174 6976 653b  ition: relative;\n+0005e390: 0a7d 0a0a 2e67 7261 7068 6971 6c2d 646f  .}...graphiql-do\n+0005e3a0: 632d 6578 706c 6f72 6572 2d73 6561 7263  c-explorer-searc\n+0005e3b0: 6820 5b72 6f6c 653d 276f 7074 696f 6e27  h [role='option'\n+0005e3c0: 5d20 7b0a 2020 626f 7264 6572 2d72 6164  ] {.  border-rad\n+0005e3d0: 6975 733a 2076 6172 282d 2d62 6f72 6465  ius: var(--borde\n+0005e3e0: 722d 7261 6469 7573 2d34 293b 0a20 2063  r-radius-4);.  c\n+0005e3f0: 6f6c 6f72 3a20 6873 6c61 2876 6172 282d  olor: hsla(var(-\n+0005e400: 2d63 6f6c 6f72 2d6e 6575 7472 616c 292c  -color-neutral),\n+0005e410: 2076 6172 282d 2d61 6c70 6861 2d73 6563   var(--alpha-sec\n+0005e420: 6f6e 6461 7279 2929 3b0a 2020 6f76 6572  ondary));.  over\n+0005e430: 666c 6f77 2d78 3a20 6869 6464 656e 3b0a  flow-x: hidden;.\n+0005e440: 2020 7061 6464 696e 673a 2076 6172 282d    padding: var(-\n+0005e450: 2d70 782d 3829 2076 6172 282d 2d70 782d  -px-8) var(--px-\n+0005e460: 3132 293b 0a20 2074 6578 742d 6f76 6572  12);.  text-over\n+0005e470: 666c 6f77 3a20 656c 6c69 7073 6973 3b0a  flow: ellipsis;.\n+0005e480: 2020 7768 6974 652d 7370 6163 653a 206e    white-space: n\n+0005e490: 6f77 7261 703b 0a20 2063 7572 736f 723a  owrap;.  cursor:\n+0005e4a0: 2070 6f69 6e74 6572 0a7d 0a0a 2e67 7261   pointer.}...gra\n+0005e4b0: 7068 6971 6c2d 646f 632d 6578 706c 6f72  phiql-doc-explor\n+0005e4c0: 6572 2d73 6561 7263 6820 5b72 6f6c 653d  er-search [role=\n+0005e4d0: 276f 7074 696f 6e27 5d5b 6461 7461 2d68  'option'][data-h\n+0005e4e0: 6561 646c 6573 7375 692d 7374 6174 653d  eadlessui-state=\n+0005e4f0: 2761 6374 6976 6527 5d20 7b0a 2020 2020  'active'] {.    \n+0005e500: 6261 636b 6772 6f75 6e64 2d63 6f6c 6f72  background-color\n+0005e510: 3a20 6873 6c61 2876 6172 282d 2d63 6f6c  : hsla(var(--col\n+0005e520: 6f72 2d6e 6575 7472 616c 292c 2076 6172  or-neutral), var\n+0005e530: 282d 2d61 6c70 6861 2d62 6163 6b67 726f  (--alpha-backgro\n+0005e540: 756e 642d 6c69 6768 7429 293b 0a20 207d  und-light));.  }\n+0005e550: 0a0a 2e67 7261 7068 6971 6c2d 646f 632d  ...graphiql-doc-\n+0005e560: 6578 706c 6f72 6572 2d73 6561 7263 6820  explorer-search \n+0005e570: 5b72 6f6c 653d 276f 7074 696f 6e27 5d3a  [role='option']:\n+0005e580: 686f 7665 7220 7b0a 2020 2020 6261 636b  hover {.    back\n+0005e590: 6772 6f75 6e64 2d63 6f6c 6f72 3a20 6873  ground-color: hs\n+0005e5a0: 6c61 280a 2020 2020 2020 7661 7228 2d2d  la(.      var(--\n+0005e5b0: 636f 6c6f 722d 6e65 7574 7261 6c29 2c0a  color-neutral),.\n+0005e5c0: 2020 2020 2020 7661 7228 2d2d 616c 7068        var(--alph\n+0005e5d0: 612d 6261 636b 6772 6f75 6e64 2d6d 6564  a-background-med\n+0005e5e0: 6975 6d29 0a20 2020 2029 3b0a 2020 7d0a  ium).    );.  }.\n+0005e5f0: 0a2e 6772 6170 6869 716c 2d64 6f63 2d65  ..graphiql-doc-e\n+0005e600: 7870 6c6f 7265 722d 7365 6172 6368 205b  xplorer-search [\n+0005e610: 726f 6c65 3d27 6f70 7469 6f6e 275d 5b64  role='option'][d\n+0005e620: 6174 612d 6865 6164 6c65 7373 7569 2d73  ata-headlessui-s\n+0005e630: 7461 7465 3d27 6163 7469 7665 275d 3a68  tate='active']:h\n+0005e640: 6f76 6572 207b 0a20 2020 2062 6163 6b67  over {.    backg\n+0005e650: 726f 756e 642d 636f 6c6f 723a 2068 736c  round-color: hsl\n+0005e660: 6128 7661 7228 2d2d 636f 6c6f 722d 6e65  a(var(--color-ne\n+0005e670: 7574 7261 6c29 2c20 7661 7228 2d2d 616c  utral), var(--al\n+0005e680: 7068 612d 6261 636b 6772 6f75 6e64 2d68  pha-background-h\n+0005e690: 6561 7679 2929 3b0a 2020 7d0a 0a3a 6973  eavy));.  }..:is\n+0005e6a0: 282e 6772 6170 6869 716c 2d64 6f63 2d65  (.graphiql-doc-e\n+0005e6b0: 7870 6c6f 7265 722d 7365 6172 6368 205b  xplorer-search [\n+0005e6c0: 726f 6c65 3d27 6f70 7469 6f6e 275d 2920  role='option']) \n+0005e6d0: 2b20 3a69 7328 2e67 7261 7068 6971 6c2d  + :is(.graphiql-\n+0005e6e0: 646f 632d 6578 706c 6f72 6572 2d73 6561  doc-explorer-sea\n+0005e6f0: 7263 6820 5b72 6f6c 653d 276f 7074 696f  rch [role='optio\n+0005e700: 6e27 5d29 207b 0a20 2020 206d 6172 6769  n']) {.    margi\n+0005e710: 6e2d 746f 703a 2076 6172 282d 2d70 782d  n-top: var(--px-\n+0005e720: 3429 3b0a 2020 7d0a 0a2e 6772 6170 6869  4);.  }...graphi\n+0005e730: 716c 2d64 6f63 2d65 7870 6c6f 7265 722d  ql-doc-explorer-\n+0005e740: 7365 6172 6368 2d74 7970 6520 7b0a 2020  search-type {.  \n+0005e750: 636f 6c6f 723a 2068 736c 2876 6172 282d  color: hsl(var(-\n+0005e760: 2d63 6f6c 6f72 2d69 6e66 6f29 293b 0a7d  -color-info));.}\n+0005e770: 0a0a 2e67 7261 7068 6971 6c2d 646f 632d  ...graphiql-doc-\n+0005e780: 6578 706c 6f72 6572 2d73 6561 7263 682d  explorer-search-\n+0005e790: 6669 656c 6420 7b0a 2020 636f 6c6f 723a  field {.  color:\n+0005e7a0: 2068 736c 2876 6172 282d 2d63 6f6c 6f72   hsl(var(--color\n+0005e7b0: 2d77 6172 6e69 6e67 2929 3b0a 7d0a 0a2e  -warning));.}...\n+0005e7c0: 6772 6170 6869 716c 2d64 6f63 2d65 7870  graphiql-doc-exp\n+0005e7d0: 6c6f 7265 722d 7365 6172 6368 2d61 7267  lorer-search-arg\n+0005e7e0: 756d 656e 7420 7b0a 2020 636f 6c6f 723a  ument {.  color:\n+0005e7f0: 2068 736c 2876 6172 282d 2d63 6f6c 6f72   hsl(var(--color\n+0005e800: 2d73 6563 6f6e 6461 7279 2929 3b0a 7d0a  -secondary));.}.\n+0005e810: 0a2e 6772 6170 6869 716c 2d64 6f63 2d65  ..graphiql-doc-e\n+0005e820: 7870 6c6f 7265 722d 7365 6172 6368 2d64  xplorer-search-d\n+0005e830: 6976 6964 6572 207b 0a20 2063 6f6c 6f72  ivider {.  color\n+0005e840: 3a20 6873 6c61 2876 6172 282d 2d63 6f6c  : hsla(var(--col\n+0005e850: 6f72 2d6e 6575 7472 616c 292c 2076 6172  or-neutral), var\n+0005e860: 282d 2d61 6c70 6861 2d73 6563 6f6e 6461  (--alpha-seconda\n+0005e870: 7279 2929 3b0a 2020 666f 6e74 2d73 697a  ry));.  font-siz\n+0005e880: 653a 2076 6172 282d 2d66 6f6e 742d 7369  e: var(--font-si\n+0005e890: 7a65 2d68 696e 7429 3b0a 2020 666f 6e74  ze-hint);.  font\n+0005e8a0: 2d77 6569 6768 743a 2076 6172 282d 2d66  -weight: var(--f\n+0005e8b0: 6f6e 742d 7765 6967 6874 2d6d 6564 6975  ont-weight-mediu\n+0005e8c0: 6d29 3b0a 2020 6d61 7267 696e 2d74 6f70  m);.  margin-top\n+0005e8d0: 3a20 7661 7228 2d2d 7078 2d38 293b 0a20  : var(--px-8);. \n+0005e8e0: 2070 6164 6469 6e67 3a20 7661 7228 2d2d   padding: var(--\n+0005e8f0: 7078 2d38 2920 7661 7228 2d2d 7078 2d31  px-8) var(--px-1\n+0005e900: 3229 3b0a 7d0a 0a2e 6772 6170 6869 716c  2);.}...graphiql\n+0005e910: 2d64 6f63 2d65 7870 6c6f 7265 722d 7365  -doc-explorer-se\n+0005e920: 6172 6368 2d65 6d70 7479 207b 0a20 2063  arch-empty {.  c\n+0005e930: 6f6c 6f72 3a20 6873 6c61 2876 6172 282d  olor: hsla(var(-\n+0005e940: 2d63 6f6c 6f72 2d6e 6575 7472 616c 292c  -color-neutral),\n+0005e950: 2076 6172 282d 2d61 6c70 6861 2d73 6563   var(--alpha-sec\n+0005e960: 6f6e 6461 7279 2929 3b0a 2020 7061 6464  ondary));.  padd\n+0005e970: 696e 673a 2076 6172 282d 2d70 782d 3829  ing: var(--px-8)\n+0005e980: 2076 6172 282d 2d70 782d 3132 293b 0a7d   var(--px-12);.}\n+0005e990: 0a61 2e67 7261 7068 6971 6c2d 646f 632d  .a.graphiql-doc-\n+0005e9a0: 6578 706c 6f72 6572 2d66 6965 6c64 2d6e  explorer-field-n\n+0005e9b0: 616d 6520 7b0a 2020 636f 6c6f 723a 2068  ame {.  color: h\n+0005e9c0: 736c 2876 6172 282d 2d63 6f6c 6f72 2d69  sl(var(--color-i\n+0005e9d0: 6e66 6f29 293b 0a20 2074 6578 742d 6465  nfo));.  text-de\n+0005e9e0: 636f 7261 7469 6f6e 3a20 6e6f 6e65 0a7d  coration: none.}\n+0005e9f0: 0a61 2e67 7261 7068 6971 6c2d 646f 632d  .a.graphiql-doc-\n+0005ea00: 6578 706c 6f72 6572 2d66 6965 6c64 2d6e  explorer-field-n\n+0005ea10: 616d 653a 686f 7665 7220 7b0a 2020 2020  ame:hover {.    \n+0005ea20: 7465 7874 2d64 6563 6f72 6174 696f 6e3a  text-decoration:\n+0005ea30: 2075 6e64 6572 6c69 6e65 3b0a 2020 7d0a   underline;.  }.\n+0005ea40: 612e 6772 6170 6869 716c 2d64 6f63 2d65  a.graphiql-doc-e\n+0005ea50: 7870 6c6f 7265 722d 6669 656c 642d 6e61  xplorer-field-na\n+0005ea60: 6d65 3a66 6f63 7573 207b 0a20 2020 206f  me:focus {.    o\n+0005ea70: 7574 6c69 6e65 3a20 6873 6c28 7661 7228  utline: hsl(var(\n+0005ea80: 2d2d 636f 6c6f 722d 696e 666f 2929 2061  --color-info)) a\n+0005ea90: 7574 6f20 3170 783b 0a20 207d 0a2e 6772  uto 1px;.  }..gr\n+0005eaa0: 6170 6869 716c 2d64 6f63 2d65 7870 6c6f  aphiql-doc-explo\n+0005eab0: 7265 722d 6974 656d 203e 203a 6e6f 7428  rer-item > :not(\n+0005eac0: 3a66 6972 7374 2d63 6869 6c64 2920 7b0a  :first-child) {.\n+0005ead0: 2020 6d61 7267 696e 2d74 6f70 3a20 7661    margin-top: va\n+0005eae0: 7228 2d2d 7078 2d31 3229 3b0a 7d0a 0a2e  r(--px-12);.}...\n+0005eaf0: 6772 6170 6869 716c 2d64 6f63 2d65 7870  graphiql-doc-exp\n+0005eb00: 6c6f 7265 722d 6172 6775 6d65 6e74 2d6d  lorer-argument-m\n+0005eb10: 756c 7469 706c 6520 7b0a 2020 6d61 7267  ultiple {.  marg\n+0005eb20: 696e 2d6c 6566 743a 2076 6172 282d 2d70  in-left: var(--p\n+0005eb30: 782d 3829 3b0a 7d0a 0a2e 6772 6170 6869  x-8);.}...graphi\n+0005eb40: 716c 2d64 6f63 2d65 7870 6c6f 7265 722d  ql-doc-explorer-\n+0005eb50: 656e 756d 2d76 616c 7565 207b 0a20 2063  enum-value {.  c\n+0005eb60: 6f6c 6f72 3a20 6873 6c28 7661 7228 2d2d  olor: hsl(var(--\n+0005eb70: 636f 6c6f 722d 696e 666f 2929 3b0a 7d0a  color-info));.}.\n+0005eb80: 2f2a 2054 6865 2068 6561 6465 7220 6f66  /* The header of\n+0005eb90: 2074 6865 2064 6f63 2065 7870 6c6f 7265   the doc explore\n+0005eba0: 7220 2a2f 0a2e 6772 6170 6869 716c 2d64  r */..graphiql-d\n+0005ebb0: 6f63 2d65 7870 6c6f 7265 722d 6865 6164  oc-explorer-head\n+0005ebc0: 6572 207b 0a20 2064 6973 706c 6179 3a20  er {.  display: \n+0005ebd0: 666c 6578 3b0a 2020 6a75 7374 6966 792d  flex;.  justify-\n+0005ebe0: 636f 6e74 656e 743a 2073 7061 6365 2d62  content: space-b\n+0005ebf0: 6574 7765 656e 3b0a 2020 706f 7369 7469  etween;.  positi\n+0005ec00: 6f6e 3a20 7265 6c61 7469 7665 0a7d 0a2e  on: relative.}..\n+0005ec10: 6772 6170 6869 716c 2d64 6f63 2d65 7870  graphiql-doc-exp\n+0005ec20: 6c6f 7265 722d 6865 6164 6572 3a66 6f63  lorer-header:foc\n+0005ec30: 7573 2d77 6974 6869 6e20 2e67 7261 7068  us-within .graph\n+0005ec40: 6971 6c2d 646f 632d 6578 706c 6f72 6572  iql-doc-explorer\n+0005ec50: 2d74 6974 6c65 207b 0a20 2020 2020 202f  -title {.      /\n+0005ec60: 2a20 4869 6465 2074 6865 2068 6561 6465  * Hide the heade\n+0005ec70: 7220 7768 656e 2066 6f63 7573 7369 6e67  r when focussing\n+0005ec80: 2074 6865 2073 6561 7263 6820 696e 7075   the search inpu\n+0005ec90: 7420 2a2f 0a20 2020 2020 2076 6973 6962  t */.      visib\n+0005eca0: 696c 6974 793a 2068 6964 6465 6e3b 0a20  ility: hidden;. \n+0005ecb0: 2020 207d 0a2e 6772 6170 6869 716c 2d64     }..graphiql-d\n+0005ecc0: 6f63 2d65 7870 6c6f 7265 722d 6865 6164  oc-explorer-head\n+0005ecd0: 6572 3a66 6f63 7573 2d77 6974 6869 6e20  er:focus-within \n+0005ece0: 2e67 7261 7068 6971 6c2d 646f 632d 6578  .graphiql-doc-ex\n+0005ecf0: 706c 6f72 6572 2d62 6163 6b3a 6e6f 7428  plorer-back:not(\n+0005ed00: 3a66 6f63 7573 2920 7b0a 2020 2020 2020  :focus) {.      \n+0005ed10: 2f2a 2a0a 2020 2020 2020 2020 2a20 4d61  /**.        * Ma\n+0005ed20: 6b65 2074 6865 2062 6163 6b20 6c69 6e6b  ke the back link\n+0005ed30: 2069 6e76 6973 6962 6c65 2077 6865 6e20   invisible when \n+0005ed40: 666f 6375 7373 696e 6720 7468 6520 7365  focussing the se\n+0005ed50: 6172 6368 2069 6e70 7574 2e20 4869 6469  arch input. Hidi\n+0005ed60: 6e67 0a20 2020 2020 2020 202a 2069 7420  ng.        * it \n+0005ed70: 696e 2061 6e79 206f 7468 6572 2077 6179  in any other way\n+0005ed80: 206d 616b 6573 2069 7420 696d 706f 7373   makes it imposs\n+0005ed90: 6962 6c65 2074 6f20 666f 6375 7320 7468  ible to focus th\n+0005eda0: 6520 6c69 6e6b 2062 7920 7072 6573 7369  e link by pressi\n+0005edb0: 6e67 0a20 2020 2020 2020 202a 2053 6869  ng.        * Shi\n+0005edc0: 6674 2d54 6162 2077 6869 6c65 2074 6865  ft-Tab while the\n+0005edd0: 2069 6e70 7574 2069 7320 666f 6375 7373   input is focuss\n+0005ede0: 6564 2e0a 2020 2020 2020 2020 2a2f 0a20  ed..        */. \n+0005edf0: 2020 2020 2063 6f6c 6f72 3a20 7472 616e       color: tran\n+0005ee00: 7370 6172 656e 743b 0a20 2020 207d 0a2e  sparent;.    }..\n+0005ee10: 6772 6170 6869 716c 2d64 6f63 2d65 7870  graphiql-doc-exp\n+0005ee20: 6c6f 7265 722d 6865 6164 6572 2d63 6f6e  lorer-header-con\n+0005ee30: 7465 6e74 207b 0a20 2064 6973 706c 6179  tent {.  display\n+0005ee40: 3a20 666c 6578 3b0a 2020 666c 6578 2d64  : flex;.  flex-d\n+0005ee50: 6972 6563 7469 6f6e 3a20 636f 6c75 6d6e  irection: column\n+0005ee60: 3b0a 2020 6d69 6e2d 7769 6474 683a 2030  ;.  min-width: 0\n+0005ee70: 3b0a 7d0a 0a2f 2a20 5468 6520 7365 6172  ;.}../* The sear\n+0005ee80: 6368 2069 6e70 7574 2069 6e20 7468 6520  ch input in the \n+0005ee90: 6865 6164 6572 206f 6620 7468 6520 646f  header of the do\n+0005eea0: 6320 6578 706c 6f72 6572 202a 2f0a 2e67  c explorer */..g\n+0005eeb0: 7261 7068 6971 6c2d 646f 632d 6578 706c  raphiql-doc-expl\n+0005eec0: 6f72 6572 2d73 6561 7263 6820 7b0a 2020  orer-search {.  \n+0005eed0: 706f 7369 7469 6f6e 3a20 6162 736f 6c75  position: absolu\n+0005eee0: 7465 3b0a 2020 7269 6768 743a 2030 3b0a  te;.  right: 0;.\n+0005eef0: 2020 746f 703a 2030 0a7d 0a2e 6772 6170    top: 0.}..grap\n+0005ef00: 6869 716c 2d64 6f63 2d65 7870 6c6f 7265  hiql-doc-explore\n+0005ef10: 722d 7365 6172 6368 3a66 6f63 7573 2d77  r-search:focus-w\n+0005ef20: 6974 6869 6e20 7b0a 2020 2020 6c65 6674  ithin {.    left\n+0005ef30: 3a20 303b 0a20 207d 0a2e 6772 6170 6869  : 0;.  }..graphi\n+0005ef40: 716c 2d64 6f63 2d65 7870 6c6f 7265 722d  ql-doc-explorer-\n+0005ef50: 7365 6172 6368 3a6e 6f74 283a 666f 6375  search:not(:focu\n+0005ef60: 732d 7769 7468 696e 2920 5b72 6f6c 653d  s-within) [role=\n+0005ef70: 2763 6f6d 626f 626f 7827 5d20 7b0a 2020  'combobox'] {.  \n+0005ef80: 2020 6865 6967 6874 3a20 3234 7078 3b0a    height: 24px;.\n+0005ef90: 2020 2020 7769 6474 683a 2035 6368 3b0a      width: 5ch;.\n+0005efa0: 2020 7d0a 2e67 7261 7068 6971 6c2d 646f    }..graphiql-do\n+0005efb0: 632d 6578 706c 6f72 6572 2d73 6561 7263  c-explorer-searc\n+0005efc0: 6820 5b72 6f6c 653d 2763 6f6d 626f 626f  h [role='combobo\n+0005efd0: 7827 5d3a 666f 6375 7320 7b0a 2020 2020  x']:focus {.    \n+0005efe0: 7769 6474 683a 2031 3030 253b 0a20 207d  width: 100%;.  }\n+0005eff0: 0a0a 2f2a 2054 6865 2062 6163 6b2d 6275  ../* The back-bu\n+0005f000: 7474 6f6e 2069 6e20 7468 6520 646f 6320  tton in the doc \n+0005f010: 6578 706c 6f72 6572 202a 2f0a 612e 6772  explorer */.a.gr\n+0005f020: 6170 6869 716c 2d64 6f63 2d65 7870 6c6f  aphiql-doc-explo\n+0005f030: 7265 722d 6261 636b 207b 0a20 2061 6c69  rer-back {.  ali\n+0005f040: 676e 2d69 7465 6d73 3a20 6365 6e74 6572  gn-items: center\n+0005f050: 3b0a 2020 636f 6c6f 723a 2068 736c 6128  ;.  color: hsla(\n+0005f060: 7661 7228 2d2d 636f 6c6f 722d 6e65 7574  var(--color-neut\n+0005f070: 7261 6c29 2c20 7661 7228 2d2d 616c 7068  ral), var(--alph\n+0005f080: 612d 7365 636f 6e64 6172 7929 293b 0a20  a-secondary));. \n+0005f090: 2064 6973 706c 6179 3a20 666c 6578 3b0a   display: flex;.\n+0005f0a0: 2020 7465 7874 2d64 6563 6f72 6174 696f    text-decoratio\n+0005f0b0: 6e3a 206e 6f6e 650a 7d0a 612e 6772 6170  n: none.}.a.grap\n+0005f0c0: 6869 716c 2d64 6f63 2d65 7870 6c6f 7265  hiql-doc-explore\n+0005f0d0: 722d 6261 636b 3a68 6f76 6572 207b 0a20  r-back:hover {. \n+0005f0e0: 2020 2074 6578 742d 6465 636f 7261 7469     text-decorati\n+0005f0f0: 6f6e 3a20 756e 6465 726c 696e 653b 0a20  on: underline;. \n+0005f100: 207d 0a61 2e67 7261 7068 6971 6c2d 646f   }.a.graphiql-do\n+0005f110: 632d 6578 706c 6f72 6572 2d62 6163 6b3a  c-explorer-back:\n+0005f120: 666f 6375 7320 7b0a 2020 2020 6f75 746c  focus {.    outl\n+0005f130: 696e 653a 2068 736c 6128 7661 7228 2d2d  ine: hsla(var(--\n+0005f140: 636f 6c6f 722d 6e65 7574 7261 6c29 2c20  color-neutral), \n+0005f150: 7661 7228 2d2d 616c 7068 612d 7365 636f  var(--alpha-seco\n+0005f160: 6e64 6172 7929 2920 6175 746f 2031 7078  ndary)) auto 1px\n+0005f170: 0a20 207d 0a61 2e67 7261 7068 6971 6c2d  .  }.a.graphiql-\n+0005f180: 646f 632d 6578 706c 6f72 6572 2d62 6163  doc-explorer-bac\n+0005f190: 6b3a 666f 6375 7320 2b20 2e67 7261 7068  k:focus + .graph\n+0005f1a0: 6971 6c2d 646f 632d 6578 706c 6f72 6572  iql-doc-explorer\n+0005f1b0: 2d74 6974 6c65 207b 0a20 2020 2020 202f  -title {.      /\n+0005f1c0: 2a20 446f 6e27 7420 6869 6465 2074 6865  * Don't hide the\n+0005f1d0: 2068 6561 6465 7220 7768 656e 2066 6f63   header when foc\n+0005f1e0: 7573 7369 6e67 2074 6865 2062 6163 6b20  ussing the back \n+0005f1f0: 6c69 6e6b 202a 2f0a 2020 2020 2020 7669  link */.      vi\n+0005f200: 7369 6269 6c69 7479 3a20 756e 7365 743b  sibility: unset;\n+0005f210: 0a20 2020 207d 0a61 2e67 7261 7068 6971  .    }.a.graphiq\n+0005f220: 6c2d 646f 632d 6578 706c 6f72 6572 2d62  l-doc-explorer-b\n+0005f230: 6163 6b20 3e20 7376 6720 7b0a 2020 2020  ack > svg {.    \n+0005f240: 6865 6967 6874 3a20 7661 7228 2d2d 7078  height: var(--px\n+0005f250: 2d38 293b 0a20 2020 206d 6172 6769 6e2d  -8);.    margin-\n+0005f260: 7269 6768 743a 2076 6172 282d 2d70 782d  right: var(--px-\n+0005f270: 3829 3b0a 2020 2020 7769 6474 683a 2076  8);.    width: v\n+0005f280: 6172 282d 2d70 782d 3829 3b0a 2020 7d0a  ar(--px-8);.  }.\n+0005f290: 0a2f 2a20 5468 6520 7469 746c 6520 6f66  ./* The title of\n+0005f2a0: 2074 6865 2063 7572 7265 6e74 6c79 2061   the currently a\n+0005f2b0: 6374 6976 6520 7061 6765 2069 6e20 7468  ctive page in th\n+0005f2c0: 6520 646f 6320 6578 706c 6f72 6572 202a  e doc explorer *\n+0005f2d0: 2f0a 2e67 7261 7068 6971 6c2d 646f 632d  /..graphiql-doc-\n+0005f2e0: 6578 706c 6f72 6572 2d74 6974 6c65 207b  explorer-title {\n+0005f2f0: 0a20 2066 6f6e 742d 7765 6967 6874 3a20  .  font-weight: \n+0005f300: 7661 7228 2d2d 666f 6e74 2d77 6569 6768  var(--font-weigh\n+0005f310: 742d 6d65 6469 756d 293b 0a20 2066 6f6e  t-medium);.  fon\n+0005f320: 742d 7369 7a65 3a20 7661 7228 2d2d 666f  t-size: var(--fo\n+0005f330: 6e74 2d73 697a 652d 6832 293b 0a20 206f  nt-size-h2);.  o\n+0005f340: 7665 7266 6c6f 772d 783a 2068 6964 6465  verflow-x: hidde\n+0005f350: 6e3b 0a20 2074 6578 742d 6f76 6572 666c  n;.  text-overfl\n+0005f360: 6f77 3a20 656c 6c69 7073 6973 3b0a 2020  ow: ellipsis;.  \n+0005f370: 7768 6974 652d 7370 6163 653a 206e 6f77  white-space: now\n+0005f380: 7261 700a 7d0a 2e67 7261 7068 6971 6c2d  rap.}..graphiql-\n+0005f390: 646f 632d 6578 706c 6f72 6572 2d74 6974  doc-explorer-tit\n+0005f3a0: 6c65 3a6e 6f74 283a 6669 7273 742d 6368  le:not(:first-ch\n+0005f3b0: 696c 6429 207b 0a20 2020 2066 6f6e 742d  ild) {.    font-\n+0005f3c0: 7369 7a65 3a20 7661 7228 2d2d 666f 6e74  size: var(--font\n+0005f3d0: 2d73 697a 652d 6833 293b 0a20 2020 206d  -size-h3);.    m\n+0005f3e0: 6172 6769 6e2d 746f 703a 2076 6172 282d  argin-top: var(-\n+0005f3f0: 2d70 782d 3829 3b0a 2020 7d0a 0a2f 2a20  -px-8);.  }../* \n+0005f400: 5468 6520 636f 6e74 656e 7473 206f 6620  The contents of \n+0005f410: 7468 6520 6375 7272 656e 746c 7920 6163  the currently ac\n+0005f420: 7469 7665 2070 6167 6520 696e 2074 6865  tive page in the\n+0005f430: 2064 6f63 2065 7870 6c6f 7265 7220 2a2f   doc explorer */\n+0005f440: 0a2e 6772 6170 6869 716c 2d64 6f63 2d65  ..graphiql-doc-e\n+0005f450: 7870 6c6f 7265 722d 636f 6e74 656e 7420  xplorer-content \n+0005f460: 3e20 2a20 7b0a 2020 636f 6c6f 723a 2068  > * {.  color: h\n+0005f470: 736c 6128 7661 7228 2d2d 636f 6c6f 722d  sla(var(--color-\n+0005f480: 6e65 7574 7261 6c29 2c20 7661 7228 2d2d  neutral), var(--\n+0005f490: 616c 7068 612d 7365 636f 6e64 6172 7929  alpha-secondary)\n+0005f4a0: 293b 0a20 206d 6172 6769 6e2d 746f 703a  );.  margin-top:\n+0005f4b0: 2076 6172 282d 2d70 782d 3230 293b 0a7d   var(--px-20);.}\n+0005f4c0: 0a0a 2f2a 2045 7272 6f72 206d 6573 7361  ../* Error messa\n+0005f4d0: 6765 202a 2f0a 2e67 7261 7068 6971 6c2d  ge */..graphiql-\n+0005f4e0: 646f 632d 6578 706c 6f72 6572 2d65 7272  doc-explorer-err\n+0005f4f0: 6f72 207b 0a20 2062 6163 6b67 726f 756e  or {.  backgroun\n+0005f500: 642d 636f 6c6f 723a 2068 736c 6128 7661  d-color: hsla(va\n+0005f510: 7228 2d2d 636f 6c6f 722d 6572 726f 7229  r(--color-error)\n+0005f520: 2c20 7661 7228 2d2d 616c 7068 612d 6261  , var(--alpha-ba\n+0005f530: 636b 6772 6f75 6e64 2d68 6561 7679 2929  ckground-heavy))\n+0005f540: 3b0a 2020 626f 7264 6572 3a20 3170 7820  ;.  border: 1px \n+0005f550: 736f 6c69 6420 6873 6c28 7661 7228 2d2d  solid hsl(var(--\n+0005f560: 636f 6c6f 722d 6572 726f 7229 293b 0a20  color-error));. \n+0005f570: 2062 6f72 6465 722d 7261 6469 7573 3a20   border-radius: \n+0005f580: 7661 7228 2d2d 626f 7264 6572 2d72 6164  var(--border-rad\n+0005f590: 6975 732d 3829 3b0a 2020 636f 6c6f 723a  ius-8);.  color:\n+0005f5a0: 2068 736c 2876 6172 282d 2d63 6f6c 6f72   hsl(var(--color\n+0005f5b0: 2d65 7272 6f72 2929 3b0a 2020 7061 6464  -error));.  padd\n+0005f5c0: 696e 673a 2076 6172 282d 2d70 782d 3829  ing: var(--px-8)\n+0005f5d0: 2076 6172 282d 2d70 782d 3132 293b 0a7d   var(--px-12);.}\n+0005f5e0: 0a2f 2a20 4241 5349 4353 202a 2f0a 0a2e  ./* BASICS */...\n+0005f5f0: 436f 6465 4d69 7272 6f72 207b 0a20 202f  CodeMirror {.  /\n+0005f600: 2a20 5365 7420 6865 6967 6874 2c20 7769  * Set height, wi\n+0005f610: 6474 682c 2062 6f72 6465 7273 2c20 616e  dth, borders, an\n+0005f620: 6420 676c 6f62 616c 2066 6f6e 7420 7072  d global font pr\n+0005f630: 6f70 6572 7469 6573 2068 6572 6520 2a2f  operties here */\n+0005f640: 0a20 2066 6f6e 742d 6661 6d69 6c79 3a20  .  font-family: \n+0005f650: 6d6f 6e6f 7370 6163 653b 0a20 2068 6569  monospace;.  hei\n+0005f660: 6768 743a 2033 3030 7078 3b0a 2020 636f  ght: 300px;.  co\n+0005f670: 6c6f 723a 2062 6c61 636b 3b0a 2020 6469  lor: black;.  di\n+0005f680: 7265 6374 696f 6e3a 206c 7472 3b0a 7d0a  rection: ltr;.}.\n+0005f690: 0a2f 2a20 5041 4444 494e 4720 2a2f 0a0a  ./* PADDING */..\n+0005f6a0: 2e43 6f64 654d 6972 726f 722d 6c69 6e65  .CodeMirror-line\n+0005f6b0: 7320 7b0a 2020 7061 6464 696e 673a 2034  s {.  padding: 4\n+0005f6c0: 7078 2030 3b20 2f2a 2056 6572 7469 6361  px 0; /* Vertica\n+0005f6d0: 6c20 7061 6464 696e 6720 6172 6f75 6e64  l padding around\n+0005f6e0: 2063 6f6e 7465 6e74 202a 2f0a 7d0a 0a2e   content */.}...\n+0005f6f0: 436f 6465 4d69 7272 6f72 2070 7265 2e43  CodeMirror pre.C\n+0005f700: 6f64 654d 6972 726f 722d 6c69 6e65 2c0a  odeMirror-line,.\n+0005f710: 2e43 6f64 654d 6972 726f 7220 7072 652e  .CodeMirror pre.\n+0005f720: 436f 6465 4d69 7272 6f72 2d6c 696e 652d  CodeMirror-line-\n+0005f730: 6c69 6b65 207b 0a20 2070 6164 6469 6e67  like {.  padding\n+0005f740: 3a20 3020 3470 783b 202f 2a20 486f 7269  : 0 4px; /* Hori\n+0005f750: 7a6f 6e74 616c 2070 6164 6469 6e67 206f  zontal padding o\n+0005f760: 6620 636f 6e74 656e 7420 2a2f 0a7d 0a0a  f content */.}..\n+0005f770: 2e43 6f64 654d 6972 726f 722d 7363 726f  .CodeMirror-scro\n+0005f780: 6c6c 6261 722d 6669 6c6c 6572 2c20 2e43  llbar-filler, .C\n+0005f790: 6f64 654d 6972 726f 722d 6775 7474 6572  odeMirror-gutter\n+0005f7a0: 2d66 696c 6c65 7220 7b0a 2020 6261 636b  -filler {.  back\n+0005f7b0: 6772 6f75 6e64 2d63 6f6c 6f72 3a20 7768  ground-color: wh\n+0005f7c0: 6974 653b 202f 2a20 5468 6520 6c69 7474  ite; /* The litt\n+0005f7d0: 6c65 2073 7175 6172 6520 6265 7477 6565  le square betwee\n+0005f7e0: 6e20 4820 616e 6420 5620 7363 726f 6c6c  n H and V scroll\n+0005f7f0: 6261 7273 202a 2f0a 7d0a 0a2f 2a20 4755  bars */.}../* GU\n+0005f800: 5454 4552 202a 2f0a 0a2e 436f 6465 4d69  TTER */...CodeMi\n+0005f810: 7272 6f72 2d67 7574 7465 7273 207b 0a20  rror-gutters {. \n+0005f820: 2062 6f72 6465 722d 7269 6768 743a 2031   border-right: 1\n+0005f830: 7078 2073 6f6c 6964 2023 6464 643b 0a20  px solid #ddd;. \n+0005f840: 2062 6163 6b67 726f 756e 642d 636f 6c6f   background-colo\n+0005f850: 723a 2023 6637 6637 6637 3b0a 2020 7768  r: #f7f7f7;.  wh\n+0005f860: 6974 652d 7370 6163 653a 206e 6f77 7261  ite-space: nowra\n+0005f870: 703b 0a7d 0a0a 2e43 6f64 654d 6972 726f  p;.}...CodeMirro\n+0005f880: 722d 6c69 6e65 6e75 6d62 6572 7320 7b7d  r-linenumbers {}\n+0005f890: 0a0a 2e43 6f64 654d 6972 726f 722d 6c69  ...CodeMirror-li\n+0005f8a0: 6e65 6e75 6d62 6572 207b 0a20 2070 6164  nenumber {.  pad\n+0005f8b0: 6469 6e67 3a20 3020 3370 7820 3020 3570  ding: 0 3px 0 5p\n+0005f8c0: 783b 0a20 206d 696e 2d77 6964 7468 3a20  x;.  min-width: \n+0005f8d0: 3230 7078 3b0a 2020 7465 7874 2d61 6c69  20px;.  text-ali\n+0005f8e0: 676e 3a20 7269 6768 743b 0a20 2063 6f6c  gn: right;.  col\n+0005f8f0: 6f72 3a20 2339 3939 3b0a 2020 7768 6974  or: #999;.  whit\n+0005f900: 652d 7370 6163 653a 206e 6f77 7261 703b  e-space: nowrap;\n+0005f910: 0a7d 0a0a 2e43 6f64 654d 6972 726f 722d  .}...CodeMirror-\n+0005f920: 6775 7474 6572 6d61 726b 6572 207b 2063  guttermarker { c\n+0005f930: 6f6c 6f72 3a20 626c 6163 6b3b 207d 0a0a  olor: black; }..\n+0005f940: 2e43 6f64 654d 6972 726f 722d 6775 7474  .CodeMirror-gutt\n+0005f950: 6572 6d61 726b 6572 2d73 7562 746c 6520  ermarker-subtle \n+0005f960: 7b20 636f 6c6f 723a 2023 3939 393b 207d  { color: #999; }\n+0005f970: 0a0a 2f2a 2043 5552 534f 5220 2a2f 0a0a  ../* CURSOR */..\n+0005f980: 2e43 6f64 654d 6972 726f 722d 6375 7273  .CodeMirror-curs\n+0005f990: 6f72 207b 0a20 2062 6f72 6465 722d 6c65  or {.  border-le\n+0005f9a0: 6674 3a20 3170 7820 736f 6c69 6420 626c  ft: 1px solid bl\n+0005f9b0: 6163 6b3b 0a20 2062 6f72 6465 722d 7269  ack;.  border-ri\n+0005f9c0: 6768 743a 206e 6f6e 653b 0a20 2077 6964  ght: none;.  wid\n+0005f9d0: 7468 3a20 303b 0a7d 0a0a 2f2a 2053 686f  th: 0;.}../* Sho\n+0005f9e0: 776e 2077 6865 6e20 6d6f 7669 6e67 2069  wn when moving i\n+0005f9f0: 6e20 6269 2d64 6972 6563 7469 6f6e 616c  n bi-directional\n+0005fa00: 2074 6578 7420 2a2f 0a0a 2e43 6f64 654d   text */...CodeM\n+0005fa10: 6972 726f 7220 6469 762e 436f 6465 4d69  irror div.CodeMi\n+0005fa20: 7272 6f72 2d73 6563 6f6e 6461 7279 6375  rror-secondarycu\n+0005fa30: 7273 6f72 207b 0a20 2062 6f72 6465 722d  rsor {.  border-\n+0005fa40: 6c65 6674 3a20 3170 7820 736f 6c69 6420  left: 1px solid \n+0005fa50: 7369 6c76 6572 3b0a 7d0a 0a2e 636d 2d66  silver;.}...cm-f\n+0005fa60: 6174 2d63 7572 736f 7220 2e43 6f64 654d  at-cursor .CodeM\n+0005fa70: 6972 726f 722d 6375 7273 6f72 207b 0a20  irror-cursor {. \n+0005fa80: 2077 6964 7468 3a20 6175 746f 3b0a 2020   width: auto;.  \n+0005fa90: 626f 7264 6572 3a20 3020 2169 6d70 6f72  border: 0 !impor\n+0005faa0: 7461 6e74 3b0a 2020 6261 636b 6772 6f75  tant;.  backgrou\n+0005fab0: 6e64 3a20 2337 6537 3b0a 7d0a 0a2e 636d  nd: #7e7;.}...cm\n+0005fac0: 2d66 6174 2d63 7572 736f 7220 6469 762e  -fat-cursor div.\n+0005fad0: 436f 6465 4d69 7272 6f72 2d63 7572 736f  CodeMirror-curso\n+0005fae0: 7273 207b 0a20 207a 2d69 6e64 6578 3a20  rs {.  z-index: \n+0005faf0: 313b 0a7d 0a0a 2e63 6d2d 6661 742d 6375  1;.}...cm-fat-cu\n+0005fb00: 7273 6f72 202e 436f 6465 4d69 7272 6f72  rsor .CodeMirror\n+0005fb10: 2d6c 696e 653a 3a73 656c 6563 7469 6f6e  -line::selection\n+0005fb20: 2c0a 2e63 6d2d 6661 742d 6375 7273 6f72  ,..cm-fat-cursor\n+0005fb30: 202e 436f 6465 4d69 7272 6f72 2d6c 696e   .CodeMirror-lin\n+0005fb40: 6520 3e20 7370 616e 3a3a 7365 6c65 6374  e > span::select\n+0005fb50: 696f 6e2c 200a 2e63 6d2d 6661 742d 6375  ion, ..cm-fat-cu\n+0005fb60: 7273 6f72 202e 436f 6465 4d69 7272 6f72  rsor .CodeMirror\n+0005fb70: 2d6c 696e 6520 3e20 7370 616e 203e 2073  -line > span > s\n+0005fb80: 7061 6e3a 3a73 656c 6563 7469 6f6e 207b  pan::selection {\n+0005fb90: 2062 6163 6b67 726f 756e 643a 2074 7261   background: tra\n+0005fba0: 6e73 7061 7265 6e74 3b20 7d0a 0a2e 636d  nsparent; }...cm\n+0005fbb0: 2d66 6174 2d63 7572 736f 7220 2e43 6f64  -fat-cursor .Cod\n+0005fbc0: 654d 6972 726f 722d 6c69 6e65 3a3a 2d6d  eMirror-line::-m\n+0005fbd0: 6f7a 2d73 656c 6563 7469 6f6e 2c0a 2e63  oz-selection,..c\n+0005fbe0: 6d2d 6661 742d 6375 7273 6f72 202e 436f  m-fat-cursor .Co\n+0005fbf0: 6465 4d69 7272 6f72 2d6c 696e 6520 3e20  deMirror-line > \n+0005fc00: 7370 616e 3a3a 2d6d 6f7a 2d73 656c 6563  span::-moz-selec\n+0005fc10: 7469 6f6e 2c0a 2e63 6d2d 6661 742d 6375  tion,..cm-fat-cu\n+0005fc20: 7273 6f72 202e 436f 6465 4d69 7272 6f72  rsor .CodeMirror\n+0005fc30: 2d6c 696e 6520 3e20 7370 616e 203e 2073  -line > span > s\n+0005fc40: 7061 6e3a 3a2d 6d6f 7a2d 7365 6c65 6374  pan::-moz-select\n+0005fc50: 696f 6e20 7b20 6261 636b 6772 6f75 6e64  ion { background\n+0005fc60: 3a20 7472 616e 7370 6172 656e 743b 207d  : transparent; }\n+0005fc70: 0a0a 2e63 6d2d 6661 742d 6375 7273 6f72  ...cm-fat-cursor\n+0005fc80: 207b 2063 6172 6574 2d63 6f6c 6f72 3a20   { caret-color: \n+0005fc90: 7472 616e 7370 6172 656e 743b 207d 0a0a  transparent; }..\n+0005fca0: 402d 6d6f 7a2d 6b65 7966 7261 6d65 7320  @-moz-keyframes \n+0005fcb0: 626c 696e 6b20 7b0a 2020 3025 207b 7d0a  blink {.  0% {}.\n+0005fcc0: 2020 3530 2520 7b20 6261 636b 6772 6f75    50% { backgrou\n+0005fcd0: 6e64 2d63 6f6c 6f72 3a20 7472 616e 7370  nd-color: transp\n+0005fce0: 6172 656e 743b 207d 0a20 2031 3030 2520  arent; }.  100% \n+0005fcf0: 7b7d 0a7d 0a0a 402d 7765 626b 6974 2d6b  {}.}..@-webkit-k\n+0005fd00: 6579 6672 616d 6573 2062 6c69 6e6b 207b  eyframes blink {\n+0005fd10: 0a20 2030 2520 7b7d 0a20 2035 3025 207b  .  0% {}.  50% {\n+0005fd20: 2062 6163 6b67 726f 756e 642d 636f 6c6f   background-colo\n+0005fd30: 723a 2074 7261 6e73 7061 7265 6e74 3b20  r: transparent; \n+0005fd40: 7d0a 2020 3130 3025 207b 7d0a 7d0a 0a40  }.  100% {}.}..@\n+0005fd50: 6b65 7966 7261 6d65 7320 626c 696e 6b20  keyframes blink \n+0005fd60: 7b0a 2020 3025 207b 7d0a 2020 3530 2520  {.  0% {}.  50% \n+0005fd70: 7b20 6261 636b 6772 6f75 6e64 2d63 6f6c  { background-col\n+0005fd80: 6f72 3a20 7472 616e 7370 6172 656e 743b  or: transparent;\n+0005fd90: 207d 0a20 2031 3030 2520 7b7d 0a7d 0a0a   }.  100% {}.}..\n+0005fda0: 2f2a 2043 616e 2073 7479 6c65 2063 7572  /* Can style cur\n+0005fdb0: 736f 7220 6469 6666 6572 656e 7420 696e  sor different in\n+0005fdc0: 206f 7665 7277 7269 7465 2028 6e6f 6e2d   overwrite (non-\n+0005fdd0: 696e 7365 7274 2920 6d6f 6465 202a 2f0a  insert) mode */.\n+0005fde0: 0a2e 436f 6465 4d69 7272 6f72 2d6f 7665  ..CodeMirror-ove\n+0005fdf0: 7277 7269 7465 202e 436f 6465 4d69 7272  rwrite .CodeMirr\n+0005fe00: 6f72 2d63 7572 736f 7220 7b7d 0a0a 2e63  or-cursor {}...c\n+0005fe10: 6d2d 7461 6220 7b20 6469 7370 6c61 793a  m-tab { display:\n+0005fe20: 2069 6e6c 696e 652d 626c 6f63 6b3b 2074   inline-block; t\n+0005fe30: 6578 742d 6465 636f 7261 7469 6f6e 3a20  ext-decoration: \n+0005fe40: 696e 6865 7269 743b 207d 0a0a 2e43 6f64  inherit; }...Cod\n+0005fe50: 654d 6972 726f 722d 7275 6c65 7273 207b  eMirror-rulers {\n+0005fe60: 0a20 2070 6f73 6974 696f 6e3a 2061 6273  .  position: abs\n+0005fe70: 6f6c 7574 653b 0a20 206c 6566 743a 2030  olute;.  left: 0\n+0005fe80: 3b20 7269 6768 743a 2030 3b20 746f 703a  ; right: 0; top:\n+0005fe90: 202d 3530 7078 3b20 626f 7474 6f6d 3a20   -50px; bottom: \n+0005fea0: 303b 0a20 206f 7665 7266 6c6f 773a 2068  0;.  overflow: h\n+0005feb0: 6964 6465 6e3b 0a7d 0a0a 2e43 6f64 654d  idden;.}...CodeM\n+0005fec0: 6972 726f 722d 7275 6c65 7220 7b0a 2020  irror-ruler {.  \n+0005fed0: 626f 7264 6572 2d6c 6566 743a 2031 7078  border-left: 1px\n+0005fee0: 2073 6f6c 6964 2023 6363 633b 0a20 2074   solid #ccc;.  t\n+0005fef0: 6f70 3a20 303b 2062 6f74 746f 6d3a 2030  op: 0; bottom: 0\n+0005ff00: 3b0a 2020 706f 7369 7469 6f6e 3a20 6162  ;.  position: ab\n+0005ff10: 736f 6c75 7465 3b0a 7d0a 0a2f 2a20 4445  solute;.}../* DE\n+0005ff20: 4641 554c 5420 5448 454d 4520 2a2f 0a0a  FAULT THEME */..\n+0005ff30: 2e63 6d2d 732d 6465 6661 756c 7420 2e63  .cm-s-default .c\n+0005ff40: 6d2d 6865 6164 6572 207b 636f 6c6f 723a  m-header {color:\n+0005ff50: 2062 6c75 653b 7d0a 0a2e 636d 2d73 2d64   blue;}...cm-s-d\n+0005ff60: 6566 6175 6c74 202e 636d 2d71 756f 7465  efault .cm-quote\n+0005ff70: 207b 636f 6c6f 723a 2023 3039 303b 7d0a   {color: #090;}.\n+0005ff80: 0a2e 636d 2d6e 6567 6174 6976 6520 7b63  ..cm-negative {c\n+0005ff90: 6f6c 6f72 3a20 2364 3434 3b7d 0a0a 2e63  olor: #d44;}...c\n+0005ffa0: 6d2d 706f 7369 7469 7665 207b 636f 6c6f  m-positive {colo\n+0005ffb0: 723a 2023 3239 323b 7d0a 0a2e 636d 2d68  r: #292;}...cm-h\n+0005ffc0: 6561 6465 722c 202e 636d 2d73 7472 6f6e  eader, .cm-stron\n+0005ffd0: 6720 7b66 6f6e 742d 7765 6967 6874 3a20  g {font-weight: \n+0005ffe0: 626f 6c64 3b7d 0a0a 2e63 6d2d 656d 207b  bold;}...cm-em {\n+0005fff0: 666f 6e74 2d73 7479 6c65 3a20 6974 616c  font-style: ital\n+00060000: 6963 3b7d 0a0a 2e63 6d2d 6c69 6e6b 207b  ic;}...cm-link {\n+00060010: 7465 7874 2d64 6563 6f72 6174 696f 6e3a  text-decoration:\n+00060020: 2075 6e64 6572 6c69 6e65 3b7d 0a0a 2e63   underline;}...c\n+00060030: 6d2d 7374 7269 6b65 7468 726f 7567 6820  m-strikethrough \n+00060040: 7b74 6578 742d 6465 636f 7261 7469 6f6e  {text-decoration\n+00060050: 3a20 6c69 6e65 2d74 6872 6f75 6768 3b7d  : line-through;}\n+00060060: 0a0a 2e63 6d2d 732d 6465 6661 756c 7420  ...cm-s-default \n+00060070: 2e63 6d2d 6b65 7977 6f72 6420 7b63 6f6c  .cm-keyword {col\n+00060080: 6f72 3a20 2337 3038 3b7d 0a0a 2e63 6d2d  or: #708;}...cm-\n+00060090: 732d 6465 6661 756c 7420 2e63 6d2d 6174  s-default .cm-at\n+000600a0: 6f6d 207b 636f 6c6f 723a 2023 3231 393b  om {color: #219;\n+000600b0: 7d0a 0a2e 636d 2d73 2d64 6566 6175 6c74  }...cm-s-default\n+000600c0: 202e 636d 2d6e 756d 6265 7220 7b63 6f6c   .cm-number {col\n+000600d0: 6f72 3a20 2331 3634 3b7d 0a0a 2e63 6d2d  or: #164;}...cm-\n+000600e0: 732d 6465 6661 756c 7420 2e63 6d2d 6465  s-default .cm-de\n+000600f0: 6620 7b63 6f6c 6f72 3a20 2330 3066 3b7d  f {color: #00f;}\n+00060100: 0a0a 2e63 6d2d 732d 6465 6661 756c 7420  ...cm-s-default \n+00060110: 2e63 6d2d 7661 7269 6162 6c65 2c0a 2e63  .cm-variable,..c\n+00060120: 6d2d 732d 6465 6661 756c 7420 2e63 6d2d  m-s-default .cm-\n+00060130: 7075 6e63 7475 6174 696f 6e2c 0a2e 636d  punctuation,..cm\n+00060140: 2d73 2d64 6566 6175 6c74 202e 636d 2d70  -s-default .cm-p\n+00060150: 726f 7065 7274 792c 0a2e 636d 2d73 2d64  roperty,..cm-s-d\n+00060160: 6566 6175 6c74 202e 636d 2d6f 7065 7261  efault .cm-opera\n+00060170: 746f 7220 7b7d 0a0a 2e63 6d2d 732d 6465  tor {}...cm-s-de\n+00060180: 6661 756c 7420 2e63 6d2d 7661 7269 6162  fault .cm-variab\n+00060190: 6c65 2d32 207b 636f 6c6f 723a 2023 3035  le-2 {color: #05\n+000601a0: 613b 7d0a 0a2e 636d 2d73 2d64 6566 6175  a;}...cm-s-defau\n+000601b0: 6c74 202e 636d 2d76 6172 6961 626c 652d  lt .cm-variable-\n+000601c0: 332c 202e 636d 2d73 2d64 6566 6175 6c74  3, .cm-s-default\n+000601d0: 202e 636d 2d74 7970 6520 7b63 6f6c 6f72   .cm-type {color\n+000601e0: 3a20 2330 3835 3b7d 0a0a 2e63 6d2d 732d  : #085;}...cm-s-\n+000601f0: 6465 6661 756c 7420 2e63 6d2d 636f 6d6d  default .cm-comm\n+00060200: 656e 7420 7b63 6f6c 6f72 3a20 2361 3530  ent {color: #a50\n+00060210: 3b7d 0a0a 2e63 6d2d 732d 6465 6661 756c  ;}...cm-s-defaul\n+00060220: 7420 2e63 6d2d 7374 7269 6e67 207b 636f  t .cm-string {co\n+00060230: 6c6f 723a 2023 6131 313b 7d0a 0a2e 636d  lor: #a11;}...cm\n+00060240: 2d73 2d64 6566 6175 6c74 202e 636d 2d73  -s-default .cm-s\n+00060250: 7472 696e 672d 3220 7b63 6f6c 6f72 3a20  tring-2 {color: \n+00060260: 2366 3530 3b7d 0a0a 2e63 6d2d 732d 6465  #f50;}...cm-s-de\n+00060270: 6661 756c 7420 2e63 6d2d 6d65 7461 207b  fault .cm-meta {\n+00060280: 636f 6c6f 723a 2023 3535 353b 7d0a 0a2e  color: #555;}...\n+00060290: 636d 2d73 2d64 6566 6175 6c74 202e 636d  cm-s-default .cm\n+000602a0: 2d71 7561 6c69 6669 6572 207b 636f 6c6f  -qualifier {colo\n+000602b0: 723a 2023 3535 353b 7d0a 0a2e 636d 2d73  r: #555;}...cm-s\n+000602c0: 2d64 6566 6175 6c74 202e 636d 2d62 7569  -default .cm-bui\n+000602d0: 6c74 696e 207b 636f 6c6f 723a 2023 3330  ltin {color: #30\n+000602e0: 613b 7d0a 0a2e 636d 2d73 2d64 6566 6175  a;}...cm-s-defau\n+000602f0: 6c74 202e 636d 2d62 7261 636b 6574 207b  lt .cm-bracket {\n+00060300: 636f 6c6f 723a 2023 3939 373b 7d0a 0a2e  color: #997;}...\n+00060310: 636d 2d73 2d64 6566 6175 6c74 202e 636d  cm-s-default .cm\n+00060320: 2d74 6167 207b 636f 6c6f 723a 2023 3137  -tag {color: #17\n+00060330: 303b 7d0a 0a2e 636d 2d73 2d64 6566 6175  0;}...cm-s-defau\n+00060340: 6c74 202e 636d 2d61 7474 7269 6275 7465  lt .cm-attribute\n+00060350: 207b 636f 6c6f 723a 2023 3030 633b 7d0a   {color: #00c;}.\n+00060360: 0a2e 636d 2d73 2d64 6566 6175 6c74 202e  ..cm-s-default .\n+00060370: 636d 2d68 7220 7b63 6f6c 6f72 3a20 2339  cm-hr {color: #9\n+00060380: 3939 3b7d 0a0a 2e63 6d2d 732d 6465 6661  99;}...cm-s-defa\n+00060390: 756c 7420 2e63 6d2d 6c69 6e6b 207b 636f  ult .cm-link {co\n+000603a0: 6c6f 723a 2023 3030 633b 7d0a 0a2e 636d  lor: #00c;}...cm\n+000603b0: 2d73 2d64 6566 6175 6c74 202e 636d 2d65  -s-default .cm-e\n+000603c0: 7272 6f72 207b 636f 6c6f 723a 2023 6630  rror {color: #f0\n+000603d0: 303b 7d0a 0a2e 636d 2d69 6e76 616c 6964  0;}...cm-invalid\n+000603e0: 6368 6172 207b 636f 6c6f 723a 2023 6630  char {color: #f0\n+000603f0: 303b 7d0a 0a2e 436f 6465 4d69 7272 6f72  0;}...CodeMirror\n+00060400: 2d63 6f6d 706f 7369 6e67 207b 2062 6f72  -composing { bor\n+00060410: 6465 722d 626f 7474 6f6d 3a20 3270 7820  der-bottom: 2px \n+00060420: 736f 6c69 643b 207d 0a0a 2f2a 2044 6566  solid; }../* Def\n+00060430: 6175 6c74 2073 7479 6c65 7320 666f 7220  ault styles for \n+00060440: 636f 6d6d 6f6e 2061 6464 6f6e 7320 2a2f  common addons */\n+00060450: 0a0a 6469 762e 436f 6465 4d69 7272 6f72  ..div.CodeMirror\n+00060460: 2073 7061 6e2e 436f 6465 4d69 7272 6f72   span.CodeMirror\n+00060470: 2d6d 6174 6368 696e 6762 7261 636b 6574  -matchingbracket\n+00060480: 207b 636f 6c6f 723a 2023 3062 303b 7d0a   {color: #0b0;}.\n+00060490: 0a64 6976 2e43 6f64 654d 6972 726f 7220  .div.CodeMirror \n+000604a0: 7370 616e 2e43 6f64 654d 6972 726f 722d  span.CodeMirror-\n+000604b0: 6e6f 6e6d 6174 6368 696e 6762 7261 636b  nonmatchingbrack\n+000604c0: 6574 207b 636f 6c6f 723a 2023 6132 323b  et {color: #a22;\n+000604d0: 7d0a 0a2e 436f 6465 4d69 7272 6f72 2d6d  }...CodeMirror-m\n+000604e0: 6174 6368 696e 6774 6167 207b 2062 6163  atchingtag { bac\n+000604f0: 6b67 726f 756e 643a 2072 6762 6128 3235  kground: rgba(25\n+00060500: 352c 2031 3530 2c20 302c 202e 3329 3b20  5, 150, 0, .3); \n+00060510: 7d0a 0a2e 436f 6465 4d69 7272 6f72 2d61  }...CodeMirror-a\n+00060520: 6374 6976 656c 696e 652d 6261 636b 6772  ctiveline-backgr\n+00060530: 6f75 6e64 207b 6261 636b 6772 6f75 6e64  ound {background\n+00060540: 3a20 2365 3866 3266 663b 7d0a 0a2f 2a20  : #e8f2ff;}../* \n+00060550: 5354 4f50 202a 2f0a 0a2f 2a20 5468 6520  STOP */../* The \n+00060560: 7265 7374 206f 6620 7468 6973 2066 696c  rest of this fil\n+00060570: 6520 636f 6e74 6169 6e73 2073 7479 6c65  e contains style\n+00060580: 7320 7265 6c61 7465 6420 746f 2074 6865  s related to the\n+00060590: 206d 6563 6861 6e69 6373 206f 660a 2020   mechanics of.  \n+000605a0: 2074 6865 2065 6469 746f 722e 2059 6f75   the editor. You\n+000605b0: 2070 726f 6261 626c 7920 7368 6f75 6c64   probably should\n+000605c0: 6e27 7420 746f 7563 6820 7468 656d 2e20  n't touch them. \n+000605d0: 2a2f 0a0a 2e43 6f64 654d 6972 726f 7220  */...CodeMirror \n+000605e0: 7b0a 2020 706f 7369 7469 6f6e 3a20 7265  {.  position: re\n+000605f0: 6c61 7469 7665 3b0a 2020 6f76 6572 666c  lative;.  overfl\n+00060600: 6f77 3a20 6869 6464 656e 3b0a 2020 6261  ow: hidden;.  ba\n+00060610: 636b 6772 6f75 6e64 3a20 7768 6974 653b  ckground: white;\n+00060620: 0a7d 0a0a 2e43 6f64 654d 6972 726f 722d  .}...CodeMirror-\n+00060630: 7363 726f 6c6c 207b 0a20 206f 7665 7266  scroll {.  overf\n+00060640: 6c6f 773a 2073 6372 6f6c 6c20 2169 6d70  low: scroll !imp\n+00060650: 6f72 7461 6e74 3b20 2f2a 2054 6869 6e67  ortant; /* Thing\n+00060660: 7320 7769 6c6c 2062 7265 616b 2069 6620  s will break if \n+00060670: 7468 6973 2069 7320 6f76 6572 7269 6464  this is overridd\n+00060680: 656e 202a 2f0a 2020 2f2a 2035 3070 7820  en */.  /* 50px \n+00060690: 6973 2074 6865 206d 6167 6963 206d 6172  is the magic mar\n+000606a0: 6769 6e20 7573 6564 2074 6f20 6869 6465  gin used to hide\n+000606b0: 2074 6865 2065 6c65 6d65 6e74 2773 2072   the element's r\n+000606c0: 6561 6c20 7363 726f 6c6c 6261 7273 202a  eal scrollbars *\n+000606d0: 2f0a 2020 2f2a 2053 6565 206f 7665 7266  /.  /* See overf\n+000606e0: 6c6f 773a 2068 6964 6465 6e20 696e 202e  low: hidden in .\n+000606f0: 436f 6465 4d69 7272 6f72 202a 2f0a 2020  CodeMirror */.  \n+00060700: 6d61 7267 696e 2d62 6f74 746f 6d3a 202d  margin-bottom: -\n+00060710: 3530 7078 3b20 6d61 7267 696e 2d72 6967  50px; margin-rig\n+00060720: 6874 3a20 2d35 3070 783b 0a20 2070 6164  ht: -50px;.  pad\n+00060730: 6469 6e67 2d62 6f74 746f 6d3a 2035 3070  ding-bottom: 50p\n+00060740: 783b 0a20 2068 6569 6768 743a 2031 3030  x;.  height: 100\n+00060750: 253b 0a20 206f 7574 6c69 6e65 3a20 6e6f  %;.  outline: no\n+00060760: 6e65 3b20 2f2a 2050 7265 7665 6e74 2064  ne; /* Prevent d\n+00060770: 7261 6767 696e 6720 6672 6f6d 2068 6967  ragging from hig\n+00060780: 686c 6967 6874 696e 6720 7468 6520 656c  hlighting the el\n+00060790: 656d 656e 7420 2a2f 0a20 2070 6f73 6974  ement */.  posit\n+000607a0: 696f 6e3a 2072 656c 6174 6976 653b 0a20  ion: relative;. \n+000607b0: 207a 2d69 6e64 6578 3a20 303b 0a7d 0a0a   z-index: 0;.}..\n+000607c0: 2e43 6f64 654d 6972 726f 722d 7369 7a65  .CodeMirror-size\n+000607d0: 7220 7b0a 2020 706f 7369 7469 6f6e 3a20  r {.  position: \n+000607e0: 7265 6c61 7469 7665 3b0a 2020 626f 7264  relative;.  bord\n+000607f0: 6572 2d72 6967 6874 3a20 3530 7078 2073  er-right: 50px s\n+00060800: 6f6c 6964 2074 7261 6e73 7061 7265 6e74  olid transparent\n+00060810: 3b0a 7d0a 0a2f 2a20 5468 6520 6661 6b65  ;.}../* The fake\n+00060820: 2c20 7669 7369 626c 6520 7363 726f 6c6c  , visible scroll\n+00060830: 6261 7273 2e20 5573 6564 2074 6f20 666f  bars. Used to fo\n+00060840: 7263 6520 7265 6472 6177 2064 7572 696e  rce redraw durin\n+00060850: 6720 7363 726f 6c6c 696e 670a 2020 2062  g scrolling.   b\n+00060860: 6566 6f72 6520 6163 7475 616c 2073 6372  efore actual scr\n+00060870: 6f6c 6c69 6e67 2068 6170 7065 6e73 2c20  olling happens, \n+00060880: 7468 7573 2070 7265 7665 6e74 696e 6720  thus preventing \n+00060890: 7368 616b 696e 6720 616e 640a 2020 2066  shaking and.   f\n+000608a0: 6c69 636b 6572 696e 6720 6172 7469 6661  lickering artifa\n+000608b0: 6374 732e 202a 2f0a 0a2e 436f 6465 4d69  cts. */...CodeMi\n+000608c0: 7272 6f72 2d76 7363 726f 6c6c 6261 722c  rror-vscrollbar,\n+000608d0: 202e 436f 6465 4d69 7272 6f72 2d68 7363   .CodeMirror-hsc\n+000608e0: 726f 6c6c 6261 722c 202e 436f 6465 4d69  rollbar, .CodeMi\n+000608f0: 7272 6f72 2d73 6372 6f6c 6c62 6172 2d66  rror-scrollbar-f\n+00060900: 696c 6c65 722c 202e 436f 6465 4d69 7272  iller, .CodeMirr\n+00060910: 6f72 2d67 7574 7465 722d 6669 6c6c 6572  or-gutter-filler\n+00060920: 207b 0a20 2070 6f73 6974 696f 6e3a 2061   {.  position: a\n+00060930: 6273 6f6c 7574 653b 0a20 207a 2d69 6e64  bsolute;.  z-ind\n+00060940: 6578 3a20 363b 0a20 2064 6973 706c 6179  ex: 6;.  display\n+00060950: 3a20 6e6f 6e65 3b0a 2020 6f75 746c 696e  : none;.  outlin\n+00060960: 653a 206e 6f6e 653b 0a7d 0a0a 2e43 6f64  e: none;.}...Cod\n+00060970: 654d 6972 726f 722d 7673 6372 6f6c 6c62  eMirror-vscrollb\n+00060980: 6172 207b 0a20 2072 6967 6874 3a20 303b  ar {.  right: 0;\n+00060990: 2074 6f70 3a20 303b 0a20 206f 7665 7266   top: 0;.  overf\n+000609a0: 6c6f 772d 783a 2068 6964 6465 6e3b 0a20  low-x: hidden;. \n+000609b0: 206f 7665 7266 6c6f 772d 793a 2073 6372   overflow-y: scr\n+000609c0: 6f6c 6c3b 0a7d 0a0a 2e43 6f64 654d 6972  oll;.}...CodeMir\n+000609d0: 726f 722d 6873 6372 6f6c 6c62 6172 207b  ror-hscrollbar {\n+000609e0: 0a20 2062 6f74 746f 6d3a 2030 3b20 6c65  .  bottom: 0; le\n+000609f0: 6674 3a20 303b 0a20 206f 7665 7266 6c6f  ft: 0;.  overflo\n+00060a00: 772d 793a 2068 6964 6465 6e3b 0a20 206f  w-y: hidden;.  o\n+00060a10: 7665 7266 6c6f 772d 783a 2073 6372 6f6c  verflow-x: scrol\n+00060a20: 6c3b 0a7d 0a0a 2e43 6f64 654d 6972 726f  l;.}...CodeMirro\n+00060a30: 722d 7363 726f 6c6c 6261 722d 6669 6c6c  r-scrollbar-fill\n+00060a40: 6572 207b 0a20 2072 6967 6874 3a20 303b  er {.  right: 0;\n+00060a50: 2062 6f74 746f 6d3a 2030 3b0a 7d0a 0a2e   bottom: 0;.}...\n+00060a60: 436f 6465 4d69 7272 6f72 2d67 7574 7465  CodeMirror-gutte\n+00060a70: 722d 6669 6c6c 6572 207b 0a20 206c 6566  r-filler {.  lef\n+00060a80: 743a 2030 3b20 626f 7474 6f6d 3a20 303b  t: 0; bottom: 0;\n+00060a90: 0a7d 0a0a 2e43 6f64 654d 6972 726f 722d  .}...CodeMirror-\n+00060aa0: 6775 7474 6572 7320 7b0a 2020 706f 7369  gutters {.  posi\n+00060ab0: 7469 6f6e 3a20 6162 736f 6c75 7465 3b20  tion: absolute; \n+00060ac0: 6c65 6674 3a20 303b 2074 6f70 3a20 303b  left: 0; top: 0;\n+00060ad0: 0a20 206d 696e 2d68 6569 6768 743a 2031  .  min-height: 1\n+00060ae0: 3030 253b 0a20 207a 2d69 6e64 6578 3a20  00%;.  z-index: \n+00060af0: 333b 0a7d 0a0a 2e43 6f64 654d 6972 726f  3;.}...CodeMirro\n+00060b00: 722d 6775 7474 6572 207b 0a20 2077 6869  r-gutter {.  whi\n+00060b10: 7465 2d73 7061 6365 3a20 6e6f 726d 616c  te-space: normal\n+00060b20: 3b0a 2020 6865 6967 6874 3a20 3130 3025  ;.  height: 100%\n+00060b30: 3b0a 2020 6469 7370 6c61 793a 2069 6e6c  ;.  display: inl\n+00060b40: 696e 652d 626c 6f63 6b3b 0a20 2076 6572  ine-block;.  ver\n+00060b50: 7469 6361 6c2d 616c 6967 6e3a 2074 6f70  tical-align: top\n+00060b60: 3b0a 2020 6d61 7267 696e 2d62 6f74 746f  ;.  margin-botto\n+00060b70: 6d3a 202d 3530 7078 3b0a 7d0a 0a2e 436f  m: -50px;.}...Co\n+00060b80: 6465 4d69 7272 6f72 2d67 7574 7465 722d  deMirror-gutter-\n+00060b90: 7772 6170 7065 7220 7b0a 2020 706f 7369  wrapper {.  posi\n+00060ba0: 7469 6f6e 3a20 6162 736f 6c75 7465 3b0a  tion: absolute;.\n+00060bb0: 2020 7a2d 696e 6465 783a 2034 3b0a 2020    z-index: 4;.  \n+00060bc0: 6261 636b 6772 6f75 6e64 3a20 6e6f 6e65  background: none\n+00060bd0: 2021 696d 706f 7274 616e 743b 0a20 2062   !important;.  b\n+00060be0: 6f72 6465 723a 206e 6f6e 6520 2169 6d70  order: none !imp\n+00060bf0: 6f72 7461 6e74 3b0a 7d0a 0a2e 436f 6465  ortant;.}...Code\n+00060c00: 4d69 7272 6f72 2d67 7574 7465 722d 6261  Mirror-gutter-ba\n+00060c10: 636b 6772 6f75 6e64 207b 0a20 2070 6f73  ckground {.  pos\n+00060c20: 6974 696f 6e3a 2061 6273 6f6c 7574 653b  ition: absolute;\n+00060c30: 0a20 2074 6f70 3a20 303b 2062 6f74 746f  .  top: 0; botto\n+00060c40: 6d3a 2030 3b0a 2020 7a2d 696e 6465 783a  m: 0;.  z-index:\n+00060c50: 2034 3b0a 7d0a 0a2e 436f 6465 4d69 7272   4;.}...CodeMirr\n+00060c60: 6f72 2d67 7574 7465 722d 656c 7420 7b0a  or-gutter-elt {.\n+00060c70: 2020 706f 7369 7469 6f6e 3a20 6162 736f    position: abso\n+00060c80: 6c75 7465 3b0a 2020 6375 7273 6f72 3a20  lute;.  cursor: \n+00060c90: 6465 6661 756c 743b 0a20 207a 2d69 6e64  default;.  z-ind\n+00060ca0: 6578 3a20 343b 0a7d 0a0a 2e43 6f64 654d  ex: 4;.}...CodeM\n+00060cb0: 6972 726f 722d 6775 7474 6572 2d77 7261  irror-gutter-wra\n+00060cc0: 7070 6572 203a 3a73 656c 6563 7469 6f6e  pper ::selection\n+00060cd0: 207b 2062 6163 6b67 726f 756e 642d 636f   { background-co\n+00060ce0: 6c6f 723a 2074 7261 6e73 7061 7265 6e74  lor: transparent\n+00060cf0: 207d 0a0a 2e43 6f64 654d 6972 726f 722d   }...CodeMirror-\n+00060d00: 6775 7474 6572 2d77 7261 7070 6572 203a  gutter-wrapper :\n+00060d10: 3a2d 6d6f 7a2d 7365 6c65 6374 696f 6e20  :-moz-selection \n+00060d20: 7b20 6261 636b 6772 6f75 6e64 2d63 6f6c  { background-col\n+00060d30: 6f72 3a20 7472 616e 7370 6172 656e 7420  or: transparent \n+00060d40: 7d0a 0a2e 436f 6465 4d69 7272 6f72 2d6c  }...CodeMirror-l\n+00060d50: 696e 6573 207b 0a20 2063 7572 736f 723a  ines {.  cursor:\n+00060d60: 2074 6578 743b 0a20 206d 696e 2d68 6569   text;.  min-hei\n+00060d70: 6768 743a 2031 7078 3b20 2f2a 2070 7265  ght: 1px; /* pre\n+00060d80: 7665 6e74 7320 636f 6c6c 6170 7369 6e67  vents collapsing\n+00060d90: 2062 6566 6f72 6520 6669 7273 7420 6472   before first dr\n+00060da0: 6177 202a 2f0a 7d0a 0a2e 436f 6465 4d69  aw */.}...CodeMi\n+00060db0: 7272 6f72 2070 7265 2e43 6f64 654d 6972  rror pre.CodeMir\n+00060dc0: 726f 722d 6c69 6e65 2c0a 2e43 6f64 654d  ror-line,..CodeM\n+00060dd0: 6972 726f 7220 7072 652e 436f 6465 4d69  irror pre.CodeMi\n+00060de0: 7272 6f72 2d6c 696e 652d 6c69 6b65 207b  rror-line-like {\n+00060df0: 0a20 202f 2a20 5265 7365 7420 736f 6d65  .  /* Reset some\n+00060e00: 2073 7479 6c65 7320 7468 6174 2074 6865   styles that the\n+00060e10: 2072 6573 7420 6f66 2074 6865 2070 6167   rest of the pag\n+00060e20: 6520 6d69 6768 7420 6861 7665 2073 6574  e might have set\n+00060e30: 202a 2f0a 2020 2d6d 6f7a 2d62 6f72 6465   */.  -moz-borde\n+00060e40: 722d 7261 6469 7573 3a20 303b 202d 7765  r-radius: 0; -we\n+00060e50: 626b 6974 2d62 6f72 6465 722d 7261 6469  bkit-border-radi\n+00060e60: 7573 3a20 303b 2062 6f72 6465 722d 7261  us: 0; border-ra\n+00060e70: 6469 7573 3a20 303b 0a20 2062 6f72 6465  dius: 0;.  borde\n+00060e80: 722d 7769 6474 683a 2030 3b0a 2020 6261  r-width: 0;.  ba\n+00060e90: 636b 6772 6f75 6e64 3a20 7472 616e 7370  ckground: transp\n+00060ea0: 6172 656e 743b 0a20 2066 6f6e 742d 6661  arent;.  font-fa\n+00060eb0: 6d69 6c79 3a20 696e 6865 7269 743b 0a20  mily: inherit;. \n+00060ec0: 2066 6f6e 742d 7369 7a65 3a20 696e 6865   font-size: inhe\n+00060ed0: 7269 743b 0a20 206d 6172 6769 6e3a 2030  rit;.  margin: 0\n+00060ee0: 3b0a 2020 7768 6974 652d 7370 6163 653a  ;.  white-space:\n+00060ef0: 2070 7265 3b0a 2020 776f 7264 2d77 7261   pre;.  word-wra\n+00060f00: 703a 206e 6f72 6d61 6c3b 0a20 206c 696e  p: normal;.  lin\n+00060f10: 652d 6865 6967 6874 3a20 696e 6865 7269  e-height: inheri\n+00060f20: 743b 0a20 2063 6f6c 6f72 3a20 696e 6865  t;.  color: inhe\n+00060f30: 7269 743b 0a20 207a 2d69 6e64 6578 3a20  rit;.  z-index: \n+00060f40: 323b 0a20 2070 6f73 6974 696f 6e3a 2072  2;.  position: r\n+00060f50: 656c 6174 6976 653b 0a20 206f 7665 7266  elative;.  overf\n+00060f60: 6c6f 773a 2076 6973 6962 6c65 3b0a 2020  low: visible;.  \n+00060f70: 2d77 6562 6b69 742d 7461 702d 6869 6768  -webkit-tap-high\n+00060f80: 6c69 6768 742d 636f 6c6f 723a 2074 7261  light-color: tra\n+00060f90: 6e73 7061 7265 6e74 3b0a 2020 2d77 6562  nsparent;.  -web\n+00060fa0: 6b69 742d 666f 6e74 2d76 6172 6961 6e74  kit-font-variant\n+00060fb0: 2d6c 6967 6174 7572 6573 3a20 636f 6e74  -ligatures: cont\n+00060fc0: 6578 7475 616c 3b0a 2020 666f 6e74 2d76  extual;.  font-v\n+00060fd0: 6172 6961 6e74 2d6c 6967 6174 7572 6573  ariant-ligatures\n+00060fe0: 3a20 636f 6e74 6578 7475 616c 3b0a 7d0a  : contextual;.}.\n+00060ff0: 0a2e 436f 6465 4d69 7272 6f72 2d77 7261  ..CodeMirror-wra\n+00061000: 7020 7072 652e 436f 6465 4d69 7272 6f72  p pre.CodeMirror\n+00061010: 2d6c 696e 652c 0a2e 436f 6465 4d69 7272  -line,..CodeMirr\n+00061020: 6f72 2d77 7261 7020 7072 652e 436f 6465  or-wrap pre.Code\n+00061030: 4d69 7272 6f72 2d6c 696e 652d 6c69 6b65  Mirror-line-like\n+00061040: 207b 0a20 2077 6f72 642d 7772 6170 3a20   {.  word-wrap: \n+00061050: 6272 6561 6b2d 776f 7264 3b0a 2020 7768  break-word;.  wh\n+00061060: 6974 652d 7370 6163 653a 2070 7265 2d77  ite-space: pre-w\n+00061070: 7261 703b 0a20 2077 6f72 642d 6272 6561  rap;.  word-brea\n+00061080: 6b3a 206e 6f72 6d61 6c3b 0a7d 0a0a 2e43  k: normal;.}...C\n+00061090: 6f64 654d 6972 726f 722d 6c69 6e65 6261  odeMirror-lineba\n+000610a0: 636b 6772 6f75 6e64 207b 0a20 2070 6f73  ckground {.  pos\n+000610b0: 6974 696f 6e3a 2061 6273 6f6c 7574 653b  ition: absolute;\n+000610c0: 0a20 206c 6566 743a 2030 3b20 7269 6768  .  left: 0; righ\n+000610d0: 743a 2030 3b20 746f 703a 2030 3b20 626f  t: 0; top: 0; bo\n+000610e0: 7474 6f6d 3a20 303b 0a20 207a 2d69 6e64  ttom: 0;.  z-ind\n+000610f0: 6578 3a20 303b 0a7d 0a0a 2e43 6f64 654d  ex: 0;.}...CodeM\n+00061100: 6972 726f 722d 6c69 6e65 7769 6467 6574  irror-linewidget\n+00061110: 207b 0a20 2070 6f73 6974 696f 6e3a 2072   {.  position: r\n+00061120: 656c 6174 6976 653b 0a20 207a 2d69 6e64  elative;.  z-ind\n+00061130: 6578 3a20 323b 0a20 2070 6164 6469 6e67  ex: 2;.  padding\n+00061140: 3a20 302e 3170 783b 202f 2a20 466f 7263  : 0.1px; /* Forc\n+00061150: 6520 7769 6467 6574 206d 6172 6769 6e73  e widget margins\n+00061160: 2074 6f20 7374 6179 2069 6e73 6964 6520   to stay inside \n+00061170: 6f66 2074 6865 2063 6f6e 7461 696e 6572  of the container\n+00061180: 202a 2f0a 7d0a 0a2e 436f 6465 4d69 7272   */.}...CodeMirr\n+00061190: 6f72 2d77 6964 6765 7420 7b7d 0a0a 2e43  or-widget {}...C\n+000611a0: 6f64 654d 6972 726f 722d 7274 6c20 7072  odeMirror-rtl pr\n+000611b0: 6520 7b20 6469 7265 6374 696f 6e3a 2072  e { direction: r\n+000611c0: 746c 3b20 7d0a 0a2e 436f 6465 4d69 7272  tl; }...CodeMirr\n+000611d0: 6f72 2d63 6f64 6520 7b0a 2020 6f75 746c  or-code {.  outl\n+000611e0: 696e 653a 206e 6f6e 653b 0a7d 0a0a 2f2a  ine: none;.}../*\n+000611f0: 2046 6f72 6365 2063 6f6e 7465 6e74 2d62   Force content-b\n+00061200: 6f78 2073 697a 696e 6720 666f 7220 7468  ox sizing for th\n+00061210: 6520 656c 656d 656e 7473 2077 6865 7265  e elements where\n+00061220: 2077 6520 6578 7065 6374 2069 7420 2a2f   we expect it */\n+00061230: 0a0a 2e43 6f64 654d 6972 726f 722d 7363  ...CodeMirror-sc\n+00061240: 726f 6c6c 2c0a 2e43 6f64 654d 6972 726f  roll,..CodeMirro\n+00061250: 722d 7369 7a65 722c 0a2e 436f 6465 4d69  r-sizer,..CodeMi\n+00061260: 7272 6f72 2d67 7574 7465 722c 0a2e 436f  rror-gutter,..Co\n+00061270: 6465 4d69 7272 6f72 2d67 7574 7465 7273  deMirror-gutters\n+00061280: 2c0a 2e43 6f64 654d 6972 726f 722d 6c69  ,..CodeMirror-li\n+00061290: 6e65 6e75 6d62 6572 207b 0a20 202d 6d6f  nenumber {.  -mo\n+000612a0: 7a2d 626f 782d 7369 7a69 6e67 3a20 636f  z-box-sizing: co\n+000612b0: 6e74 656e 742d 626f 783b 0a20 2062 6f78  ntent-box;.  box\n+000612c0: 2d73 697a 696e 673a 2063 6f6e 7465 6e74  -sizing: content\n+000612d0: 2d62 6f78 3b0a 7d0a 0a2e 436f 6465 4d69  -box;.}...CodeMi\n+000612e0: 7272 6f72 2d6d 6561 7375 7265 207b 0a20  rror-measure {. \n+000612f0: 2070 6f73 6974 696f 6e3a 2061 6273 6f6c   position: absol\n+00061300: 7574 653b 0a20 2077 6964 7468 3a20 3130  ute;.  width: 10\n+00061310: 3025 3b0a 2020 6865 6967 6874 3a20 303b  0%;.  height: 0;\n+00061320: 0a20 206f 7665 7266 6c6f 773a 2068 6964  .  overflow: hid\n+00061330: 6465 6e3b 0a20 2076 6973 6962 696c 6974  den;.  visibilit\n+00061340: 793a 2068 6964 6465 6e3b 0a7d 0a0a 2e43  y: hidden;.}...C\n+00061350: 6f64 654d 6972 726f 722d 6375 7273 6f72  odeMirror-cursor\n+00061360: 207b 0a20 2070 6f73 6974 696f 6e3a 2061   {.  position: a\n+00061370: 6273 6f6c 7574 653b 0a20 2070 6f69 6e74  bsolute;.  point\n+00061380: 6572 2d65 7665 6e74 733a 206e 6f6e 653b  er-events: none;\n+00061390: 0a7d 0a0a 2e43 6f64 654d 6972 726f 722d  .}...CodeMirror-\n+000613a0: 6d65 6173 7572 6520 7072 6520 7b20 706f  measure pre { po\n+000613b0: 7369 7469 6f6e 3a20 7374 6174 6963 3b20  sition: static; \n+000613c0: 7d0a 0a64 6976 2e43 6f64 654d 6972 726f  }..div.CodeMirro\n+000613d0: 722d 6375 7273 6f72 7320 7b0a 2020 7669  r-cursors {.  vi\n+000613e0: 7369 6269 6c69 7479 3a20 6869 6464 656e  sibility: hidden\n+000613f0: 3b0a 2020 706f 7369 7469 6f6e 3a20 7265  ;.  position: re\n+00061400: 6c61 7469 7665 3b0a 2020 7a2d 696e 6465  lative;.  z-inde\n+00061410: 783a 2033 3b0a 7d0a 0a64 6976 2e43 6f64  x: 3;.}..div.Cod\n+00061420: 654d 6972 726f 722d 6472 6167 6375 7273  eMirror-dragcurs\n+00061430: 6f72 7320 7b0a 2020 7669 7369 6269 6c69  ors {.  visibili\n+00061440: 7479 3a20 7669 7369 626c 653b 0a7d 0a0a  ty: visible;.}..\n+00061450: 2e43 6f64 654d 6972 726f 722d 666f 6375  .CodeMirror-focu\n+00061460: 7365 6420 6469 762e 436f 6465 4d69 7272  sed div.CodeMirr\n+00061470: 6f72 2d63 7572 736f 7273 207b 0a20 2076  or-cursors {.  v\n+00061480: 6973 6962 696c 6974 793a 2076 6973 6962  isibility: visib\n+00061490: 6c65 3b0a 7d0a 0a2e 436f 6465 4d69 7272  le;.}...CodeMirr\n+000614a0: 6f72 2d73 656c 6563 7465 6420 7b20 6261  or-selected { ba\n+000614b0: 636b 6772 6f75 6e64 3a20 2364 3964 3964  ckground: #d9d9d\n+000614c0: 393b 207d 0a0a 2e43 6f64 654d 6972 726f  9; }...CodeMirro\n+000614d0: 722d 666f 6375 7365 6420 2e43 6f64 654d  r-focused .CodeM\n+000614e0: 6972 726f 722d 7365 6c65 6374 6564 207b  irror-selected {\n+000614f0: 2062 6163 6b67 726f 756e 643a 2023 6437   background: #d7\n+00061500: 6434 6630 3b20 7d0a 0a2e 436f 6465 4d69  d4f0; }...CodeMi\n+00061510: 7272 6f72 2d63 726f 7373 6861 6972 207b  rror-crosshair {\n+00061520: 2063 7572 736f 723a 2063 726f 7373 6861   cursor: crossha\n+00061530: 6972 3b20 7d0a 0a2e 436f 6465 4d69 7272  ir; }...CodeMirr\n+00061540: 6f72 2d6c 696e 653a 3a73 656c 6563 7469  or-line::selecti\n+00061550: 6f6e 2c20 2e43 6f64 654d 6972 726f 722d  on, .CodeMirror-\n+00061560: 6c69 6e65 203e 2073 7061 6e3a 3a73 656c  line > span::sel\n+00061570: 6563 7469 6f6e 2c20 2e43 6f64 654d 6972  ection, .CodeMir\n+00061580: 726f 722d 6c69 6e65 203e 2073 7061 6e20  ror-line > span \n+00061590: 3e20 7370 616e 3a3a 7365 6c65 6374 696f  > span::selectio\n+000615a0: 6e20 7b20 6261 636b 6772 6f75 6e64 3a20  n { background: \n+000615b0: 2364 3764 3466 303b 207d 0a0a 2e43 6f64  #d7d4f0; }...Cod\n+000615c0: 654d 6972 726f 722d 6c69 6e65 3a3a 2d6d  eMirror-line::-m\n+000615d0: 6f7a 2d73 656c 6563 7469 6f6e 2c20 2e43  oz-selection, .C\n+000615e0: 6f64 654d 6972 726f 722d 6c69 6e65 203e  odeMirror-line >\n+000615f0: 2073 7061 6e3a 3a2d 6d6f 7a2d 7365 6c65   span::-moz-sele\n+00061600: 6374 696f 6e2c 202e 436f 6465 4d69 7272  ction, .CodeMirr\n+00061610: 6f72 2d6c 696e 6520 3e20 7370 616e 203e  or-line > span >\n+00061620: 2073 7061 6e3a 3a2d 6d6f 7a2d 7365 6c65   span::-moz-sele\n+00061630: 6374 696f 6e20 7b20 6261 636b 6772 6f75  ction { backgrou\n+00061640: 6e64 3a20 2364 3764 3466 303b 207d 0a0a  nd: #d7d4f0; }..\n+00061650: 2e63 6d2d 7365 6172 6368 696e 6720 7b0a  .cm-searching {.\n+00061660: 2020 6261 636b 6772 6f75 6e64 2d63 6f6c    background-col\n+00061670: 6f72 3a20 2366 6661 3b0a 2020 6261 636b  or: #ffa;.  back\n+00061680: 6772 6f75 6e64 2d63 6f6c 6f72 3a20 7267  ground-color: rg\n+00061690: 6261 2832 3535 2c20 3235 352c 2030 2c20  ba(255, 255, 0, \n+000616a0: 2e34 293b 0a7d 0a0a 2f2a 2055 7365 6420  .4);.}../* Used \n+000616b0: 746f 2066 6f72 6365 2061 2062 6f72 6465  to force a borde\n+000616c0: 7220 6d6f 6465 6c20 666f 7220 6120 6e6f  r model for a no\n+000616d0: 6465 202a 2f0a 0a2e 636d 2d66 6f72 6365  de */...cm-force\n+000616e0: 2d62 6f72 6465 7220 7b20 7061 6464 696e  -border { paddin\n+000616f0: 672d 7269 6768 743a 202e 3170 783b 207d  g-right: .1px; }\n+00061700: 0a0a 406d 6564 6961 2070 7269 6e74 207b  ..@media print {\n+00061710: 0a20 202f 2a20 4869 6465 2074 6865 2063  .  /* Hide the c\n+00061720: 7572 736f 7220 7768 656e 2070 7269 6e74  ursor when print\n+00061730: 696e 6720 2a2f 0a20 202e 436f 6465 4d69  ing */.  .CodeMi\n+00061740: 7272 6f72 2064 6976 2e43 6f64 654d 6972  rror div.CodeMir\n+00061750: 726f 722d 6375 7273 6f72 7320 7b0a 2020  ror-cursors {.  \n+00061760: 2020 7669 7369 6269 6c69 7479 3a20 6869    visibility: hi\n+00061770: 6464 656e 3b0a 2020 7d0a 7d0a 0a2f 2a20  dden;.  }.}../* \n+00061780: 5365 6520 6973 7375 6520 2332 3930 3120  See issue #2901 \n+00061790: 2a2f 0a0a 2e63 6d2d 7461 622d 7772 6170  */...cm-tab-wrap\n+000617a0: 2d68 6163 6b3a 6166 7465 7220 7b20 636f  -hack:after { co\n+000617b0: 6e74 656e 743a 2027 273b 207d 0a0a 2f2a  ntent: ''; }../*\n+000617c0: 2048 656c 7020 7573 6572 7320 7573 6520   Help users use \n+000617d0: 6d61 726b 7365 6c65 6374 696f 6e20 746f  markselection to\n+000617e0: 2073 6166 656c 7920 7374 796c 6520 7465   safely style te\n+000617f0: 7874 2062 6163 6b67 726f 756e 6420 2a2f  xt background */\n+00061800: 0a0a 7370 616e 2e43 6f64 654d 6972 726f  ..span.CodeMirro\n+00061810: 722d 7365 6c65 6374 6564 7465 7874 207b  r-selectedtext {\n+00061820: 2062 6163 6b67 726f 756e 643a 206e 6f6e   background: non\n+00061830: 653b 207d 0a0a 2f2a 204d 616b 6520 7468  e; }../* Make th\n+00061840: 6520 6564 6974 6f72 7320 6669 6c6c 2075  e editors fill u\n+00061850: 7020 7468 6569 7220 636f 6e74 6169 6e65  p their containe\n+00061860: 7220 616e 6420 6d61 6b65 2074 6865 6d20  r and make them \n+00061870: 7363 726f 6c6c 6162 6c65 202a 2f0a 0a2e  scrollable */...\n+00061880: 6772 6170 6869 716c 2d63 6f6e 7461 696e  graphiql-contain\n+00061890: 6572 202e 436f 6465 4d69 7272 6f72 207b  er .CodeMirror {\n+000618a0: 0a20 2068 6569 6768 743a 2031 3030 253b  .  height: 100%;\n+000618b0: 0a20 2070 6f73 6974 696f 6e3a 2061 6273  .  position: abs\n+000618c0: 6f6c 7574 653b 0a20 2077 6964 7468 3a20  olute;.  width: \n+000618d0: 3130 3025 3b0a 7d0a 0a2f 2a20 4f76 6572  100%;.}../* Over\n+000618e0: 7269 6465 2066 6f6e 7420 7365 7474 696e  ride font settin\n+000618f0: 6773 202a 2f0a 0a2e 6772 6170 6869 716c  gs */...graphiql\n+00061900: 2d63 6f6e 7461 696e 6572 202e 436f 6465  -container .Code\n+00061910: 4d69 7272 6f72 207b 0a20 2066 6f6e 742d  Mirror {.  font-\n+00061920: 6661 6d69 6c79 3a20 7661 7228 2d2d 666f  family: var(--fo\n+00061930: 6e74 2d66 616d 696c 792d 6d6f 6e6f 293b  nt-family-mono);\n+00061940: 0a7d 0a0a 2f2a 2053 6574 2064 6566 6175  .}../* Set defau\n+00061950: 6c74 2062 6163 6b67 726f 756e 6420 636f  lt background co\n+00061960: 6c6f 7220 2a2f 0a0a 2e67 7261 7068 6971  lor */...graphiq\n+00061970: 6c2d 636f 6e74 6169 6e65 7220 2e43 6f64  l-container .Cod\n+00061980: 654d 6972 726f 722c 0a2e 6772 6170 6869  eMirror,..graphi\n+00061990: 716c 2d63 6f6e 7461 696e 6572 202e 436f  ql-container .Co\n+000619a0: 6465 4d69 7272 6f72 2d67 7574 7465 7273  deMirror-gutters\n+000619b0: 207b 0a20 2062 6163 6b67 726f 756e 643a   {.  background:\n+000619c0: 206e 6f6e 653b 0a20 2062 6163 6b67 726f   none;.  backgro\n+000619d0: 756e 642d 636f 6c6f 723a 2076 6172 282d  und-color: var(-\n+000619e0: 2d65 6469 746f 722d 6261 636b 6772 6f75  -editor-backgrou\n+000619f0: 6e64 2c20 6873 6c28 7661 7228 2d2d 636f  nd, hsl(var(--co\n+00061a00: 6c6f 722d 6261 7365 2929 293b 0a7d 0a0a  lor-base)));.}..\n+00061a10: 2f2a 204e 6f20 7061 6464 696e 6720 6172  /* No padding ar\n+00061a20: 6f75 6e64 206c 696e 6520 6e75 6d62 6572  ound line number\n+00061a30: 7320 2a2f 0a0a 2e67 7261 7068 6971 6c2d  s */...graphiql-\n+00061a40: 636f 6e74 6169 6e65 7220 2e43 6f64 654d  container .CodeM\n+00061a50: 6972 726f 722d 6c69 6e65 6e75 6d62 6572  irror-linenumber\n+00061a60: 207b 0a20 2070 6164 6469 6e67 3a20 303b   {.  padding: 0;\n+00061a70: 0a7d 0a0a 2f2a 204e 6f20 626f 7264 6572  .}../* No border\n+00061a80: 2062 6574 7765 656e 2067 7574 7465 7220   between gutter \n+00061a90: 616e 6420 6564 6974 6f72 202a 2f0a 0a2e  and editor */...\n+00061aa0: 6772 6170 6869 716c 2d63 6f6e 7461 696e  graphiql-contain\n+00061ab0: 6572 202e 436f 6465 4d69 7272 6f72 2d67  er .CodeMirror-g\n+00061ac0: 7574 7465 7273 207b 0a20 2062 6f72 6465  utters {.  borde\n+00061ad0: 723a 206e 6f6e 653b 0a7d 0a0a 2f2a 2a0a  r: none;.}../**.\n+00061ae0: 202a 2045 6469 746f 7220 7468 656d 650a   * Editor theme.\n+00061af0: 202a 2f0a 0a2e 636d 2d73 2d67 7261 7068   */...cm-s-graph\n+00061b00: 6971 6c20 7b0a 2020 2f2a 2044 6566 6175  iql {.  /* Defau\n+00061b10: 6c74 2074 6f20 7075 6e63 7475 6174 696f  lt to punctuatio\n+00061b20: 6e20 2a2f 0a20 2063 6f6c 6f72 3a20 6873  n */.  color: hs\n+00061b30: 6c61 2876 6172 282d 2d63 6f6c 6f72 2d6e  la(var(--color-n\n+00061b40: 6575 7472 616c 292c 2076 6172 282d 2d61  eutral), var(--a\n+00061b50: 6c70 6861 2d74 6572 7469 6172 7929 290a  lpha-tertiary)).\n+00061b60: 0a20 202f 2a20 4f70 6572 6174 696f 6e54  .  /* OperationT\n+00061b70: 7970 652c 2060 6672 6167 6d65 6e74 602c  ype, `fragment`,\n+00061b80: 2060 6f6e 6020 2a2f 0a7d 0a0a 2e63 6d2d   `on` */.}...cm-\n+00061b90: 732d 6772 6170 6869 716c 202e 636d 2d6b  s-graphiql .cm-k\n+00061ba0: 6579 776f 7264 207b 0a20 2020 2063 6f6c  eyword {.    col\n+00061bb0: 6f72 3a20 6873 6c28 7661 7228 2d2d 636f  or: hsl(var(--co\n+00061bc0: 6c6f 722d 7072 696d 6172 7929 293b 0a20  lor-primary));. \n+00061bd0: 207d 0a0a 2f2a 204e 616d 6520 284f 7065   }../* Name (Ope\n+00061be0: 7261 7469 6f6e 4465 6669 6e69 7469 6f6e  rationDefinition\n+00061bf0: 292c 2046 7261 676d 656e 744e 616d 6520  ), FragmentName \n+00061c00: 2a2f 0a0a 2e63 6d2d 732d 6772 6170 6869  */...cm-s-graphi\n+00061c10: 716c 202e 636d 2d64 6566 207b 0a20 2020  ql .cm-def {.   \n+00061c20: 2063 6f6c 6f72 3a20 6873 6c28 7661 7228   color: hsl(var(\n+00061c30: 2d2d 636f 6c6f 722d 7465 7274 6961 7279  --color-tertiary\n+00061c40: 2929 3b0a 2020 7d0a 0a2f 2a20 5075 6e63  ));.  }../* Punc\n+00061c50: 7475 6174 6f72 2028 6578 6365 7074 2060  tuator (except `\n+00061c60: 2460 2061 6e64 2060 4060 2920 2a2f 0a0a  $` and `@`) */..\n+00061c70: 2e63 6d2d 732d 6772 6170 6869 716c 202e  .cm-s-graphiql .\n+00061c80: 636d 2d70 756e 6374 7561 7469 6f6e 207b  cm-punctuation {\n+00061c90: 0a20 2020 2063 6f6c 6f72 3a20 6873 6c61  .    color: hsla\n+00061ca0: 2876 6172 282d 2d63 6f6c 6f72 2d6e 6575  (var(--color-neu\n+00061cb0: 7472 616c 292c 2076 6172 282d 2d61 6c70  tral), var(--alp\n+00061cc0: 6861 2d74 6572 7469 6172 7929 293b 0a20  ha-tertiary));. \n+00061cd0: 207d 0a0a 2f2a 2056 6172 6961 626c 6520   }../* Variable \n+00061ce0: 2a2f 0a0a 2e63 6d2d 732d 6772 6170 6869  */...cm-s-graphi\n+00061cf0: 716c 202e 636d 2d76 6172 6961 626c 6520  ql .cm-variable \n+00061d00: 7b0a 2020 2020 636f 6c6f 723a 2068 736c  {.    color: hsl\n+00061d10: 2876 6172 282d 2d63 6f6c 6f72 2d73 6563  (var(--color-sec\n+00061d20: 6f6e 6461 7279 2929 3b0a 2020 7d0a 0a2f  ondary));.  }../\n+00061d30: 2a20 4e61 6d65 6454 7970 6520 2a2f 0a0a  * NamedType */..\n+00061d40: 2e63 6d2d 732d 6772 6170 6869 716c 202e  .cm-s-graphiql .\n+00061d50: 636d 2d61 746f 6d20 7b0a 2020 2020 636f  cm-atom {.    co\n+00061d60: 6c6f 723a 2068 736c 2876 6172 282d 2d63  lor: hsl(var(--c\n+00061d70: 6f6c 6f72 2d74 6572 7469 6172 7929 293b  olor-tertiary));\n+00061d80: 0a20 207d 0a0a 2f2a 2049 6e74 5661 6c75  .  }../* IntValu\n+00061d90: 652c 2046 6c6f 6174 5661 6c75 6520 2a2f  e, FloatValue */\n+00061da0: 0a0a 2e63 6d2d 732d 6772 6170 6869 716c  ...cm-s-graphiql\n+00061db0: 202e 636d 2d6e 756d 6265 7220 7b0a 2020   .cm-number {.  \n+00061dc0: 2020 636f 6c6f 723a 2068 736c 2876 6172    color: hsl(var\n+00061dd0: 282d 2d63 6f6c 6f72 2d73 7563 6365 7373  (--color-success\n+00061de0: 2929 3b0a 2020 7d0a 0a2f 2a20 5374 7269  ));.  }../* Stri\n+00061df0: 6e67 5661 6c75 6520 2a2f 0a0a 2e63 6d2d  ngValue */...cm-\n+00061e00: 732d 6772 6170 6869 716c 202e 636d 2d73  s-graphiql .cm-s\n+00061e10: 7472 696e 6720 7b0a 2020 2020 636f 6c6f  tring {.    colo\n+00061e20: 723a 2068 736c 2876 6172 282d 2d63 6f6c  r: hsl(var(--col\n+00061e30: 6f72 2d77 6172 6e69 6e67 2929 3b0a 2020  or-warning));.  \n+00061e40: 7d0a 0a2f 2a20 426f 6f6c 6561 6e56 616c  }../* BooleanVal\n+00061e50: 7565 202a 2f0a 0a2e 636d 2d73 2d67 7261  ue */...cm-s-gra\n+00061e60: 7068 6971 6c20 2e63 6d2d 6275 696c 7469  phiql .cm-builti\n+00061e70: 6e20 7b0a 2020 2020 636f 6c6f 723a 2068  n {.    color: h\n+00061e80: 736c 2876 6172 282d 2d63 6f6c 6f72 2d73  sl(var(--color-s\n+00061e90: 7563 6365 7373 2929 3b0a 2020 7d0a 0a2f  uccess));.  }../\n+00061ea0: 2a20 456e 756d 5661 6c75 6520 2a2f 0a0a  * EnumValue */..\n+00061eb0: 2e63 6d2d 732d 6772 6170 6869 716c 202e  .cm-s-graphiql .\n+00061ec0: 636d 2d73 7472 696e 672d 3220 7b0a 2020  cm-string-2 {.  \n+00061ed0: 2020 636f 6c6f 723a 2068 736c 2876 6172    color: hsl(var\n+00061ee0: 282d 2d63 6f6c 6f72 2d73 6563 6f6e 6461  (--color-seconda\n+00061ef0: 7279 2929 3b0a 2020 7d0a 0a2f 2a20 4e61  ry));.  }../* Na\n+00061f00: 6d65 2028 4f62 6a65 6374 4669 656c 642c  me (ObjectField,\n+00061f10: 2041 7267 756d 656e 7429 202a 2f0a 0a2e   Argument) */...\n+00061f20: 636d 2d73 2d67 7261 7068 6971 6c20 2e63  cm-s-graphiql .c\n+00061f30: 6d2d 6174 7472 6962 7574 6520 7b0a 2020  m-attribute {.  \n+00061f40: 2020 636f 6c6f 723a 2068 736c 2876 6172    color: hsl(var\n+00061f50: 282d 2d63 6f6c 6f72 2d74 6572 7469 6172  (--color-tertiar\n+00061f60: 7929 293b 0a20 207d 0a0a 2f2a 204e 616d  y));.  }../* Nam\n+00061f70: 6520 2844 6972 6563 7469 7665 2920 2a2f  e (Directive) */\n+00061f80: 0a0a 2e63 6d2d 732d 6772 6170 6869 716c  ...cm-s-graphiql\n+00061f90: 202e 636d 2d6d 6574 6120 7b0a 2020 2020   .cm-meta {.    \n+00061fa0: 636f 6c6f 723a 2068 736c 2876 6172 282d  color: hsl(var(-\n+00061fb0: 2d63 6f6c 6f72 2d74 6572 7469 6172 7929  -color-tertiary)\n+00061fc0: 293b 0a20 207d 0a0a 2f2a 204e 616d 6520  );.  }../* Name \n+00061fd0: 2841 6c69 6173 2c20 4669 656c 6420 7769  (Alias, Field wi\n+00061fe0: 7468 6f75 7420 416c 6961 7329 202a 2f0a  thout Alias) */.\n+00061ff0: 0a2e 636d 2d73 2d67 7261 7068 6971 6c20  ..cm-s-graphiql \n+00062000: 2e63 6d2d 7072 6f70 6572 7479 207b 0a20  .cm-property {. \n+00062010: 2020 2063 6f6c 6f72 3a20 6873 6c28 7661     color: hsl(va\n+00062020: 7228 2d2d 636f 6c6f 722d 696e 666f 2929  r(--color-info))\n+00062030: 3b0a 2020 7d0a 0a2f 2a20 4e61 6d65 2028  ;.  }../* Name (\n+00062040: 4669 656c 6420 7769 7468 2041 6c69 6173  Field with Alias\n+00062050: 2920 2a2f 0a0a 2e63 6d2d 732d 6772 6170  ) */...cm-s-grap\n+00062060: 6869 716c 202e 636d 2d71 7561 6c69 6669  hiql .cm-qualifi\n+00062070: 6572 207b 0a20 2020 2063 6f6c 6f72 3a20  er {.    color: \n+00062080: 6873 6c28 7661 7228 2d2d 636f 6c6f 722d  hsl(var(--color-\n+00062090: 7365 636f 6e64 6172 7929 293b 0a20 207d  secondary));.  }\n+000620a0: 0a0a 2f2a 2043 6f6d 6d65 6e74 202a 2f0a  ../* Comment */.\n+000620b0: 0a2e 636d 2d73 2d67 7261 7068 6971 6c20  ..cm-s-graphiql \n+000620c0: 2e63 6d2d 636f 6d6d 656e 7420 7b0a 2020  .cm-comment {.  \n+000620d0: 2020 636f 6c6f 723a 2068 736c 6128 7661    color: hsla(va\n+000620e0: 7228 2d2d 636f 6c6f 722d 6e65 7574 7261  r(--color-neutra\n+000620f0: 6c29 2c20 7661 7228 2d2d 616c 7068 612d  l), var(--alpha-\n+00062100: 7365 636f 6e64 6172 7929 293b 0a20 207d  secondary));.  }\n+00062110: 0a0a 2f2a 2057 6869 7465 7370 6163 6520  ../* Whitespace \n+00062120: 2a2f 0a0a 2e63 6d2d 732d 6772 6170 6869  */...cm-s-graphi\n+00062130: 716c 202e 636d 2d77 7320 7b0a 2020 2020  ql .cm-ws {.    \n+00062140: 636f 6c6f 723a 2068 736c 6128 7661 7228  color: hsla(var(\n+00062150: 2d2d 636f 6c6f 722d 6e65 7574 7261 6c29  --color-neutral)\n+00062160: 2c20 7661 7228 2d2d 616c 7068 612d 7465  , var(--alpha-te\n+00062170: 7274 6961 7279 2929 3b0a 2020 7d0a 0a2f  rtiary));.  }../\n+00062180: 2a20 496e 7661 6c69 6420 6368 6172 6163  * Invalid charac\n+00062190: 7465 7273 202a 2f0a 0a2e 636d 2d73 2d67  ters */...cm-s-g\n+000621a0: 7261 7068 6971 6c20 2e63 6d2d 696e 7661  raphiql .cm-inva\n+000621b0: 6c69 6463 6861 7220 7b0a 2020 2020 636f  lidchar {.    co\n+000621c0: 6c6f 723a 2068 736c 2876 6172 282d 2d63  lor: hsl(var(--c\n+000621d0: 6f6c 6f72 2d65 7272 6f72 2929 3b0a 2020  olor-error));.  \n+000621e0: 7d0a 0a2f 2a20 4375 7273 6f72 202a 2f0a  }../* Cursor */.\n+000621f0: 0a2e 636d 2d73 2d67 7261 7068 6971 6c20  ..cm-s-graphiql \n+00062200: 2e43 6f64 654d 6972 726f 722d 6375 7273  .CodeMirror-curs\n+00062210: 6f72 207b 0a20 2020 2062 6f72 6465 722d  or {.    border-\n+00062220: 6c65 6674 3a20 3270 7820 736f 6c69 6420  left: 2px solid \n+00062230: 6873 6c61 2876 6172 282d 2d63 6f6c 6f72  hsla(var(--color\n+00062240: 2d6e 6575 7472 616c 292c 2076 6172 282d  -neutral), var(-\n+00062250: 2d61 6c70 6861 2d73 6563 6f6e 6461 7279  -alpha-secondary\n+00062260: 2929 3b0a 2020 7d0a 0a2f 2a20 436f 6c6f  ));.  }../* Colo\n+00062270: 7220 666f 7220 6c69 6e65 206e 756d 6265  r for line numbe\n+00062280: 7273 2061 6e64 2066 6f6c 642d 6775 7474  rs and fold-gutt\n+00062290: 6572 7320 2a2f 0a0a 2e63 6d2d 732d 6772  ers */...cm-s-gr\n+000622a0: 6170 6869 716c 202e 436f 6465 4d69 7272  aphiql .CodeMirr\n+000622b0: 6f72 2d6c 696e 656e 756d 6265 7220 7b0a  or-linenumber {.\n+000622c0: 2020 2020 636f 6c6f 723a 2068 736c 6128      color: hsla(\n+000622d0: 7661 7228 2d2d 636f 6c6f 722d 6e65 7574  var(--color-neut\n+000622e0: 7261 6c29 2c20 7661 7228 2d2d 616c 7068  ral), var(--alph\n+000622f0: 612d 7465 7274 6961 7279 2929 3b0a 2020  a-tertiary));.  \n+00062300: 7d0a 0a2f 2a20 4d61 7463 6869 6e67 2062  }../* Matching b\n+00062310: 7261 636b 6574 2063 6f6c 6f72 7320 2a2f  racket colors */\n+00062320: 0a0a 2e67 7261 7068 6971 6c2d 636f 6e74  ...graphiql-cont\n+00062330: 6169 6e65 7220 6469 762e 436f 6465 4d69  ainer div.CodeMi\n+00062340: 7272 6f72 2073 7061 6e2e 436f 6465 4d69  rror span.CodeMi\n+00062350: 7272 6f72 2d6d 6174 6368 696e 6762 7261  rror-matchingbra\n+00062360: 636b 6574 2c0a 2e67 7261 7068 6971 6c2d  cket,..graphiql-\n+00062370: 636f 6e74 6169 6e65 7220 6469 762e 436f  container div.Co\n+00062380: 6465 4d69 7272 6f72 2073 7061 6e2e 436f  deMirror span.Co\n+00062390: 6465 4d69 7272 6f72 2d6e 6f6e 6d61 7463  deMirror-nonmatc\n+000623a0: 6869 6e67 6272 6163 6b65 7420 7b0a 2020  hingbracket {.  \n+000623b0: 636f 6c6f 723a 2068 736c 2876 6172 282d  color: hsl(var(-\n+000623c0: 2d63 6f6c 6f72 2d77 6172 6e69 6e67 2929  -color-warning))\n+000623d0: 3b0a 7d0a 0a2f 2a20 5365 6c65 6374 6564  ;.}../* Selected\n+000623e0: 2074 6578 7420 626c 6f63 6b73 202a 2f0a   text blocks */.\n+000623f0: 0a2e 6772 6170 6869 716c 2d63 6f6e 7461  ..graphiql-conta\n+00062400: 696e 6572 202e 436f 6465 4d69 7272 6f72  iner .CodeMirror\n+00062410: 2d73 656c 6563 7465 642c 0a2e 6772 6170  -selected,..grap\n+00062420: 6869 716c 2d63 6f6e 7461 696e 6572 202e  hiql-container .\n+00062430: 436f 6465 4d69 7272 6f72 2d66 6f63 7573  CodeMirror-focus\n+00062440: 6564 202e 436f 6465 4d69 7272 6f72 2d73  ed .CodeMirror-s\n+00062450: 656c 6563 7465 6420 7b0a 2020 6261 636b  elected {.  back\n+00062460: 6772 6f75 6e64 3a20 6873 6c61 2876 6172  ground: hsla(var\n+00062470: 282d 2d63 6f6c 6f72 2d6e 6575 7472 616c  (--color-neutral\n+00062480: 292c 2076 6172 282d 2d61 6c70 6861 2d62  ), var(--alpha-b\n+00062490: 6163 6b67 726f 756e 642d 6865 6176 7929  ackground-heavy)\n+000624a0: 293b 0a7d 0a0a 2f2a 2050 6f73 6974 696f  );.}../* Positio\n+000624b0: 6e20 7468 6520 7365 6172 6368 2064 6961  n the search dia\n+000624c0: 6c6f 6720 2a2f 0a0a 2e67 7261 7068 6971  log */...graphiq\n+000624d0: 6c2d 636f 6e74 6169 6e65 7220 2e43 6f64  l-container .Cod\n+000624e0: 654d 6972 726f 722d 6469 616c 6f67 207b  eMirror-dialog {\n+000624f0: 0a20 2062 6163 6b67 726f 756e 643a 2069  .  background: i\n+00062500: 6e68 6572 6974 3b0a 2020 636f 6c6f 723a  nherit;.  color:\n+00062510: 2069 6e68 6572 6974 3b0a 2020 6c65 6674   inherit;.  left\n+00062520: 3a20 303b 0a20 2072 6967 6874 3a20 303b  : 0;.  right: 0;\n+00062530: 0a20 206f 7665 7266 6c6f 773a 2068 6964  .  overflow: hid\n+00062540: 6465 6e3b 0a20 2070 6164 6469 6e67 3a20  den;.  padding: \n+00062550: 7661 7228 2d2d 7078 2d32 2920 7661 7228  var(--px-2) var(\n+00062560: 2d2d 7078 2d36 293b 0a20 2070 6f73 6974  --px-6);.  posit\n+00062570: 696f 6e3a 2061 6273 6f6c 7574 653b 0a20  ion: absolute;. \n+00062580: 207a 2d69 6e64 6578 3a20 363b 0a7d 0a0a   z-index: 6;.}..\n+00062590: 2e67 7261 7068 6971 6c2d 636f 6e74 6169  .graphiql-contai\n+000625a0: 6e65 7220 2e43 6f64 654d 6972 726f 722d  ner .CodeMirror-\n+000625b0: 6469 616c 6f67 2d74 6f70 207b 0a20 2062  dialog-top {.  b\n+000625c0: 6f72 6465 722d 626f 7474 6f6d 3a20 3170  order-bottom: 1p\n+000625d0: 7820 736f 6c69 640a 2020 2020 6873 6c61  x solid.    hsla\n+000625e0: 2876 6172 282d 2d63 6f6c 6f72 2d6e 6575  (var(--color-neu\n+000625f0: 7472 616c 292c 2076 6172 282d 2d61 6c70  tral), var(--alp\n+00062600: 6861 2d62 6163 6b67 726f 756e 642d 6865  ha-background-he\n+00062610: 6176 7929 293b 0a20 2070 6164 6469 6e67  avy));.  padding\n+00062620: 2d62 6f74 746f 6d3a 2076 6172 282d 2d70  -bottom: var(--p\n+00062630: 782d 3132 293b 0a20 2074 6f70 3a20 303b  x-12);.  top: 0;\n+00062640: 0a7d 0a0a 2e67 7261 7068 6971 6c2d 636f  .}...graphiql-co\n+00062650: 6e74 6169 6e65 7220 2e43 6f64 654d 6972  ntainer .CodeMir\n+00062660: 726f 722d 6469 616c 6f67 2d62 6f74 746f  ror-dialog-botto\n+00062670: 6d20 7b0a 2020 626f 7264 6572 2d74 6f70  m {.  border-top\n+00062680: 3a20 3170 7820 736f 6c69 640a 2020 2020  : 1px solid.    \n+00062690: 6873 6c61 2876 6172 282d 2d63 6f6c 6f72  hsla(var(--color\n+000626a0: 2d6e 6575 7472 616c 292c 2076 6172 282d  -neutral), var(-\n+000626b0: 2d61 6c70 6861 2d62 6163 6b67 726f 756e  -alpha-backgroun\n+000626c0: 642d 6865 6176 7929 293b 0a20 2062 6f74  d-heavy));.  bot\n+000626d0: 746f 6d3a 2030 3b0a 2020 7061 6464 696e  tom: 0;.  paddin\n+000626e0: 672d 746f 703a 2076 6172 282d 2d70 782d  g-top: var(--px-\n+000626f0: 3132 293b 0a7d 0a0a 2f2a 2048 6964 6520  12);.}../* Hide \n+00062700: 7468 6520 7365 6172 6368 2068 696e 7420  the search hint \n+00062710: 2a2f 0a0a 2e67 7261 7068 6971 6c2d 636f  */...graphiql-co\n+00062720: 6e74 6169 6e65 7220 2e43 6f64 654d 6972  ntainer .CodeMir\n+00062730: 726f 722d 7365 6172 6368 2d68 696e 7420  ror-search-hint \n+00062740: 7b0a 2020 6469 7370 6c61 793a 206e 6f6e  {.  display: non\n+00062750: 653b 0a7d 0a0a 2f2a 2053 7479 6c65 2074  e;.}../* Style t\n+00062760: 6865 2069 6e70 7574 2066 6965 6c64 2066  he input field f\n+00062770: 6f72 2073 6561 7263 6869 6e67 202a 2f0a  or searching */.\n+00062780: 0a2e 6772 6170 6869 716c 2d63 6f6e 7461  ..graphiql-conta\n+00062790: 696e 6572 202e 436f 6465 4d69 7272 6f72  iner .CodeMirror\n+000627a0: 2d64 6961 6c6f 6720 696e 7075 7420 7b0a  -dialog input {.\n+000627b0: 2020 626f 7264 6572 3a20 3170 7820 736f    border: 1px so\n+000627c0: 6c69 6420 6873 6c61 2876 6172 282d 2d63  lid hsla(var(--c\n+000627d0: 6f6c 6f72 2d6e 6575 7472 616c 292c 2076  olor-neutral), v\n+000627e0: 6172 282d 2d61 6c70 6861 2d62 6163 6b67  ar(--alpha-backg\n+000627f0: 726f 756e 642d 6865 6176 7929 293b 0a20  round-heavy));. \n+00062800: 2062 6f72 6465 722d 7261 6469 7573 3a20   border-radius: \n+00062810: 7661 7228 2d2d 626f 7264 6572 2d72 6164  var(--border-rad\n+00062820: 6975 732d 3429 3b0a 2020 7061 6464 696e  ius-4);.  paddin\n+00062830: 673a 2076 6172 282d 2d70 782d 3429 3b0a  g: var(--px-4);.\n+00062840: 7d0a 0a2e 6772 6170 6869 716c 2d63 6f6e  }...graphiql-con\n+00062850: 7461 696e 6572 202e 436f 6465 4d69 7272  tainer .CodeMirr\n+00062860: 6f72 2d64 6961 6c6f 6720 696e 7075 743a  or-dialog input:\n+00062870: 666f 6375 7320 7b0a 2020 6f75 746c 696e  focus {.  outlin\n+00062880: 653a 2068 736c 2876 6172 282d 2d63 6f6c  e: hsl(var(--col\n+00062890: 6f72 2d70 7269 6d61 7279 2929 2073 6f6c  or-primary)) sol\n+000628a0: 6964 2032 7078 3b0a 7d0a 0a2f 2a20 5365  id 2px;.}../* Se\n+000628b0: 7420 7468 6520 6869 6768 6c69 6768 7420  t the highlight \n+000628c0: 636f 6c6f 7220 666f 7220 7365 6172 6368  color for search\n+000628d0: 2072 6573 756c 7473 202a 2f0a 0a2e 6772   results */...gr\n+000628e0: 6170 6869 716c 2d63 6f6e 7461 696e 6572  aphiql-container\n+000628f0: 202e 636d 2d73 6561 7263 6869 6e67 207b   .cm-searching {\n+00062900: 0a20 2062 6163 6b67 726f 756e 642d 636f  .  background-co\n+00062910: 6c6f 723a 2068 736c 6128 7661 7228 2d2d  lor: hsla(var(--\n+00062920: 636f 6c6f 722d 7761 726e 696e 6729 2c20  color-warning), \n+00062930: 7661 7228 2d2d 616c 7068 612d 6261 636b  var(--alpha-back\n+00062940: 6772 6f75 6e64 2d6c 6967 6874 2929 3b0a  ground-light));.\n+00062950: 2020 2f2a 2a0a 2020 202a 2057 6865 6e20    /**.   * When \n+00062960: 6379 636c 696e 6720 7468 726f 7567 6820  cycling through \n+00062970: 7365 6172 6368 2072 6573 756c 7473 2c20  search results, \n+00062980: 436f 6465 4d69 7272 6f72 206f 7665 726c  CodeMirror overl\n+00062990: 6179 7320 7468 6520 6375 7272 656e 7420  ays the current \n+000629a0: 0a20 2020 2a20 7365 6c65 6374 696f 6e20  .   * selection \n+000629b0: 7769 7468 2061 6e6f 7468 6572 2065 6c65  with another ele\n+000629c0: 6d65 6e74 2074 6861 7420 6861 7320 7468  ment that has th\n+000629d0: 6520 2e43 6f64 654d 6972 726f 722d 7365  e .CodeMirror-se\n+000629e0: 6c65 6374 6564 2063 6c61 7373 0a20 2020  lected class.   \n+000629f0: 2a20 6170 706c 6965 642e 2054 6869 7320  * applied. This \n+00062a00: 6164 6473 2061 6e6f 7468 6572 2062 6163  adds another bac\n+00062a10: 6b67 726f 756e 6420 636f 6c6f 7220 2873  kground color (s\n+00062a20: 6565 2061 626f 7665 292c 2062 7574 2074  ee above), but t\n+00062a30: 6869 7320 6578 7472 610a 2020 202a 2062  his extra.   * b\n+00062a40: 6f78 2064 6f65 7320 6e6f 7420 7175 6974  ox does not quit\n+00062a50: 6520 6d61 7463 6820 7468 6520 6865 6967  e match the heig\n+00062a60: 6874 206f 6620 7468 6973 2065 6c65 6d65  ht of this eleme\n+00062a70: 6e74 2e20 546f 206d 6174 6368 2074 6865  nt. To match the\n+00062a80: 6d20 7570 2077 650a 2020 202a 2061 6464  m up we.   * add\n+00062a90: 2073 6f6d 6520 6578 7472 6120 7061 6464   some extra padd\n+00062aa0: 696e 6720 6865 7265 2e20 284e 6f74 6520  ing here. (Note \n+00062ab0: 7468 6174 2074 6869 7320 646f 6573 6e27  that this doesn'\n+00062ac0: 7420 6166 6665 6374 2074 6865 206c 696e  t affect the lin\n+00062ad0: 650a 2020 202a 2068 6569 6768 7420 6f66  e.   * height of\n+00062ae0: 2074 6865 2043 6f64 654d 6972 726f 7220   the CodeMirror \n+00062af0: 6564 6974 6f72 2061 7320 616c 6c20 6c69  editor as all li\n+00062b00: 6e65 2077 7261 7070 6572 7320 6861 7665  ne wrappers have\n+00062b10: 2061 2066 6978 6564 2068 6569 6768 742e   a fixed height.\n+00062b20: 290a 2020 202a 2f0a 2020 7061 6464 696e  ).   */.  paddin\n+00062b30: 672d 626f 7474 6f6d 3a20 312e 3570 783b  g-bottom: 1.5px;\n+00062b40: 0a20 2070 6164 6469 6e67 2d74 6f70 3a20  .  padding-top: \n+00062b50: 302e 3570 783b 0a7d 0a2e 436f 6465 4d69  0.5px;.}..CodeMi\n+00062b60: 7272 6f72 2d66 6f6c 646d 6172 6b65 7220  rror-foldmarker \n+00062b70: 7b0a 2020 636f 6c6f 723a 2062 6c75 653b  {.  color: blue;\n+00062b80: 0a20 2074 6578 742d 7368 6164 6f77 3a20  .  text-shadow: \n+00062b90: 2362 3966 2031 7078 2031 7078 2032 7078  #b9f 1px 1px 2px\n+00062ba0: 2c20 2362 3966 202d 3170 7820 2d31 7078  , #b9f -1px -1px\n+00062bb0: 2032 7078 2c20 2362 3966 2031 7078 202d   2px, #b9f 1px -\n+00062bc0: 3170 7820 3270 782c 2023 6239 6620 2d31  1px 2px, #b9f -1\n+00062bd0: 7078 2031 7078 2032 7078 3b0a 2020 666f  px 1px 2px;.  fo\n+00062be0: 6e74 2d66 616d 696c 793a 2061 7269 616c  nt-family: arial\n+00062bf0: 3b0a 2020 6c69 6e65 2d68 6569 6768 743a  ;.  line-height:\n+00062c00: 202e 333b 0a20 2063 7572 736f 723a 2070   .3;.  cursor: p\n+00062c10: 6f69 6e74 6572 3b0a 7d0a 2e43 6f64 654d  ointer;.}..CodeM\n+00062c20: 6972 726f 722d 666f 6c64 6775 7474 6572  irror-foldgutter\n+00062c30: 207b 0a20 2077 6964 7468 3a20 2e37 656d   {.  width: .7em\n+00062c40: 3b0a 7d0a 2e43 6f64 654d 6972 726f 722d  ;.}..CodeMirror-\n+00062c50: 666f 6c64 6775 7474 6572 2d6f 7065 6e2c  foldgutter-open,\n+00062c60: 0a2e 436f 6465 4d69 7272 6f72 2d66 6f6c  ..CodeMirror-fol\n+00062c70: 6467 7574 7465 722d 666f 6c64 6564 207b  dgutter-folded {\n+00062c80: 0a20 2063 7572 736f 723a 2070 6f69 6e74  .  cursor: point\n+00062c90: 6572 3b0a 7d0a 2e43 6f64 654d 6972 726f  er;.}..CodeMirro\n+00062ca0: 722d 666f 6c64 6775 7474 6572 2d6f 7065  r-foldgutter-ope\n+00062cb0: 6e3a 6166 7465 7220 7b0a 2020 636f 6e74  n:after {.  cont\n+00062cc0: 656e 743a 2022 5c32 3542 4522 3b0a 7d0a  ent: \"\\25BE\";.}.\n+00062cd0: 2e43 6f64 654d 6972 726f 722d 666f 6c64  .CodeMirror-fold\n+00062ce0: 6775 7474 6572 2d66 6f6c 6465 643a 6166  gutter-folded:af\n+00062cf0: 7465 7220 7b0a 2020 636f 6e74 656e 743a  ter {.  content:\n+00062d00: 2022 5c32 3542 3822 3b0a 7d0a 2e43 6f64   \"\\25B8\";.}..Cod\n+00062d10: 654d 6972 726f 722d 666f 6c64 6775 7474  eMirror-foldgutt\n+00062d20: 6572 207b 0a20 2077 6964 7468 3a20 7661  er {.  width: va\n+00062d30: 7228 2d2d 7078 2d31 3229 3b0a 7d0a 2e43  r(--px-12);.}..C\n+00062d40: 6f64 654d 6972 726f 722d 666f 6c64 6d61  odeMirror-foldma\n+00062d50: 726b 6572 207b 0a20 2062 6163 6b67 726f  rker {.  backgro\n+00062d60: 756e 642d 636f 6c6f 723a 2068 736c 2876  und-color: hsl(v\n+00062d70: 6172 282d 2d63 6f6c 6f72 2d69 6e66 6f29  ar(--color-info)\n+00062d80: 293b 0a20 2062 6f72 6465 722d 7261 6469  );.  border-radi\n+00062d90: 7573 3a20 7661 7228 2d2d 626f 7264 6572  us: var(--border\n+00062da0: 2d72 6164 6975 732d 3429 3b0a 2020 636f  -radius-4);.  co\n+00062db0: 6c6f 723a 2068 736c 2876 6172 282d 2d63  lor: hsl(var(--c\n+00062dc0: 6f6c 6f72 2d62 6173 6529 293b 0a20 2066  olor-base));.  f\n+00062dd0: 6f6e 742d 6661 6d69 6c79 3a20 696e 6865  ont-family: inhe\n+00062de0: 7269 743b 0a20 206d 6172 6769 6e3a 2030  rit;.  margin: 0\n+00062df0: 2076 6172 282d 2d70 782d 3429 3b0a 2020   var(--px-4);.  \n+00062e00: 7061 6464 696e 673a 2030 2076 6172 282d  padding: 0 var(-\n+00062e10: 2d70 782d 3829 3b0a 2020 7465 7874 2d73  -px-8);.  text-s\n+00062e20: 6861 646f 773a 206e 6f6e 653b 0a7d 0a2e  hadow: none;.}..\n+00062e30: 436f 6465 4d69 7272 6f72 2d66 6f6c 6467  CodeMirror-foldg\n+00062e40: 7574 7465 722d 6f70 656e 2c0a 2e43 6f64  utter-open,..Cod\n+00062e50: 654d 6972 726f 722d 666f 6c64 6775 7474  eMirror-foldgutt\n+00062e60: 6572 2d66 6f6c 6465 6420 7b0a 2020 636f  er-folded {.  co\n+00062e70: 6c6f 723a 2068 736c 6128 7661 7228 2d2d  lor: hsla(var(--\n+00062e80: 636f 6c6f 722d 6e65 7574 7261 6c29 2c20  color-neutral), \n+00062e90: 7661 7228 2d2d 616c 7068 612d 7465 7274  var(--alpha-tert\n+00062ea0: 6961 7279 2929 0a7d 0a2e 436f 6465 4d69  iary)).}..CodeMi\n+00062eb0: 7272 6f72 2d66 6f6c 6467 7574 7465 722d  rror-foldgutter-\n+00062ec0: 6f70 656e 3a3a 6166 7465 722c 202e 436f  open::after, .Co\n+00062ed0: 6465 4d69 7272 6f72 2d66 6f6c 6467 7574  deMirror-foldgut\n+00062ee0: 7465 722d 666f 6c64 6564 3a3a 6166 7465  ter-folded::afte\n+00062ef0: 7220 7b0a 2020 2020 6d61 7267 696e 3a20  r {.    margin: \n+00062f00: 3020 7661 7228 2d2d 7078 2d32 293b 0a20  0 var(--px-2);. \n+00062f10: 207d 0a2e 6772 6170 6869 716c 2d65 6469   }..graphiql-edi\n+00062f20: 746f 7220 7b0a 2020 6865 6967 6874 3a20  tor {.  height: \n+00062f30: 3130 3025 3b0a 2020 706f 7369 7469 6f6e  100%;.  position\n+00062f40: 3a20 7265 6c61 7469 7665 3b0a 2020 7769  : relative;.  wi\n+00062f50: 6474 683a 2031 3030 250a 7d0a 2e67 7261  dth: 100%.}..gra\n+00062f60: 7068 6971 6c2d 6564 6974 6f72 2e68 6964  phiql-editor.hid\n+00062f70: 6465 6e20 7b0a 2020 2020 2f2a 204a 7573  den {.    /* Jus\n+00062f80: 7420 7365 7474 696e 6720 6064 6973 706c  t setting `displ\n+00062f90: 6179 3a20 6e6f 6e65 3b60 2077 6f75 6c64  ay: none;` would\n+00062fa0: 2062 7265 616b 2074 6865 2065 6469 746f   break the edito\n+00062fb0: 7220 6775 7474 6572 7320 2a2f 0a20 2020  r gutters */.   \n+00062fc0: 206c 6566 743a 202d 3939 3939 7078 3b0a   left: -9999px;.\n+00062fd0: 2020 2020 706f 7369 7469 6f6e 3a20 6162      position: ab\n+00062fe0: 736f 6c75 7465 3b0a 2020 2020 746f 703a  solute;.    top:\n+00062ff0: 202d 3939 3939 7078 3b0a 2020 2020 7669   -9999px;.    vi\n+00063000: 7369 6269 6c69 7479 3a20 6869 6464 656e  sibility: hidden\n+00063010: 3b0a 2020 7d0a 2f2a 2054 6865 206c 696e  ;.  }./* The lin\n+00063020: 7420 6d61 726b 6572 2067 7574 7465 7220  t marker gutter \n+00063030: 2a2f 0a2e 436f 6465 4d69 7272 6f72 2d6c  */..CodeMirror-l\n+00063040: 696e 742d 6d61 726b 6572 7320 7b0a 2020  int-markers {.  \n+00063050: 7769 6474 683a 2031 3670 783b 0a7d 0a2e  width: 16px;.}..\n+00063060: 436f 6465 4d69 7272 6f72 2d6c 696e 742d  CodeMirror-lint-\n+00063070: 746f 6f6c 7469 7020 7b0a 2020 6261 636b  tooltip {.  back\n+00063080: 6772 6f75 6e64 2d63 6f6c 6f72 3a20 2366  ground-color: #f\n+00063090: 6664 3b0a 2020 626f 7264 6572 3a20 3170  fd;.  border: 1p\n+000630a0: 7820 736f 6c69 6420 626c 6163 6b3b 0a20  x solid black;. \n+000630b0: 2062 6f72 6465 722d 7261 6469 7573 3a20   border-radius: \n+000630c0: 3470 7820 3470 7820 3470 7820 3470 783b  4px 4px 4px 4px;\n+000630d0: 0a20 2063 6f6c 6f72 3a20 626c 6163 6b3b  .  color: black;\n+000630e0: 0a20 2066 6f6e 742d 6661 6d69 6c79 3a20  .  font-family: \n+000630f0: 6d6f 6e6f 7370 6163 653b 0a20 2066 6f6e  monospace;.  fon\n+00063100: 742d 7369 7a65 3a20 3130 7074 3b0a 2020  t-size: 10pt;.  \n+00063110: 6f76 6572 666c 6f77 3a20 6869 6464 656e  overflow: hidden\n+00063120: 3b0a 2020 7061 6464 696e 673a 2032 7078  ;.  padding: 2px\n+00063130: 2035 7078 3b0a 2020 706f 7369 7469 6f6e   5px;.  position\n+00063140: 3a20 6669 7865 643b 0a20 2077 6869 7465  : fixed;.  white\n+00063150: 2d73 7061 6365 3a20 7072 653b 0a20 2077  -space: pre;.  w\n+00063160: 6869 7465 2d73 7061 6365 3a20 7072 652d  hite-space: pre-\n+00063170: 7772 6170 3b0a 2020 7a2d 696e 6465 783a  wrap;.  z-index:\n+00063180: 2031 3030 3b0a 2020 6d61 782d 7769 6474   100;.  max-widt\n+00063190: 683a 2036 3030 7078 3b0a 2020 6f70 6163  h: 600px;.  opac\n+000631a0: 6974 793a 2030 3b0a 2020 7472 616e 7369  ity: 0;.  transi\n+000631b0: 7469 6f6e 3a20 6f70 6163 6974 7920 2e34  tion: opacity .4\n+000631c0: 733b 0a20 202d 6d6f 7a2d 7472 616e 7369  s;.  -moz-transi\n+000631d0: 7469 6f6e 3a20 6f70 6163 6974 7920 2e34  tion: opacity .4\n+000631e0: 733b 0a20 202d 7765 626b 6974 2d74 7261  s;.  -webkit-tra\n+000631f0: 6e73 6974 696f 6e3a 206f 7061 6369 7479  nsition: opacity\n+00063200: 202e 3473 3b0a 2020 2d6f 2d74 7261 6e73   .4s;.  -o-trans\n+00063210: 6974 696f 6e3a 206f 7061 6369 7479 202e  ition: opacity .\n+00063220: 3473 3b0a 2020 2d6d 732d 7472 616e 7369  4s;.  -ms-transi\n+00063230: 7469 6f6e 3a20 6f70 6163 6974 7920 2e34  tion: opacity .4\n+00063240: 733b 0a7d 0a2e 436f 6465 4d69 7272 6f72  s;.}..CodeMirror\n+00063250: 2d6c 696e 742d 6d61 726b 207b 0a20 2062  -lint-mark {.  b\n+00063260: 6163 6b67 726f 756e 642d 706f 7369 7469  ackground-positi\n+00063270: 6f6e 3a20 6c65 6674 2062 6f74 746f 6d3b  on: left bottom;\n+00063280: 0a20 2062 6163 6b67 726f 756e 642d 7265  .  background-re\n+00063290: 7065 6174 3a20 7265 7065 6174 2d78 3b0a  peat: repeat-x;.\n+000632a0: 7d0a 2e43 6f64 654d 6972 726f 722d 6c69  }..CodeMirror-li\n+000632b0: 6e74 2d6d 6172 6b2d 7761 726e 696e 6720  nt-mark-warning \n+000632c0: 7b0a 2020 6261 636b 6772 6f75 6e64 2d69  {.  background-i\n+000632d0: 6d61 6765 3a20 7572 6c28 6461 7461 3a69  mage: url(data:i\n+000632e0: 6d61 6765 2f70 6e67 3b62 6173 6536 342c  mage/png;base64,\n+000632f0: 6956 424f 5277 304b 4767 6f41 4141 414e  iVBORw0KGgoAAAAN\n+00063300: 5355 6845 5567 4141 4141 5141 4141 4144  SUhEUgAAAAQAAAAD\n+00063310: 4341 5941 4141 4330 394b 3747 4141 4141  CAYAAAC09K7GAAAA\n+00063320: 4158 4e53 5230 4941 7273 3463 3651 4141  AXNSR0IArs4c6QAA\n+00063330: 4141 5a69 5330 6445 4150 3841 2f77 442f  AAZiS0dEAP8A/wD/\n+00063340: 6f4c 326e 6b77 4141 4141 6c77 5346 6c7a  oL2nkwAAAAlwSFlz\n+00063350: 4141 414c 4577 4141 4378 4d42 414a 7163  AAALEwAACxMBAJqc\n+00063360: 4741 4141 4141 6430 5355 3146 4239 734a  GAAAAAd0SU1FB9sJ\n+00063370: 4668 5158 4562 6854 6737 5941 4141 415a  FhQXEbhTg7YAAAAZ\n+00063380: 6445 5659 6445 4e76 6257 316c 626e 5141  dEVYdENvbW1lbnQA\n+00063390: 5133 4a6c 5958 526c 5a43 4233 6158 526f  Q3JlYXRlZCB3aXRo\n+000633a0: 4945 644a 5456 4258 6751 3458 4141 4141  IEdJTVBXgQ4XAAAA\n+000633b0: 4d6b 6c45 5156 5149 3132 4e6b 6749 4976  MklEQVQI12NkgIIv\n+000633c0: 4a33 5158 4d6a 4177 6444 4e2b 4f61 4562  J3QXMjAwdDN+OaEb\n+000633d0: 7973 4441 344d 5041 774e 444e 774d 4377  ysDA4MPAwNDNwMCw\n+000633e0: 694f 484c 4364 317a 5830 376f 366b 4256  iOHLCd1zX07o6kBV\n+000633f0: 4751 4541 4b42 414e 746f 6273 6b4e 4d41  GQEAKBANtobskNMA\n+00063400: 4141 4141 5355 564f 524b 3543 5949 493d  AAAASUVORK5CYII=\n+00063410: 293b 0a7d 0a2e 436f 6465 4d69 7272 6f72  );.}..CodeMirror\n+00063420: 2d6c 696e 742d 6d61 726b 2d65 7272 6f72  -lint-mark-error\n+00063430: 207b 0a20 2062 6163 6b67 726f 756e 642d   {.  background-\n+00063440: 696d 6167 653a 2075 726c 2864 6174 613a  image: url(data:\n+00063450: 696d 6167 652f 706e 673b 6261 7365 3634  image/png;base64\n+00063460: 2c69 5642 4f52 7730 4b47 676f 4141 4141  ,iVBORw0KGgoAAAA\n+00063470: 4e53 5568 4555 6741 4141 4151 4141 4141  NSUhEUgAAAAQAAAA\n+00063480: 4443 4159 4141 4143 3039 4b37 4741 4141  DCAYAAAC09K7GAAA\n+00063490: 4141 584e 5352 3049 4172 7334 6336 5141  AAXNSR0IArs4c6QA\n+000634a0: 4141 415a 6953 3064 4541 5038 412f 7744  AAAZiS0dEAP8A/wD\n+000634b0: 2f6f 4c32 6e6b 7741 4141 416c 7753 466c  /oL2nkwAAAAlwSFl\n+000634c0: 7a41 4141 4c45 7741 4143 784d 4241 4a71  zAAALEwAACxMBAJq\n+000634d0: 6347 4141 4141 4164 3053 5531 4642 3973  cGAAAAAd0SU1FB9s\n+000634e0: 4a44 7734 634f 4357 312f 4b49 4141 4141  JDw4cOCW1/KIAAAA\n+000634f0: 5a64 4556 5964 454e 7662 5731 6c62 6e51  ZdEVYdENvbW1lbnQ\n+00063500: 4151 334a 6c59 5852 6c5a 4342 3361 5852  AQ3JlYXRlZCB3aXR\n+00063510: 6f49 4564 4a54 5642 5867 5134 5841 4141  oIEdJTVBXgQ4XAAA\n+00063520: 4148 456c 4551 5651 4931 324e 6767 494c  AHElEQVQI12NggIL\n+00063530: 2f44 417a 2f47 6441 352f 786b 592f 7150  /DAz/GdA5/xkY/qP\n+00063540: 4b4d 4441 7741 4144 4c5a 7766 3572 766d  KMDAwAADLZwf5rvm\n+00063550: 2b4c 5141 4141 4142 4a52 5535 4572 6b4a  +LQAAAABJRU5ErkJ\n+00063560: 6767 673d 3d29 3b0a 7d0a 2e43 6f64 654d  ggg==);.}..CodeM\n+00063570: 6972 726f 722d 6c69 6e74 2d6d 6172 6b65  irror-lint-marke\n+00063580: 7220 7b0a 2020 6261 636b 6772 6f75 6e64  r {.  background\n+00063590: 2d70 6f73 6974 696f 6e3a 2063 656e 7465  -position: cente\n+000635a0: 7220 6365 6e74 6572 3b0a 2020 6261 636b  r center;.  back\n+000635b0: 6772 6f75 6e64 2d72 6570 6561 743a 206e  ground-repeat: n\n+000635c0: 6f2d 7265 7065 6174 3b0a 2020 6375 7273  o-repeat;.  curs\n+000635d0: 6f72 3a20 706f 696e 7465 723b 0a20 2064  or: pointer;.  d\n+000635e0: 6973 706c 6179 3a20 696e 6c69 6e65 2d62  isplay: inline-b\n+000635f0: 6c6f 636b 3b0a 2020 6865 6967 6874 3a20  lock;.  height: \n+00063600: 3136 7078 3b0a 2020 7769 6474 683a 2031  16px;.  width: 1\n+00063610: 3670 783b 0a20 2076 6572 7469 6361 6c2d  6px;.  vertical-\n+00063620: 616c 6967 6e3a 206d 6964 646c 653b 0a20  align: middle;. \n+00063630: 2070 6f73 6974 696f 6e3a 2072 656c 6174   position: relat\n+00063640: 6976 653b 0a7d 0a2e 436f 6465 4d69 7272  ive;.}..CodeMirr\n+00063650: 6f72 2d6c 696e 742d 6d65 7373 6167 6520  or-lint-message \n+00063660: 7b0a 2020 7061 6464 696e 672d 6c65 6674  {.  padding-left\n+00063670: 3a20 3138 7078 3b0a 2020 6261 636b 6772  : 18px;.  backgr\n+00063680: 6f75 6e64 2d70 6f73 6974 696f 6e3a 2074  ound-position: t\n+00063690: 6f70 206c 6566 743b 0a20 2062 6163 6b67  op left;.  backg\n+000636a0: 726f 756e 642d 7265 7065 6174 3a20 6e6f  round-repeat: no\n+000636b0: 2d72 6570 6561 743b 0a7d 0a2e 436f 6465  -repeat;.}..Code\n+000636c0: 4d69 7272 6f72 2d6c 696e 742d 6d61 726b  Mirror-lint-mark\n+000636d0: 6572 2d77 6172 6e69 6e67 2c20 2e43 6f64  er-warning, .Cod\n+000636e0: 654d 6972 726f 722d 6c69 6e74 2d6d 6573  eMirror-lint-mes\n+000636f0: 7361 6765 2d77 6172 6e69 6e67 207b 0a20  sage-warning {. \n+00063700: 2062 6163 6b67 726f 756e 642d 696d 6167   background-imag\n+00063710: 653a 2075 726c 2864 6174 613a 696d 6167  e: url(data:imag\n+00063720: 652f 706e 673b 6261 7365 3634 2c69 5642  e/png;base64,iVB\n+00063730: 4f52 7730 4b47 676f 4141 4141 4e53 5568  ORw0KGgoAAAANSUh\n+00063740: 4555 6741 4141 4241 4141 4141 5143 414d  EUgAAABAAAAAQCAM\n+00063750: 4141 4141 6f4c 5139 5441 4141 414e 6c42  AAAAoLQ9TAAAANlB\n+00063760: 4d56 4558 2f75 7744 7672 7744 2f75 7744  MVEX/uwDvrwD/uwD\n+00063770: 2f75 7744 2f75 7744 2f75 7744 2f75 7744  /uwD/uwD/uwD/uwD\n+00063780: 2f75 7744 2f75 7744 3674 7744 2f75 7741  /uwD/uwD6twD/uwA\n+00063790: 4141 4144 7572 7744 3274 5144 3775 4144  AAADurwD2tQD7uAD\n+000637a0: 2b75 6741 4141 4144 2f75 7744 686d 6554  +ugAAAAD/uwDhmeT\n+000637b0: 5241 4141 4144 4852 5354 6c4d 4a38 6d4e  RAAAADHRSTlMJ8mN\n+000637c0: 3145 5963 626d 6969 7867 4143 6d37 5762  1EYcbmiixgACm7Wb\n+000637d0: 7541 4141 4156 6b6c 4551 5652 3432 6e33  uAAAAVklEQVR42n3\n+000637e0: 5055 5171 4149 4242 4655 5531 4c4c 6333  PUQqAIBBFUU1LLc3\n+000637f0: 752f 6a64 624f 4a6f 5731 5030 3844 4139  u/jdbOJoW1P08DA9\n+00063800: 4762 6138 2b59 574a 3667 4e4a 6f4e 5949  Gba8+YWJ6gNJoNYI\n+00063810: 427a 4141 3263 6842 7468 356b 4c6d 4739  BzAA2chBth5kLmG9\n+00063820: 5955 6f47 304e 4841 5577 4658 774f 394c  YUoG0NHAUwFXwO9L\n+00063830: 7542 514c 3167 6943 5162 3867 4339 4f72  uBQL1giCQb8gC9Or\n+00063840: 6f32 7670 3572 6e63 4349 5938 4c38 7545  o2vp5rncCIY8L8uE\n+00063850: 7835 5a6b 4141 4141 4153 5556 4f52 4b35  x5ZkAAAAASUVORK5\n+00063860: 4359 4949 3d29 3b0a 7d0a 2e43 6f64 654d  CYII=);.}..CodeM\n+00063870: 6972 726f 722d 6c69 6e74 2d6d 6172 6b65  irror-lint-marke\n+00063880: 722d 6572 726f 722c 202e 436f 6465 4d69  r-error, .CodeMi\n+00063890: 7272 6f72 2d6c 696e 742d 6d65 7373 6167  rror-lint-messag\n+000638a0: 652d 6572 726f 7220 7b0a 2020 6261 636b  e-error {.  back\n+000638b0: 6772 6f75 6e64 2d69 6d61 6765 3a20 7572  ground-image: ur\n+000638c0: 6c28 6461 7461 3a69 6d61 6765 2f70 6e67  l(data:image/png\n+000638d0: 3b62 6173 6536 342c 6956 424f 5277 304b  ;base64,iVBORw0K\n+000638e0: 4767 6f41 4141 414e 5355 6845 5567 4141  GgoAAAANSUhEUgAA\n+000638f0: 4142 4141 4141 4151 4341 4d41 4141 416f  ABAAAAAQCAMAAAAo\n+00063900: 4c51 3954 4141 4141 486c 424d 5645 5737  LQ9TAAAAHlBMVEW7\n+00063910: 4141 4337 4141 4378 4141 4337 4141 4337  AAC7AACxAAC7AAC7\n+00063920: 4141 4141 4141 4334 4141 4335 4141 442f  AAAAAAC4AAC5AAD/\n+00063930: 2f2f 2b37 4141 4155 6463 6c70 4141 4141  //+7AAAUdclpAAAA\n+00063940: 426e 5253 546c 4d58 6e4f 5253 6977 434b  BnRSTlMXnORSiwCK\n+00063950: 305a 4b53 4141 4141 5455 6c45 5156 5234  0ZKSAAAATUlEQVR4\n+00063960: 326d 5750 4f51 3741 5141 6744 7551 4c78  2mWPOQ7AQAgDuQLx\n+00063970: 2f7a 3863 7359 526d 5052 4946 4977 5247  /z8csYRmPRIFIwRG\n+00063980: 6e6f 7352 7270 616d 766b 4b69 3046 5449  nosRrpamvkKi0FTI\n+00063990: 694d 4153 5233 6868 4b57 2b68 414e 362f  iMASR3hhKW+hAN6/\n+000639a0: 7449 5768 7539 5044 5769 5447 4e45 6b54  tIWhu9PDWiTGNEkT\n+000639b0: 7449 4f75 6341 354f 7972 3963 6b50 6741  tIOucA5Oyr9ckPgA\n+000639c0: 576d 3047 5042 6f67 3676 3441 4141 4141  Wm0GPBog6v4AAAAA\n+000639d0: 5355 564f 524b 3543 5949 493d 293b 0a7d  SUVORK5CYII=);.}\n+000639e0: 0a2e 436f 6465 4d69 7272 6f72 2d6c 696e  ..CodeMirror-lin\n+000639f0: 742d 6d61 726b 6572 2d6d 756c 7469 706c  t-marker-multipl\n+00063a00: 6520 7b0a 2020 6261 636b 6772 6f75 6e64  e {.  background\n+00063a10: 2d69 6d61 6765 3a20 7572 6c28 6461 7461  -image: url(data\n+00063a20: 3a69 6d61 6765 2f70 6e67 3b62 6173 6536  :image/png;base6\n+00063a30: 342c 6956 424f 5277 304b 4767 6f41 4141  4,iVBORw0KGgoAAA\n+00063a40: 414e 5355 6845 5567 4141 4141 6341 4141  ANSUhEUgAAAAcAAA\n+00063a50: 4148 4341 4d41 4141 447a 6a4b 6668 4141  AHCAMAAADzjKfhAA\n+00063a60: 4141 4356 424d 5645 5541 4141 4141 4141  AACVBMVEUAAAAAAA\n+00063a70: 432f 7637 3931 346b 7948 4141 4141 4158  C/v7914kyHAAAAAX\n+00063a80: 5253 546c 4d41 514f 6259 5a67 4141 4143  RSTlMAQObYZgAAAC\n+00063a90: 4e4a 5245 4655 654e 6f31 696f 454a 4141  NJREFUeNo1ioEJAA\n+00063aa0: 4149 776d 7a2f 4839 3069 4646 5347 4a67  AIwmz/H90iFFSGJg\n+00063ab0: 464d 6533 6761 4c5a 306f 642b 392f 4151  FMe3gaLZ0od+9/AQ\n+00063ac0: 5a30 4144 6f73 6259 7261 4141 4141 4145  Z0ADosbYraAAAAAE\n+00063ad0: 6c46 546b 5375 516d 4343 293b 0a20 2062  lFTkSuQmCC);.  b\n+00063ae0: 6163 6b67 726f 756e 642d 7265 7065 6174  ackground-repeat\n+00063af0: 3a20 6e6f 2d72 6570 6561 743b 0a20 2062  : no-repeat;.  b\n+00063b00: 6163 6b67 726f 756e 642d 706f 7369 7469  ackground-positi\n+00063b10: 6f6e 3a20 7269 6768 7420 626f 7474 6f6d  on: right bottom\n+00063b20: 3b0a 2020 7769 6474 683a 2031 3030 253b  ;.  width: 100%;\n+00063b30: 2068 6569 6768 743a 2031 3030 253b 0a7d   height: 100%;.}\n+00063b40: 0a2e 436f 6465 4d69 7272 6f72 2d6c 696e  ..CodeMirror-lin\n+00063b50: 742d 6c69 6e65 2d65 7272 6f72 207b 0a20  t-line-error {. \n+00063b60: 2062 6163 6b67 726f 756e 642d 636f 6c6f   background-colo\n+00063b70: 723a 2072 6762 6128 3138 332c 2037 362c  r: rgba(183, 76,\n+00063b80: 2038 312c 2030 2e30 3829 3b0a 7d0a 2e43   81, 0.08);.}..C\n+00063b90: 6f64 654d 6972 726f 722d 6c69 6e74 2d6c  odeMirror-lint-l\n+00063ba0: 696e 652d 7761 726e 696e 6720 7b0a 2020  ine-warning {.  \n+00063bb0: 6261 636b 6772 6f75 6e64 2d63 6f6c 6f72  background-color\n+00063bc0: 3a20 7267 6261 2832 3535 2c20 3231 312c  : rgba(255, 211,\n+00063bd0: 2030 2c20 302e 3129 3b0a 7d0a 2f2a 2054   0, 0.1);.}./* T\n+00063be0: 6578 7420 7374 796c 6573 202a 2f0a 2e43  ext styles */..C\n+00063bf0: 6f64 654d 6972 726f 722d 6c69 6e74 2d6d  odeMirror-lint-m\n+00063c00: 6172 6b2d 6572 726f 722c 0a2e 436f 6465  ark-error,..Code\n+00063c10: 4d69 7272 6f72 2d6c 696e 742d 6d61 726b  Mirror-lint-mark\n+00063c20: 2d77 6172 6e69 6e67 207b 0a20 2062 6163  -warning {.  bac\n+00063c30: 6b67 726f 756e 642d 7265 7065 6174 3a20  kground-repeat: \n+00063c40: 7265 7065 6174 2d78 3b0a 2020 2f2a 2a0a  repeat-x;.  /**.\n+00063c50: 2020 202a 2054 6865 2066 6f6c 6c6f 7769     * The followi\n+00063c60: 6e67 2074 776f 2061 7265 2076 6572 7920  ng two are very \n+00063c70: 7370 6563 6966 6963 2074 6f20 7468 6520  specific to the \n+00063c80: 666f 6e74 2073 697a 652c 2073 6f20 7765  font size, so we\n+00063c90: 2075 7365 200a 2020 202a 2022 6d61 6769   use .   * \"magi\n+00063ca0: 6320 7661 6c75 6573 2220 696e 7374 6561  c values\" instea\n+00063cb0: 6420 6f66 2076 6172 6961 626c 6573 2e0a  d of variables..\n+00063cc0: 2020 202a 2f0a 2020 6261 636b 6772 6f75     */.  backgrou\n+00063cd0: 6e64 2d73 697a 653a 2031 3070 7820 3370  nd-size: 10px 3p\n+00063ce0: 783b 0a20 2062 6163 6b67 726f 756e 642d  x;.  background-\n+00063cf0: 706f 7369 7469 6f6e 3a20 3020 3935 253b  position: 0 95%;\n+00063d00: 0a7d 0a2e 636d 2d73 2d67 7261 7068 6971  .}..cm-s-graphiq\n+00063d10: 6c20 2e43 6f64 654d 6972 726f 722d 6c69  l .CodeMirror-li\n+00063d20: 6e74 2d6d 6172 6b2d 6572 726f 7220 7b0a  nt-mark-error {.\n+00063d30: 2020 636f 6c6f 723a 2068 736c 2876 6172    color: hsl(var\n+00063d40: 282d 2d63 6f6c 6f72 2d65 7272 6f72 2929  (--color-error))\n+00063d50: 3b0a 7d0a 2e43 6f64 654d 6972 726f 722d  ;.}..CodeMirror-\n+00063d60: 6c69 6e74 2d6d 6172 6b2d 6572 726f 7220  lint-mark-error \n+00063d70: 7b0a 2020 6261 636b 6772 6f75 6e64 2d69  {.  background-i\n+00063d80: 6d61 6765 3a20 6c69 6e65 6172 2d67 7261  mage: linear-gra\n+00063d90: 6469 656e 7428 0a20 2020 2020 2034 3564  dient(.      45d\n+00063da0: 6567 2c0a 2020 2020 2020 7472 616e 7370  eg,.      transp\n+00063db0: 6172 656e 7420 3635 252c 0a20 2020 2020  arent 65%,.     \n+00063dc0: 2068 736c 2876 6172 282d 2d63 6f6c 6f72   hsl(var(--color\n+00063dd0: 2d65 7272 6f72 2929 2038 3025 2c0a 2020  -error)) 80%,.  \n+00063de0: 2020 2020 7472 616e 7370 6172 656e 7420      transparent \n+00063df0: 3930 250a 2020 2020 292c 0a20 2020 206c  90%.    ),.    l\n+00063e00: 696e 6561 722d 6772 6164 6965 6e74 280a  inear-gradient(.\n+00063e10: 2020 2020 2020 3133 3564 6567 2c0a 2020        135deg,.  \n+00063e20: 2020 2020 7472 616e 7370 6172 656e 7420      transparent \n+00063e30: 3525 2c0a 2020 2020 2020 6873 6c28 7661  5%,.      hsl(va\n+00063e40: 7228 2d2d 636f 6c6f 722d 6572 726f 7229  r(--color-error)\n+00063e50: 2920 3135 252c 0a20 2020 2020 2074 7261  ) 15%,.      tra\n+00063e60: 6e73 7061 7265 6e74 2032 3525 0a20 2020  nsparent 25%.   \n+00063e70: 2029 2c0a 2020 2020 6c69 6e65 6172 2d67   ),.    linear-g\n+00063e80: 7261 6469 656e 7428 0a20 2020 2020 2031  radient(.      1\n+00063e90: 3335 6465 672c 0a20 2020 2020 2074 7261  35deg,.      tra\n+00063ea0: 6e73 7061 7265 6e74 2034 3525 2c0a 2020  nsparent 45%,.  \n+00063eb0: 2020 2020 6873 6c28 7661 7228 2d2d 636f      hsl(var(--co\n+00063ec0: 6c6f 722d 6572 726f 7229 2920 3535 252c  lor-error)) 55%,\n+00063ed0: 0a20 2020 2020 2074 7261 6e73 7061 7265  .      transpare\n+00063ee0: 6e74 2036 3525 0a20 2020 2029 2c0a 2020  nt 65%.    ),.  \n+00063ef0: 2020 6c69 6e65 6172 2d67 7261 6469 656e    linear-gradien\n+00063f00: 7428 0a20 2020 2020 2034 3564 6567 2c0a  t(.      45deg,.\n+00063f10: 2020 2020 2020 7472 616e 7370 6172 656e        transparen\n+00063f20: 7420 3235 252c 0a20 2020 2020 2068 736c  t 25%,.      hsl\n+00063f30: 2876 6172 282d 2d63 6f6c 6f72 2d65 7272  (var(--color-err\n+00063f40: 6f72 2929 2033 3525 2c0a 2020 2020 2020  or)) 35%,.      \n+00063f50: 7472 616e 7370 6172 656e 7420 3530 250a  transparent 50%.\n+00063f60: 2020 2020 293b 0a7d 0a2e 636d 2d73 2d67      );.}..cm-s-g\n+00063f70: 7261 7068 6971 6c20 2e43 6f64 654d 6972  raphiql .CodeMir\n+00063f80: 726f 722d 6c69 6e74 2d6d 6172 6b2d 7761  ror-lint-mark-wa\n+00063f90: 726e 696e 6720 7b0a 2020 636f 6c6f 723a  rning {.  color:\n+00063fa0: 2068 736c 2876 6172 282d 2d63 6f6c 6f72   hsl(var(--color\n+00063fb0: 2d77 6172 6e69 6e67 2929 3b0a 7d0a 2e43  -warning));.}..C\n+00063fc0: 6f64 654d 6972 726f 722d 6c69 6e74 2d6d  odeMirror-lint-m\n+00063fd0: 6172 6b2d 7761 726e 696e 6720 7b0a 2020  ark-warning {.  \n+00063fe0: 6261 636b 6772 6f75 6e64 2d69 6d61 6765  background-image\n+00063ff0: 3a20 6c69 6e65 6172 2d67 7261 6469 656e  : linear-gradien\n+00064000: 7428 0a20 2020 2020 2034 3564 6567 2c0a  t(.      45deg,.\n+00064010: 2020 2020 2020 7472 616e 7370 6172 656e        transparen\n+00064020: 7420 3635 252c 0a20 2020 2020 2068 736c  t 65%,.      hsl\n+00064030: 2876 6172 282d 2d63 6f6c 6f72 2d77 6172  (var(--color-war\n+00064040: 6e69 6e67 2929 2038 3025 2c0a 2020 2020  ning)) 80%,.    \n+00064050: 2020 7472 616e 7370 6172 656e 7420 3930    transparent 90\n+00064060: 250a 2020 2020 292c 0a20 2020 206c 696e  %.    ),.    lin\n+00064070: 6561 722d 6772 6164 6965 6e74 280a 2020  ear-gradient(.  \n+00064080: 2020 2020 3133 3564 6567 2c0a 2020 2020      135deg,.    \n+00064090: 2020 7472 616e 7370 6172 656e 7420 3525    transparent 5%\n+000640a0: 2c0a 2020 2020 2020 6873 6c28 7661 7228  ,.      hsl(var(\n+000640b0: 2d2d 636f 6c6f 722d 7761 726e 696e 6729  --color-warning)\n+000640c0: 2920 3135 252c 0a20 2020 2020 2074 7261  ) 15%,.      tra\n+000640d0: 6e73 7061 7265 6e74 2032 3525 0a20 2020  nsparent 25%.   \n+000640e0: 2029 2c0a 2020 2020 6c69 6e65 6172 2d67   ),.    linear-g\n+000640f0: 7261 6469 656e 7428 0a20 2020 2020 2031  radient(.      1\n+00064100: 3335 6465 672c 0a20 2020 2020 2074 7261  35deg,.      tra\n+00064110: 6e73 7061 7265 6e74 2034 3525 2c0a 2020  nsparent 45%,.  \n+00064120: 2020 2020 6873 6c28 7661 7228 2d2d 636f      hsl(var(--co\n+00064130: 6c6f 722d 7761 726e 696e 6729 2920 3535  lor-warning)) 55\n+00064140: 252c 0a20 2020 2020 2074 7261 6e73 7061  %,.      transpa\n+00064150: 7265 6e74 2036 3525 0a20 2020 2029 2c0a  rent 65%.    ),.\n+00064160: 2020 2020 6c69 6e65 6172 2d67 7261 6469      linear-gradi\n+00064170: 656e 7428 0a20 2020 2020 2034 3564 6567  ent(.      45deg\n+00064180: 2c0a 2020 2020 2020 7472 616e 7370 6172  ,.      transpar\n+00064190: 656e 7420 3235 252c 0a20 2020 2020 2068  ent 25%,.      h\n+000641a0: 736c 2876 6172 282d 2d63 6f6c 6f72 2d77  sl(var(--color-w\n+000641b0: 6172 6e69 6e67 2929 2033 3525 2c0a 2020  arning)) 35%,.  \n+000641c0: 2020 2020 7472 616e 7370 6172 656e 7420      transparent \n+000641d0: 3530 250a 2020 2020 293b 0a7d 0a2f 2a20  50%.    );.}./* \n+000641e0: 506f 7075 7020 7374 796c 6573 202a 2f0a  Popup styles */.\n+000641f0: 2e43 6f64 654d 6972 726f 722d 6c69 6e74  .CodeMirror-lint\n+00064200: 2d74 6f6f 6c74 6970 207b 0a20 2062 6163  -tooltip {.  bac\n+00064210: 6b67 726f 756e 642d 636f 6c6f 723a 2068  kground-color: h\n+00064220: 736c 2876 6172 282d 2d63 6f6c 6f72 2d62  sl(var(--color-b\n+00064230: 6173 6529 293b 0a20 2062 6f72 6465 723a  ase));.  border:\n+00064240: 2076 6172 282d 2d70 6f70 6f76 6572 2d62   var(--popover-b\n+00064250: 6f72 6465 7229 3b0a 2020 626f 7264 6572  order);.  border\n+00064260: 2d72 6164 6975 733a 2076 6172 282d 2d62  -radius: var(--b\n+00064270: 6f72 6465 722d 7261 6469 7573 2d38 293b  order-radius-8);\n+00064280: 0a20 2062 6f78 2d73 6861 646f 773a 2076  .  box-shadow: v\n+00064290: 6172 282d 2d70 6f70 6f76 6572 2d62 6f78  ar(--popover-box\n+000642a0: 2d73 6861 646f 7729 3b0a 2020 666f 6e74  -shadow);.  font\n+000642b0: 2d73 697a 653a 2076 6172 282d 2d66 6f6e  -size: var(--fon\n+000642c0: 742d 7369 7a65 2d62 6f64 7929 3b0a 2020  t-size-body);.  \n+000642d0: 666f 6e74 2d66 616d 696c 793a 2076 6172  font-family: var\n+000642e0: 282d 2d66 6f6e 742d 6661 6d69 6c79 293b  (--font-family);\n+000642f0: 0a20 206d 6178 2d77 6964 7468 3a20 3630  .  max-width: 60\n+00064300: 3070 783b 0a20 206f 7665 7266 6c6f 773a  0px;.  overflow:\n+00064310: 2068 6964 6465 6e3b 0a20 2070 6164 6469   hidden;.  paddi\n+00064320: 6e67 3a20 7661 7228 2d2d 7078 2d31 3229  ng: var(--px-12)\n+00064330: 3b0a 7d0a 2e43 6f64 654d 6972 726f 722d  ;.}..CodeMirror-\n+00064340: 6c69 6e74 2d6d 6573 7361 6765 2d65 7272  lint-message-err\n+00064350: 6f72 2c0a 2e43 6f64 654d 6972 726f 722d  or,..CodeMirror-\n+00064360: 6c69 6e74 2d6d 6573 7361 6765 2d77 6172  lint-message-war\n+00064370: 6e69 6e67 207b 0a20 2062 6163 6b67 726f  ning {.  backgro\n+00064380: 756e 642d 696d 6167 653a 206e 6f6e 653b  und-image: none;\n+00064390: 0a20 2070 6164 6469 6e67 3a20 303b 0a7d  .  padding: 0;.}\n+000643a0: 0a2e 436f 6465 4d69 7272 6f72 2d6c 696e  ..CodeMirror-lin\n+000643b0: 742d 6d65 7373 6167 652d 6572 726f 7220  t-message-error \n+000643c0: 7b0a 2020 636f 6c6f 723a 2068 736c 2876  {.  color: hsl(v\n+000643d0: 6172 282d 2d63 6f6c 6f72 2d65 7272 6f72  ar(--color-error\n+000643e0: 2929 3b0a 7d0a 2e43 6f64 654d 6972 726f  ));.}..CodeMirro\n+000643f0: 722d 6c69 6e74 2d6d 6573 7361 6765 2d77  r-lint-message-w\n+00064400: 6172 6e69 6e67 207b 0a20 2063 6f6c 6f72  arning {.  color\n+00064410: 3a20 6873 6c28 7661 7228 2d2d 636f 6c6f  : hsl(var(--colo\n+00064420: 722d 7761 726e 696e 6729 293b 0a7d 0a2e  r-warning));.}..\n+00064430: 436f 6465 4d69 7272 6f72 2d68 696e 7473  CodeMirror-hints\n+00064440: 207b 0a20 2070 6f73 6974 696f 6e3a 2061   {.  position: a\n+00064450: 6273 6f6c 7574 653b 0a20 207a 2d69 6e64  bsolute;.  z-ind\n+00064460: 6578 3a20 3130 3b0a 2020 6f76 6572 666c  ex: 10;.  overfl\n+00064470: 6f77 3a20 6869 6464 656e 3b0a 2020 6c69  ow: hidden;.  li\n+00064480: 7374 2d73 7479 6c65 3a20 6e6f 6e65 3b0a  st-style: none;.\n+00064490: 0a20 206d 6172 6769 6e3a 2030 3b0a 2020  .  margin: 0;.  \n+000644a0: 7061 6464 696e 673a 2032 7078 3b0a 0a20  padding: 2px;.. \n+000644b0: 202d 7765 626b 6974 2d62 6f78 2d73 6861   -webkit-box-sha\n+000644c0: 646f 773a 2032 7078 2033 7078 2035 7078  dow: 2px 3px 5px\n+000644d0: 2072 6762 6128 302c 302c 302c 2e32 293b   rgba(0,0,0,.2);\n+000644e0: 0a20 202d 6d6f 7a2d 626f 782d 7368 6164  .  -moz-box-shad\n+000644f0: 6f77 3a20 3270 7820 3370 7820 3570 7820  ow: 2px 3px 5px \n+00064500: 7267 6261 2830 2c30 2c30 2c2e 3229 3b0a  rgba(0,0,0,.2);.\n+00064510: 2020 626f 782d 7368 6164 6f77 3a20 3270    box-shadow: 2p\n+00064520: 7820 3370 7820 3570 7820 7267 6261 2830  x 3px 5px rgba(0\n+00064530: 2c30 2c30 2c2e 3229 3b0a 2020 626f 7264  ,0,0,.2);.  bord\n+00064540: 6572 2d72 6164 6975 733a 2033 7078 3b0a  er-radius: 3px;.\n+00064550: 2020 626f 7264 6572 3a20 3170 7820 736f    border: 1px so\n+00064560: 6c69 6420 7369 6c76 6572 3b0a 0a20 2062  lid silver;..  b\n+00064570: 6163 6b67 726f 756e 643a 2077 6869 7465  ackground: white\n+00064580: 3b0a 2020 666f 6e74 2d73 697a 653a 2039  ;.  font-size: 9\n+00064590: 3025 3b0a 2020 666f 6e74 2d66 616d 696c  0%;.  font-famil\n+000645a0: 793a 206d 6f6e 6f73 7061 6365 3b0a 0a20  y: monospace;.. \n+000645b0: 206d 6178 2d68 6569 6768 743a 2032 3065   max-height: 20e\n+000645c0: 6d3b 0a20 206f 7665 7266 6c6f 772d 793a  m;.  overflow-y:\n+000645d0: 2061 7574 6f3b 0a7d 0a0a 2e43 6f64 654d   auto;.}...CodeM\n+000645e0: 6972 726f 722d 6869 6e74 207b 0a20 206d  irror-hint {.  m\n+000645f0: 6172 6769 6e3a 2030 3b0a 2020 7061 6464  argin: 0;.  padd\n+00064600: 696e 673a 2030 2034 7078 3b0a 2020 626f  ing: 0 4px;.  bo\n+00064610: 7264 6572 2d72 6164 6975 733a 2032 7078  rder-radius: 2px\n+00064620: 3b0a 2020 7768 6974 652d 7370 6163 653a  ;.  white-space:\n+00064630: 2070 7265 3b0a 2020 636f 6c6f 723a 2062   pre;.  color: b\n+00064640: 6c61 636b 3b0a 2020 6375 7273 6f72 3a20  lack;.  cursor: \n+00064650: 706f 696e 7465 723b 0a7d 0a0a 6c69 2e43  pointer;.}..li.C\n+00064660: 6f64 654d 6972 726f 722d 6869 6e74 2d61  odeMirror-hint-a\n+00064670: 6374 6976 6520 7b0a 2020 6261 636b 6772  ctive {.  backgr\n+00064680: 6f75 6e64 3a20 2330 3866 3b0a 2020 636f  ound: #08f;.  co\n+00064690: 6c6f 723a 2077 6869 7465 3b0a 7d0a 0a2f  lor: white;.}../\n+000646a0: 2a20 506f 7075 7020 7374 796c 6573 202a  * Popup styles *\n+000646b0: 2f0a 0a2e 436f 6465 4d69 7272 6f72 2d68  /...CodeMirror-h\n+000646c0: 696e 7473 207b 0a20 2062 6163 6b67 726f  ints {.  backgro\n+000646d0: 756e 643a 2068 736c 2876 6172 282d 2d63  und: hsl(var(--c\n+000646e0: 6f6c 6f72 2d62 6173 6529 293b 0a20 2062  olor-base));.  b\n+000646f0: 6f72 6465 723a 2076 6172 282d 2d70 6f70  order: var(--pop\n+00064700: 6f76 6572 2d62 6f72 6465 7229 3b0a 2020  over-border);.  \n+00064710: 626f 7264 6572 2d72 6164 6975 733a 2076  border-radius: v\n+00064720: 6172 282d 2d62 6f72 6465 722d 7261 6469  ar(--border-radi\n+00064730: 7573 2d38 293b 0a20 2062 6f78 2d73 6861  us-8);.  box-sha\n+00064740: 646f 773a 2076 6172 282d 2d70 6f70 6f76  dow: var(--popov\n+00064750: 6572 2d62 6f78 2d73 6861 646f 7729 3b0a  er-box-shadow);.\n+00064760: 2020 6469 7370 6c61 793a 2067 7269 643b    display: grid;\n+00064770: 0a20 2066 6f6e 742d 6661 6d69 6c79 3a20  .  font-family: \n+00064780: 7661 7228 2d2d 666f 6e74 2d66 616d 696c  var(--font-famil\n+00064790: 7929 3b0a 2020 666f 6e74 2d73 697a 653a  y);.  font-size:\n+000647a0: 2076 6172 282d 2d66 6f6e 742d 7369 7a65   var(--font-size\n+000647b0: 2d62 6f64 7929 3b0a 2020 6772 6964 2d74  -body);.  grid-t\n+000647c0: 656d 706c 6174 652d 636f 6c75 6d6e 733a  emplate-columns:\n+000647d0: 2061 7574 6f20 6669 742d 636f 6e74 656e   auto fit-conten\n+000647e0: 7428 3330 3070 7829 3b0a 2020 2f2a 2042  t(300px);.  /* B\n+000647f0: 7920 6465 6661 756c 7420 7468 6973 2069  y default this i\n+00064800: 7320 6571 7561 6c73 2065 7861 6374 6c79  s equals exactly\n+00064810: 2038 2069 7465 6d73 2069 6e63 6c75 6469   8 items includi\n+00064820: 6e67 206d 6172 6769 6e73 202a 2f0a 2020  ng margins */.  \n+00064830: 6d61 782d 6865 6967 6874 3a20 3236 3470  max-height: 264p\n+00064840: 783b 0a20 2070 6164 6469 6e67 3a20 303b  x;.  padding: 0;\n+00064850: 0a7d 0a0a 2f2a 2041 7574 6f63 6f6d 706c  .}../* Autocompl\n+00064860: 6574 6520 6974 656d 7320 2a2f 0a0a 2e43  ete items */...C\n+00064870: 6f64 654d 6972 726f 722d 6869 6e74 207b  odeMirror-hint {\n+00064880: 0a20 2062 6f72 6465 722d 7261 6469 7573  .  border-radius\n+00064890: 3a20 7661 7228 2d2d 626f 7264 6572 2d72  : var(--border-r\n+000648a0: 6164 6975 732d 3429 3b0a 2020 636f 6c6f  adius-4);.  colo\n+000648b0: 723a 2068 736c 6128 7661 7228 2d2d 636f  r: hsla(var(--co\n+000648c0: 6c6f 722d 6e65 7574 7261 6c29 2c20 7661  lor-neutral), va\n+000648d0: 7228 2d2d 616c 7068 612d 7365 636f 6e64  r(--alpha-second\n+000648e0: 6172 7929 293b 0a20 2067 7269 642d 636f  ary));.  grid-co\n+000648f0: 6c75 6d6e 3a20 3120 2f20 323b 0a20 206d  lumn: 1 / 2;.  m\n+00064900: 6172 6769 6e3a 2076 6172 282d 2d70 782d  argin: var(--px-\n+00064910: 3429 3b0a 2020 2f2a 204f 7665 7272 6964  4);.  /* Overrid\n+00064920: 6520 656c 656d 656e 7420 7374 796c 6520  e element style \n+00064930: 6164 6465 6420 6279 2063 6f64 656d 6972  added by codemir\n+00064940: 726f 7220 2a2f 0a20 2070 6164 6469 6e67  ror */.  padding\n+00064950: 3a20 7661 7228 2d2d 7078 2d36 2920 7661  : var(--px-6) va\n+00064960: 7228 2d2d 7078 2d38 2920 2169 6d70 6f72  r(--px-8) !impor\n+00064970: 7461 6e74 0a7d 0a0a 2e43 6f64 654d 6972  tant.}...CodeMir\n+00064980: 726f 722d 6869 6e74 3a6e 6f74 283a 6669  ror-hint:not(:fi\n+00064990: 7273 742d 6368 696c 6429 207b 0a20 2020  rst-child) {.   \n+000649a0: 206d 6172 6769 6e2d 746f 703a 2030 3b0a   margin-top: 0;.\n+000649b0: 2020 7d0a 0a6c 692e 436f 6465 4d69 7272    }..li.CodeMirr\n+000649c0: 6f72 2d68 696e 742d 6163 7469 7665 207b  or-hint-active {\n+000649d0: 0a20 2062 6163 6b67 726f 756e 643a 2068  .  background: h\n+000649e0: 736c 6128 7661 7228 2d2d 636f 6c6f 722d  sla(var(--color-\n+000649f0: 7072 696d 6172 7929 2c20 7661 7228 2d2d  primary), var(--\n+00064a00: 616c 7068 612d 6261 636b 6772 6f75 6e64  alpha-background\n+00064a10: 2d6d 6564 6975 6d29 293b 0a20 2063 6f6c  -medium));.  col\n+00064a20: 6f72 3a20 6873 6c28 7661 7228 2d2d 636f  or: hsl(var(--co\n+00064a30: 6c6f 722d 7072 696d 6172 7929 293b 0a7d  lor-primary));.}\n+00064a40: 0a0a 2f2a 2053 6964 6562 6172 2077 6974  ../* Sidebar wit\n+00064a50: 6820 6164 6469 7469 6f6e 616c 2069 6e66  h additional inf\n+00064a60: 6f72 6d61 7469 6f6e 202a 2f0a 0a2e 436f  ormation */...Co\n+00064a70: 6465 4d69 7272 6f72 2d68 696e 742d 696e  deMirror-hint-in\n+00064a80: 666f 726d 6174 696f 6e20 7b0a 2020 626f  formation {.  bo\n+00064a90: 7264 6572 2d6c 6566 743a 2031 7078 2073  rder-left: 1px s\n+00064aa0: 6f6c 6964 0a20 2020 2068 736c 6128 7661  olid.    hsla(va\n+00064ab0: 7228 2d2d 636f 6c6f 722d 6e65 7574 7261  r(--color-neutra\n+00064ac0: 6c29 2c20 7661 7228 2d2d 616c 7068 612d  l), var(--alpha-\n+00064ad0: 6261 636b 6772 6f75 6e64 2d68 6561 7679  background-heavy\n+00064ae0: 2929 3b0a 2020 6772 6964 2d63 6f6c 756d  ));.  grid-colum\n+00064af0: 6e3a 2032 202f 2033 3b0a 2020 6772 6964  n: 2 / 3;.  grid\n+00064b00: 2d72 6f77 3a20 3120 2f20 3939 3939 393b  -row: 1 / 99999;\n+00064b10: 0a20 202f 2a20 5361 6d65 2061 7320 7468  .  /* Same as th\n+00064b20: 6520 706f 7075 7020 2a2f 0a20 206d 6178  e popup */.  max\n+00064b30: 2d68 6569 6768 743a 2032 3634 7078 3b0a  -height: 264px;.\n+00064b40: 2020 6f76 6572 666c 6f77 3a20 6175 746f    overflow: auto\n+00064b50: 3b0a 2020 7061 6464 696e 673a 2076 6172  ;.  padding: var\n+00064b60: 282d 2d70 782d 3132 293b 0a7d 0a0a 2e43  (--px-12);.}...C\n+00064b70: 6f64 654d 6972 726f 722d 6869 6e74 2d69  odeMirror-hint-i\n+00064b80: 6e66 6f72 6d61 7469 6f6e 2d68 6561 6465  nformation-heade\n+00064b90: 7220 7b0a 2020 6469 7370 6c61 793a 2066  r {.  display: f\n+00064ba0: 6c65 783b 0a20 2061 6c69 676e 2d69 7465  lex;.  align-ite\n+00064bb0: 6d73 3a20 6261 7365 6c69 6e65 3b0a 7d0a  ms: baseline;.}.\n+00064bc0: 0a2e 436f 6465 4d69 7272 6f72 2d68 696e  ..CodeMirror-hin\n+00064bd0: 742d 696e 666f 726d 6174 696f 6e2d 6669  t-information-fi\n+00064be0: 656c 642d 6e61 6d65 207b 0a20 2066 6f6e  eld-name {.  fon\n+00064bf0: 742d 7369 7a65 3a20 7661 7228 2d2d 666f  t-size: var(--fo\n+00064c00: 6e74 2d73 697a 652d 6834 293b 0a20 2066  nt-size-h4);.  f\n+00064c10: 6f6e 742d 7765 6967 6874 3a20 7661 7228  ont-weight: var(\n+00064c20: 2d2d 666f 6e74 2d77 6569 6768 742d 6d65  --font-weight-me\n+00064c30: 6469 756d 293b 0a7d 0a0a 2e43 6f64 654d  dium);.}...CodeM\n+00064c40: 6972 726f 722d 6869 6e74 2d69 6e66 6f72  irror-hint-infor\n+00064c50: 6d61 7469 6f6e 2d74 7970 652d 6e61 6d65  mation-type-name\n+00064c60: 2d70 696c 6c20 7b0a 2020 626f 7264 6572  -pill {.  border\n+00064c70: 3a20 3170 7820 736f 6c69 6420 6873 6c61  : 1px solid hsla\n+00064c80: 2876 6172 282d 2d63 6f6c 6f72 2d6e 6575  (var(--color-neu\n+00064c90: 7472 616c 292c 2076 6172 282d 2d61 6c70  tral), var(--alp\n+00064ca0: 6861 2d74 6572 7469 6172 7929 293b 0a20  ha-tertiary));. \n+00064cb0: 2062 6f72 6465 722d 7261 6469 7573 3a20   border-radius: \n+00064cc0: 7661 7228 2d2d 626f 7264 6572 2d72 6164  var(--border-rad\n+00064cd0: 6975 732d 3429 3b0a 2020 636f 6c6f 723a  ius-4);.  color:\n+00064ce0: 2068 736c 6128 7661 7228 2d2d 636f 6c6f   hsla(var(--colo\n+00064cf0: 722d 6e65 7574 7261 6c29 2c20 7661 7228  r-neutral), var(\n+00064d00: 2d2d 616c 7068 612d 7365 636f 6e64 6172  --alpha-secondar\n+00064d10: 7929 293b 0a20 206d 6172 6769 6e2d 6c65  y));.  margin-le\n+00064d20: 6674 3a20 7661 7228 2d2d 7078 2d36 293b  ft: var(--px-6);\n+00064d30: 0a20 2070 6164 6469 6e67 3a20 7661 7228  .  padding: var(\n+00064d40: 2d2d 7078 2d34 293b 0a7d 0a0a 2e43 6f64  --px-4);.}...Cod\n+00064d50: 654d 6972 726f 722d 6869 6e74 2d69 6e66  eMirror-hint-inf\n+00064d60: 6f72 6d61 7469 6f6e 2d74 7970 652d 6e61  ormation-type-na\n+00064d70: 6d65 207b 0a20 2063 6f6c 6f72 3a20 696e  me {.  color: in\n+00064d80: 6865 7269 743b 0a20 2074 6578 742d 6465  herit;.  text-de\n+00064d90: 636f 7261 7469 6f6e 3a20 6e6f 6e65 0a7d  coration: none.}\n+00064da0: 0a0a 2e43 6f64 654d 6972 726f 722d 6869  ...CodeMirror-hi\n+00064db0: 6e74 2d69 6e66 6f72 6d61 7469 6f6e 2d74  nt-information-t\n+00064dc0: 7970 652d 6e61 6d65 3a68 6f76 6572 207b  ype-name:hover {\n+00064dd0: 0a20 2020 2074 6578 742d 6465 636f 7261  .    text-decora\n+00064de0: 7469 6f6e 3a20 756e 6465 726c 696e 6520  tion: underline \n+00064df0: 646f 7474 6564 3b0a 2020 7d0a 0a2e 436f  dotted;.  }...Co\n+00064e00: 6465 4d69 7272 6f72 2d68 696e 742d 696e  deMirror-hint-in\n+00064e10: 666f 726d 6174 696f 6e2d 6465 7363 7269  formation-descri\n+00064e20: 7074 696f 6e20 7b0a 2020 636f 6c6f 723a  ption {.  color:\n+00064e30: 2068 736c 6128 7661 7228 2d2d 636f 6c6f   hsla(var(--colo\n+00064e40: 722d 6e65 7574 7261 6c29 2c20 7661 7228  r-neutral), var(\n+00064e50: 2d2d 616c 7068 612d 7365 636f 6e64 6172  --alpha-secondar\n+00064e60: 7929 293b 0a20 206d 6172 6769 6e2d 746f  y));.  margin-to\n+00064e70: 703a 2076 6172 282d 2d70 782d 3132 293b  p: var(--px-12);\n+00064e80: 0a7d 0a2f 2a20 506f 7075 7020 7374 796c  .}./* Popup styl\n+00064e90: 6573 202a 2f0a 2e43 6f64 654d 6972 726f  es */..CodeMirro\n+00064ea0: 722d 696e 666f 207b 0a20 2062 6163 6b67  r-info {.  backg\n+00064eb0: 726f 756e 642d 636f 6c6f 723a 2068 736c  round-color: hsl\n+00064ec0: 2876 6172 282d 2d63 6f6c 6f72 2d62 6173  (var(--color-bas\n+00064ed0: 6529 293b 0a20 2062 6f72 6465 723a 2076  e));.  border: v\n+00064ee0: 6172 282d 2d70 6f70 6f76 6572 2d62 6f72  ar(--popover-bor\n+00064ef0: 6465 7229 3b0a 2020 626f 7264 6572 2d72  der);.  border-r\n+00064f00: 6164 6975 733a 2076 6172 282d 2d62 6f72  adius: var(--bor\n+00064f10: 6465 722d 7261 6469 7573 2d38 293b 0a20  der-radius-8);. \n+00064f20: 2062 6f78 2d73 6861 646f 773a 2076 6172   box-shadow: var\n+00064f30: 282d 2d70 6f70 6f76 6572 2d62 6f78 2d73  (--popover-box-s\n+00064f40: 6861 646f 7729 3b0a 2020 636f 6c6f 723a  hadow);.  color:\n+00064f50: 2068 736c 2876 6172 282d 2d63 6f6c 6f72   hsl(var(--color\n+00064f60: 2d6e 6575 7472 616c 2929 3b0a 2020 6d61  -neutral));.  ma\n+00064f70: 782d 6865 6967 6874 3a20 3330 3070 783b  x-height: 300px;\n+00064f80: 0a20 206d 6178 2d77 6964 7468 3a20 3430  .  max-width: 40\n+00064f90: 3070 783b 0a20 206f 7061 6369 7479 3a20  0px;.  opacity: \n+00064fa0: 303b 0a20 206f 7665 7266 6c6f 773a 2061  0;.  overflow: a\n+00064fb0: 7574 6f3b 0a20 2070 6164 6469 6e67 3a20  uto;.  padding: \n+00064fc0: 7661 7228 2d2d 7078 2d31 3229 3b0a 2020  var(--px-12);.  \n+00064fd0: 706f 7369 7469 6f6e 3a20 6669 7865 643b  position: fixed;\n+00064fe0: 0a20 2074 7261 6e73 6974 696f 6e3a 206f  .  transition: o\n+00064ff0: 7061 6369 7479 2030 2e31 3573 3b0a 2020  pacity 0.15s;.  \n+00065000: 7a2d 696e 6465 783a 2031 300a 0a20 202f  z-index: 10..  /\n+00065010: 2a20 4c69 6e6b 2073 7479 6c65 7320 2a2f  * Link styles */\n+00065020: 0a7d 0a2e 436f 6465 4d69 7272 6f72 2d69  .}..CodeMirror-i\n+00065030: 6e66 6f20 6120 7b0a 2020 2020 636f 6c6f  nfo a {.    colo\n+00065040: 723a 2069 6e68 6572 6974 3b0a 2020 2020  r: inherit;.    \n+00065050: 7465 7874 2d64 6563 6f72 6174 696f 6e3a  text-decoration:\n+00065060: 206e 6f6e 650a 2020 7d0a 2e43 6f64 654d   none.  }..CodeM\n+00065070: 6972 726f 722d 696e 666f 2061 3a68 6f76  irror-info a:hov\n+00065080: 6572 207b 0a20 2020 2020 2074 6578 742d  er {.      text-\n+00065090: 6465 636f 7261 7469 6f6e 3a20 756e 6465  decoration: unde\n+000650a0: 726c 696e 6520 646f 7474 6564 3b0a 2020  rline dotted;.  \n+000650b0: 2020 7d0a 2f2a 2041 6c69 676e 2065 6c65    }./* Align ele\n+000650c0: 6d65 6e74 7320 696e 2068 6561 6465 7220  ments in header \n+000650d0: 2a2f 0a2e 436f 6465 4d69 7272 6f72 2d69  */..CodeMirror-i\n+000650e0: 6e66 6f20 2e43 6f64 654d 6972 726f 722d  nfo .CodeMirror-\n+000650f0: 696e 666f 2d68 6561 6465 7220 7b0a 2020  info-header {.  \n+00065100: 2020 6469 7370 6c61 793a 2066 6c65 783b    display: flex;\n+00065110: 0a20 2020 2061 6c69 676e 2d69 7465 6d73  .    align-items\n+00065120: 3a20 6261 7365 6c69 6e65 3b0a 2020 7d0a  : baseline;.  }.\n+00065130: 2f2a 204d 6169 6e20 656c 656d 656e 7473  /* Main elements\n+00065140: 202a 2f0a 2e43 6f64 654d 6972 726f 722d   */..CodeMirror-\n+00065150: 696e 666f 202e 436f 6465 4d69 7272 6f72  info .CodeMirror\n+00065160: 2d69 6e66 6f2d 6865 6164 6572 203e 202e  -info-header > .\n+00065170: 7479 7065 2d6e 616d 652c 0a20 2020 202e  type-name,.    .\n+00065180: 436f 6465 4d69 7272 6f72 2d69 6e66 6f20  CodeMirror-info \n+00065190: 2e43 6f64 654d 6972 726f 722d 696e 666f  .CodeMirror-info\n+000651a0: 2d68 6561 6465 7220 3e20 2e66 6965 6c64  -header > .field\n+000651b0: 2d6e 616d 652c 0a20 2020 202e 436f 6465  -name,.    .Code\n+000651c0: 4d69 7272 6f72 2d69 6e66 6f20 2e43 6f64  Mirror-info .Cod\n+000651d0: 654d 6972 726f 722d 696e 666f 2d68 6561  eMirror-info-hea\n+000651e0: 6465 7220 3e20 2e61 7267 2d6e 616d 652c  der > .arg-name,\n+000651f0: 0a20 2020 202e 436f 6465 4d69 7272 6f72  .    .CodeMirror\n+00065200: 2d69 6e66 6f20 2e43 6f64 654d 6972 726f  -info .CodeMirro\n+00065210: 722d 696e 666f 2d68 6561 6465 7220 3e20  r-info-header > \n+00065220: 2e64 6972 6563 7469 7665 2d6e 616d 652c  .directive-name,\n+00065230: 0a20 2020 202e 436f 6465 4d69 7272 6f72  .    .CodeMirror\n+00065240: 2d69 6e66 6f20 2e43 6f64 654d 6972 726f  -info .CodeMirro\n+00065250: 722d 696e 666f 2d68 6561 6465 7220 3e20  r-info-header > \n+00065260: 2e65 6e75 6d2d 7661 6c75 6520 7b0a 2020  .enum-value {.  \n+00065270: 2020 2020 666f 6e74 2d73 697a 653a 2076      font-size: v\n+00065280: 6172 282d 2d66 6f6e 742d 7369 7a65 2d68  ar(--font-size-h\n+00065290: 3429 3b0a 2020 2020 2020 666f 6e74 2d77  4);.      font-w\n+000652a0: 6569 6768 743a 2076 6172 282d 2d66 6f6e  eight: var(--fon\n+000652b0: 742d 7765 6967 6874 2d6d 6564 6975 6d29  t-weight-medium)\n+000652c0: 3b0a 2020 2020 7d0a 2f2a 2054 7970 6520  ;.    }./* Type \n+000652d0: 6e61 6d65 7320 2a2f 0a2e 436f 6465 4d69  names */..CodeMi\n+000652e0: 7272 6f72 2d69 6e66 6f20 2e74 7970 652d  rror-info .type-\n+000652f0: 6e61 6d65 2d70 696c 6c20 7b0a 2020 2020  name-pill {.    \n+00065300: 626f 7264 6572 3a20 3170 7820 736f 6c69  border: 1px soli\n+00065310: 6420 6873 6c61 2876 6172 282d 2d63 6f6c  d hsla(var(--col\n+00065320: 6f72 2d6e 6575 7472 616c 292c 2076 6172  or-neutral), var\n+00065330: 282d 2d61 6c70 6861 2d74 6572 7469 6172  (--alpha-tertiar\n+00065340: 7929 293b 0a20 2020 2062 6f72 6465 722d  y));.    border-\n+00065350: 7261 6469 7573 3a20 7661 7228 2d2d 626f  radius: var(--bo\n+00065360: 7264 6572 2d72 6164 6975 732d 3429 3b0a  rder-radius-4);.\n+00065370: 2020 2020 636f 6c6f 723a 2068 736c 6128      color: hsla(\n+00065380: 7661 7228 2d2d 636f 6c6f 722d 6e65 7574  var(--color-neut\n+00065390: 7261 6c29 2c20 7661 7228 2d2d 616c 7068  ral), var(--alph\n+000653a0: 612d 7365 636f 6e64 6172 7929 293b 0a20  a-secondary));. \n+000653b0: 2020 206d 6172 6769 6e2d 6c65 6674 3a20     margin-left: \n+000653c0: 7661 7228 2d2d 7078 2d36 293b 0a20 2020  var(--px-6);.   \n+000653d0: 2070 6164 6469 6e67 3a20 7661 7228 2d2d   padding: var(--\n+000653e0: 7078 2d34 293b 0a20 207d 0a2f 2a20 4465  px-4);.  }./* De\n+000653f0: 7363 7269 7074 696f 6e73 202a 2f0a 2e43  scriptions */..C\n+00065400: 6f64 654d 6972 726f 722d 696e 666f 202e  odeMirror-info .\n+00065410: 696e 666f 2d64 6573 6372 6970 7469 6f6e  info-description\n+00065420: 207b 0a20 2020 2063 6f6c 6f72 3a20 6873   {.    color: hs\n+00065430: 6c61 2876 6172 282d 2d63 6f6c 6f72 2d6e  la(var(--color-n\n+00065440: 6575 7472 616c 292c 2076 6172 282d 2d61  eutral), var(--a\n+00065450: 6c70 6861 2d73 6563 6f6e 6461 7279 2929  lpha-secondary))\n+00065460: 3b0a 2020 2020 6d61 7267 696e 2d74 6f70  ;.    margin-top\n+00065470: 3a20 7661 7228 2d2d 7078 2d31 3229 3b0a  : var(--px-12);.\n+00065480: 2020 2020 6f76 6572 666c 6f77 3a20 6869      overflow: hi\n+00065490: 6464 656e 3b0a 2020 7d0a 2f2a 2055 6e64  dden;.  }./* Und\n+000654a0: 6572 6c69 6e65 2074 6865 2063 6c69 636b  erline the click\n+000654b0: 6162 6c65 2074 6f6b 656e 202a 2f0a 2e43  able token */..C\n+000654c0: 6f64 654d 6972 726f 722d 6a75 6d70 2d74  odeMirror-jump-t\n+000654d0: 6f6b 656e 207b 0a20 2074 6578 742d 6465  oken {.  text-de\n+000654e0: 636f 7261 7469 6f6e 3a20 756e 6465 726c  coration: underl\n+000654f0: 696e 6520 646f 7474 6564 3b0a 2020 6375  ine dotted;.  cu\n+00065500: 7273 6f72 3a20 706f 696e 7465 723b 0a7d  rsor: pointer;.}\n+00065510: 0a2e 6175 746f 2d69 6e73 6572 7465 642d  ..auto-inserted-\n+00065520: 6c65 6166 2e63 6d2d 7072 6f70 6572 7479  leaf.cm-property\n+00065530: 207b 0a20 2061 6e69 6d61 7469 6f6e 2d64   {.  animation-d\n+00065540: 7572 6174 696f 6e3a 2036 733b 0a20 2061  uration: 6s;.  a\n+00065550: 6e69 6d61 7469 6f6e 2d6e 616d 653a 2069  nimation-name: i\n+00065560: 6e73 6572 7469 6f6e 4661 6465 3b0a 2020  nsertionFade;.  \n+00065570: 626f 7264 6572 2d72 6164 6975 733a 2076  border-radius: v\n+00065580: 6172 282d 2d62 6f72 6465 722d 7261 6469  ar(--border-radi\n+00065590: 7573 2d34 293b 0a20 2070 6164 6469 6e67  us-4);.  padding\n+000655a0: 3a20 7661 7228 2d2d 7078 2d32 293b 0a7d  : var(--px-2);.}\n+000655b0: 0a0a 406b 6579 6672 616d 6573 2069 6e73  ..@keyframes ins\n+000655c0: 6572 7469 6f6e 4661 6465 207b 0a20 2066  ertionFade {.  f\n+000655d0: 726f 6d2c 0a20 2074 6f20 7b0a 2020 2020  rom,.  to {.    \n+000655e0: 6261 636b 6772 6f75 6e64 2d63 6f6c 6f72  background-color\n+000655f0: 3a20 6e6f 6e65 3b0a 2020 7d0a 0a20 2031  : none;.  }..  1\n+00065600: 3525 2c0a 2020 3835 2520 7b0a 2020 2020  5%,.  85% {.    \n+00065610: 6261 636b 6772 6f75 6e64 2d63 6f6c 6f72  background-color\n+00065620: 3a20 6873 6c61 2876 6172 282d 2d63 6f6c  : hsla(var(--col\n+00065630: 6f72 2d77 6172 6e69 6e67 292c 2076 6172  or-warning), var\n+00065640: 282d 2d61 6c70 6861 2d62 6163 6b67 726f  (--alpha-backgro\n+00065650: 756e 642d 6c69 6768 7429 293b 0a20 207d  und-light));.  }\n+00065660: 0a7d 0a62 7574 746f 6e2e 6772 6170 6869  .}.button.graphi\n+00065670: 716c 2d74 6f6f 6c62 6172 2d62 7574 746f  ql-toolbar-butto\n+00065680: 6e20 7b0a 2020 6469 7370 6c61 793a 2066  n {.  display: f\n+00065690: 6c65 783b 0a20 2061 6c69 676e 2d69 7465  lex;.  align-ite\n+000656a0: 6d73 3a20 6365 6e74 6572 3b0a 2020 6a75  ms: center;.  ju\n+000656b0: 7374 6966 792d 636f 6e74 656e 743a 2063  stify-content: c\n+000656c0: 656e 7465 723b 0a20 2068 6569 6768 743a  enter;.  height:\n+000656d0: 2076 6172 282d 2d74 6f6f 6c62 6172 2d77   var(--toolbar-w\n+000656e0: 6964 7468 293b 0a20 2077 6964 7468 3a20  idth);.  width: \n+000656f0: 7661 7228 2d2d 746f 6f6c 6261 722d 7769  var(--toolbar-wi\n+00065700: 6474 6829 0a7d 0a62 7574 746f 6e2e 6772  dth).}.button.gr\n+00065710: 6170 6869 716c 2d74 6f6f 6c62 6172 2d62  aphiql-toolbar-b\n+00065720: 7574 746f 6e2e 6572 726f 7220 7b0a 2020  utton.error {.  \n+00065730: 2020 6261 636b 6772 6f75 6e64 3a20 6873    background: hs\n+00065740: 6c61 2876 6172 282d 2d63 6f6c 6f72 2d65  la(var(--color-e\n+00065750: 7272 6f72 292c 2076 6172 282d 2d61 6c70  rror), var(--alp\n+00065760: 6861 2d62 6163 6b67 726f 756e 642d 6865  ha-background-he\n+00065770: 6176 7929 293b 0a20 207d 0a2e 6772 6170  avy));.  }..grap\n+00065780: 6869 716c 2d65 7865 6375 7465 2d62 7574  hiql-execute-but\n+00065790: 746f 6e2d 7772 6170 7065 7220 7b0a 2020  ton-wrapper {.  \n+000657a0: 706f 7369 7469 6f6e 3a20 7265 6c61 7469  position: relati\n+000657b0: 7665 3b0a 7d0a 0a62 7574 746f 6e2e 6772  ve;.}..button.gr\n+000657c0: 6170 6869 716c 2d65 7865 6375 7465 2d62  aphiql-execute-b\n+000657d0: 7574 746f 6e20 7b0a 2020 6261 636b 6772  utton {.  backgr\n+000657e0: 6f75 6e64 2d63 6f6c 6f72 3a20 6873 6c28  ound-color: hsl(\n+000657f0: 7661 7228 2d2d 636f 6c6f 722d 7072 696d  var(--color-prim\n+00065800: 6172 7929 293b 0a20 2062 6f72 6465 723a  ary));.  border:\n+00065810: 206e 6f6e 653b 0a20 2062 6f72 6465 722d   none;.  border-\n+00065820: 7261 6469 7573 3a20 7661 7228 2d2d 626f  radius: var(--bo\n+00065830: 7264 6572 2d72 6164 6975 732d 3829 3b0a  rder-radius-8);.\n+00065840: 2020 6375 7273 6f72 3a20 706f 696e 7465    cursor: pointe\n+00065850: 723b 0a20 2068 6569 6768 743a 2076 6172  r;.  height: var\n+00065860: 282d 2d74 6f6f 6c62 6172 2d77 6964 7468  (--toolbar-width\n+00065870: 293b 0a20 2070 6164 6469 6e67 3a20 303b  );.  padding: 0;\n+00065880: 0a20 2077 6964 7468 3a20 7661 7228 2d2d  .  width: var(--\n+00065890: 746f 6f6c 6261 722d 7769 6474 6829 0a7d  toolbar-width).}\n+000658a0: 0a0a 6275 7474 6f6e 2e67 7261 7068 6971  ..button.graphiq\n+000658b0: 6c2d 6578 6563 7574 652d 6275 7474 6f6e  l-execute-button\n+000658c0: 3a68 6f76 6572 207b 0a20 2020 2062 6163  :hover {.    bac\n+000658d0: 6b67 726f 756e 642d 636f 6c6f 723a 2068  kground-color: h\n+000658e0: 736c 6128 7661 7228 2d2d 636f 6c6f 722d  sla(var(--color-\n+000658f0: 7072 696d 6172 7929 2c20 302e 3929 3b0a  primary), 0.9);.\n+00065900: 2020 7d0a 0a62 7574 746f 6e2e 6772 6170    }..button.grap\n+00065910: 6869 716c 2d65 7865 6375 7465 2d62 7574  hiql-execute-but\n+00065920: 746f 6e3a 6163 7469 7665 207b 0a20 2020  ton:active {.   \n+00065930: 2062 6163 6b67 726f 756e 642d 636f 6c6f   background-colo\n+00065940: 723a 2068 736c 6128 7661 7228 2d2d 636f  r: hsla(var(--co\n+00065950: 6c6f 722d 7072 696d 6172 7929 2c20 302e  lor-primary), 0.\n+00065960: 3829 3b0a 2020 7d0a 0a62 7574 746f 6e2e  8);.  }..button.\n+00065970: 6772 6170 6869 716c 2d65 7865 6375 7465  graphiql-execute\n+00065980: 2d62 7574 746f 6e3a 666f 6375 7320 7b0a  -button:focus {.\n+00065990: 2020 2020 6f75 746c 696e 653a 2068 736c      outline: hsl\n+000659a0: 6128 7661 7228 2d2d 636f 6c6f 722d 7072  a(var(--color-pr\n+000659b0: 696d 6172 7929 2c20 302e 3829 2061 7574  imary), 0.8) aut\n+000659c0: 6f20 3170 783b 0a20 207d 0a0a 6275 7474  o 1px;.  }..butt\n+000659d0: 6f6e 2e67 7261 7068 6971 6c2d 6578 6563  on.graphiql-exec\n+000659e0: 7574 652d 6275 7474 6f6e 203e 2073 7667  ute-button > svg\n+000659f0: 207b 0a20 2020 2063 6f6c 6f72 3a20 7768   {.    color: wh\n+00065a00: 6974 653b 0a20 2020 2064 6973 706c 6179  ite;.    display\n+00065a10: 3a20 626c 6f63 6b3b 0a20 2020 2068 6569  : block;.    hei\n+00065a20: 6768 743a 2076 6172 282d 2d70 782d 3136  ght: var(--px-16\n+00065a30: 293b 0a20 2020 206d 6172 6769 6e3a 2061  );.    margin: a\n+00065a40: 7574 6f3b 0a20 2020 2077 6964 7468 3a20  uto;.    width: \n+00065a50: 7661 7228 2d2d 7078 2d31 3629 3b0a 2020  var(--px-16);.  \n+00065a60: 7d0a 6275 7474 6f6e 2e67 7261 7068 6971  }.button.graphiq\n+00065a70: 6c2d 746f 6f6c 6261 722d 6d65 6e75 207b  l-toolbar-menu {\n+00065a80: 0a20 2064 6973 706c 6179 3a20 626c 6f63  .  display: bloc\n+00065a90: 6b3b 0a20 2068 6569 6768 743a 2076 6172  k;.  height: var\n+00065aa0: 282d 2d74 6f6f 6c62 6172 2d77 6964 7468  (--toolbar-width\n+00065ab0: 293b 0a20 2077 6964 7468 3a20 7661 7228  );.  width: var(\n+00065ac0: 2d2d 746f 6f6c 6261 722d 7769 6474 6829  --toolbar-width)\n+00065ad0: 3b0a 7d0a 0a2f 2a21 2a2a 2a2a 2a2a 2a2a  ;.}../*!********\n+00065ae0: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n+00065af0: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n+00065b00: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n+00065b10: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n+00065b20: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n+00065b30: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n+00065b40: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a21 2a5c  *************!*\\\n+00065b50: 0a20 2021 2a2a 2a20 6373 7320 2e2e 2f2e  .  !*** css ../.\n+00065b60: 2e2f 2e2e 2f6e 6f64 655f 6d6f 6475 6c65  ./../node_module\n+00065b70: 732f 6373 732d 6c6f 6164 6572 2f64 6973  s/css-loader/dis\n+00065b80: 742f 636a 732e 6a73 212e 2e2f 2e2e 2f2e  t/cjs.js!../../.\n+00065b90: 2e2f 6e6f 6465 5f6d 6f64 756c 6573 2f70  ./node_modules/p\n+00065ba0: 6f73 7463 7373 2d6c 6f61 6465 722f 6469  ostcss-loader/di\n+00065bb0: 7374 2f63 6a73 2e6a 7321 2e2f 7374 796c  st/cjs.js!./styl\n+00065bc0: 652e 6373 7320 2a2a 2a21 0a20 205c 2a2a  e.css ***!.  \\**\n+00065bd0: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n+00065be0: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n+00065bf0: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n+00065c00: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n+00065c10: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n+00065c20: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n+00065c30: 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a 2a2a  ****************\n+00065c40: 2a2a 2a2f 0a2f 2a20 4576 6572 7974 6869  ***/./* Everythi\n+00065c50: 6e67 202a 2f0a 2e67 7261 7068 6971 6c2d  ng */..graphiql-\n+00065c60: 636f 6e74 6169 6e65 7220 7b0a 2020 6261  container {.  ba\n+00065c70: 636b 6772 6f75 6e64 2d63 6f6c 6f72 3a20  ckground-color: \n+00065c80: 6873 6c28 7661 7228 2d2d 636f 6c6f 722d  hsl(var(--color-\n+00065c90: 6261 7365 2929 3b0a 2020 6469 7370 6c61  base));.  displa\n+00065ca0: 793a 2066 6c65 783b 0a20 2068 6569 6768  y: flex;.  heigh\n+00065cb0: 743a 2031 3030 253b 0a20 206d 6172 6769  t: 100%;.  margi\n+00065cc0: 6e3a 2030 3b0a 2020 6f76 6572 666c 6f77  n: 0;.  overflow\n+00065cd0: 3a20 6869 6464 656e 3b0a 2020 7769 6474  : hidden;.  widt\n+00065ce0: 683a 2031 3030 253b 0a7d 0a2f 2a20 5468  h: 100%;.}./* Th\n+00065cf0: 6520 7369 6465 6261 7220 2a2f 0a2e 6772  e sidebar */..gr\n+00065d00: 6170 6869 716c 2d63 6f6e 7461 696e 6572  aphiql-container\n+00065d10: 202e 6772 6170 6869 716c 2d73 6964 6562   .graphiql-sideb\n+00065d20: 6172 207b 0a20 2064 6973 706c 6179 3a20  ar {.  display: \n+00065d30: 666c 6578 3b0a 2020 666c 6578 2d64 6972  flex;.  flex-dir\n+00065d40: 6563 7469 6f6e 3a20 636f 6c75 6d6e 3b0a  ection: column;.\n+00065d50: 2020 6a75 7374 6966 792d 636f 6e74 656e    justify-conten\n+00065d60: 743a 2073 7061 6365 2d62 6574 7765 656e  t: space-between\n+00065d70: 3b0a 2020 7061 6464 696e 673a 2076 6172  ;.  padding: var\n+00065d80: 282d 2d70 782d 3829 3b0a 2020 7769 6474  (--px-8);.  widt\n+00065d90: 683a 2076 6172 282d 2d73 6964 6562 6172  h: var(--sidebar\n+00065da0: 2d77 6964 7468 293b 0a7d 0a2e 6772 6170  -width);.}..grap\n+00065db0: 6869 716c 2d63 6f6e 7461 696e 6572 202e  hiql-container .\n+00065dc0: 6772 6170 6869 716c 2d73 6964 6562 6172  graphiql-sidebar\n+00065dd0: 202e 6772 6170 6869 716c 2d73 6964 6562   .graphiql-sideb\n+00065de0: 6172 2d73 6563 7469 6f6e 207b 0a20 2064  ar-section {.  d\n+00065df0: 6973 706c 6179 3a20 666c 6578 3b0a 2020  isplay: flex;.  \n+00065e00: 666c 6578 2d64 6972 6563 7469 6f6e 3a20  flex-direction: \n+00065e10: 636f 6c75 6d6e 3b0a 2020 6761 703a 2076  column;.  gap: v\n+00065e20: 6172 282d 2d70 782d 3829 3b0a 7d0a 2e67  ar(--px-8);.}..g\n+00065e30: 7261 7068 6971 6c2d 636f 6e74 6169 6e65  raphiql-containe\n+00065e40: 7220 2e67 7261 7068 6971 6c2d 7369 6465  r .graphiql-side\n+00065e50: 6261 7220 6275 7474 6f6e 207b 0a20 2064  bar button {.  d\n+00065e60: 6973 706c 6179 3a20 666c 6578 3b0a 2020  isplay: flex;.  \n+00065e70: 616c 6967 6e2d 6974 656d 733a 2063 656e  align-items: cen\n+00065e80: 7465 723b 0a20 206a 7573 7469 6679 2d63  ter;.  justify-c\n+00065e90: 6f6e 7465 6e74 3a20 6365 6e74 6572 3b0a  ontent: center;.\n+00065ea0: 2020 636f 6c6f 723a 2068 736c 6128 7661    color: hsla(va\n+00065eb0: 7228 2d2d 636f 6c6f 722d 6e65 7574 7261  r(--color-neutra\n+00065ec0: 6c29 2c20 7661 7228 2d2d 616c 7068 612d  l), var(--alpha-\n+00065ed0: 7365 636f 6e64 6172 7929 293b 0a20 2068  secondary));.  h\n+00065ee0: 6569 6768 743a 2063 616c 6328 7661 7228  eight: calc(var(\n+00065ef0: 2d2d 7369 6465 6261 722d 7769 6474 6829  --sidebar-width)\n+00065f00: 202d 2028 3220 2a20 7661 7228 2d2d 7078   - (2 * var(--px\n+00065f10: 2d38 2929 293b 0a20 2077 6964 7468 3a20  -8)));.  width: \n+00065f20: 6361 6c63 2876 6172 282d 2d73 6964 6562  calc(var(--sideb\n+00065f30: 6172 2d77 6964 7468 2920 2d20 2832 202a  ar-width) - (2 *\n+00065f40: 2076 6172 282d 2d70 782d 3829 2929 3b0a   var(--px-8)));.\n+00065f50: 7d0a 2e67 7261 7068 6971 6c2d 636f 6e74  }..graphiql-cont\n+00065f60: 6169 6e65 7220 2e67 7261 7068 6971 6c2d  ainer .graphiql-\n+00065f70: 7369 6465 6261 7220 6275 7474 6f6e 2e61  sidebar button.a\n+00065f80: 6374 6976 6520 7b0a 2020 636f 6c6f 723a  ctive {.  color:\n+00065f90: 2068 736c 2876 6172 282d 2d63 6f6c 6f72   hsl(var(--color\n+00065fa0: 2d6e 6575 7472 616c 2929 3b0a 7d0a 2e67  -neutral));.}..g\n+00065fb0: 7261 7068 6971 6c2d 636f 6e74 6169 6e65  raphiql-containe\n+00065fc0: 7220 2e67 7261 7068 6971 6c2d 7369 6465  r .graphiql-side\n+00065fd0: 6261 7220 6275 7474 6f6e 3a6e 6f74 283a  bar button:not(:\n+00065fe0: 6669 7273 742d 6368 696c 6429 207b 0a20  first-child) {. \n+00065ff0: 206d 6172 6769 6e2d 746f 703a 2076 6172   margin-top: var\n+00066000: 282d 2d70 782d 3429 3b0a 7d0a 2e67 7261  (--px-4);.}..gra\n+00066010: 7068 6971 6c2d 636f 6e74 6169 6e65 7220  phiql-container \n+00066020: 2e67 7261 7068 6971 6c2d 7369 6465 6261  .graphiql-sideba\n+00066030: 7220 6275 7474 6f6e 203e 2073 7667 207b  r button > svg {\n+00066040: 0a20 2068 6569 6768 743a 2076 6172 282d  .  height: var(-\n+00066050: 2d70 782d 3230 293b 0a20 2077 6964 7468  -px-20);.  width\n+00066060: 3a20 7661 7228 2d2d 7078 2d32 3029 3b0a  : var(--px-20);.\n+00066070: 7d0a 2f2a 2054 6865 206d 6169 6e20 636f  }./* The main co\n+00066080: 6e74 656e 742c 2069 2e65 2e20 6576 6572  ntent, i.e. ever\n+00066090: 7974 6869 6e67 2065 7863 6570 7420 7468  ything except th\n+000660a0: 6520 7369 6465 6261 7220 2a2f 0a2e 6772  e sidebar */..gr\n+000660b0: 6170 6869 716c 2d63 6f6e 7461 696e 6572  aphiql-container\n+000660c0: 202e 6772 6170 6869 716c 2d6d 6169 6e20   .graphiql-main \n+000660d0: 7b0a 2020 6469 7370 6c61 793a 2066 6c65  {.  display: fle\n+000660e0: 783b 0a20 2066 6c65 783a 2031 3b0a 2020  x;.  flex: 1;.  \n+000660f0: 6d69 6e2d 7769 6474 683a 2030 3b0a 7d0a  min-width: 0;.}.\n+00066100: 2f2a 2054 6865 2063 7572 7265 6e74 2073  /* The current s\n+00066110: 6573 7369 6f6e 2061 6e64 2074 6162 7320  ession and tabs \n+00066120: 2a2f 0a2e 6772 6170 6869 716c 2d63 6f6e  */..graphiql-con\n+00066130: 7461 696e 6572 202e 6772 6170 6869 716c  tainer .graphiql\n+00066140: 2d73 6573 7369 6f6e 7320 7b0a 2020 6261  -sessions {.  ba\n+00066150: 636b 6772 6f75 6e64 2d63 6f6c 6f72 3a20  ckground-color: \n+00066160: 6873 6c61 2876 6172 282d 2d63 6f6c 6f72  hsla(var(--color\n+00066170: 2d6e 6575 7472 616c 292c 2076 6172 282d  -neutral), var(-\n+00066180: 2d61 6c70 6861 2d62 6163 6b67 726f 756e  -alpha-backgroun\n+00066190: 642d 6c69 6768 7429 293b 0a20 202f 2a20  d-light));.  /* \n+000661a0: 4164 6469 6e67 2074 6865 2038 7078 206f  Adding the 8px o\n+000661b0: 6620 7061 6464 696e 6720 746f 2074 6865  f padding to the\n+000661c0: 2069 6e6e 6572 2062 6f72 6465 7220 7261   inner border ra\n+000661d0: 6469 7573 206f 6620 7468 6520 7175 6572  dius of the quer\n+000661e0: 7920 6564 6974 6f72 202a 2f0a 2020 626f  y editor */.  bo\n+000661f0: 7264 6572 2d72 6164 6975 733a 2063 616c  rder-radius: cal\n+00066200: 6328 7661 7228 2d2d 626f 7264 6572 2d72  c(var(--border-r\n+00066210: 6164 6975 732d 3132 2920 2b20 7661 7228  adius-12) + var(\n+00066220: 2d2d 7078 2d38 2929 3b0a 2020 6469 7370  --px-8));.  disp\n+00066230: 6c61 793a 2066 6c65 783b 0a20 2066 6c65  lay: flex;.  fle\n+00066240: 782d 6469 7265 6374 696f 6e3a 2063 6f6c  x-direction: col\n+00066250: 756d 6e3b 0a20 2066 6c65 783a 2031 3b0a  umn;.  flex: 1;.\n+00066260: 2020 6d61 782d 6865 6967 6874 3a20 3130    max-height: 10\n+00066270: 3025 3b0a 2020 6d61 7267 696e 3a20 7661  0%;.  margin: va\n+00066280: 7228 2d2d 7078 2d31 3629 3b0a 2020 6d61  r(--px-16);.  ma\n+00066290: 7267 696e 2d6c 6566 743a 2030 3b0a 2020  rgin-left: 0;.  \n+000662a0: 6d69 6e2d 7769 6474 683a 2030 3b0a 7d0a  min-width: 0;.}.\n+000662b0: 2f2a 2054 6865 2073 6573 7369 6f6e 2068  /* The session h\n+000662c0: 6561 6465 7220 636f 6e74 6169 6e69 6e67  eader containing\n+000662d0: 2074 6162 7320 616e 6420 7468 6520 6c6f   tabs and the lo\n+000662e0: 676f 202a 2f0a 2e67 7261 7068 6971 6c2d  go */..graphiql-\n+000662f0: 636f 6e74 6169 6e65 7220 2e67 7261 7068  container .graph\n+00066300: 6971 6c2d 7365 7373 696f 6e2d 6865 6164  iql-session-head\n+00066310: 6572 207b 0a20 2061 6c69 676e 2d69 7465  er {.  align-ite\n+00066320: 6d73 3a20 6365 6e74 6572 3b0a 2020 6469  ms: center;.  di\n+00066330: 7370 6c61 793a 2066 6c65 783b 0a20 206a  splay: flex;.  j\n+00066340: 7573 7469 6679 2d63 6f6e 7465 6e74 3a20  ustify-content: \n+00066350: 7370 6163 652d 6265 7477 6565 6e3b 0a20  space-between;. \n+00066360: 2068 6569 6768 743a 2076 6172 282d 2d73   height: var(--s\n+00066370: 6573 7369 6f6e 2d68 6561 6465 722d 6865  ession-header-he\n+00066380: 6967 6874 293b 0a7d 0a2f 2a20 5468 6520  ight);.}./* The \n+00066390: 6275 7474 6f6e 2074 6f20 6164 6420 6120  button to add a \n+000663a0: 6e65 7720 7461 6220 2a2f 0a62 7574 746f  new tab */.butto\n+000663b0: 6e2e 6772 6170 6869 716c 2d74 6162 2d61  n.graphiql-tab-a\n+000663c0: 6464 207b 0a20 2068 6569 6768 743a 2031  dd {.  height: 1\n+000663d0: 3030 253b 0a20 2070 6164 6469 6e67 3a20  00%;.  padding: \n+000663e0: 7661 7228 2d2d 7078 2d34 293b 0a7d 0a62  var(--px-4);.}.b\n+000663f0: 7574 746f 6e2e 6772 6170 6869 716c 2d74  utton.graphiql-t\n+00066400: 6162 2d61 6464 203e 2073 7667 207b 0a20  ab-add > svg {. \n+00066410: 2063 6f6c 6f72 3a20 6873 6c61 2876 6172   color: hsla(var\n+00066420: 282d 2d63 6f6c 6f72 2d6e 6575 7472 616c  (--color-neutral\n+00066430: 292c 2076 6172 282d 2d61 6c70 6861 2d73  ), var(--alpha-s\n+00066440: 6563 6f6e 6461 7279 2929 3b0a 2020 6469  econdary));.  di\n+00066450: 7370 6c61 793a 2062 6c6f 636b 3b0a 2020  splay: block;.  \n+00066460: 6865 6967 6874 3a20 7661 7228 2d2d 7078  height: var(--px\n+00066470: 2d31 3629 3b0a 2020 7769 6474 683a 2076  -16);.  width: v\n+00066480: 6172 282d 2d70 782d 3136 293b 0a7d 0a2f  ar(--px-16);.}./\n+00066490: 2a20 5468 6520 7269 6768 742d 6861 6e64  * The right-hand\n+000664a0: 2d73 6964 6520 6f66 2074 6865 2073 6573  -side of the ses\n+000664b0: 7369 6f6e 2068 6561 6465 7220 2a2f 0a2e  sion header */..\n+000664c0: 6772 6170 6869 716c 2d63 6f6e 7461 696e  graphiql-contain\n+000664d0: 6572 202e 6772 6170 6869 716c 2d73 6573  er .graphiql-ses\n+000664e0: 7369 6f6e 2d68 6561 6465 722d 7269 6768  sion-header-righ\n+000664f0: 7420 7b0a 2020 616c 6967 6e2d 6974 656d  t {.  align-item\n+00066500: 733a 2063 656e 7465 723b 0a20 2064 6973  s: center;.  dis\n+00066510: 706c 6179 3a20 666c 6578 3b0a 7d0a 2f2a  play: flex;.}./*\n+00066520: 2054 6865 2047 7261 7068 6951 4c20 6c6f   The GraphiQL lo\n+00066530: 676f 202a 2f0a 2e67 7261 7068 6971 6c2d  go */..graphiql-\n+00066540: 636f 6e74 6169 6e65 7220 2e67 7261 7068  container .graph\n+00066550: 6971 6c2d 6c6f 676f 207b 0a20 2063 6f6c  iql-logo {.  col\n+00066560: 6f72 3a20 6873 6c61 2876 6172 282d 2d63  or: hsla(var(--c\n+00066570: 6f6c 6f72 2d6e 6575 7472 616c 292c 2076  olor-neutral), v\n+00066580: 6172 282d 2d61 6c70 6861 2d73 6563 6f6e  ar(--alpha-secon\n+00066590: 6461 7279 2929 3b0a 2020 666f 6e74 2d73  dary));.  font-s\n+000665a0: 697a 653a 2076 6172 282d 2d66 6f6e 742d  ize: var(--font-\n+000665b0: 7369 7a65 2d68 3429 3b0a 2020 666f 6e74  size-h4);.  font\n+000665c0: 2d77 6569 6768 743a 2076 6172 282d 2d66  -weight: var(--f\n+000665d0: 6f6e 742d 7765 6967 6874 2d6d 6564 6975  ont-weight-mediu\n+000665e0: 6d29 3b0a 2020 7061 6464 696e 673a 2076  m);.  padding: v\n+000665f0: 6172 282d 2d70 782d 3132 2920 7661 7228  ar(--px-12) var(\n+00066600: 2d2d 7078 2d31 3629 3b0a 7d0a 2f2a 2055  --px-16);.}./* U\n+00066610: 6e64 6f20 6465 6661 756c 7420 6c69 6e6b  ndo default link\n+00066620: 2073 7479 6c69 6e67 2066 6f72 2074 6865   styling for the\n+00066630: 2064 6566 6175 6c74 2047 7261 7068 6951   default GraphiQ\n+00066640: 4c20 6c6f 676f 206c 696e 6b20 2a2f 0a2e  L logo link */..\n+00066650: 6772 6170 6869 716c 2d63 6f6e 7461 696e  graphiql-contain\n+00066660: 6572 202e 6772 6170 6869 716c 2d6c 6f67  er .graphiql-log\n+00066670: 6f20 2e67 7261 7068 6971 6c2d 6c6f 676f  o .graphiql-logo\n+00066680: 2d6c 696e 6b20 7b0a 2020 636f 6c6f 723a  -link {.  color:\n+00066690: 2068 736c 6128 7661 7228 2d2d 636f 6c6f   hsla(var(--colo\n+000666a0: 722d 6e65 7574 7261 6c29 2c20 7661 7228  r-neutral), var(\n+000666b0: 2d2d 616c 7068 612d 7365 636f 6e64 6172  --alpha-secondar\n+000666c0: 7929 293b 0a20 2074 6578 742d 6465 636f  y));.  text-deco\n+000666d0: 7261 7469 6f6e 3a20 6e6f 6e65 3b0a 7d0a  ration: none;.}.\n+000666e0: 2f2a 2054 6865 2065 6469 746f 7220 6f66  /* The editor of\n+000666f0: 2074 6865 2073 6573 7369 6f6e 202a 2f0a   the session */.\n+00066700: 2e67 7261 7068 6971 6c2d 636f 6e74 6169  .graphiql-contai\n+00066710: 6e65 7220 2e67 7261 7068 6971 6c2d 7365  ner .graphiql-se\n+00066720: 7373 696f 6e20 7b0a 2020 6469 7370 6c61  ssion {.  displa\n+00066730: 793a 2066 6c65 783b 0a20 2066 6c65 783a  y: flex;.  flex:\n+00066740: 2031 3b0a 2020 7061 6464 696e 673a 2030   1;.  padding: 0\n+00066750: 2076 6172 282d 2d70 782d 3829 2076 6172   var(--px-8) var\n+00066760: 282d 2d70 782d 3829 3b0a 7d0a 2f2a 2041  (--px-8);.}./* A\n+00066770: 6c6c 2065 6469 746f 7273 2028 7175 6572  ll editors (quer\n+00066780: 792c 2076 6172 6961 626c 652c 2068 6561  y, variable, hea\n+00066790: 6465 7273 2920 2a2f 0a2e 6772 6170 6869  ders) */..graphi\n+000667a0: 716c 2d63 6f6e 7461 696e 6572 202e 6772  ql-container .gr\n+000667b0: 6170 6869 716c 2d65 6469 746f 7273 207b  aphiql-editors {\n+000667c0: 0a20 2062 6163 6b67 726f 756e 642d 636f  .  background-co\n+000667d0: 6c6f 723a 2068 736c 2876 6172 282d 2d63  lor: hsl(var(--c\n+000667e0: 6f6c 6f72 2d62 6173 6529 293b 0a20 2062  olor-base));.  b\n+000667f0: 6f72 6465 722d 7261 6469 7573 3a20 6361  order-radius: ca\n+00066800: 6c63 2876 6172 282d 2d62 6f72 6465 722d  lc(var(--border-\n+00066810: 7261 6469 7573 2d31 3229 293b 0a20 2062  radius-12));.  b\n+00066820: 6f78 2d73 6861 646f 773a 2076 6172 282d  ox-shadow: var(-\n+00066830: 2d70 6f70 6f76 6572 2d62 6f78 2d73 6861  -popover-box-sha\n+00066840: 646f 7729 3b0a 2020 6469 7370 6c61 793a  dow);.  display:\n+00066850: 2066 6c65 783b 0a20 2066 6c65 783a 2031   flex;.  flex: 1\n+00066860: 3b0a 2020 666c 6578 2d64 6972 6563 7469  ;.  flex-directi\n+00066870: 6f6e 3a20 636f 6c75 6d6e 3b0a 7d0a 2e67  on: column;.}..g\n+00066880: 7261 7068 6971 6c2d 636f 6e74 6169 6e65  raphiql-containe\n+00066890: 7220 2e67 7261 7068 6971 6c2d 6564 6974  r .graphiql-edit\n+000668a0: 6f72 732e 6675 6c6c 2d68 6569 6768 7420  ors.full-height \n+000668b0: 7b0a 2020 6d61 7267 696e 2d74 6f70 3a20  {.  margin-top: \n+000668c0: 6361 6c63 2876 6172 282d 2d70 782d 3829  calc(var(--px-8)\n+000668d0: 202d 2076 6172 282d 2d73 6573 7369 6f6e   - var(--session\n+000668e0: 2d68 6561 6465 722d 6865 6967 6874 2929  -header-height))\n+000668f0: 3b0a 7d0a 2f2a 2054 6865 2071 7565 7279  ;.}./* The query\n+00066900: 2065 6469 746f 7220 616e 6420 7468 6520   editor and the \n+00066910: 746f 6f6c 6261 7220 2a2f 0a2e 6772 6170  toolbar */..grap\n+00066920: 6869 716c 2d63 6f6e 7461 696e 6572 202e  hiql-container .\n+00066930: 6772 6170 6869 716c 2d71 7565 7279 2d65  graphiql-query-e\n+00066940: 6469 746f 7220 7b0a 2020 626f 7264 6572  ditor {.  border\n+00066950: 2d62 6f74 746f 6d3a 2031 7078 2073 6f6c  -bottom: 1px sol\n+00066960: 6964 0a20 2020 2068 736c 6128 7661 7228  id.    hsla(var(\n+00066970: 2d2d 636f 6c6f 722d 6e65 7574 7261 6c29  --color-neutral)\n+00066980: 2c20 7661 7228 2d2d 616c 7068 612d 6261  , var(--alpha-ba\n+00066990: 636b 6772 6f75 6e64 2d68 6561 7679 2929  ckground-heavy))\n+000669a0: 3b0a 2020 7061 6464 696e 673a 2076 6172  ;.  padding: var\n+000669b0: 282d 2d70 782d 3136 293b 0a20 2063 6f6c  (--px-16);.  col\n+000669c0: 756d 6e2d 6761 703a 2076 6172 282d 2d70  umn-gap: var(--p\n+000669d0: 782d 3136 293b 0a20 2064 6973 706c 6179  x-16);.  display\n+000669e0: 3a20 666c 6578 3b0a 2020 7769 6474 683a  : flex;.  width:\n+000669f0: 2031 3030 253b 0a7d 0a2f 2a20 5468 6520   100%;.}./* The \n+00066a00: 7665 7274 6963 616c 2074 6f6f 6c62 6172  vertical toolbar\n+00066a10: 206e 6578 7420 746f 2074 6865 2071 7565   next to the que\n+00066a20: 7279 2065 6469 746f 7220 2a2f 0a2e 6772  ry editor */..gr\n+00066a30: 6170 6869 716c 2d63 6f6e 7461 696e 6572  aphiql-container\n+00066a40: 202e 6772 6170 6869 716c 2d74 6f6f 6c62   .graphiql-toolb\n+00066a50: 6172 207b 0a20 2077 6964 7468 3a20 7661  ar {.  width: va\n+00066a60: 7228 2d2d 746f 6f6c 6261 722d 7769 6474  r(--toolbar-widt\n+00066a70: 6829 3b0a 7d0a 2e67 7261 7068 6971 6c2d  h);.}..graphiql-\n+00066a80: 636f 6e74 6169 6e65 7220 2e67 7261 7068  container .graph\n+00066a90: 6971 6c2d 746f 6f6c 6261 7220 3e20 2a20  iql-toolbar > * \n+00066aa0: 2b20 2a20 7b0a 2020 6d61 7267 696e 2d74  + * {.  margin-t\n+00066ab0: 6f70 3a20 7661 7228 2d2d 7078 2d38 293b  op: var(--px-8);\n+00066ac0: 0a7d 0a2f 2a20 5468 6520 746f 6f6c 6261  .}./* The toolba\n+00066ad0: 7220 6963 6f6e 7320 2a2f 0a2e 6772 6170  r icons */..grap\n+00066ae0: 6869 716c 2d74 6f6f 6c62 6172 2d69 636f  hiql-toolbar-ico\n+00066af0: 6e20 7b0a 2020 636f 6c6f 723a 2068 736c  n {.  color: hsl\n+00066b00: 6128 7661 7228 2d2d 636f 6c6f 722d 6e65  a(var(--color-ne\n+00066b10: 7574 7261 6c29 2c20 7661 7228 2d2d 616c  utral), var(--al\n+00066b20: 7068 612d 7465 7274 6961 7279 2929 3b0a  pha-tertiary));.\n+00066b30: 2020 6469 7370 6c61 793a 2062 6c6f 636b    display: block\n+00066b40: 3b0a 2020 6865 6967 6874 3a20 6361 6c63  ;.  height: calc\n+00066b50: 2876 6172 282d 2d74 6f6f 6c62 6172 2d77  (var(--toolbar-w\n+00066b60: 6964 7468 2920 2d20 2876 6172 282d 2d70  idth) - (var(--p\n+00066b70: 782d 3829 202a 2032 2929 3b0a 2020 7769  x-8) * 2));.  wi\n+00066b80: 6474 683a 2063 616c 6328 7661 7228 2d2d  dth: calc(var(--\n+00066b90: 746f 6f6c 6261 722d 7769 6474 6829 202d  toolbar-width) -\n+00066ba0: 2028 7661 7228 2d2d 7078 2d38 2920 2a20   (var(--px-8) * \n+00066bb0: 3229 293b 0a7d 0a2f 2a20 5468 6520 7461  2));.}./* The ta\n+00066bc0: 6220 6261 7220 666f 7220 6564 6974 6f72  b bar for editor\n+00066bd0: 2074 6f6f 6c73 202a 2f0a 2e67 7261 7068   tools */..graph\n+00066be0: 6971 6c2d 636f 6e74 6169 6e65 7220 2e67  iql-container .g\n+00066bf0: 7261 7068 6971 6c2d 6564 6974 6f72 2d74  raphiql-editor-t\n+00066c00: 6f6f 6c73 207b 0a20 2063 7572 736f 723a  ools {.  cursor:\n+00066c10: 2072 6f77 2d72 6573 697a 653b 0a20 2064   row-resize;.  d\n+00066c20: 6973 706c 6179 3a20 666c 6578 3b0a 2020  isplay: flex;.  \n+00066c30: 7769 6474 683a 2031 3030 253b 0a20 2063  width: 100%;.  c\n+00066c40: 6f6c 756d 6e2d 6761 703a 2076 6172 282d  olumn-gap: var(-\n+00066c50: 2d70 782d 3829 3b0a 2020 7061 6464 696e  -px-8);.  paddin\n+00066c60: 673a 2076 6172 282d 2d70 782d 3829 3b0a  g: var(--px-8);.\n+00066c70: 7d0a 2e67 7261 7068 6971 6c2d 636f 6e74  }..graphiql-cont\n+00066c80: 6169 6e65 7220 2e67 7261 7068 6971 6c2d  ainer .graphiql-\n+00066c90: 6564 6974 6f72 2d74 6f6f 6c73 2062 7574  editor-tools but\n+00066ca0: 746f 6e20 7b0a 2020 636f 6c6f 723a 2068  ton {.  color: h\n+00066cb0: 736c 6128 7661 7228 2d2d 636f 6c6f 722d  sla(var(--color-\n+00066cc0: 6e65 7574 7261 6c29 2c20 7661 7228 2d2d  neutral), var(--\n+00066cd0: 616c 7068 612d 7365 636f 6e64 6172 7929  alpha-secondary)\n+00066ce0: 293b 0a7d 0a2e 6772 6170 6869 716c 2d63  );.}..graphiql-c\n+00066cf0: 6f6e 7461 696e 6572 202e 6772 6170 6869  ontainer .graphi\n+00066d00: 716c 2d65 6469 746f 722d 746f 6f6c 7320  ql-editor-tools \n+00066d10: 6275 7474 6f6e 2e61 6374 6976 6520 7b0a  button.active {.\n+00066d20: 2020 636f 6c6f 723a 2068 736c 2876 6172    color: hsl(var\n+00066d30: 282d 2d63 6f6c 6f72 2d6e 6575 7472 616c  (--color-neutral\n+00066d40: 2929 3b0a 7d0a 2f2a 2054 6865 2074 6162  ));.}./* The tab\n+00066d50: 2062 7574 746f 6e73 2074 6f20 7377 6974   buttons to swit\n+00066d60: 6368 2062 6574 7765 656e 2065 6469 746f  ch between edito\n+00066d70: 7220 746f 6f6c 7320 2a2f 0a2e 6772 6170  r tools */..grap\n+00066d80: 6869 716c 2d63 6f6e 7461 696e 6572 0a20  hiql-container. \n+00066d90: 202e 6772 6170 6869 716c 2d65 6469 746f   .graphiql-edito\n+00066da0: 722d 746f 6f6c 730a 2020 3e20 6275 7474  r-tools.  > butt\n+00066db0: 6f6e 3a6e 6f74 282e 6772 6170 6869 716c  on:not(.graphiql\n+00066dc0: 2d74 6f67 676c 652d 6564 6974 6f72 2d74  -toggle-editor-t\n+00066dd0: 6f6f 6c73 2920 7b0a 2020 7061 6464 696e  ools) {.  paddin\n+00066de0: 673a 2076 6172 282d 2d70 782d 3829 2076  g: var(--px-8) v\n+00066df0: 6172 282d 2d70 782d 3132 293b 0a7d 0a2e  ar(--px-12);.}..\n+00066e00: 6772 6170 6869 716c 2d63 6f6e 7461 696e  graphiql-contain\n+00066e10: 6572 202e 6772 6170 6869 716c 2d65 6469  er .graphiql-edi\n+00066e20: 746f 722d 746f 6f6c 7320 2e67 7261 7068  tor-tools .graph\n+00066e30: 6971 6c2d 746f 6767 6c65 2d65 6469 746f  iql-toggle-edito\n+00066e40: 722d 746f 6f6c 7320 7b0a 2020 6d61 7267  r-tools {.  marg\n+00066e50: 696e 2d6c 6566 743a 2061 7574 6f3b 0a7d  in-left: auto;.}\n+00066e60: 0a2f 2a20 416e 2065 6469 746f 7220 746f  ./* An editor to\n+00066e70: 6f6c 2c20 652e 672e 2076 6172 6961 626c  ol, e.g. variabl\n+00066e80: 6520 6f72 2068 6561 6465 7220 6564 6974  e or header edit\n+00066e90: 6f72 202a 2f0a 2e67 7261 7068 6971 6c2d  or */..graphiql-\n+00066ea0: 636f 6e74 6169 6e65 7220 2e67 7261 7068  container .graph\n+00066eb0: 6971 6c2d 6564 6974 6f72 2d74 6f6f 6c20  iql-editor-tool \n+00066ec0: 7b0a 2020 666c 6578 3a20 313b 0a20 2070  {.  flex: 1;.  p\n+00066ed0: 6164 6469 6e67 3a20 7661 7228 2d2d 7078  adding: var(--px\n+00066ee0: 2d31 3629 3b0a 7d0a 2f2a 2a0a 2020 202a  -16);.}./**.   *\n+00066ef0: 2054 6865 2077 6179 2043 6f64 654d 6972   The way CodeMir\n+00066f00: 726f 7220 6564 6974 6f72 7320 6172 6520  ror editors are \n+00066f10: 7374 796c 6564 2074 6865 7920 6f76 6572  styled they over\n+00066f20: 666c 6f77 2074 6865 6972 2063 6f6e 7461  flow their conta\n+00066f30: 696e 696e 670a 2020 202a 2065 6c65 6d65  ining.   * eleme\n+00066f40: 6e74 2e20 466f 7220 736f 6d65 204f 532d  nt. For some OS-\n+00066f50: 6272 6f77 7365 722d 636f 6d62 696e 6174  browser-combinat\n+00066f60: 696f 6e73 2074 6869 7320 6d69 6768 7420  ions this might \n+00066f70: 6361 7573 6520 6f76 6572 6c61 7020 6973  cause overlap is\n+00066f80: 7375 6573 2c0a 2020 202a 2073 6574 7469  sues,.   * setti\n+00066f90: 6e67 2074 6865 2070 6f73 6974 696f 6e20  ng the position \n+00066fa0: 6f66 2074 6869 7320 746f 2060 7265 6c61  of this to `rela\n+00066fb0: 7469 7665 6020 6d61 6b65 7320 7375 7265  tive` makes sure\n+00066fc0: 2074 6869 7320 656c 656d 656e 7420 7769   this element wi\n+00066fd0: 6c6c 0a20 2020 2a20 616c 7761 7973 2062  ll.   * always b\n+00066fe0: 6520 6f6e 2074 6f70 206f 6620 616e 7920  e on top of any \n+00066ff0: 6564 6974 6f72 732e 0a20 2020 2a2f 0a2e  editors..   */..\n+00067000: 6772 6170 6869 716c 2d63 6f6e 7461 696e  graphiql-contain\n+00067010: 6572 202e 6772 6170 6869 716c 2d74 6f6f  er .graphiql-too\n+00067020: 6c62 6172 2c0a 2e67 7261 7068 6971 6c2d  lbar,..graphiql-\n+00067030: 636f 6e74 6169 6e65 7220 2e67 7261 7068  container .graph\n+00067040: 6971 6c2d 6564 6974 6f72 2d74 6f6f 6c73  iql-editor-tools\n+00067050: 2c0a 2e67 7261 7068 6971 6c2d 636f 6e74  ,..graphiql-cont\n+00067060: 6169 6e65 7220 2e67 7261 7068 6971 6c2d  ainer .graphiql-\n+00067070: 6564 6974 6f72 2d74 6f6f 6c20 7b0a 2020  editor-tool {.  \n+00067080: 706f 7369 7469 6f6e 3a20 7265 6c61 7469  position: relati\n+00067090: 7665 3b0a 7d0a 2f2a 2054 6865 2072 6573  ve;.}./* The res\n+000670a0: 706f 6e73 6520 7669 6577 202a 2f0a 2e67  ponse view */..g\n+000670b0: 7261 7068 6971 6c2d 636f 6e74 6169 6e65  raphiql-containe\n+000670c0: 7220 2e67 7261 7068 6971 6c2d 7265 7370  r .graphiql-resp\n+000670d0: 6f6e 7365 207b 0a20 202d 2d65 6469 746f  onse {.  --edito\n+000670e0: 722d 6261 636b 6772 6f75 6e64 3a20 7472  r-background: tr\n+000670f0: 616e 7370 6172 656e 743b 0a20 2064 6973  ansparent;.  dis\n+00067100: 706c 6179 3a20 666c 6578 3b0a 2020 7769  play: flex;.  wi\n+00067110: 6474 683a 2031 3030 253b 0a20 2066 6c65  dth: 100%;.  fle\n+00067120: 782d 6469 7265 6374 696f 6e3a 2063 6f6c  x-direction: col\n+00067130: 756d 6e3b 0a7d 0a2f 2a20 5468 6520 7265  umn;.}./* The re\n+00067140: 7375 6c74 7320 6564 6974 6f72 2077 7261  sults editor wra\n+00067150: 7070 696e 6720 636f 6e74 6169 6e65 7220  pping container \n+00067160: 2a2f 0a2e 6772 6170 6869 716c 2d63 6f6e  */..graphiql-con\n+00067170: 7461 696e 6572 202e 6772 6170 6869 716c  tainer .graphiql\n+00067180: 2d72 6573 706f 6e73 6520 2e72 6573 756c  -response .resul\n+00067190: 742d 7769 6e64 6f77 207b 0a20 2070 6f73  t-window {.  pos\n+000671a0: 6974 696f 6e3a 2072 656c 6174 6976 653b  ition: relative;\n+000671b0: 0a20 2066 6c65 783a 2031 3b0a 7d0a 2f2a  .  flex: 1;.}./*\n+000671c0: 2054 6865 2066 6f6f 7465 7220 6265 6c6f   The footer belo\n+000671d0: 7720 7468 6520 7265 7370 6f6e 7365 2076  w the response v\n+000671e0: 6965 7720 2a2f 0a2e 6772 6170 6869 716c  iew */..graphiql\n+000671f0: 2d63 6f6e 7461 696e 6572 202e 6772 6170  -container .grap\n+00067200: 6869 716c 2d66 6f6f 7465 7220 7b0a 2020  hiql-footer {.  \n+00067210: 626f 7264 6572 2d74 6f70 3a20 3170 7820  border-top: 1px \n+00067220: 736f 6c69 640a 2020 2020 6873 6c61 2876  solid.    hsla(v\n+00067230: 6172 282d 2d63 6f6c 6f72 2d6e 6575 7472  ar(--color-neutr\n+00067240: 616c 292c 2076 6172 282d 2d61 6c70 6861  al), var(--alpha\n+00067250: 2d62 6163 6b67 726f 756e 642d 6865 6176  -background-heav\n+00067260: 7929 293b 0a7d 0a2f 2a20 5468 6520 706c  y));.}./* The pl\n+00067270: 7567 696e 2063 6f6e 7461 696e 6572 202a  ugin container *\n+00067280: 2f0a 2e67 7261 7068 6971 6c2d 636f 6e74  /..graphiql-cont\n+00067290: 6169 6e65 7220 2e67 7261 7068 6971 6c2d  ainer .graphiql-\n+000672a0: 706c 7567 696e 207b 0a20 2062 6f72 6465  plugin {.  borde\n+000672b0: 722d 6c65 6674 3a20 3170 7820 736f 6c69  r-left: 1px soli\n+000672c0: 640a 2020 2020 6873 6c61 2876 6172 282d  d.    hsla(var(-\n+000672d0: 2d63 6f6c 6f72 2d6e 6575 7472 616c 292c  -color-neutral),\n+000672e0: 2076 6172 282d 2d61 6c70 6861 2d62 6163   var(--alpha-bac\n+000672f0: 6b67 726f 756e 642d 6865 6176 7929 293b  kground-heavy));\n+00067300: 0a20 2066 6c65 783a 2031 3b0a 2020 6f76  .  flex: 1;.  ov\n+00067310: 6572 666c 6f77 2d79 3a20 6175 746f 3b0a  erflow-y: auto;.\n+00067320: 2020 7061 6464 696e 673a 2076 6172 282d    padding: var(-\n+00067330: 2d70 782d 3136 293b 0a7d 0a2f 2a20 4765  -px-16);.}./* Ge\n+00067340: 6e65 7269 6320 6472 6167 2062 6172 2066  neric drag bar f\n+00067350: 6f72 2068 6f72 697a 6f6e 7461 6c20 7265  or horizontal re\n+00067360: 7369 7a69 6e67 202a 2f0a 2e67 7261 7068  sizing */..graph\n+00067370: 6971 6c2d 686f 7269 7a6f 6e74 616c 2d64  iql-horizontal-d\n+00067380: 7261 672d 6261 7220 7b0a 2020 7769 6474  rag-bar {.  widt\n+00067390: 683a 2076 6172 282d 2d70 782d 3132 293b  h: var(--px-12);\n+000673a0: 0a20 2063 7572 736f 723a 2063 6f6c 2d72  .  cursor: col-r\n+000673b0: 6573 697a 653b 0a7d 0a2e 6772 6170 6869  esize;.}..graphi\n+000673c0: 716c 2d68 6f72 697a 6f6e 7461 6c2d 6472  ql-horizontal-dr\n+000673d0: 6167 2d62 6172 3a68 6f76 6572 3a3a 6166  ag-bar:hover::af\n+000673e0: 7465 7220 7b0a 2020 626f 7264 6572 3a20  ter {.  border: \n+000673f0: 7661 7228 2d2d 7078 2d32 2920 736f 6c69  var(--px-2) soli\n+00067400: 640a 2020 2020 6873 6c61 2876 6172 282d  d.    hsla(var(-\n+00067410: 2d63 6f6c 6f72 2d6e 6575 7472 616c 292c  -color-neutral),\n+00067420: 2076 6172 282d 2d61 6c70 6861 2d62 6163   var(--alpha-bac\n+00067430: 6b67 726f 756e 642d 6865 6176 7929 293b  kground-heavy));\n+00067440: 0a20 2062 6f72 6465 722d 7261 6469 7573  .  border-radius\n+00067450: 3a20 7661 7228 2d2d 626f 7264 6572 2d72  : var(--border-r\n+00067460: 6164 6975 732d 3229 3b0a 2020 636f 6e74  adius-2);.  cont\n+00067470: 656e 743a 2027 273b 0a20 2064 6973 706c  ent: '';.  displ\n+00067480: 6179 3a20 626c 6f63 6b3b 0a20 2068 6569  ay: block;.  hei\n+00067490: 6768 743a 2032 3525 3b0a 2020 6d61 7267  ght: 25%;.  marg\n+000674a0: 696e 3a20 3020 6175 746f 3b0a 2020 706f  in: 0 auto;.  po\n+000674b0: 7369 7469 6f6e 3a20 7265 6c61 7469 7665  sition: relative\n+000674c0: 3b0a 2020 2f2a 2028 3130 3025 202d 2032  ;.  /* (100% - 2\n+000674d0: 3525 2920 2f20 3220 3d20 3337 2e35 2520  5%) / 2 = 37.5% \n+000674e0: 2a2f 0a20 2074 6f70 3a20 3337 2e35 253b  */.  top: 37.5%;\n+000674f0: 0a20 2077 6964 7468 3a20 303b 0a7d 0a2e  .  width: 0;.}..\n+00067500: 6772 6170 6869 716c 2d63 6f6e 7461 696e  graphiql-contain\n+00067510: 6572 202e 6772 6170 6869 716c 2d63 6865  er .graphiql-che\n+00067520: 7672 6f6e 2d69 636f 6e20 7b0a 2020 636f  vron-icon {.  co\n+00067530: 6c6f 723a 2068 736c 6128 7661 7228 2d2d  lor: hsla(var(--\n+00067540: 636f 6c6f 722d 6e65 7574 7261 6c29 2c20  color-neutral), \n+00067550: 7661 7228 2d2d 616c 7068 612d 7465 7274  var(--alpha-tert\n+00067560: 6961 7279 2929 3b0a 2020 6469 7370 6c61  iary));.  displa\n+00067570: 793a 2062 6c6f 636b 3b0a 2020 6865 6967  y: block;.  heig\n+00067580: 6874 3a20 7661 7228 2d2d 7078 2d31 3229  ht: var(--px-12)\n+00067590: 3b0a 2020 6d61 7267 696e 3a20 7661 7228  ;.  margin: var(\n+000675a0: 2d2d 7078 2d31 3229 3b0a 2020 7769 6474  --px-12);.  widt\n+000675b0: 683a 2076 6172 282d 2d70 782d 3132 293b  h: var(--px-12);\n+000675c0: 0a7d 0a2f 2a20 4765 6e65 7269 6320 7370  .}./* Generic sp\n+000675d0: 696e 2061 6e69 6d61 7469 6f6e 202a 2f0a  in animation */.\n+000675e0: 2e67 7261 7068 6971 6c2d 7370 696e 207b  .graphiql-spin {\n+000675f0: 0a20 2061 6e69 6d61 7469 6f6e 3a20 7370  .  animation: sp\n+00067600: 696e 2030 2e38 7320 6c69 6e65 6172 2030  in 0.8s linear 0\n+00067610: 7320 696e 6669 6e69 7465 3b0a 7d0a 406b  s infinite;.}.@k\n+00067620: 6579 6672 616d 6573 2073 7069 6e20 7b0a  eyframes spin {.\n+00067630: 2020 6672 6f6d 207b 0a20 2020 2074 7261    from {.    tra\n+00067640: 6e73 666f 726d 3a20 726f 7461 7465 2830  nsform: rotate(0\n+00067650: 6465 6729 3b0a 2020 7d0a 2020 746f 207b  deg);.  }.  to {\n+00067660: 0a20 2020 2074 7261 6e73 666f 726d 3a20  .    transform: \n+00067670: 726f 7461 7465 2833 3630 6465 6729 3b0a  rotate(360deg);.\n+00067680: 2020 7d0a 7d0a 2f2a 2054 6865 2068 6561    }.}./* The hea\n+00067690: 6465 7220 6f66 2074 6865 2073 6574 7469  der of the setti\n+000676a0: 6e67 7320 6469 616c 6f67 202a 2f0a 2e67  ngs dialog */..g\n+000676b0: 7261 7068 6971 6c2d 6469 616c 6f67 202e  raphiql-dialog .\n+000676c0: 6772 6170 6869 716c 2d64 6961 6c6f 672d  graphiql-dialog-\n+000676d0: 6865 6164 6572 207b 0a20 2061 6c69 676e  header {.  align\n+000676e0: 2d69 7465 6d73 3a20 6365 6e74 6572 3b0a  -items: center;.\n+000676f0: 2020 6469 7370 6c61 793a 2066 6c65 783b    display: flex;\n+00067700: 0a20 206a 7573 7469 6679 2d63 6f6e 7465  .  justify-conte\n+00067710: 6e74 3a20 7370 6163 652d 6265 7477 6565  nt: space-betwee\n+00067720: 6e3b 0a20 2070 6164 6469 6e67 3a20 7661  n;.  padding: va\n+00067730: 7228 2d2d 7078 2d32 3429 3b0a 7d0a 2f2a  r(--px-24);.}./*\n+00067740: 2054 6865 2074 6974 6c65 206f 6620 7468   The title of th\n+00067750: 6520 7365 7474 696e 6773 2064 6961 6c6f  e settings dialo\n+00067760: 6720 2a2f 0a2e 6772 6170 6869 716c 2d64  g */..graphiql-d\n+00067770: 6961 6c6f 6720 2e67 7261 7068 6971 6c2d  ialog .graphiql-\n+00067780: 6469 616c 6f67 2d74 6974 6c65 207b 0a20  dialog-title {. \n+00067790: 2066 6f6e 742d 7369 7a65 3a20 7661 7228   font-size: var(\n+000677a0: 2d2d 666f 6e74 2d73 697a 652d 6833 293b  --font-size-h3);\n+000677b0: 0a20 2066 6f6e 742d 7765 6967 6874 3a20  .  font-weight: \n+000677c0: 7661 7228 2d2d 666f 6e74 2d77 6569 6768  var(--font-weigh\n+000677d0: 742d 6d65 6469 756d 293b 0a20 206d 6172  t-medium);.  mar\n+000677e0: 6769 6e3a 2030 3b0a 7d0a 2f2a 2041 2073  gin: 0;.}./* A s\n+000677f0: 6563 7469 6f6e 2069 6e73 6964 6520 7468  ection inside th\n+00067800: 6520 7365 7474 696e 6773 2064 6961 6c6f  e settings dialo\n+00067810: 6720 2a2f 0a2e 6772 6170 6869 716c 2d64  g */..graphiql-d\n+00067820: 6961 6c6f 6720 2e67 7261 7068 6971 6c2d  ialog .graphiql-\n+00067830: 6469 616c 6f67 2d73 6563 7469 6f6e 207b  dialog-section {\n+00067840: 0a20 2061 6c69 676e 2d69 7465 6d73 3a20  .  align-items: \n+00067850: 6365 6e74 6572 3b0a 2020 626f 7264 6572  center;.  border\n+00067860: 2d74 6f70 3a20 3170 7820 736f 6c69 640a  -top: 1px solid.\n+00067870: 2020 2020 6873 6c61 2876 6172 282d 2d63      hsla(var(--c\n+00067880: 6f6c 6f72 2d6e 6575 7472 616c 292c 2076  olor-neutral), v\n+00067890: 6172 282d 2d61 6c70 6861 2d62 6163 6b67  ar(--alpha-backg\n+000678a0: 726f 756e 642d 6865 6176 7929 293b 0a20  round-heavy));. \n+000678b0: 2064 6973 706c 6179 3a20 666c 6578 3b0a   display: flex;.\n+000678c0: 2020 6a75 7374 6966 792d 636f 6e74 656e    justify-conten\n+000678d0: 743a 2073 7061 6365 2d62 6574 7765 656e  t: space-between\n+000678e0: 3b0a 2020 7061 6464 696e 673a 2076 6172  ;.  padding: var\n+000678f0: 282d 2d70 782d 3234 293b 0a7d 0a2e 6772  (--px-24);.}..gr\n+00067900: 6170 6869 716c 2d64 6961 6c6f 6720 2e67  aphiql-dialog .g\n+00067910: 7261 7068 6971 6c2d 6469 616c 6f67 2d73  raphiql-dialog-s\n+00067920: 6563 7469 6f6e 203e 203a 6e6f 7428 3a66  ection > :not(:f\n+00067930: 6972 7374 2d63 6869 6c64 2920 7b0a 2020  irst-child) {.  \n+00067940: 6d61 7267 696e 2d6c 6566 743a 2076 6172  margin-left: var\n+00067950: 282d 2d70 782d 3234 293b 0a7d 0a2f 2a20  (--px-24);.}./* \n+00067960: 5468 6520 7365 6374 696f 6e20 7469 746c  The section titl\n+00067970: 6520 696e 2074 6865 2073 6574 7469 6e67  e in the setting\n+00067980: 7320 6469 616c 6f67 202a 2f0a 2e67 7261  s dialog */..gra\n+00067990: 7068 6971 6c2d 6469 616c 6f67 202e 6772  phiql-dialog .gr\n+000679a0: 6170 6869 716c 2d64 6961 6c6f 672d 7365  aphiql-dialog-se\n+000679b0: 6374 696f 6e2d 7469 746c 6520 7b0a 2020  ction-title {.  \n+000679c0: 666f 6e74 2d73 697a 653a 2076 6172 282d  font-size: var(-\n+000679d0: 2d66 6f6e 742d 7369 7a65 2d68 3429 3b0a  -font-size-h4);.\n+000679e0: 2020 666f 6e74 2d77 6569 6768 743a 2076    font-weight: v\n+000679f0: 6172 282d 2d66 6f6e 742d 7765 6967 6874  ar(--font-weight\n+00067a00: 2d6d 6564 6975 6d29 3b0a 7d0a 2f2a 2054  -medium);.}./* T\n+00067a10: 6865 2073 6563 7469 6f6e 2063 6170 7469  he section capti\n+00067a20: 6f6e 2069 6e20 7468 6520 7365 7474 696e  on in the settin\n+00067a30: 6773 2064 6961 6c6f 6720 2a2f 0a2e 6772  gs dialog */..gr\n+00067a40: 6170 6869 716c 2d64 6961 6c6f 6720 2e67  aphiql-dialog .g\n+00067a50: 7261 7068 6971 6c2d 6469 616c 6f67 2d73  raphiql-dialog-s\n+00067a60: 6563 7469 6f6e 2d63 6170 7469 6f6e 207b  ection-caption {\n+00067a70: 0a20 2063 6f6c 6f72 3a20 6873 6c61 2876  .  color: hsla(v\n+00067a80: 6172 282d 2d63 6f6c 6f72 2d6e 6575 7472  ar(--color-neutr\n+00067a90: 616c 292c 2076 6172 282d 2d61 6c70 6861  al), var(--alpha\n+00067aa0: 2d73 6563 6f6e 6461 7279 2929 3b0a 7d0a  -secondary));.}.\n+00067ab0: 2e67 7261 7068 6971 6c2d 6469 616c 6f67  .graphiql-dialog\n+00067ac0: 202e 6772 6170 6869 716c 2d77 6172 6e69   .graphiql-warni\n+00067ad0: 6e67 2d74 6578 7420 7b0a 2020 636f 6c6f  ng-text {.  colo\n+00067ae0: 723a 2068 736c 2876 6172 282d 2d63 6f6c  r: hsl(var(--col\n+00067af0: 6f72 2d77 6172 6e69 6e67 2929 3b0a 2020  or-warning));.  \n+00067b00: 666f 6e74 2d77 6569 6768 743a 2076 6172  font-weight: var\n+00067b10: 282d 2d66 6f6e 742d 7765 6967 6874 2d6d  (--font-weight-m\n+00067b20: 6564 6975 6d29 3b0a 7d0a 2e67 7261 7068  edium);.}..graph\n+00067b30: 6971 6c2d 6469 616c 6f67 202e 6772 6170  iql-dialog .grap\n+00067b40: 6869 716c 2d74 6162 6c65 207b 0a20 2062  hiql-table {.  b\n+00067b50: 6f72 6465 722d 636f 6c6c 6170 7365 3a20  order-collapse: \n+00067b60: 636f 6c6c 6170 7365 3b0a 2020 7769 6474  collapse;.  widt\n+00067b70: 683a 2031 3030 253b 0a7d 0a2e 6772 6170  h: 100%;.}..grap\n+00067b80: 6869 716c 2d64 6961 6c6f 6720 2e67 7261  hiql-dialog .gra\n+00067b90: 7068 6971 6c2d 7461 626c 6520 3a69 7328  phiql-table :is(\n+00067ba0: 7468 2c20 7464 2920 7b0a 2020 626f 7264  th, td) {.  bord\n+00067bb0: 6572 3a20 3170 7820 736f 6c69 6420 6873  er: 1px solid hs\n+00067bc0: 6c61 2876 6172 282d 2d63 6f6c 6f72 2d6e  la(var(--color-n\n+00067bd0: 6575 7472 616c 292c 2076 6172 282d 2d61  eutral), var(--a\n+00067be0: 6c70 6861 2d62 6163 6b67 726f 756e 642d  lpha-background-\n+00067bf0: 6865 6176 7929 293b 0a20 2070 6164 6469  heavy));.  paddi\n+00067c00: 6e67 3a20 7661 7228 2d2d 7078 2d38 2920  ng: var(--px-8) \n+00067c10: 7661 7228 2d2d 7078 2d31 3229 3b0a 7d0a  var(--px-12);.}.\n+00067c20: 2f2a 2041 2073 696e 676c 6520 6b65 7920  /* A single key \n+00067c30: 7468 6520 7368 6f72 742d 6b65 7920 6469  the short-key di\n+00067c40: 616c 6f67 202a 2f0a 2e67 7261 7068 6971  alog */..graphiq\n+00067c50: 6c2d 6469 616c 6f67 202e 6772 6170 6869  l-dialog .graphi\n+00067c60: 716c 2d6b 6579 207b 0a20 2062 6163 6b67  ql-key {.  backg\n+00067c70: 726f 756e 642d 636f 6c6f 723a 2068 736c  round-color: hsl\n+00067c80: 6128 7661 7228 2d2d 636f 6c6f 722d 6e65  a(var(--color-ne\n+00067c90: 7574 7261 6c29 2c20 7661 7228 2d2d 616c  utral), var(--al\n+00067ca0: 7068 612d 6261 636b 6772 6f75 6e64 2d6d  pha-background-m\n+00067cb0: 6564 6975 6d29 293b 0a20 2062 6f72 6465  edium));.  borde\n+00067cc0: 722d 7261 6469 7573 3a20 7661 7228 2d2d  r-radius: var(--\n+00067cd0: 626f 7264 6572 2d72 6164 6975 732d 3429  border-radius-4)\n+00067ce0: 3b0a 2020 7061 6464 696e 673a 2076 6172  ;.  padding: var\n+00067cf0: 282d 2d70 782d 3429 3b0a 7d0a 2f2a 2041  (--px-4);.}./* A\n+00067d00: 766f 6964 2073 686f 7769 6e67 206e 6174  void showing nat\n+00067d10: 6976 6520 746f 6f6c 7469 7073 2066 6f72  ive tooltips for\n+00067d20: 2069 636f 6e73 2077 6974 6820 7469 746c   icons with titl\n+00067d30: 6573 202a 2f0a 2e67 7261 7068 6971 6c2d  es */..graphiql-\n+00067d40: 636f 6e74 6169 6e65 7220 7376 6720 7b0a  container svg {.\n+00067d50: 2020 706f 696e 7465 722d 6576 656e 7473    pointer-events\n+00067d60: 3a20 6e6f 6e65 3b0a 7d0a 0a0a 2f2a 2320  : none;.}.../*# \n+00067d70: 736f 7572 6365 4d61 7070 696e 6755 524c  sourceMappingURL\n+00067d80: 3d67 7261 7068 6971 6c2e 6373 732e 6d61  =graphiql.css.ma\n+00067d90: 702a 2f                                  p*/\n"}, {"source1": "graphiql/graphiql.min.js", "source2": "graphiql/graphiql.min.js", "unified_diff": null, "details": [{"source1": "js-beautify {}", "source2": "js-beautify {}", "unified_diff": "@@ -1,22 +1,21 @@\n /******/\n (function() { // webpackBootstrap\n     /******/\n-    \"use strict\";\n-    /******/\n     var __webpack_modules__ = ({\n \n         /***/\n         \"../../../node_modules/@emotion/is-prop-valid/dist/is-prop-valid.browser.esm.js\":\n             /*!**************************************************************************************!*\\\n               !*** ../../../node_modules/@emotion/is-prop-valid/dist/is-prop-valid.browser.esm.js ***!\n               \\**************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports[\"default\"] = void 0;\n                 var _memoize = _interopRequireDefault(__webpack_require__( /*! @emotion/memoize */ \"../../../node_modules/@emotion/memoize/dist/memoize.browser.esm.js\"));\n@@ -33,56 +32,56 @@\n                             /* o */\n                             && prop.charCodeAt(1) === 110\n                             /* n */\n                             && prop.charCodeAt(2) < 91;\n                     }\n                     /* Z+1 */\n                 );\n-                var _default = index;\n-                exports[\"default\"] = _default;\n+                var _default = exports[\"default\"] = index;\n \n                 /***/\n             }),\n \n         /***/\n         \"../../../node_modules/@emotion/memoize/dist/memoize.browser.esm.js\":\n             /*!**************************************************************************!*\\\n               !*** ../../../node_modules/@emotion/memoize/dist/memoize.browser.esm.js ***!\n               \\**************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports[\"default\"] = void 0;\n \n                 function memoize(fn) {\n                     var cache = {};\n                     return function(arg) {\n                         if (cache[arg] === undefined) cache[arg] = fn(arg);\n                         return cache[arg];\n                     };\n                 }\n-                var _default = memoize;\n-                exports[\"default\"] = _default;\n+                var _default = exports[\"default\"] = memoize;\n \n                 /***/\n             }),\n \n         /***/\n         \"../../../node_modules/@floating-ui/core/dist/floating-ui.core.esm.js\":\n             /*!****************************************************************************!*\\\n               !*** ../../../node_modules/@floating-ui/core/dist/floating-ui.core.esm.js ***!\n               \\****************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.computePosition = exports.autoPlacement = exports.arrow = void 0;\n                 exports.detectOverflow = detectOverflow;\n@@ -1235,14 +1234,15 @@\n         \"../../../node_modules/@floating-ui/dom/dist/floating-ui.dom.esm.js\":\n             /*!**************************************************************************!*\\\n               !*** ../../../node_modules/@floating-ui/dom/dist/floating-ui.dom.esm.js ***!\n               \\**************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 Object.defineProperty(exports, \"arrow\", ({\n                     enumerable: true,\n@@ -1843,15 +1843,15 @@\n                     return {\n                         x: rect.left + scroll.scrollLeft - offsets.x,\n                         y: rect.top + scroll.scrollTop - offsets.y,\n                         width: rect.width,\n                         height: rect.height\n                     };\n                 }\n-                const platform = {\n+                const platform = exports.platform = {\n                     getClippingRect,\n                     convertOffsetParentRelativeRectToViewportRelativeRect,\n                     isElement,\n                     getDimensions,\n                     getOffsetParent,\n                     getDocumentElement,\n                     getScale,\n@@ -1880,16 +1880,14 @@\n                  * Automatically updates the position of the floating element when necessary.\n                  * Should only be called when the floating element is mounted on the DOM or\n                  * visible on the screen.\n                  * @returns cleanup function that should be invoked when the floating element is\n                  * removed from the DOM or hidden from the screen.\n                  * @see https://floating-ui.com/docs/autoUpdate\n                  */\n-                exports.platform = platform;\n-\n                 function autoUpdate(reference, floating, update, options) {\n                     if (options === void 0) {\n                         options = {};\n                     }\n                     const {\n                         ancestorScroll = true,\n                             ancestorResize = true,\n@@ -1979,14 +1977,15 @@\n         \"../../../node_modules/@floating-ui/react-dom/dist/floating-ui.react-dom.esm.js\":\n             /*!**************************************************************************************!*\\\n               !*** ../../../node_modules/@floating-ui/react-dom/dist/floating-ui.react-dom.esm.js ***!\n               \\**************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.arrow = void 0;\n                 Object.defineProperty(exports, \"autoPlacement\", ({\n@@ -2065,56 +2064,43 @@\n                     enumerable: true,\n                     get: function() {\n                         return _dom.size;\n                     }\n                 }));\n                 exports.useFloating = useFloating;\n                 var _dom = __webpack_require__( /*! @floating-ui/dom */ \"../../../node_modules/@floating-ui/dom/dist/floating-ui.dom.esm.js\");\n-                var React = _interopRequireWildcard(__webpack_require__( /*! react */ \"react\"));\n+                var _react = _interopRequireWildcard(__webpack_require__( /*! react */ \"react\"));\n+                var React = _react;\n                 var ReactDOM = _interopRequireWildcard(__webpack_require__( /*! react-dom */ \"react-dom\"));\n \n-                function _getRequireWildcardCache(nodeInterop) {\n-                    if (typeof WeakMap !== \"function\") return null;\n-                    var cacheBabelInterop = new WeakMap();\n-                    var cacheNodeInterop = new WeakMap();\n-                    return (_getRequireWildcardCache = function(nodeInterop) {\n-                        return nodeInterop ? cacheNodeInterop : cacheBabelInterop;\n-                    })(nodeInterop);\n-                }\n-\n-                function _interopRequireWildcard(obj, nodeInterop) {\n-                    if (!nodeInterop && obj && obj.__esModule) {\n-                        return obj;\n-                    }\n-                    if (obj === null || typeof obj !== \"object\" && typeof obj !== \"function\") {\n-                        return {\n-                            default: obj\n-                        };\n-                    }\n-                    var cache = _getRequireWildcardCache(nodeInterop);\n-                    if (cache && cache.has(obj)) {\n-                        return cache.get(obj);\n-                    }\n-                    var newObj = {};\n-                    var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;\n-                    for (var key in obj) {\n-                        if (key !== \"default\" && Object.prototype.hasOwnProperty.call(obj, key)) {\n-                            var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;\n-                            if (desc && (desc.get || desc.set)) {\n-                                Object.defineProperty(newObj, key, desc);\n-                            } else {\n-                                newObj[key] = obj[key];\n-                            }\n-                        }\n-                    }\n-                    newObj.default = obj;\n-                    if (cache) {\n-                        cache.set(obj, newObj);\n-                    }\n-                    return newObj;\n+                function _getRequireWildcardCache(e) {\n+                    if (\"function\" != typeof WeakMap) return null;\n+                    var r = new WeakMap(),\n+                        t = new WeakMap();\n+                    return (_getRequireWildcardCache = function(e) {\n+                        return e ? t : r;\n+                    })(e);\n+                }\n+\n+                function _interopRequireWildcard(e, r) {\n+                    if (!r && e && e.__esModule) return e;\n+                    if (null === e || \"object\" != typeof e && \"function\" != typeof e) return {\n+                        default: e\n+                    };\n+                    var t = _getRequireWildcardCache(r);\n+                    if (t && t.has(e)) return t.get(e);\n+                    var n = {\n+                            __proto__: null\n+                        },\n+                        a = Object.defineProperty && Object.getOwnPropertyDescriptor;\n+                    for (var u in e)\n+                        if (\"default\" !== u && Object.prototype.hasOwnProperty.call(e, u)) {\n+                            var i = a ? Object.getOwnPropertyDescriptor(e, u) : null;\n+                            i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u];\n+                        } return n.default = e, t && t.set(e, n), n;\n                 }\n                 /**\n                  * Provides data to position an inner element of the floating element so that it\n                  * appears centered to the reference element.\n                  * This wraps the core `arrow` middleware to allow React refs as the element.\n                  * @see https://floating-ui.com/docs/arrow\n                  */\n@@ -2145,15 +2131,15 @@\n                                 }).fn(state);\n                             }\n                             return {};\n                         }\n                     };\n                 };\n                 exports.arrow = arrow;\n-                var index = typeof document !== 'undefined' ? React.useLayoutEffect : React.useEffect;\n+                var index = typeof document !== 'undefined' ? _react.useLayoutEffect : _react.useEffect;\n \n                 // Fork of `fast-deep-equal` that only does the comparisons we need and compares\n                 // functions\n                 function deepEqual(a, b) {\n                     if (a === b) {\n                         return true;\n                     }\n@@ -2378,34 +2364,33 @@\n         \"../../../node_modules/@motionone/animation/dist/Animation.es.js\":\n             /*!***********************************************************************!*\\\n               !*** ../../../node_modules/@motionone/animation/dist/Animation.es.js ***!\n               \\***********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.Animation = void 0;\n                 var _utils = __webpack_require__( /*! @motionone/utils */ \"../../../node_modules/@motionone/utils/dist/index.es.js\");\n                 var _easingEs = __webpack_require__( /*! ./utils/easing.es.js */ \"../../../node_modules/@motionone/animation/dist/utils/easing.es.js\");\n                 class Animation {\n-                    constructor(output) {\n-                        let keyframes = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [0, 1];\n-                        let {\n-                            easing,\n-                            duration: initialDuration = _utils.defaults.duration,\n-                            delay = _utils.defaults.delay,\n-                            endDelay = _utils.defaults.endDelay,\n-                            repeat = _utils.defaults.repeat,\n-                            offset,\n-                            direction = \"normal\"\n-                        } = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n+                    constructor(output, keyframes = [0, 1], {\n+                        easing,\n+                        duration: initialDuration = _utils.defaults.duration,\n+                        delay = _utils.defaults.delay,\n+                        endDelay = _utils.defaults.endDelay,\n+                        repeat = _utils.defaults.repeat,\n+                        offset,\n+                        direction = \"normal\"\n+                    } = {}) {\n                         this.startTime = null;\n                         this.rate = 1;\n                         this.t = 0;\n                         this.cancelTimestamp = null;\n                         this.easing = _utils.noopReturn;\n                         this.duration = 0;\n                         this.totalDuration = 0;\n@@ -2559,14 +2544,15 @@\n         \"../../../node_modules/@motionone/animation/dist/index.es.js\":\n             /*!*******************************************************************!*\\\n               !*** ../../../node_modules/@motionone/animation/dist/index.es.js ***!\n               \\*******************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 Object.defineProperty(exports, \"Animation\", ({\n                     enumerable: true,\n@@ -2590,14 +2576,15 @@\n         \"../../../node_modules/@motionone/animation/dist/utils/easing.es.js\":\n             /*!**************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/animation/dist/utils/easing.es.js ***!\n               \\**************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.getEasingFunction = getEasingFunction;\n                 var _easing = __webpack_require__( /*! @motionone/easing */ \"../../../node_modules/@motionone/easing/dist/index.es.js\");\n@@ -2635,14 +2622,15 @@\n         \"../../../node_modules/@motionone/dom/dist/animate/animate-style.es.js\":\n             /*!*****************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/animate/animate-style.es.js ***!\n               \\*****************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.animateStyle = animateStyle;\n                 var _dataEs = __webpack_require__( /*! ./data.es.js */ \"../../../node_modules/@motionone/dom/dist/animate/data.es.js\");\n@@ -2657,16 +2645,15 @@\n                 var _getStyleNameEs = __webpack_require__( /*! ./utils/get-style-name.es.js */ \"../../../node_modules/@motionone/dom/dist/animate/utils/get-style-name.es.js\");\n                 var _stopAnimationEs = __webpack_require__( /*! ./utils/stop-animation.es.js */ \"../../../node_modules/@motionone/dom/dist/animate/utils/stop-animation.es.js\");\n \n                 function getDevToolsRecord() {\n                     return window.__MOTION_DEV_TOOLS_RECORD;\n                 }\n \n-                function animateStyle(element, key, keyframesDefinition) {\n-                    let options = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};\n+                function animateStyle(element, key, keyframesDefinition, options = {}) {\n                     const record = getDevToolsRecord();\n                     const isRecording = options.record !== false && record;\n                     let animation;\n                     let {\n                         duration = _utils.defaults.duration,\n                             delay = _utils.defaults.delay,\n                             endDelay = _utils.defaults.endDelay,\n@@ -2838,14 +2825,15 @@\n         \"../../../node_modules/@motionone/dom/dist/animate/data.es.js\":\n             /*!********************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/animate/data.es.js ***!\n               \\********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.getAnimationData = getAnimationData;\n                 exports.getMotionValue = getMotionValue;\n@@ -2876,28 +2864,28 @@\n         \"../../../node_modules/@motionone/dom/dist/animate/index.es.js\":\n             /*!*********************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/animate/index.es.js ***!\n               \\*********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.animate = animate;\n                 var _animateStyleEs = __webpack_require__( /*! ./animate-style.es.js */ \"../../../node_modules/@motionone/dom/dist/animate/animate-style.es.js\");\n                 var _optionsEs = __webpack_require__( /*! ./utils/options.es.js */ \"../../../node_modules/@motionone/dom/dist/animate/utils/options.es.js\");\n                 var _resolveElementsEs = __webpack_require__( /*! ../utils/resolve-elements.es.js */ \"../../../node_modules/@motionone/dom/dist/utils/resolve-elements.es.js\");\n                 var _controlsEs = __webpack_require__( /*! ./utils/controls.es.js */ \"../../../node_modules/@motionone/dom/dist/animate/utils/controls.es.js\");\n                 var _staggerEs = __webpack_require__( /*! ../utils/stagger.es.js */ \"../../../node_modules/@motionone/dom/dist/utils/stagger.es.js\");\n \n-                function animate(elements, keyframes) {\n-                    let options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n+                function animate(elements, keyframes, options = {}) {\n                     elements = (0, _resolveElementsEs.resolveElements)(elements);\n                     const numElements = elements.length;\n                     /**\n                      * Create and start new animations\n                      */\n                     const animationFactories = [];\n                     for (let i = 0; i < numElements; i++) {\n@@ -2929,24 +2917,25 @@\n         \"../../../node_modules/@motionone/dom/dist/animate/style.es.js\":\n             /*!*********************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/animate/style.es.js ***!\n               \\*********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.style = void 0;\n                 var _cssVarEs = __webpack_require__( /*! ./utils/css-var.es.js */ \"../../../node_modules/@motionone/dom/dist/animate/utils/css-var.es.js\");\n                 var _getStyleNameEs = __webpack_require__( /*! ./utils/get-style-name.es.js */ \"../../../node_modules/@motionone/dom/dist/animate/utils/get-style-name.es.js\");\n                 var _transformsEs = __webpack_require__( /*! ./utils/transforms.es.js */ \"../../../node_modules/@motionone/dom/dist/animate/utils/transforms.es.js\");\n-                const style = {\n+                const style = exports.style = {\n                     get: (element, name) => {\n                         name = (0, _getStyleNameEs.getStyleName)(name);\n                         let value = (0, _cssVarEs.isCssVar)(name) ? element.style.getPropertyValue(name) : getComputedStyle(element)[name];\n                         if (!value && value !== 0) {\n                             const definition = _transformsEs.transformDefinitions.get(name);\n                             if (definition) value = definition.initialValue;\n                         }\n@@ -2957,52 +2946,51 @@\n                         if ((0, _cssVarEs.isCssVar)(name)) {\n                             element.style.setProperty(name, value);\n                         } else {\n                             element.style[name] = value;\n                         }\n                     }\n                 };\n-                exports.style = style;\n \n                 /***/\n             }),\n \n         /***/\n         \"../../../node_modules/@motionone/dom/dist/animate/utils/controls.es.js\":\n             /*!******************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/animate/utils/controls.es.js ***!\n               \\******************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.withControls = exports.controls = void 0;\n                 var _utils = __webpack_require__( /*! @motionone/utils */ \"../../../node_modules/@motionone/utils/dist/index.es.js\");\n                 var _stopAnimationEs = __webpack_require__( /*! ./stop-animation.es.js */ \"../../../node_modules/@motionone/dom/dist/animate/utils/stop-animation.es.js\");\n                 const createAnimation = factory => factory();\n-                const withControls = function(animationFactory, options) {\n-                    let duration = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : _utils.defaults.duration;\n+                const withControls = (animationFactory, options, duration = _utils.defaults.duration) => {\n                     return new Proxy({\n                         animations: animationFactory.map(createAnimation).filter(Boolean),\n                         duration,\n                         options\n                     }, controls);\n                 };\n                 /**\n                  * TODO:\n                  * Currently this returns the first animation, ideally it would return\n                  * the first active animation.\n                  */\n                 exports.withControls = withControls;\n                 const getActiveAnimation = state => state.animations[0];\n-                const controls = {\n+                const controls = exports.controls = {\n                     get: (target, key) => {\n                         const activeAnimation = getActiveAnimation(target);\n                         switch (key) {\n                             case \"duration\":\n                                 return target.duration;\n                             case \"currentTime\":\n                                 return _utils.time.s((activeAnimation === null || activeAnimation === void 0 ? void 0 : activeAnimation[key]) || 0);\n@@ -3040,41 +3028,40 @@\n                                     target.animations[i][key] = value;\n                                 }\n                                 return true;\n                         }\n                         return false;\n                     }\n                 };\n-                exports.controls = controls;\n                 const selectFinished = animation => animation.finished;\n \n                 /***/\n             }),\n \n         /***/\n         \"../../../node_modules/@motionone/dom/dist/animate/utils/css-var.es.js\":\n             /*!*****************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/animate/utils/css-var.es.js ***!\n               \\*****************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.isCssVar = void 0;\n                 exports.registerCssVariable = registerCssVariable;\n                 exports.registeredProperties = void 0;\n                 var _transformsEs = __webpack_require__( /*! ./transforms.es.js */ \"../../../node_modules/@motionone/dom/dist/animate/utils/transforms.es.js\");\n                 const isCssVar = name => name.startsWith(\"--\");\n                 exports.isCssVar = isCssVar;\n-                const registeredProperties = new Set();\n-                exports.registeredProperties = registeredProperties;\n+                const registeredProperties = exports.registeredProperties = new Set();\n \n                 function registerCssVariable(name) {\n                     if (registeredProperties.has(name)) return;\n                     registeredProperties.add(name);\n                     try {\n                         const {\n                             syntax,\n@@ -3096,40 +3083,39 @@\n         \"../../../node_modules/@motionone/dom/dist/animate/utils/easing.es.js\":\n             /*!****************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/animate/utils/easing.es.js ***!\n               \\****************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.cubicBezierAsString = exports.convertEasing = void 0;\n                 var _utils = __webpack_require__( /*! @motionone/utils */ \"../../../node_modules/@motionone/utils/dist/index.es.js\");\n                 const convertEasing = easing => (0, _utils.isCubicBezier)(easing) ? cubicBezierAsString(easing) : easing;\n                 exports.convertEasing = convertEasing;\n-                const cubicBezierAsString = _ref => {\n-                    let [a, b, c, d] = _ref;\n-                    return `cubic-bezier(${a}, ${b}, ${c}, ${d})`;\n-                };\n+                const cubicBezierAsString = ([a, b, c, d]) => `cubic-bezier(${a}, ${b}, ${c}, ${d})`;\n                 exports.cubicBezierAsString = cubicBezierAsString;\n \n                 /***/\n             }),\n \n         /***/\n         \"../../../node_modules/@motionone/dom/dist/animate/utils/feature-detection.es.js\":\n             /*!***************************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/animate/utils/feature-detection.es.js ***!\n               \\***************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.supports = void 0;\n                 const testAnimation = keyframes => document.createElement(\"div\").animate(keyframes, {\n@@ -3149,16 +3135,15 @@\n                         return true;\n                     },\n                     finished: () => Boolean(testAnimation({\n                         opacity: [0, 1]\n                     }).finished)\n                 };\n                 const results = {};\n-                const supports = {};\n-                exports.supports = supports;\n+                const supports = exports.supports = {};\n                 for (const key in featureTests) {\n                     supports[key] = () => {\n                         if (results[key] === undefined) results[key] = featureTests[key]();\n                         return results[key];\n                     };\n                 }\n \n@@ -3169,14 +3154,15 @@\n         \"../../../node_modules/@motionone/dom/dist/animate/utils/get-style-name.es.js\":\n             /*!************************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/animate/utils/get-style-name.es.js ***!\n               \\************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.getStyleName = getStyleName;\n                 var _transformsEs = __webpack_require__( /*! ./transforms.es.js */ \"../../../node_modules/@motionone/dom/dist/animate/utils/transforms.es.js\");\n@@ -3193,14 +3179,15 @@\n         \"../../../node_modules/@motionone/dom/dist/animate/utils/keyframes.es.js\":\n             /*!*******************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/animate/utils/keyframes.es.js ***!\n               \\*******************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.hydrateKeyframes = hydrateKeyframes;\n                 exports.keyframesList = void 0;\n@@ -3223,14 +3210,15 @@\n         \"../../../node_modules/@motionone/dom/dist/animate/utils/options.es.js\":\n             /*!*****************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/animate/utils/options.es.js ***!\n               \\*****************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.getOptions = void 0;\n                 const getOptions = (options, key) =>\n@@ -3249,23 +3237,23 @@\n         \"../../../node_modules/@motionone/dom/dist/animate/utils/stop-animation.es.js\":\n             /*!************************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/animate/utils/stop-animation.es.js ***!\n               \\************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.stopAnimation = stopAnimation;\n \n-                function stopAnimation(animation) {\n-                    let needsCommit = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n+                function stopAnimation(animation, needsCommit = true) {\n                     if (!animation || animation.playState === \"finished\") return;\n                     // Suppress error thrown by WAAPI\n                     try {\n                         if (animation.stop) {\n                             animation.stop();\n                         } else {\n                             needsCommit && animation.commitStyles();\n@@ -3281,14 +3269,15 @@\n         \"../../../node_modules/@motionone/dom/dist/animate/utils/style-object.es.js\":\n             /*!**********************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/animate/utils/style-object.es.js ***!\n               \\**********************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.createStyles = createStyles;\n                 var _utils = __webpack_require__( /*! @motionone/utils */ \"../../../node_modules/@motionone/utils/dist/index.es.js\");\n@@ -3328,26 +3317,26 @@\n         \"../../../node_modules/@motionone/dom/dist/animate/utils/style-string.es.js\":\n             /*!**********************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/animate/utils/style-string.es.js ***!\n               \\**********************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.createStyleString = createStyleString;\n                 var _styleObjectEs = __webpack_require__( /*! ./style-object.es.js */ \"../../../node_modules/@motionone/dom/dist/animate/utils/style-object.es.js\");\n                 const camelLetterToPipeLetter = letter => `-${letter.toLowerCase()}`;\n                 const camelToPipeCase = str => str.replace(/[A-Z]/g, camelLetterToPipeLetter);\n \n-                function createStyleString() {\n-                    let target = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n+                function createStyleString(target = {}) {\n                     const styles = (0, _styleObjectEs.createStyles)(target);\n                     let style = \"\";\n                     for (const key in styles) {\n                         style += key.startsWith(\"--\") ? key : camelToPipeCase(key);\n                         style += `: ${styles[key]}; `;\n                     }\n                     return style;\n@@ -3360,39 +3349,38 @@\n         \"../../../node_modules/@motionone/dom/dist/animate/utils/transforms.es.js\":\n             /*!********************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/animate/utils/transforms.es.js ***!\n               \\********************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.transformDefinitions = exports.transformAlias = exports.isTransform = exports.compareTransformOrder = exports.buildTransformTemplate = exports.axes = exports.asTransformCssVar = exports.addTransformToElement = void 0;\n                 var _utils = __webpack_require__( /*! @motionone/utils */ \"../../../node_modules/@motionone/utils/dist/index.es.js\");\n                 var _dataEs = __webpack_require__( /*! ../data.es.js */ \"../../../node_modules/@motionone/dom/dist/animate/data.es.js\");\n                 /**\n                  * A list of all transformable axes. We'll use this list to generated a version\n                  * of each axes for each transform.\n                  */\n-                const axes = [\"\", \"X\", \"Y\", \"Z\"];\n+                const axes = exports.axes = [\"\", \"X\", \"Y\", \"Z\"];\n                 /**\n                  * An ordered array of each transformable value. By default, transform values\n                  * will be sorted to this order.\n                  */\n-                exports.axes = axes;\n                 const order = [\"translate\", \"scale\", \"rotate\", \"skew\"];\n-                const transformAlias = {\n+                const transformAlias = exports.transformAlias = {\n                     x: \"translateX\",\n                     y: \"translateY\",\n                     z: \"translateZ\"\n                 };\n-                exports.transformAlias = transformAlias;\n                 const rotation = {\n                     syntax: \"<angle>\",\n                     initialValue: \"0deg\",\n                     toDefaultUnit: v => v + \"deg\"\n                 };\n                 const baseTransformProperties = {\n                     translate: {\n@@ -3404,16 +3392,15 @@\n                     scale: {\n                         syntax: \"<number>\",\n                         initialValue: 1,\n                         toDefaultUnit: _utils.noopReturn\n                     },\n                     skew: rotation\n                 };\n-                const transformDefinitions = new Map();\n-                exports.transformDefinitions = transformDefinitions;\n+                const transformDefinitions = exports.transformDefinitions = new Map();\n                 const asTransformCssVar = name => `--motion-${name}`;\n                 /**\n                  * Generate a list of every possible transform key\n                  */\n                 exports.asTransformCssVar = asTransformCssVar;\n                 const transforms = [\"x\", \"y\", \"z\"];\n                 order.forEach(name => {\n@@ -3458,32 +3445,28 @@\n         \"../../../node_modules/@motionone/dom/dist/easing/create-generator-easing.es.js\":\n             /*!**************************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/easing/create-generator-easing.es.js ***!\n               \\**************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.createGeneratorEasing = createGeneratorEasing;\n                 var _generators = __webpack_require__( /*! @motionone/generators */ \"../../../node_modules/@motionone/generators/dist/index.es.js\");\n \n                 function createGeneratorEasing(createGenerator) {\n                     const keyframesCache = new WeakMap();\n-                    return function() {\n-                        let options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n+                    return (options = {}) => {\n                         const generatorCache = new Map();\n-                        const getGenerator = function() {\n-                            let from = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;\n-                            let to = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 100;\n-                            let velocity = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0;\n-                            let isScale = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;\n+                        const getGenerator = (from = 0, to = 100, velocity = 0, isScale = false) => {\n                             const key = `${from}-${to}-${velocity}-${isScale}`;\n                             if (!generatorCache.has(key)) {\n                                 generatorCache.set(key, createGenerator(Object.assign({\n                                     from,\n                                     to,\n                                     velocity,\n                                     restSpeed: isScale ? 0.05 : 2,\n@@ -3560,76 +3543,76 @@\n         \"../../../node_modules/@motionone/dom/dist/easing/glide/index.es.js\":\n             /*!**************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/easing/glide/index.es.js ***!\n               \\**************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.glide = void 0;\n                 var _generators = __webpack_require__( /*! @motionone/generators */ \"../../../node_modules/@motionone/generators/dist/index.es.js\");\n                 var _createGeneratorEasingEs = __webpack_require__( /*! ../create-generator-easing.es.js */ \"../../../node_modules/@motionone/dom/dist/easing/create-generator-easing.es.js\");\n-                const glide = (0, _createGeneratorEasingEs.createGeneratorEasing)(_generators.glide);\n-                exports.glide = glide;\n+                const glide = exports.glide = (0, _createGeneratorEasingEs.createGeneratorEasing)(_generators.glide);\n \n                 /***/\n             }),\n \n         /***/\n         \"../../../node_modules/@motionone/dom/dist/easing/spring/index.es.js\":\n             /*!***************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/easing/spring/index.es.js ***!\n               \\***************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.spring = void 0;\n                 var _generators = __webpack_require__( /*! @motionone/generators */ \"../../../node_modules/@motionone/generators/dist/index.es.js\");\n                 var _createGeneratorEasingEs = __webpack_require__( /*! ../create-generator-easing.es.js */ \"../../../node_modules/@motionone/dom/dist/easing/create-generator-easing.es.js\");\n-                const spring = (0, _createGeneratorEasingEs.createGeneratorEasing)(_generators.spring);\n-                exports.spring = spring;\n+                const spring = exports.spring = (0, _createGeneratorEasingEs.createGeneratorEasing)(_generators.spring);\n \n                 /***/\n             }),\n \n         /***/\n         \"../../../node_modules/@motionone/dom/dist/gestures/in-view.es.js\":\n             /*!************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/gestures/in-view.es.js ***!\n               \\************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.inView = inView;\n                 var _resolveElementsEs = __webpack_require__( /*! ../utils/resolve-elements.es.js */ \"../../../node_modules/@motionone/dom/dist/utils/resolve-elements.es.js\");\n                 const thresholds = {\n                     any: 0,\n                     all: 1\n                 };\n \n-                function inView(elementOrSelector, onStart) {\n-                    let {\n-                        root,\n-                        margin: rootMargin,\n-                        amount = \"any\"\n-                    } = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n+                function inView(elementOrSelector, onStart, {\n+                    root,\n+                    margin: rootMargin,\n+                    amount = \"any\"\n+                } = {}) {\n                     /**\n                      * If this browser doesn't support IntersectionObserver, return a dummy stop function.\n                      * Default triggering of onStart is tricky - it could be used for starting/stopping\n                      * videos, lazy loading content etc. We could provide an option to enable a fallback, or\n                      * provide a fallback callback option.\n                      */\n                     if (typeof IntersectionObserver === \"undefined\") {\n@@ -3674,14 +3657,15 @@\n         \"../../../node_modules/@motionone/dom/dist/gestures/resize/handle-element.es.js\":\n             /*!**************************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/gestures/resize/handle-element.es.js ***!\n               \\**************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.resizeElement = resizeElement;\n                 var _resolveElementsEs = __webpack_require__( /*! ../../utils/resolve-elements.es.js */ \"../../../node_modules/@motionone/dom/dist/utils/resolve-elements.es.js\");\n@@ -3704,20 +3688,19 @@\n                         return {\n                             width: target.offsetWidth,\n                             height: target.offsetHeight\n                         };\n                     }\n                 }\n \n-                function notifyTarget(_ref) {\n-                    let {\n-                        target,\n-                        contentRect,\n-                        borderBoxSize\n-                    } = _ref;\n+                function notifyTarget({\n+                    target,\n+                    contentRect,\n+                    borderBoxSize\n+                }) {\n                     var _a;\n                     (_a = resizeHandlers.get(target)) === null || _a === void 0 ? void 0 : _a.forEach(handler => {\n                         handler({\n                             target,\n                             contentSize: contentRect,\n                             get size() {\n                                 return getElementSize(target, borderBoxSize);\n@@ -3765,14 +3748,15 @@\n         \"../../../node_modules/@motionone/dom/dist/gestures/resize/handle-window.es.js\":\n             /*!*************************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/gestures/resize/handle-window.es.js ***!\n               \\*************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.resizeWindow = resizeWindow;\n                 const windowCallbacks = new Set();\n@@ -3812,14 +3796,15 @@\n         \"../../../node_modules/@motionone/dom/dist/gestures/resize/index.es.js\":\n             /*!*****************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/gestures/resize/index.es.js ***!\n               \\*****************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.resize = resize;\n                 var _handleElementEs = __webpack_require__( /*! ./handle-element.es.js */ \"../../../node_modules/@motionone/dom/dist/gestures/resize/handle-element.es.js\");\n@@ -3836,31 +3821,31 @@\n         \"../../../node_modules/@motionone/dom/dist/gestures/scroll/index.es.js\":\n             /*!*****************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/gestures/scroll/index.es.js ***!\n               \\*****************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.scroll = scroll;\n-                var _tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.js\");\n+                var _tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.mjs\");\n                 var _indexEs = __webpack_require__( /*! ../resize/index.es.js */ \"../../../node_modules/@motionone/dom/dist/gestures/resize/index.es.js\");\n                 var _infoEs = __webpack_require__( /*! ./info.es.js */ \"../../../node_modules/@motionone/dom/dist/gestures/scroll/info.es.js\");\n                 var _onScrollHandlerEs = __webpack_require__( /*! ./on-scroll-handler.es.js */ \"../../../node_modules/@motionone/dom/dist/gestures/scroll/on-scroll-handler.es.js\");\n                 const scrollListeners = new WeakMap();\n                 const resizeListeners = new WeakMap();\n                 const onScrollHandlers = new WeakMap();\n                 const getEventTarget = element => element === document.documentElement ? window : element;\n \n-                function scroll(onScroll) {\n-                    let _a = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n+                function scroll(onScroll, _a = {}) {\n                     var {\n                         container = document.documentElement\n                     } = _a,\n                     options = (0, _tslib.__rest)(_a, [\"container\"]);\n                     let containerHandlers = onScrollHandlers.get(container);\n                     /**\n                      * Get the onScroll handlers for this container.\n@@ -3932,14 +3917,15 @@\n         \"../../../node_modules/@motionone/dom/dist/gestures/scroll/info.es.js\":\n             /*!****************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/gestures/scroll/info.es.js ***!\n               \\****************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.createScrollInfo = void 0;\n                 exports.updateScrollInfo = updateScrollInfo;\n@@ -4006,31 +3992,30 @@\n         \"../../../node_modules/@motionone/dom/dist/gestures/scroll/offsets/edge.es.js\":\n             /*!************************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/gestures/scroll/offsets/edge.es.js ***!\n               \\************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.namedEdges = void 0;\n                 exports.resolveEdge = resolveEdge;\n                 var _utils = __webpack_require__( /*! @motionone/utils */ \"../../../node_modules/@motionone/utils/dist/index.es.js\");\n-                const namedEdges = {\n+                const namedEdges = exports.namedEdges = {\n                     start: 0,\n                     center: 0.5,\n                     end: 1\n                 };\n-                exports.namedEdges = namedEdges;\n \n-                function resolveEdge(edge, length) {\n-                    let inset = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0;\n+                function resolveEdge(edge, length, inset = 0) {\n                     let delta = 0;\n                     /**\n                      * If we have this edge defined as a preset, replace the definition\n                      * with the numerical value.\n                      */\n                     if (namedEdges[edge] !== undefined) {\n                         edge = namedEdges[edge];\n@@ -4068,14 +4053,15 @@\n         \"../../../node_modules/@motionone/dom/dist/gestures/scroll/offsets/index.es.js\":\n             /*!*************************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/gestures/scroll/offsets/index.es.js ***!\n               \\*************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.resolveOffsets = resolveOffsets;\n                 var _utils = __webpack_require__( /*! @motionone/utils */ \"../../../node_modules/@motionone/utils/dist/index.es.js\");\n@@ -4149,14 +4135,15 @@\n         \"../../../node_modules/@motionone/dom/dist/gestures/scroll/offsets/inset.es.js\":\n             /*!*************************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/gestures/scroll/offsets/inset.es.js ***!\n               \\*************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.calcInset = calcInset;\n \n@@ -4196,14 +4183,15 @@\n         \"../../../node_modules/@motionone/dom/dist/gestures/scroll/offsets/offset.es.js\":\n             /*!**************************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/gestures/scroll/offsets/offset.es.js ***!\n               \\**************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.resolveOffset = resolveOffset;\n                 var _utils = __webpack_require__( /*! @motionone/utils */ \"../../../node_modules/@motionone/utils/dist/index.es.js\");\n@@ -4246,21 +4234,22 @@\n         \"../../../node_modules/@motionone/dom/dist/gestures/scroll/offsets/presets.es.js\":\n             /*!***************************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/gestures/scroll/offsets/presets.es.js ***!\n               \\***************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.ScrollOffset = void 0;\n-                const ScrollOffset = {\n+                const ScrollOffset = exports.ScrollOffset = {\n                     Enter: [\n                         [0, 1],\n                         [1, 1]\n                     ],\n                     Exit: [\n                         [0, 0],\n                         [1, 0]\n@@ -4270,40 +4259,38 @@\n                         [0, 1]\n                     ],\n                     All: [\n                         [0, 0],\n                         [1, 1]\n                     ]\n                 };\n-                exports.ScrollOffset = ScrollOffset;\n \n                 /***/\n             }),\n \n         /***/\n         \"../../../node_modules/@motionone/dom/dist/gestures/scroll/on-scroll-handler.es.js\":\n             /*!*****************************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/gestures/scroll/on-scroll-handler.es.js ***!\n               \\*****************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.createOnScrollHandler = createOnScrollHandler;\n                 var _utils = __webpack_require__( /*! @motionone/utils */ \"../../../node_modules/@motionone/utils/dist/index.es.js\");\n                 var _infoEs = __webpack_require__( /*! ./info.es.js */ \"../../../node_modules/@motionone/dom/dist/gestures/scroll/info.es.js\");\n                 var _indexEs = __webpack_require__( /*! ./offsets/index.es.js */ \"../../../node_modules/@motionone/dom/dist/gestures/scroll/offsets/index.es.js\");\n \n-                function measure(container) {\n-                    let target = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : container;\n-                    let info = arguments.length > 2 ? arguments[2] : undefined;\n+                function measure(container, target = container, info) {\n                     /**\n                      * Find inset of target within scrollable container\n                      */\n                     info.x.targetOffset = 0;\n                     info.y.targetOffset = 0;\n                     if (target !== container) {\n                         let node = target;\n@@ -4315,16 +4302,15 @@\n                     }\n                     info.x.targetLength = target === container ? target.scrollWidth : target.clientWidth;\n                     info.y.targetLength = target === container ? target.scrollHeight : target.clientHeight;\n                     info.x.containerLength = container.clientWidth;\n                     info.y.containerLength = container.clientHeight;\n                 }\n \n-                function createOnScrollHandler(element, onScroll, info) {\n-                    let options = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};\n+                function createOnScrollHandler(element, onScroll, info, options = {}) {\n                     const axis = options.axis || \"y\";\n                     return {\n                         measure: () => measure(element, options.target, info),\n                         update: time => {\n                             (0, _infoEs.updateScrollInfo)(element, info, time);\n                             if (options.offset || options.target) {\n                                 (0, _indexEs.resolveOffsets)(element, info, options);\n@@ -4332,18 +4318,17 @@\n                         },\n                         notify: typeof onScroll === \"function\" ? () => onScroll(info) : scrubAnimation(onScroll, info[axis])\n                     };\n                 }\n \n                 function scrubAnimation(controls, axisInfo) {\n                     controls.pause();\n-                    controls.forEachNative((animation, _ref) => {\n-                        let {\n-                            easing\n-                        } = _ref;\n+                    controls.forEachNative((animation, {\n+                        easing\n+                    }) => {\n                         var _a, _b;\n                         if (animation.updateDuration) {\n                             if (!easing) animation.easing = _utils.noopReturn;\n                             animation.updateDuration(1);\n                         } else {\n                             const timingOptions = {\n                                 duration: 1000\n@@ -4364,14 +4349,15 @@\n         \"../../../node_modules/@motionone/dom/dist/index.es.js\":\n             /*!*************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/index.es.js ***!\n               \\*************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 Object.defineProperty(exports, \"ScrollOffset\", ({\n                     enumerable: true,\n@@ -4506,75 +4492,73 @@\n         \"../../../node_modules/@motionone/dom/dist/state/gestures/hover.es.js\":\n             /*!****************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/state/gestures/hover.es.js ***!\n               \\****************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.hover = void 0;\n                 var _eventsEs = __webpack_require__( /*! ../utils/events.es.js */ \"../../../node_modules/@motionone/dom/dist/state/utils/events.es.js\");\n                 const mouseEvent = (element, name, action) => event => {\n                     if (event.pointerType && event.pointerType !== \"mouse\") return;\n                     action();\n                     (0, _eventsEs.dispatchPointerEvent)(element, name, event);\n                 };\n-                const hover = {\n+                const hover = exports.hover = {\n                     isActive: options => Boolean(options.hover),\n-                    subscribe: (element, _ref) => {\n-                        let {\n-                            enable,\n-                            disable\n-                        } = _ref;\n+                    subscribe: (element, {\n+                        enable,\n+                        disable\n+                    }) => {\n                         const onEnter = mouseEvent(element, \"hoverstart\", enable);\n                         const onLeave = mouseEvent(element, \"hoverend\", disable);\n                         element.addEventListener(\"pointerenter\", onEnter);\n                         element.addEventListener(\"pointerleave\", onLeave);\n                         return () => {\n                             element.removeEventListener(\"pointerenter\", onEnter);\n                             element.removeEventListener(\"pointerleave\", onLeave);\n                         };\n                     }\n                 };\n-                exports.hover = hover;\n \n                 /***/\n             }),\n \n         /***/\n         \"../../../node_modules/@motionone/dom/dist/state/gestures/in-view.es.js\":\n             /*!******************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/state/gestures/in-view.es.js ***!\n               \\******************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.inView = void 0;\n-                var _tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.js\");\n+                var _tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.mjs\");\n                 var _eventsEs = __webpack_require__( /*! ../utils/events.es.js */ \"../../../node_modules/@motionone/dom/dist/state/utils/events.es.js\");\n                 var _inViewEs = __webpack_require__( /*! ../../gestures/in-view.es.js */ \"../../../node_modules/@motionone/dom/dist/gestures/in-view.es.js\");\n-                const inView = {\n+                const inView = exports.inView = {\n                     isActive: options => Boolean(options.inView),\n-                    subscribe: (element, _ref, _ref2) => {\n-                        let {\n-                            enable,\n-                            disable\n-                        } = _ref;\n-                        let {\n-                            inViewOptions = {}\n-                        } = _ref2;\n+                    subscribe: (element, {\n+                        enable,\n+                        disable\n+                    }, {\n+                        inViewOptions = {}\n+                    }) => {\n                         const {\n                             once\n                         } = inViewOptions,\n                         viewOptions = (0, _tslib.__rest)(inViewOptions, [\"once\"]);\n                         return (0, _inViewEs.inView)(element, enterEntry => {\n                             enable();\n                             (0, _eventsEs.dispatchViewEvent)(element, \"viewenter\", enterEntry);\n@@ -4583,41 +4567,40 @@\n                                     disable();\n                                     (0, _eventsEs.dispatchViewEvent)(element, \"viewleave\", leaveEntry);\n                                 };\n                             }\n                         }, viewOptions);\n                     }\n                 };\n-                exports.inView = inView;\n \n                 /***/\n             }),\n \n         /***/\n         \"../../../node_modules/@motionone/dom/dist/state/gestures/press.es.js\":\n             /*!****************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/state/gestures/press.es.js ***!\n               \\****************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.press = void 0;\n                 var _eventsEs = __webpack_require__( /*! ../utils/events.es.js */ \"../../../node_modules/@motionone/dom/dist/state/utils/events.es.js\");\n-                const press = {\n+                const press = exports.press = {\n                     isActive: options => Boolean(options.press),\n-                    subscribe: (element, _ref) => {\n-                        let {\n-                            enable,\n-                            disable\n-                        } = _ref;\n+                    subscribe: (element, {\n+                        enable,\n+                        disable\n+                    }) => {\n                         const onPointerUp = event => {\n                             disable();\n                             (0, _eventsEs.dispatchPointerEvent)(element, \"pressend\", event);\n                             window.removeEventListener(\"pointerup\", onPointerUp);\n                         };\n                         const onPointerDown = event => {\n                             enable();\n@@ -4627,35 +4610,35 @@\n                         element.addEventListener(\"pointerdown\", onPointerDown);\n                         return () => {\n                             element.removeEventListener(\"pointerdown\", onPointerDown);\n                             window.removeEventListener(\"pointerup\", onPointerUp);\n                         };\n                     }\n                 };\n-                exports.press = press;\n \n                 /***/\n             }),\n \n         /***/\n         \"../../../node_modules/@motionone/dom/dist/state/index.es.js\":\n             /*!*******************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/state/index.es.js ***!\n               \\*******************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.createMotionState = createMotionState;\n                 exports.mountedStates = void 0;\n-                var _tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.js\");\n+                var _tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.mjs\");\n                 var _heyListen = __webpack_require__( /*! hey-listen */ \"../../../node_modules/hey-listen/dist/hey-listen.es.js\");\n                 var _utils = __webpack_require__( /*! @motionone/utils */ \"../../../node_modules/@motionone/utils/dist/index.es.js\");\n                 var _animateStyleEs = __webpack_require__( /*! ../animate/animate-style.es.js */ \"../../../node_modules/@motionone/dom/dist/animate/animate-style.es.js\");\n                 var _styleEs = __webpack_require__( /*! ../animate/style.es.js */ \"../../../node_modules/@motionone/dom/dist/animate/style.es.js\");\n                 var _optionsEs = __webpack_require__( /*! ../animate/utils/options.es.js */ \"../../../node_modules/@motionone/dom/dist/animate/utils/options.es.js\");\n                 var _hasChangedEs = __webpack_require__( /*! ./utils/has-changed.es.js */ \"../../../node_modules/@motionone/dom/dist/state/utils/has-changed.es.js\");\n                 var _resolveVariantEs = __webpack_require__( /*! ./utils/resolve-variant.es.js */ \"../../../node_modules/@motionone/dom/dist/state/utils/resolve-variant.es.js\");\n@@ -4674,20 +4657,17 @@\n                  * a righter-most type, it will override any definition in a lefter-most.\n                  */\n                 const stateTypes = [\"initial\", \"animate\", ...Object.keys(gestures), \"exit\"];\n                 /**\n                  * A global store of all generated motion states. This can be used to lookup\n                  * a motion state for a given Element.\n                  */\n-                const mountedStates = new WeakMap();\n-                exports.mountedStates = mountedStates;\n+                const mountedStates = exports.mountedStates = new WeakMap();\n \n-                function createMotionState() {\n-                    let options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n-                    let parent = arguments.length > 1 ? arguments[1] : undefined;\n+                function createMotionState(options = {}, parent) {\n                     /**\n                      * The element represented by the motion state. This is an empty reference\n                      * when we create the state to support SSR and allow for later mounting\n                      * in view libraries.\n                      *\n                      * @ts-ignore\n                      */\n@@ -4836,14 +4816,15 @@\n         \"../../../node_modules/@motionone/dom/dist/state/utils/events.es.js\":\n             /*!**************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/state/utils/events.es.js ***!\n               \\**************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.dispatchPointerEvent = dispatchPointerEvent;\n                 exports.dispatchViewEvent = dispatchViewEvent;\n@@ -4878,14 +4859,15 @@\n         \"../../../node_modules/@motionone/dom/dist/state/utils/has-changed.es.js\":\n             /*!*******************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/state/utils/has-changed.es.js ***!\n               \\*******************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.hasChanged = hasChanged;\n                 exports.shallowCompare = shallowCompare;\n@@ -4912,14 +4894,15 @@\n         \"../../../node_modules/@motionone/dom/dist/state/utils/is-variant.es.js\":\n             /*!******************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/state/utils/is-variant.es.js ***!\n               \\******************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.isVariant = isVariant;\n \n@@ -4934,14 +4917,15 @@\n         \"../../../node_modules/@motionone/dom/dist/state/utils/resolve-variant.es.js\":\n             /*!***********************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/state/utils/resolve-variant.es.js ***!\n               \\***********************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.resolveVariant = resolveVariant;\n                 var _isVariantEs = __webpack_require__( /*! ./is-variant.es.js */ \"../../../node_modules/@motionone/dom/dist/state/utils/is-variant.es.js\");\n@@ -4961,14 +4945,15 @@\n         \"../../../node_modules/@motionone/dom/dist/state/utils/schedule.es.js\":\n             /*!****************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/state/utils/schedule.es.js ***!\n               \\****************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.scheduleAnimation = scheduleAnimation;\n                 exports.unscheduleAnimation = unscheduleAnimation;\n@@ -5006,50 +4991,49 @@\n         \"../../../node_modules/@motionone/dom/dist/timeline/index.es.js\":\n             /*!**********************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/timeline/index.es.js ***!\n               \\**********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.createAnimationsFromTimeline = createAnimationsFromTimeline;\n                 exports.timeline = timeline;\n-                var _tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.js\");\n+                var _tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.mjs\");\n                 var _heyListen = __webpack_require__( /*! hey-listen */ \"../../../node_modules/hey-listen/dist/hey-listen.es.js\");\n                 var _utils = __webpack_require__( /*! @motionone/utils */ \"../../../node_modules/@motionone/utils/dist/index.es.js\");\n                 var _staggerEs = __webpack_require__( /*! ../utils/stagger.es.js */ \"../../../node_modules/@motionone/dom/dist/utils/stagger.es.js\");\n                 var _animateStyleEs = __webpack_require__( /*! ../animate/animate-style.es.js */ \"../../../node_modules/@motionone/dom/dist/animate/animate-style.es.js\");\n                 var _controlsEs = __webpack_require__( /*! ../animate/utils/controls.es.js */ \"../../../node_modules/@motionone/dom/dist/animate/utils/controls.es.js\");\n                 var _keyframesEs = __webpack_require__( /*! ../animate/utils/keyframes.es.js */ \"../../../node_modules/@motionone/dom/dist/animate/utils/keyframes.es.js\");\n                 var _optionsEs = __webpack_require__( /*! ../animate/utils/options.es.js */ \"../../../node_modules/@motionone/dom/dist/animate/utils/options.es.js\");\n                 var _resolveElementsEs = __webpack_require__( /*! ../utils/resolve-elements.es.js */ \"../../../node_modules/@motionone/dom/dist/utils/resolve-elements.es.js\");\n                 var _transformsEs = __webpack_require__( /*! ../animate/utils/transforms.es.js */ \"../../../node_modules/@motionone/dom/dist/animate/utils/transforms.es.js\");\n                 var _calcTimeEs = __webpack_require__( /*! ./utils/calc-time.es.js */ \"../../../node_modules/@motionone/dom/dist/timeline/utils/calc-time.es.js\");\n                 var _editEs = __webpack_require__( /*! ./utils/edit.es.js */ \"../../../node_modules/@motionone/dom/dist/timeline/utils/edit.es.js\");\n                 var _sortEs = __webpack_require__( /*! ./utils/sort.es.js */ \"../../../node_modules/@motionone/dom/dist/timeline/utils/sort.es.js\");\n \n-                function timeline(definition) {\n-                    let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n+                function timeline(definition, options = {}) {\n                     var _a;\n                     const animationDefinitions = createAnimationsFromTimeline(definition, options);\n                     /**\n                      * Create and start animations\n                      */\n                     const animationFactories = animationDefinitions.map(definition => (0, _animateStyleEs.animateStyle)(...definition)).filter(Boolean);\n                     return (0, _controlsEs.withControls)(animationFactories, options,\n                         // Get the duration from the first animation definition\n                         (_a = animationDefinitions[0]) === null || _a === void 0 ? void 0 : _a[3].duration);\n                 }\n \n-                function createAnimationsFromTimeline(definition) {\n-                    let _a = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n+                function createAnimationsFromTimeline(definition, _a = {}) {\n                     var {\n                         defaultOptions = {}\n                     } = _a,\n                     timelineOptions = (0, _tslib.__rest)(_a, [\"defaultOptions\"]);\n                     const animationDefinitions = [];\n                     const elementSequences = new Map();\n                     const elementCache = {};\n@@ -5227,14 +5211,15 @@\n         \"../../../node_modules/@motionone/dom/dist/timeline/utils/calc-time.es.js\":\n             /*!********************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/timeline/utils/calc-time.es.js ***!\n               \\********************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.calcNextTime = calcNextTime;\n                 var _utils = __webpack_require__( /*! @motionone/utils */ \"../../../node_modules/@motionone/utils/dist/index.es.js\");\n@@ -5259,14 +5244,15 @@\n         \"../../../node_modules/@motionone/dom/dist/timeline/utils/edit.es.js\":\n             /*!***************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/timeline/utils/edit.es.js ***!\n               \\***************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.addKeyframes = addKeyframes;\n                 exports.eraseKeyframes = eraseKeyframes;\n@@ -5306,14 +5292,15 @@\n         \"../../../node_modules/@motionone/dom/dist/timeline/utils/sort.es.js\":\n             /*!***************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/timeline/utils/sort.es.js ***!\n               \\***************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.compareByTime = compareByTime;\n \n@@ -5332,14 +5319,15 @@\n         \"../../../node_modules/@motionone/dom/dist/utils/resolve-elements.es.js\":\n             /*!******************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/utils/resolve-elements.es.js ***!\n               \\******************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.resolveElements = resolveElements;\n \n@@ -5368,32 +5356,31 @@\n         \"../../../node_modules/@motionone/dom/dist/utils/stagger.es.js\":\n             /*!*********************************************************************!*\\\n               !*** ../../../node_modules/@motionone/dom/dist/utils/stagger.es.js ***!\n               \\*********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.getFromIndex = getFromIndex;\n                 exports.resolveOption = resolveOption;\n                 exports.stagger = stagger;\n                 var _utils = __webpack_require__( /*! @motionone/utils */ \"../../../node_modules/@motionone/utils/dist/index.es.js\");\n                 var _animation = __webpack_require__( /*! @motionone/animation */ \"../../../node_modules/@motionone/animation/dist/index.es.js\");\n \n-                function stagger() {\n-                    let duration = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0.1;\n-                    let {\n-                        start = 0,\n-                            from = 0,\n-                            easing\n-                    } = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n+                function stagger(duration = 0.1, {\n+                    start = 0,\n+                    from = 0,\n+                    easing\n+                } = {}) {\n                     return (i, total) => {\n                         const fromIndex = (0, _utils.isNumber)(from) ? from : getFromIndex(from, total);\n                         const distance = Math.abs(fromIndex - i);\n                         let delay = duration * distance;\n                         if (easing) {\n                             const maxDelay = total * duration;\n                             const easingFunction = (0, _animation.getEasingFunction)(easing);\n@@ -5423,14 +5410,15 @@\n         \"../../../node_modules/@motionone/easing/dist/cubic-bezier.es.js\":\n             /*!***********************************************************************!*\\\n               !*** ../../../node_modules/@motionone/easing/dist/cubic-bezier.es.js ***!\n               \\***********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.cubicBezier = cubicBezier;\n                 var _utils = __webpack_require__( /*! @motionone/utils */ \"../../../node_modules/@motionone/utils/dist/index.es.js\");\n@@ -5490,14 +5478,15 @@\n         \"../../../node_modules/@motionone/easing/dist/index.es.js\":\n             /*!****************************************************************!*\\\n               !*** ../../../node_modules/@motionone/easing/dist/index.es.js ***!\n               \\****************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 Object.defineProperty(exports, \"cubicBezier\", ({\n                     enumerable: true,\n@@ -5521,66 +5510,64 @@\n         \"../../../node_modules/@motionone/easing/dist/steps.es.js\":\n             /*!****************************************************************!*\\\n               !*** ../../../node_modules/@motionone/easing/dist/steps.es.js ***!\n               \\****************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.steps = void 0;\n                 var _utils = __webpack_require__( /*! @motionone/utils */ \"../../../node_modules/@motionone/utils/dist/index.es.js\");\n-                const steps = function(steps) {\n-                    let direction = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : \"end\";\n-                    return progress => {\n-                        progress = direction === \"end\" ? Math.min(progress, 0.999) : Math.max(progress, 0.001);\n-                        const expanded = progress * steps;\n-                        const rounded = direction === \"end\" ? Math.floor(expanded) : Math.ceil(expanded);\n-                        return (0, _utils.clamp)(0, 1, rounded / steps);\n-                    };\n+                const steps = (steps, direction = \"end\") => progress => {\n+                    progress = direction === \"end\" ? Math.min(progress, 0.999) : Math.max(progress, 0.001);\n+                    const expanded = progress * steps;\n+                    const rounded = direction === \"end\" ? Math.floor(expanded) : Math.ceil(expanded);\n+                    return (0, _utils.clamp)(0, 1, rounded / steps);\n                 };\n                 exports.steps = steps;\n \n                 /***/\n             }),\n \n         /***/\n         \"../../../node_modules/@motionone/generators/dist/glide/index.es.js\":\n             /*!**************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/generators/dist/glide/index.es.js ***!\n               \\**************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.glide = void 0;\n                 var _utils = __webpack_require__( /*! @motionone/utils */ \"../../../node_modules/@motionone/utils/dist/index.es.js\");\n                 var _velocityEs = __webpack_require__( /*! ../utils/velocity.es.js */ \"../../../node_modules/@motionone/generators/dist/utils/velocity.es.js\");\n                 var _indexEs = __webpack_require__( /*! ../spring/index.es.js */ \"../../../node_modules/@motionone/generators/dist/spring/index.es.js\");\n-                const glide = _ref => {\n-                    let {\n-                        from = 0,\n-                            velocity = 0.0,\n-                            power = 0.8,\n-                            decay = 0.325,\n-                            bounceDamping,\n-                            bounceStiffness,\n-                            changeTarget,\n-                            min,\n-                            max,\n-                            restDistance = 0.5,\n-                            restSpeed\n-                    } = _ref;\n+                const glide = ({\n+                    from = 0,\n+                    velocity = 0.0,\n+                    power = 0.8,\n+                    decay = 0.325,\n+                    bounceDamping,\n+                    bounceStiffness,\n+                    changeTarget,\n+                    min,\n+                    max,\n+                    restDistance = 0.5,\n+                    restSpeed\n+                }) => {\n                     decay = _utils.time.ms(decay);\n                     const state = {\n                         hasReachedTarget: false,\n                         done: false,\n                         current: from,\n                         target: from\n                     };\n@@ -5665,14 +5652,15 @@\n         \"../../../node_modules/@motionone/generators/dist/index.es.js\":\n             /*!********************************************************************!*\\\n               !*** ../../../node_modules/@motionone/generators/dist/index.es.js ***!\n               \\********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 Object.defineProperty(exports, \"calcGeneratorVelocity\", ({\n                     enumerable: true,\n@@ -5710,60 +5698,60 @@\n         \"../../../node_modules/@motionone/generators/dist/spring/defaults.es.js\":\n             /*!******************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/generators/dist/spring/defaults.es.js ***!\n               \\******************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.defaults = void 0;\n-                const defaults = {\n+                const defaults = exports.defaults = {\n                     stiffness: 100.0,\n                     damping: 10.0,\n                     mass: 1.0\n                 };\n-                exports.defaults = defaults;\n \n                 /***/\n             }),\n \n         /***/\n         \"../../../node_modules/@motionone/generators/dist/spring/index.es.js\":\n             /*!***************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/generators/dist/spring/index.es.js ***!\n               \\***************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.spring = void 0;\n                 var _utils = __webpack_require__( /*! @motionone/utils */ \"../../../node_modules/@motionone/utils/dist/index.es.js\");\n                 var _defaultsEs = __webpack_require__( /*! ./defaults.es.js */ \"../../../node_modules/@motionone/generators/dist/spring/defaults.es.js\");\n                 var _utilsEs = __webpack_require__( /*! ./utils.es.js */ \"../../../node_modules/@motionone/generators/dist/spring/utils.es.js\");\n                 var _hasReachedTargetEs = __webpack_require__( /*! ../utils/has-reached-target.es.js */ \"../../../node_modules/@motionone/generators/dist/utils/has-reached-target.es.js\");\n                 var _velocityEs = __webpack_require__( /*! ../utils/velocity.es.js */ \"../../../node_modules/@motionone/generators/dist/utils/velocity.es.js\");\n-                const spring = function() {\n-                    let {\n-                        stiffness = _defaultsEs.defaults.stiffness,\n-                            damping = _defaultsEs.defaults.damping,\n-                            mass = _defaultsEs.defaults.mass,\n-                            from = 0,\n-                            to = 1,\n-                            velocity = 0.0,\n-                            restSpeed = 2,\n-                            restDistance = 0.5\n-                    } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n+                const spring = ({\n+                    stiffness = _defaultsEs.defaults.stiffness,\n+                    damping = _defaultsEs.defaults.damping,\n+                    mass = _defaultsEs.defaults.mass,\n+                    from = 0,\n+                    to = 1,\n+                    velocity = 0.0,\n+                    restSpeed = 2,\n+                    restDistance = 0.5\n+                } = {}) => {\n                     velocity = velocity ? _utils.time.s(velocity) : 0.0;\n                     const state = {\n                         done: false,\n                         hasReachedTarget: false,\n                         current: from,\n                         target: to\n                     };\n@@ -5800,40 +5788,37 @@\n         \"../../../node_modules/@motionone/generators/dist/spring/utils.es.js\":\n             /*!***************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/generators/dist/spring/utils.es.js ***!\n               \\***************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.calcDampingRatio = void 0;\n                 var _defaultsEs = __webpack_require__( /*! ./defaults.es.js */ \"../../../node_modules/@motionone/generators/dist/spring/defaults.es.js\");\n-                const calcDampingRatio = function() {\n-                    let stiffness = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : _defaultsEs.defaults.stiffness;\n-                    let damping = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : _defaultsEs.defaults.damping;\n-                    let mass = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : _defaultsEs.defaults.mass;\n-                    return damping / (2 * Math.sqrt(stiffness * mass));\n-                };\n+                const calcDampingRatio = (stiffness = _defaultsEs.defaults.stiffness, damping = _defaultsEs.defaults.damping, mass = _defaultsEs.defaults.mass) => damping / (2 * Math.sqrt(stiffness * mass));\n                 exports.calcDampingRatio = calcDampingRatio;\n \n                 /***/\n             }),\n \n         /***/\n         \"../../../node_modules/@motionone/generators/dist/utils/has-reached-target.es.js\":\n             /*!***************************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/generators/dist/utils/has-reached-target.es.js ***!\n               \\***************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.hasReachedTarget = hasReachedTarget;\n \n@@ -5848,26 +5833,26 @@\n         \"../../../node_modules/@motionone/generators/dist/utils/pregenerate-keyframes.es.js\":\n             /*!******************************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/generators/dist/utils/pregenerate-keyframes.es.js ***!\n               \\******************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.pregenerateKeyframes = pregenerateKeyframes;\n                 var _utils = __webpack_require__( /*! @motionone/utils */ \"../../../node_modules/@motionone/utils/dist/index.es.js\");\n                 const timeStep = 10;\n                 const maxDuration = 10000;\n \n-                function pregenerateKeyframes(generator) {\n-                    let toUnit = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : _utils.noopReturn;\n+                function pregenerateKeyframes(generator, toUnit = _utils.noopReturn) {\n                     let overshootDuration = undefined;\n                     let timestamp = timeStep;\n                     let state = generator(0);\n                     const keyframes = [toUnit(state.current)];\n                     while (!state.done && timestamp < maxDuration) {\n                         state = generator(timestamp);\n                         keyframes.push(toUnit(state.done ? state.target : state.current));\n@@ -5896,14 +5881,15 @@\n         \"../../../node_modules/@motionone/generators/dist/utils/velocity.es.js\":\n             /*!*****************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/generators/dist/utils/velocity.es.js ***!\n               \\*****************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.calcGeneratorVelocity = calcGeneratorVelocity;\n                 var _utils = __webpack_require__( /*! @motionone/utils */ \"../../../node_modules/@motionone/utils/dist/index.es.js\");\n@@ -5920,14 +5906,15 @@\n         \"../../../node_modules/@motionone/types/dist/MotionValue.es.js\":\n             /*!*********************************************************************!*\\\n               !*** ../../../node_modules/@motionone/types/dist/MotionValue.es.js ***!\n               \\*********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.MotionValue = void 0;\n                 /**\n@@ -5954,14 +5941,15 @@\n         \"../../../node_modules/@motionone/types/dist/index.es.js\":\n             /*!***************************************************************!*\\\n               !*** ../../../node_modules/@motionone/types/dist/index.es.js ***!\n               \\***************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 Object.defineProperty(exports, \"MotionValue\", ({\n                     enumerable: true,\n@@ -5978,14 +5966,15 @@\n         \"../../../node_modules/@motionone/utils/dist/array.es.js\":\n             /*!***************************************************************!*\\\n               !*** ../../../node_modules/@motionone/utils/dist/array.es.js ***!\n               \\***************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.addUniqueItem = addUniqueItem;\n                 exports.removeItem = removeItem;\n@@ -6006,14 +5995,15 @@\n         \"../../../node_modules/@motionone/utils/dist/clamp.es.js\":\n             /*!***************************************************************!*\\\n               !*** ../../../node_modules/@motionone/utils/dist/clamp.es.js ***!\n               \\***************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.clamp = void 0;\n                 const clamp = (min, max, v) => Math.min(Math.max(v, min), max);\n@@ -6026,40 +6016,41 @@\n         \"../../../node_modules/@motionone/utils/dist/defaults.es.js\":\n             /*!******************************************************************!*\\\n               !*** ../../../node_modules/@motionone/utils/dist/defaults.es.js ***!\n               \\******************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.defaults = void 0;\n-                const defaults = {\n+                const defaults = exports.defaults = {\n                     duration: 0.3,\n                     delay: 0,\n                     endDelay: 0,\n                     repeat: 0,\n                     easing: \"ease\"\n                 };\n-                exports.defaults = defaults;\n \n                 /***/\n             }),\n \n         /***/\n         \"../../../node_modules/@motionone/utils/dist/easing.es.js\":\n             /*!****************************************************************!*\\\n               !*** ../../../node_modules/@motionone/utils/dist/easing.es.js ***!\n               \\****************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.getEasingForSegment = getEasingForSegment;\n                 var _isEasingListEs = __webpack_require__( /*! ./is-easing-list.es.js */ \"../../../node_modules/@motionone/utils/dist/is-easing-list.es.js\");\n@@ -6076,14 +6067,15 @@\n         \"../../../node_modules/@motionone/utils/dist/index.es.js\":\n             /*!***************************************************************!*\\\n               !*** ../../../node_modules/@motionone/utils/dist/index.es.js ***!\n               \\***************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 Object.defineProperty(exports, \"addUniqueItem\", ({\n                     enumerable: true,\n@@ -6237,30 +6229,29 @@\n         \"../../../node_modules/@motionone/utils/dist/interpolate.es.js\":\n             /*!*********************************************************************!*\\\n               !*** ../../../node_modules/@motionone/utils/dist/interpolate.es.js ***!\n               \\*********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.interpolate = interpolate;\n                 var _mixEs = __webpack_require__( /*! ./mix.es.js */ \"../../../node_modules/@motionone/utils/dist/mix.es.js\");\n                 var _noopEs = __webpack_require__( /*! ./noop.es.js */ \"../../../node_modules/@motionone/utils/dist/noop.es.js\");\n                 var _offsetEs = __webpack_require__( /*! ./offset.es.js */ \"../../../node_modules/@motionone/utils/dist/offset.es.js\");\n                 var _progressEs = __webpack_require__( /*! ./progress.es.js */ \"../../../node_modules/@motionone/utils/dist/progress.es.js\");\n                 var _easingEs = __webpack_require__( /*! ./easing.es.js */ \"../../../node_modules/@motionone/utils/dist/easing.es.js\");\n                 var _clampEs = __webpack_require__( /*! ./clamp.es.js */ \"../../../node_modules/@motionone/utils/dist/clamp.es.js\");\n \n-                function interpolate(output) {\n-                    let input = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : (0, _offsetEs.defaultOffset)(output.length);\n-                    let easing = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : _noopEs.noopReturn;\n+                function interpolate(output, input = (0, _offsetEs.defaultOffset)(output.length), easing = _noopEs.noopReturn) {\n                     const length = output.length;\n                     /**\n                      * If the input length is lower than the output we\n                      * fill the input to match. This currently assumes the input\n                      * is an animation progress value so is a good candidate for\n                      * moving outside the function.\n                      */\n@@ -6285,14 +6276,15 @@\n         \"../../../node_modules/@motionone/utils/dist/is-cubic-bezier.es.js\":\n             /*!*************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/utils/dist/is-cubic-bezier.es.js ***!\n               \\*************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.isCubicBezier = void 0;\n                 var _isNumberEs = __webpack_require__( /*! ./is-number.es.js */ \"../../../node_modules/@motionone/utils/dist/is-number.es.js\");\n@@ -6306,14 +6298,15 @@\n         \"../../../node_modules/@motionone/utils/dist/is-easing-generator.es.js\":\n             /*!*****************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/utils/dist/is-easing-generator.es.js ***!\n               \\*****************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.isEasingGenerator = void 0;\n                 const isEasingGenerator = easing => typeof easing === \"object\" && Boolean(easing.createAnimation);\n@@ -6326,14 +6319,15 @@\n         \"../../../node_modules/@motionone/utils/dist/is-easing-list.es.js\":\n             /*!************************************************************************!*\\\n               !*** ../../../node_modules/@motionone/utils/dist/is-easing-list.es.js ***!\n               \\************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.isEasingList = void 0;\n                 var _isNumberEs = __webpack_require__( /*! ./is-number.es.js */ \"../../../node_modules/@motionone/utils/dist/is-number.es.js\");\n@@ -6347,14 +6341,15 @@\n         \"../../../node_modules/@motionone/utils/dist/is-function.es.js\":\n             /*!*********************************************************************!*\\\n               !*** ../../../node_modules/@motionone/utils/dist/is-function.es.js ***!\n               \\*********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.isFunction = void 0;\n                 const isFunction = value => typeof value === \"function\";\n@@ -6367,14 +6362,15 @@\n         \"../../../node_modules/@motionone/utils/dist/is-number.es.js\":\n             /*!*******************************************************************!*\\\n               !*** ../../../node_modules/@motionone/utils/dist/is-number.es.js ***!\n               \\*******************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.isNumber = void 0;\n                 const isNumber = value => typeof value === \"number\";\n@@ -6387,14 +6383,15 @@\n         \"../../../node_modules/@motionone/utils/dist/is-string.es.js\":\n             /*!*******************************************************************!*\\\n               !*** ../../../node_modules/@motionone/utils/dist/is-string.es.js ***!\n               \\*******************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.isString = void 0;\n                 const isString = value => typeof value === \"string\";\n@@ -6407,14 +6404,15 @@\n         \"../../../node_modules/@motionone/utils/dist/mix.es.js\":\n             /*!*************************************************************!*\\\n               !*** ../../../node_modules/@motionone/utils/dist/mix.es.js ***!\n               \\*************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.mix = void 0;\n                 const mix = (min, max, progress) => -progress * min + progress * max + min;\n@@ -6427,14 +6425,15 @@\n         \"../../../node_modules/@motionone/utils/dist/noop.es.js\":\n             /*!**************************************************************!*\\\n               !*** ../../../node_modules/@motionone/utils/dist/noop.es.js ***!\n               \\**************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.noopReturn = exports.noop = void 0;\n                 const noop = () => {};\n@@ -6449,14 +6448,15 @@\n         \"../../../node_modules/@motionone/utils/dist/offset.es.js\":\n             /*!****************************************************************!*\\\n               !*** ../../../node_modules/@motionone/utils/dist/offset.es.js ***!\n               \\****************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.defaultOffset = defaultOffset;\n                 exports.fillOffset = fillOffset;\n@@ -6484,14 +6484,15 @@\n         \"../../../node_modules/@motionone/utils/dist/progress.es.js\":\n             /*!******************************************************************!*\\\n               !*** ../../../node_modules/@motionone/utils/dist/progress.es.js ***!\n               \\******************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.progress = void 0;\n                 const progress = (min, max, value) => max - min === 0 ? 1 : (value - min) / (max - min);\n@@ -6504,37 +6505,38 @@\n         \"../../../node_modules/@motionone/utils/dist/time.es.js\":\n             /*!**************************************************************!*\\\n               !*** ../../../node_modules/@motionone/utils/dist/time.es.js ***!\n               \\**************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.time = void 0;\n-                const time = {\n+                const time = exports.time = {\n                     ms: seconds => seconds * 1000,\n                     s: milliseconds => milliseconds / 1000\n                 };\n-                exports.time = time;\n \n                 /***/\n             }),\n \n         /***/\n         \"../../../node_modules/@motionone/utils/dist/velocity.es.js\":\n             /*!******************************************************************!*\\\n               !*** ../../../node_modules/@motionone/utils/dist/velocity.es.js ***!\n               \\******************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.velocityPerSecond = velocityPerSecond;\n                 /*\n@@ -6554,14 +6556,15 @@\n         \"../../../node_modules/@motionone/utils/dist/wrap.es.js\":\n             /*!**************************************************************!*\\\n               !*** ../../../node_modules/@motionone/utils/dist/wrap.es.js ***!\n               \\**************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.wrap = void 0;\n                 const wrap = (min, max, v) => {\n@@ -6577,14 +6580,15 @@\n         \"../../../node_modules/@n1ru4l/push-pull-async-iterable-iterator/index.js\":\n             /*!********************************************************************************!*\\\n               !*** ../../../node_modules/@n1ru4l/push-pull-async-iterable-iterator/index.js ***!\n               \\********************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n \n                 function createDeferred() {\n@@ -6634,18 +6638,20 @@\n                         values.push(value);\n                         newValueD.resolve(SYMBOL_NEW_VALUE);\n                         newValueD = createDeferred();\n                     }\n                     // We monkey patch the original generator for clean-up\n                     // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n                     const originalReturn = asyncIterableIterator.return.bind(asyncIterableIterator);\n-                    asyncIterableIterator.return = function() {\n+                    asyncIterableIterator.return = (\n+                        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n+                        ...args) => {\n                         isRunning = false;\n                         finishedD.resolve(SYMBOL_FINISHED);\n-                        return originalReturn(...arguments);\n+                        return originalReturn(...args);\n                     };\n                     // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n                     const originalThrow = asyncIterableIterator.throw.bind(asyncIterableIterator);\n                     asyncIterableIterator.throw = err => {\n                         isRunning = false;\n                         finishedD.resolve(err);\n                         return originalThrow(err);\n@@ -6724,30 +6730,30 @@\n         \"../../../node_modules/@radix-ui/primitive/dist/index.js\":\n             /*!***************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/primitive/dist/index.js ***!\n               \\***************************************************************/\n             /***/\n             (function(module) {\n \n+                \"use strict\";\n \n \n                 function $parcel$export(e, n, v, s) {\n                     Object.defineProperty(e, n, {\n                         get: v,\n                         set: s,\n                         enumerable: true,\n                         configurable: true\n                     });\n                 }\n                 $parcel$export(module.exports, \"composeEventHandlers\", () => $1a6a90a521dcd173$export$b9ecd428b558ff10);\n \n-                function $1a6a90a521dcd173$export$b9ecd428b558ff10(originalEventHandler, ourEventHandler) {\n-                    let {\n-                        checkForDefaultPrevented = true\n-                    } = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n+                function $1a6a90a521dcd173$export$b9ecd428b558ff10(originalEventHandler, ourEventHandler, {\n+                    checkForDefaultPrevented = true\n+                } = {}) {\n                     return function handleEvent(event) {\n                         originalEventHandler === null || originalEventHandler === void 0 || originalEventHandler(event);\n                         if (checkForDefaultPrevented === false || !event.defaultPrevented) return ourEventHandler === null || ourEventHandler === void 0 ? void 0 : ourEventHandler(event);\n                     };\n                 }\n \n                 /***/\n@@ -6757,14 +6763,15 @@\n         \"../../../node_modules/@radix-ui/react-arrow/dist/index.js\":\n             /*!*****************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-arrow/dist/index.js ***!\n               \\*****************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $eQpDd$babelruntimehelpersextends = __webpack_require__( /*! @babel/runtime/helpers/extends */ \"../../../node_modules/@babel/runtime/helpers/extends.js\");\n                 var $eQpDd$react = __webpack_require__( /*! react */ \"react\");\n                 var $eQpDd$radixuireactprimitive = __webpack_require__( /*! @radix-ui/react-primitive */ \"../../../node_modules/@radix-ui/react-primitive/dist/index.js\");\n \n                 function $parcel$export(e, n, v, s) {\n@@ -6817,14 +6824,15 @@\n         \"../../../node_modules/@radix-ui/react-collection/dist/index.js\":\n             /*!**********************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-collection/dist/index.js ***!\n               \\**********************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $hnlpS$react = __webpack_require__( /*! react */ \"react\");\n                 var $hnlpS$radixuireactcontext = __webpack_require__( /*! @radix-ui/react-context */ \"../../../node_modules/@radix-ui/react-context/dist/index.js\");\n                 var $hnlpS$radixuireactcomposerefs = __webpack_require__( /*! @radix-ui/react-compose-refs */ \"../../../node_modules/@radix-ui/react-compose-refs/dist/index.js\");\n                 var $hnlpS$radixuireactslot = __webpack_require__( /*! @radix-ui/react-slot */ \"../../../node_modules/@radix-ui/react-slot/dist/index.js\");\n \n@@ -6953,14 +6961,15 @@\n         \"../../../node_modules/@radix-ui/react-compose-refs/dist/index.js\":\n             /*!************************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-compose-refs/dist/index.js ***!\n               \\************************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $dJwbH$react = __webpack_require__( /*! react */ \"react\");\n \n                 function $parcel$export(e, n, v, s) {\n                     Object.defineProperty(e, n, {\n                         get: v,\n@@ -6980,28 +6989,22 @@\n                     if (typeof ref === 'function') ref(value);\n                     else if (ref !== null && ref !== undefined) ref.current = value;\n                 }\n                 /**\n                  * A utility to compose multiple refs together\n                  * Accepts callback refs and RefObject(s)\n                  */\n-                function $9c2aaba23466b352$export$43e446d32b3d21af() {\n-                    for (var _len = arguments.length, refs = new Array(_len), _key = 0; _key < _len; _key++) {\n-                        refs[_key] = arguments[_key];\n-                    }\n+                function $9c2aaba23466b352$export$43e446d32b3d21af(...refs) {\n                     return node => refs.forEach(ref => $9c2aaba23466b352$var$setRef(ref, node));\n                 }\n                 /**\n                  * A custom hook that composes multiple refs\n                  * Accepts callback refs and RefObject(s)\n                  */\n-                function $9c2aaba23466b352$export$c7b2cbe3552a0d05() {\n-                    for (var _len2 = arguments.length, refs = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n-                        refs[_key2] = arguments[_key2];\n-                    }\n+                function $9c2aaba23466b352$export$c7b2cbe3552a0d05(...refs) {\n                     // eslint-disable-next-line react-hooks/exhaustive-deps\n                     return $dJwbH$react.useCallback($9c2aaba23466b352$export$43e446d32b3d21af(...refs), refs);\n                 }\n \n                 /***/\n             }),\n \n@@ -7009,14 +7012,15 @@\n         \"../../../node_modules/@radix-ui/react-context/dist/index.js\":\n             /*!*******************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-context/dist/index.js ***!\n               \\*******************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $4O1Ne$react = __webpack_require__( /*! react */ \"react\");\n \n                 function $parcel$export(e, n, v, s) {\n                     Object.defineProperty(e, n, {\n                         get: v,\n@@ -7051,16 +7055,15 @@\n                     }\n                     Provider.displayName = rootComponentName + 'Provider';\n                     return [Provider, useContext];\n                 }\n                 /* -------------------------------------------------------------------------------------------------\n                  * createContextScope\n                  * -----------------------------------------------------------------------------------------------*/\n-                function $dec3cc0142d4f286$export$50c7b4e9d9f19c1(scopeName) {\n-                    let createContextScopeDeps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];\n+                function $dec3cc0142d4f286$export$50c7b4e9d9f19c1(scopeName, createContextScopeDeps = []) {\n                     let defaultContexts = [];\n                     /* -----------------------------------------------------------------------------------------------\n                      * createContext\n                      * ---------------------------------------------------------------------------------------------*/\n                     function $dec3cc0142d4f286$export$fd42f52fd3ae1109(rootComponentName, defaultContext) {\n                         const BaseContext = /*#__PURE__*/ $4O1Ne$react.createContext(defaultContext);\n                         const index = defaultContexts.length;\n@@ -7109,31 +7112,27 @@\n                     };\n                     createScope.scopeName = scopeName;\n                     return [$dec3cc0142d4f286$export$fd42f52fd3ae1109, $dec3cc0142d4f286$var$composeContextScopes(createScope, ...createContextScopeDeps)];\n                 }\n                 /* -------------------------------------------------------------------------------------------------\n                  * composeContextScopes\n                  * -----------------------------------------------------------------------------------------------*/\n-                function $dec3cc0142d4f286$var$composeContextScopes() {\n-                    for (var _len = arguments.length, scopes = new Array(_len), _key = 0; _key < _len; _key++) {\n-                        scopes[_key] = arguments[_key];\n-                    }\n+                function $dec3cc0142d4f286$var$composeContextScopes(...scopes) {\n                     const baseScope = scopes[0];\n                     if (scopes.length === 1) return baseScope;\n                     const createScope1 = () => {\n                         const scopeHooks = scopes.map(createScope => ({\n                             useScope: createScope(),\n                             scopeName: createScope.scopeName\n                         }));\n                         return function useComposedScopes(overrideScopes) {\n-                            const nextScopes1 = scopeHooks.reduce((nextScopes, _ref) => {\n-                                let {\n-                                    useScope: useScope,\n-                                    scopeName: scopeName\n-                                } = _ref;\n+                            const nextScopes1 = scopeHooks.reduce((nextScopes, {\n+                                useScope: useScope,\n+                                scopeName: scopeName\n+                            }) => {\n                                 // We are calling a hook inside a callback which React warns against to avoid inconsistent\n                                 // renders, however, scoping doesn't have render side effects so we ignore the rule.\n                                 // eslint-disable-next-line react-hooks/rules-of-hooks\n                                 const scopeProps = useScope(overrideScopes);\n                                 const currentScope = scopeProps[`__scope${scopeName}`];\n                                 return {\n                                     ...nextScopes,\n@@ -7156,14 +7155,15 @@\n         \"../../../node_modules/@radix-ui/react-dialog/dist/index.js\":\n             /*!******************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-dialog/dist/index.js ***!\n               \\******************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $aJCrN$babelruntimehelpersextends = __webpack_require__( /*! @babel/runtime/helpers/extends */ \"../../../node_modules/@babel/runtime/helpers/extends.js\");\n                 var $aJCrN$react = __webpack_require__( /*! react */ \"react\");\n                 var $aJCrN$radixuiprimitive = __webpack_require__( /*! @radix-ui/primitive */ \"../../../node_modules/@radix-ui/primitive/dist/index.js\");\n                 var $aJCrN$radixuireactcomposerefs = __webpack_require__( /*! @radix-ui/react-compose-refs */ \"../../../node_modules/@radix-ui/react-compose-refs/dist/index.js\");\n                 var $aJCrN$radixuireactcontext = __webpack_require__( /*! @radix-ui/react-context */ \"../../../node_modules/@radix-ui/react-context/dist/index.js\");\n@@ -7542,18 +7542,17 @@\n                 }\n                 const $f4833395aa1bca1a$var$TITLE_WARNING_NAME = 'DialogTitleWarning';\n                 const [$f4833395aa1bca1a$export$69b62a49393917d6, $f4833395aa1bca1a$var$useWarningContext] = $aJCrN$radixuireactcontext.createContext($f4833395aa1bca1a$var$TITLE_WARNING_NAME, {\n                     contentName: $f4833395aa1bca1a$var$CONTENT_NAME,\n                     titleName: $f4833395aa1bca1a$var$TITLE_NAME,\n                     docsSlug: 'dialog'\n                 });\n-                const $f4833395aa1bca1a$var$TitleWarning = _ref => {\n-                    let {\n-                        titleId: titleId\n-                    } = _ref;\n+                const $f4833395aa1bca1a$var$TitleWarning = ({\n+                    titleId: titleId\n+                }) => {\n                     const titleWarningContext = $f4833395aa1bca1a$var$useWarningContext($f4833395aa1bca1a$var$TITLE_WARNING_NAME);\n                     const MESSAGE = `\\`${titleWarningContext.contentName}\\` requires a \\`${titleWarningContext.titleName}\\` for the component to be accessible for screen reader users.\n \n If you want to hide the \\`${titleWarningContext.titleName}\\`, you can wrap it with our VisuallyHidden component.\n \n For more information, see https://radix-ui.com/primitives/docs/components/${titleWarningContext.docsSlug}`;\n                     $aJCrN$react.useEffect(() => {\n@@ -7561,19 +7560,18 @@\n                             const hasTitle = document.getElementById(titleId);\n                             if (!hasTitle) throw new Error(MESSAGE);\n                         }\n                     }, [MESSAGE, titleId]);\n                     return null;\n                 };\n                 const $f4833395aa1bca1a$var$DESCRIPTION_WARNING_NAME = 'DialogDescriptionWarning';\n-                const $f4833395aa1bca1a$var$DescriptionWarning = _ref2 => {\n-                    let {\n-                        contentRef: contentRef,\n-                        descriptionId: descriptionId\n-                    } = _ref2;\n+                const $f4833395aa1bca1a$var$DescriptionWarning = ({\n+                    contentRef: contentRef,\n+                    descriptionId: descriptionId\n+                }) => {\n                     const descriptionWarningContext = $f4833395aa1bca1a$var$useWarningContext($f4833395aa1bca1a$var$DESCRIPTION_WARNING_NAME);\n                     const MESSAGE = `Warning: Missing \\`Description\\` or \\`aria-describedby={undefined}\\` for {${descriptionWarningContext.contentName}}.`;\n                     $aJCrN$react.useEffect(() => {\n                         var _contentRef$current;\n                         const describedById = (_contentRef$current = contentRef.current) === null || _contentRef$current === void 0 ? void 0 : _contentRef$current.getAttribute('aria-describedby'); // if we have an id and the user hasn't set aria-describedby={undefined}\n                         if (descriptionId && describedById) {\n                             const hasDescription = document.getElementById(descriptionId);\n@@ -7598,14 +7596,15 @@\n         \"../../../node_modules/@radix-ui/react-direction/dist/index.js\":\n             /*!*********************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-direction/dist/index.js ***!\n               \\*********************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $9g4ps$react = __webpack_require__( /*! react */ \"react\");\n \n                 function $parcel$export(e, n, v, s) {\n                     Object.defineProperty(e, n, {\n                         get: v,\n@@ -7644,14 +7643,15 @@\n         \"../../../node_modules/@radix-ui/react-dismissable-layer/dist/index.js\":\n             /*!*****************************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-dismissable-layer/dist/index.js ***!\n               \\*****************************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $g2vWm$babelruntimehelpersextends = __webpack_require__( /*! @babel/runtime/helpers/extends */ \"../../../node_modules/@babel/runtime/helpers/extends.js\");\n                 var $g2vWm$react = __webpack_require__( /*! react */ \"react\");\n                 var $g2vWm$radixuiprimitive = __webpack_require__( /*! @radix-ui/primitive */ \"../../../node_modules/@radix-ui/primitive/dist/index.js\");\n                 var $g2vWm$radixuireactprimitive = __webpack_require__( /*! @radix-ui/react-primitive */ \"../../../node_modules/@radix-ui/react-primitive/dist/index.js\");\n                 var $g2vWm$radixuireactcomposerefs = __webpack_require__( /*! @radix-ui/react-compose-refs */ \"../../../node_modules/@radix-ui/react-compose-refs/dist/index.js\");\n@@ -7811,16 +7811,15 @@\n                 });\n                 /* -----------------------------------------------------------------------------------------------*/\n                 /**\n                  * Listens for `pointerdown` outside a react subtree. We use `pointerdown` rather than `pointerup`\n                  * to mimic layer dismissing behaviour present in OS.\n                  * Returns props to pass to the node we want to check for outside events.\n                  */\n-                function $d715e0554b679f1f$var$usePointerDownOutside(onPointerDownOutside) {\n-                    let ownerDocument = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : globalThis === null || globalThis === void 0 ? void 0 : globalThis.document;\n+                function $d715e0554b679f1f$var$usePointerDownOutside(onPointerDownOutside, ownerDocument = globalThis === null || globalThis === void 0 ? void 0 : globalThis.document) {\n                     const handlePointerDownOutside = $g2vWm$radixuireactusecallbackref.useCallbackRef(onPointerDownOutside);\n                     const isPointerInsideReactTreeRef = $g2vWm$react.useRef(false);\n                     const handleClickRef = $g2vWm$react.useRef(() => {});\n                     $g2vWm$react.useEffect(() => {\n                         const handlePointerDown = event => {\n                             if (event.target && !isPointerInsideReactTreeRef.current) {\n                                 const eventDetail = {\n@@ -7881,16 +7880,15 @@\n                         onPointerDownCapture: () => isPointerInsideReactTreeRef.current = true\n                     };\n                 }\n                 /**\n                  * Listens for when focus happens outside a react subtree.\n                  * Returns props to pass to the root (node) of the subtree we want to check.\n                  */\n-                function $d715e0554b679f1f$var$useFocusOutside(onFocusOutside) {\n-                    let ownerDocument = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : globalThis === null || globalThis === void 0 ? void 0 : globalThis.document;\n+                function $d715e0554b679f1f$var$useFocusOutside(onFocusOutside, ownerDocument = globalThis === null || globalThis === void 0 ? void 0 : globalThis.document) {\n                     const handleFocusOutside = $g2vWm$radixuireactusecallbackref.useCallbackRef(onFocusOutside);\n                     const isFocusInsideReactTreeRef = $g2vWm$react.useRef(false);\n                     $g2vWm$react.useEffect(() => {\n                         const handleFocus = event => {\n                             if (event.target && !isFocusInsideReactTreeRef.current) {\n                                 const eventDetail = {\n                                     originalEvent: event\n@@ -7910,18 +7908,17 @@\n                 }\n \n                 function $d715e0554b679f1f$var$dispatchUpdate() {\n                     const event = new CustomEvent($d715e0554b679f1f$var$CONTEXT_UPDATE);\n                     document.dispatchEvent(event);\n                 }\n \n-                function $d715e0554b679f1f$var$handleAndDispatchCustomEvent(name, handler, detail, _ref) {\n-                    let {\n-                        discrete: discrete\n-                    } = _ref;\n+                function $d715e0554b679f1f$var$handleAndDispatchCustomEvent(name, handler, detail, {\n+                    discrete: discrete\n+                }) {\n                     const target = detail.originalEvent.target;\n                     const event = new CustomEvent(name, {\n                         bubbles: false,\n                         cancelable: true,\n                         detail: detail\n                     });\n                     if (handler) target.addEventListener(name, handler, {\n@@ -7940,14 +7937,15 @@\n         \"../../../node_modules/@radix-ui/react-dropdown-menu/dist/index.js\":\n             /*!*************************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-dropdown-menu/dist/index.js ***!\n               \\*************************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $7dQ7Q$babelruntimehelpersextends = __webpack_require__( /*! @babel/runtime/helpers/extends */ \"../../../node_modules/@babel/runtime/helpers/extends.js\");\n                 var $7dQ7Q$react = __webpack_require__( /*! react */ \"react\");\n                 var $7dQ7Q$radixuiprimitive = __webpack_require__( /*! @radix-ui/primitive */ \"../../../node_modules/@radix-ui/primitive/dist/index.js\");\n                 var $7dQ7Q$radixuireactcomposerefs = __webpack_require__( /*! @radix-ui/react-compose-refs */ \"../../../node_modules/@radix-ui/react-compose-refs/dist/index.js\");\n                 var $7dQ7Q$radixuireactcontext = __webpack_require__( /*! @radix-ui/react-context */ \"../../../node_modules/@radix-ui/react-context/dist/index.js\");\n@@ -8405,14 +8403,15 @@\n         \"../../../node_modules/@radix-ui/react-focus-guards/dist/index.js\":\n             /*!************************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-focus-guards/dist/index.js ***!\n               \\************************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $cnctE$react = __webpack_require__( /*! react */ \"react\");\n \n                 function $parcel$export(e, n, v, s) {\n                     Object.defineProperty(e, n, {\n                         get: v,\n@@ -8466,14 +8465,15 @@\n         \"../../../node_modules/@radix-ui/react-focus-scope/dist/index.js\":\n             /*!***********************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-focus-scope/dist/index.js ***!\n               \\***********************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $buum9$babelruntimehelpersextends = __webpack_require__( /*! @babel/runtime/helpers/extends */ \"../../../node_modules/@babel/runtime/helpers/extends.js\");\n                 var $buum9$react = __webpack_require__( /*! react */ \"react\");\n                 var $buum9$radixuireactcomposerefs = __webpack_require__( /*! @radix-ui/react-compose-refs */ \"../../../node_modules/@radix-ui/react-compose-refs/dist/index.js\");\n                 var $buum9$radixuireactprimitive = __webpack_require__( /*! @radix-ui/react-primitive */ \"../../../node_modules/@radix-ui/react-primitive/dist/index.js\");\n                 var $buum9$radixuireactusecallbackref = __webpack_require__( /*! @radix-ui/react-use-callback-ref */ \"../../../node_modules/@radix-ui/react-use-callback-ref/dist/index.js\");\n@@ -8651,18 +8651,17 @@\n                 /* -------------------------------------------------------------------------------------------------\n                  * Utils\n                  * -----------------------------------------------------------------------------------------------*/\n                 /**\n                  * Attempts focusing the first element in a list of candidates.\n                  * Stops when focus has actually moved.\n                  */\n-                function $2bc01e66e04aa9ed$var$focusFirst(candidates) {\n-                    let {\n-                        select = false\n-                    } = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n+                function $2bc01e66e04aa9ed$var$focusFirst(candidates, {\n+                    select = false\n+                } = {}) {\n                     const previouslyFocusedElement = document.activeElement;\n                     for (const candidate of candidates) {\n                         $2bc01e66e04aa9ed$var$focus(candidate, {\n                             select: select\n                         });\n                         if (document.activeElement !== previouslyFocusedElement) return;\n                     }\n@@ -8710,36 +8709,34 @@\n                         // we stop checking if it's hidden at the `container` level (excluding)\n                         if (!$2bc01e66e04aa9ed$var$isHidden(element, {\n                                 upTo: container\n                             })) return element;\n                     }\n                 }\n \n-                function $2bc01e66e04aa9ed$var$isHidden(node, _ref) {\n-                    let {\n-                        upTo: upTo\n-                    } = _ref;\n+                function $2bc01e66e04aa9ed$var$isHidden(node, {\n+                    upTo: upTo\n+                }) {\n                     if (getComputedStyle(node).visibility === 'hidden') return true;\n                     while (node) {\n                         // we stop at `upTo` (excluding it)\n                         if (upTo !== undefined && node === upTo) return false;\n                         if (getComputedStyle(node).display === 'none') return true;\n                         node = node.parentElement;\n                     }\n                     return false;\n                 }\n \n                 function $2bc01e66e04aa9ed$var$isSelectableInput(element) {\n                     return element instanceof HTMLInputElement && 'select' in element;\n                 }\n \n-                function $2bc01e66e04aa9ed$var$focus(element) {\n-                    let {\n-                        select = false\n-                    } = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n+                function $2bc01e66e04aa9ed$var$focus(element, {\n+                    select = false\n+                } = {}) {\n                     // only focus if that element is focusable\n                     if (element && element.focus) {\n                         const previouslyFocusedElement = document.activeElement; // NOTE: we prevent scrolling on focus, to minimize jarring transitions for users\n                         element.focus({\n                             preventScroll: true\n                         }); // only select if its not the same element, it supports selection and we need to select\n                         if (element !== previouslyFocusedElement && $2bc01e66e04aa9ed$var$isSelectableInput(element) && select) element.select();\n@@ -8789,14 +8786,15 @@\n         \"../../../node_modules/@radix-ui/react-id/dist/index.js\":\n             /*!**************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-id/dist/index.js ***!\n               \\**************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $47woD$react = __webpack_require__( /*! react */ \"react\");\n                 var $47woD$radixuireactuselayouteffect = __webpack_require__( /*! @radix-ui/react-use-layout-effect */ \"../../../node_modules/@radix-ui/react-use-layout-effect/dist/index.js\");\n \n                 function $parcel$export(e, n, v, s) {\n                     Object.defineProperty(e, n, {\n@@ -8825,14 +8823,15 @@\n         \"../../../node_modules/@radix-ui/react-menu/dist/index.js\":\n             /*!****************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-menu/dist/index.js ***!\n               \\****************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $cnSS2$babelruntimehelpersextends = __webpack_require__( /*! @babel/runtime/helpers/extends */ \"../../../node_modules/@babel/runtime/helpers/extends.js\");\n                 var $cnSS2$react = __webpack_require__( /*! react */ \"react\");\n                 var $cnSS2$radixuiprimitive = __webpack_require__( /*! @radix-ui/primitive */ \"../../../node_modules/@radix-ui/primitive/dist/index.js\");\n                 var $cnSS2$radixuireactcollection = __webpack_require__( /*! @radix-ui/react-collection */ \"../../../node_modules/@radix-ui/react-collection/dist/index.js\");\n                 var $cnSS2$radixuireactcomposerefs = __webpack_require__( /*! @radix-ui/react-compose-refs */ \"../../../node_modules/@radix-ui/react-compose-refs/dist/index.js\");\n@@ -9905,14 +9904,15 @@\n         \"../../../node_modules/@radix-ui/react-popper/dist/index.js\":\n             /*!******************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-popper/dist/index.js ***!\n               \\******************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $50Iv9$babelruntimehelpersextends = __webpack_require__( /*! @babel/runtime/helpers/extends */ \"../../../node_modules/@babel/runtime/helpers/extends.js\");\n                 var $50Iv9$react = __webpack_require__( /*! react */ \"react\");\n                 var $50Iv9$floatinguireactdom = __webpack_require__( /*! @floating-ui/react-dom */ \"../../../node_modules/@floating-ui/react-dom/dist/floating-ui.react-dom.esm.js\");\n                 var $50Iv9$radixuireactarrow = __webpack_require__( /*! @radix-ui/react-arrow */ \"../../../node_modules/@radix-ui/react-arrow/dist/index.js\");\n                 var $50Iv9$radixuireactcomposerefs = __webpack_require__( /*! @radix-ui/react-compose-refs */ \"../../../node_modules/@radix-ui/react-compose-refs/dist/index.js\");\n@@ -10063,21 +10063,20 @@\n                             crossAxis: false,\n                             limiter: sticky === 'partial' ? $50Iv9$floatinguireactdom.limitShift() : undefined,\n                             ...detectOverflowOptions\n                         }), avoidCollisions && $50Iv9$floatinguireactdom.flip({\n                             ...detectOverflowOptions\n                         }), $50Iv9$floatinguireactdom.size({\n                             ...detectOverflowOptions,\n-                            apply: _ref => {\n-                                let {\n-                                    elements: elements,\n-                                    rects: rects,\n-                                    availableWidth: availableWidth,\n-                                    availableHeight: availableHeight\n-                                } = _ref;\n+                            apply: ({\n+                                elements: elements,\n+                                rects: rects,\n+                                availableWidth: availableWidth,\n+                                availableHeight: availableHeight\n+                            }) => {\n                                 const {\n                                     width: anchorWidth,\n                                     height: anchorHeight\n                                 } = rects.reference;\n                                 const contentStyle = elements.floating.style;\n                                 contentStyle.setProperty('--radix-popper-available-width', `${availableWidth}px`);\n                                 contentStyle.setProperty('--radix-popper-available-height', `${availableHeight}px`);\n@@ -10267,14 +10266,15 @@\n         \"../../../node_modules/@radix-ui/react-portal/dist/index.js\":\n             /*!******************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-portal/dist/index.js ***!\n               \\******************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $amzHf$babelruntimehelpersextends = __webpack_require__( /*! @babel/runtime/helpers/extends */ \"../../../node_modules/@babel/runtime/helpers/extends.js\");\n                 var $amzHf$react = __webpack_require__( /*! react */ \"react\");\n                 var $amzHf$reactdom = __webpack_require__( /*! react-dom */ \"react-dom\");\n                 var $amzHf$radixuireactprimitive = __webpack_require__( /*! @radix-ui/react-primitive */ \"../../../node_modules/@radix-ui/react-primitive/dist/index.js\");\n \n@@ -10321,14 +10321,15 @@\n         \"../../../node_modules/@radix-ui/react-presence/dist/index.js\":\n             /*!********************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-presence/dist/index.js ***!\n               \\********************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $fnLeV$react = __webpack_require__( /*! react */ \"react\");\n                 var $fnLeV$reactdom = __webpack_require__( /*! react-dom */ \"react-dom\");\n                 var $fnLeV$radixuireactcomposerefs = __webpack_require__( /*! @radix-ui/react-compose-refs */ \"../../../node_modules/@radix-ui/react-compose-refs/dist/index.js\");\n                 var $fnLeV$radixuireactuselayouteffect = __webpack_require__( /*! @radix-ui/react-use-layout-effect */ \"../../../node_modules/@radix-ui/react-use-layout-effect/dist/index.js\");\n \n@@ -10470,14 +10471,15 @@\n         \"../../../node_modules/@radix-ui/react-primitive/dist/index.js\":\n             /*!*********************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-primitive/dist/index.js ***!\n               \\*********************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $iMixA$babelruntimehelpersextends = __webpack_require__( /*! @babel/runtime/helpers/extends */ \"../../../node_modules/@babel/runtime/helpers/extends.js\");\n                 var $iMixA$react = __webpack_require__( /*! react */ \"react\");\n                 var $iMixA$reactdom = __webpack_require__( /*! react-dom */ \"react-dom\");\n                 var $iMixA$radixuireactslot = __webpack_require__( /*! @radix-ui/react-slot */ \"../../../node_modules/@radix-ui/react-slot/dist/index.js\");\n \n@@ -10574,14 +10576,15 @@\n         \"../../../node_modules/@radix-ui/react-roving-focus/dist/index.js\":\n             /*!************************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-roving-focus/dist/index.js ***!\n               \\************************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $9QJ9Y$babelruntimehelpersextends = __webpack_require__( /*! @babel/runtime/helpers/extends */ \"../../../node_modules/@babel/runtime/helpers/extends.js\");\n                 var $9QJ9Y$react = __webpack_require__( /*! react */ \"react\");\n                 var $9QJ9Y$radixuiprimitive = __webpack_require__( /*! @radix-ui/primitive */ \"../../../node_modules/@radix-ui/primitive/dist/index.js\");\n                 var $9QJ9Y$radixuireactcollection = __webpack_require__( /*! @radix-ui/react-collection */ \"../../../node_modules/@radix-ui/react-collection/dist/index.js\");\n                 var $9QJ9Y$radixuireactcomposerefs = __webpack_require__( /*! @radix-ui/react-compose-refs */ \"../../../node_modules/@radix-ui/react-compose-refs/dist/index.js\");\n@@ -10836,14 +10839,15 @@\n         \"../../../node_modules/@radix-ui/react-slot/dist/index.js\":\n             /*!****************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-slot/dist/index.js ***!\n               \\****************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $dAvBt$babelruntimehelpersextends = __webpack_require__( /*! @babel/runtime/helpers/extends */ \"../../../node_modules/@babel/runtime/helpers/extends.js\");\n                 var $dAvBt$react = __webpack_require__( /*! react */ \"react\");\n                 var $dAvBt$radixuireactcomposerefs = __webpack_require__( /*! @radix-ui/react-compose-refs */ \"../../../node_modules/@radix-ui/react-compose-refs/dist/index.js\");\n \n                 function $parcel$export(e, n, v, s) {\n@@ -10906,18 +10910,17 @@\n                     });\n                     return $dAvBt$react.Children.count(children) > 1 ? $dAvBt$react.Children.only(null) : null;\n                 });\n                 $82dc8d030dec7549$var$SlotClone.displayName = 'SlotClone';\n                 /* -------------------------------------------------------------------------------------------------\n                  * Slottable\n                  * -----------------------------------------------------------------------------------------------*/\n-                const $82dc8d030dec7549$export$d9f1ccf0bdb05d45 = _ref => {\n-                    let {\n-                        children: children\n-                    } = _ref;\n+                const $82dc8d030dec7549$export$d9f1ccf0bdb05d45 = ({\n+                    children: children\n+                }) => {\n                     return /*#__PURE__*/ $dAvBt$react.createElement($dAvBt$react.Fragment, null, children);\n                 };\n                 /* ---------------------------------------------------------------------------------------------- */\n                 function $82dc8d030dec7549$var$isSlottable(child) {\n                     return /*#__PURE__*/ $dAvBt$react.isValidElement(child) && child.type === $82dc8d030dec7549$export$d9f1ccf0bdb05d45;\n                 }\n \n@@ -10928,17 +10931,17 @@\n                     };\n                     for (const propName in childProps) {\n                         const slotPropValue = slotProps[propName];\n                         const childPropValue = childProps[propName];\n                         const isHandler = /^on[A-Z]/.test(propName);\n                         if (isHandler) {\n                             // if the handler exists on both, we compose them\n-                            if (slotPropValue && childPropValue) overrideProps[propName] = function() {\n-                                childPropValue(...arguments);\n-                                slotPropValue(...arguments);\n+                            if (slotPropValue && childPropValue) overrideProps[propName] = (...args) => {\n+                                childPropValue(...args);\n+                                slotPropValue(...args);\n                             };\n                             else if (slotPropValue) overrideProps[propName] = slotPropValue;\n                         } else if (propName === 'style') overrideProps[propName] = {\n                             ...slotPropValue,\n                             ...childPropValue\n                         };\n                         else if (propName === 'className') overrideProps[propName] = [slotPropValue, childPropValue].filter(Boolean).join(' ');\n@@ -10957,14 +10960,15 @@\n         \"../../../node_modules/@radix-ui/react-tooltip/dist/index.js\":\n             /*!*******************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-tooltip/dist/index.js ***!\n               \\*******************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $iVrL9$babelruntimehelpersextends = __webpack_require__( /*! @babel/runtime/helpers/extends */ \"../../../node_modules/@babel/runtime/helpers/extends.js\");\n                 var $iVrL9$react = __webpack_require__( /*! react */ \"react\");\n                 var $iVrL9$radixuiprimitive = __webpack_require__( /*! @radix-ui/primitive */ \"../../../node_modules/@radix-ui/primitive/dist/index.js\");\n                 var $iVrL9$radixuireactcomposerefs = __webpack_require__( /*! @radix-ui/react-compose-refs */ \"../../../node_modules/@radix-ui/react-compose-refs/dist/index.js\");\n                 var $iVrL9$radixuireactcontext = __webpack_require__( /*! @radix-ui/react-context */ \"../../../node_modules/@radix-ui/react-context/dist/index.js\");\n@@ -11415,16 +11419,15 @@\n                         case bottom:\n                             return 'bottom';\n                         default:\n                             throw new Error('unreachable');\n                     }\n                 }\n \n-                function $c34afbc43c90cc6f$var$getPaddedExitPoints(exitPoint, exitSide) {\n-                    let padding = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 5;\n+                function $c34afbc43c90cc6f$var$getPaddedExitPoints(exitPoint, exitSide, padding = 5) {\n                     const paddedExitPoints = [];\n                     switch (exitSide) {\n                         case 'top':\n                             paddedExitPoints.push({\n                                 x: exitPoint.x - padding,\n                                 y: exitPoint.y + padding\n                             }, {\n@@ -11556,14 +11559,15 @@\n         \"../../../node_modules/@radix-ui/react-use-callback-ref/dist/index.js\":\n             /*!****************************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-use-callback-ref/dist/index.js ***!\n               \\****************************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $92muK$react = __webpack_require__( /*! react */ \"react\");\n \n                 function $parcel$export(e, n, v, s) {\n                     Object.defineProperty(e, n, {\n                         get: v,\n@@ -11579,19 +11583,16 @@\n                  * prop or avoid re-executing effects when passed as a dependency\n                  */\n                 function $28e03942f763e819$export$25bec8c6f54ee79a(callback) {\n                     const callbackRef = $92muK$react.useRef(callback);\n                     $92muK$react.useEffect(() => {\n                         callbackRef.current = callback;\n                     }); // https://github.com/facebook/react/issues/19240\n-                    return $92muK$react.useMemo(() => function() {\n+                    return $92muK$react.useMemo(() => (...args) => {\n                         var _callbackRef$current;\n-                        for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n-                            args[_key] = arguments[_key];\n-                        }\n                         return (_callbackRef$current = callbackRef.current) === null || _callbackRef$current === void 0 ? void 0 : _callbackRef$current.call(callbackRef, ...args);\n                     }, []);\n                 }\n \n                 /***/\n             }),\n \n@@ -11599,14 +11600,15 @@\n         \"../../../node_modules/@radix-ui/react-use-controllable-state/dist/index.js\":\n             /*!**********************************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-use-controllable-state/dist/index.js ***!\n               \\**********************************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $ijazI$react = __webpack_require__( /*! react */ \"react\");\n                 var $ijazI$radixuireactusecallbackref = __webpack_require__( /*! @radix-ui/react-use-callback-ref */ \"../../../node_modules/@radix-ui/react-use-callback-ref/dist/index.js\");\n \n                 function $parcel$export(e, n, v, s) {\n                     Object.defineProperty(e, n, {\n@@ -11614,20 +11616,19 @@\n                         set: s,\n                         enumerable: true,\n                         configurable: true\n                     });\n                 }\n                 $parcel$export(module.exports, \"useControllableState\", () => $b84d42d44371bff7$export$6f32135080cb4c3);\n \n-                function $b84d42d44371bff7$export$6f32135080cb4c3(_ref) {\n-                    let {\n-                        prop: prop,\n-                        defaultProp: defaultProp,\n-                        onChange = () => {}\n-                    } = _ref;\n+                function $b84d42d44371bff7$export$6f32135080cb4c3({\n+                    prop: prop,\n+                    defaultProp: defaultProp,\n+                    onChange = () => {}\n+                }) {\n                     const [uncontrolledProp, setUncontrolledProp] = $b84d42d44371bff7$var$useUncontrolledState({\n                         defaultProp: defaultProp,\n                         onChange: onChange\n                     });\n                     const isControlled = prop !== undefined;\n                     const value1 = isControlled ? prop : uncontrolledProp;\n                     const handleChange = $ijazI$radixuireactusecallbackref.useCallbackRef(onChange);\n@@ -11637,19 +11638,18 @@\n                             const value = typeof nextValue === 'function' ? setter(prop) : nextValue;\n                             if (value !== prop) handleChange(value);\n                         } else setUncontrolledProp(nextValue);\n                     }, [isControlled, prop, setUncontrolledProp, handleChange]);\n                     return [value1, setValue];\n                 }\n \n-                function $b84d42d44371bff7$var$useUncontrolledState(_ref2) {\n-                    let {\n-                        defaultProp: defaultProp,\n-                        onChange: onChange\n-                    } = _ref2;\n+                function $b84d42d44371bff7$var$useUncontrolledState({\n+                    defaultProp: defaultProp,\n+                    onChange: onChange\n+                }) {\n                     const uncontrolledState = $ijazI$react.useState(defaultProp);\n                     const [value] = uncontrolledState;\n                     const prevValueRef = $ijazI$react.useRef(value);\n                     const handleChange = $ijazI$radixuireactusecallbackref.useCallbackRef(onChange);\n                     $ijazI$react.useEffect(() => {\n                         if (prevValueRef.current !== value) {\n                             handleChange(value);\n@@ -11666,14 +11666,15 @@\n         \"../../../node_modules/@radix-ui/react-use-escape-keydown/dist/index.js\":\n             /*!******************************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-use-escape-keydown/dist/index.js ***!\n               \\******************************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $b0gz3$react = __webpack_require__( /*! react */ \"react\");\n                 var $b0gz3$radixuireactusecallbackref = __webpack_require__( /*! @radix-ui/react-use-callback-ref */ \"../../../node_modules/@radix-ui/react-use-callback-ref/dist/index.js\");\n \n                 function $parcel$export(e, n, v, s) {\n                     Object.defineProperty(e, n, {\n@@ -11684,16 +11685,15 @@\n                     });\n                 }\n                 $parcel$export(module.exports, \"useEscapeKeydown\", () => $24c84e9f83c4454f$export$3a72a57244d6e765);\n \n                 /**\n                  * Listens for when the escape key is down\n                  */\n-                function $24c84e9f83c4454f$export$3a72a57244d6e765(onEscapeKeyDownProp) {\n-                    let ownerDocument = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : globalThis === null || globalThis === void 0 ? void 0 : globalThis.document;\n+                function $24c84e9f83c4454f$export$3a72a57244d6e765(onEscapeKeyDownProp, ownerDocument = globalThis === null || globalThis === void 0 ? void 0 : globalThis.document) {\n                     const onEscapeKeyDown = $b0gz3$radixuireactusecallbackref.useCallbackRef(onEscapeKeyDownProp);\n                     $b0gz3$react.useEffect(() => {\n                         const handleKeyDown = event => {\n                             if (event.key === 'Escape') onEscapeKeyDown(event);\n                         };\n                         ownerDocument.addEventListener('keydown', handleKeyDown);\n                         return () => ownerDocument.removeEventListener('keydown', handleKeyDown);\n@@ -11707,14 +11707,15 @@\n         \"../../../node_modules/@radix-ui/react-use-layout-effect/dist/index.js\":\n             /*!*****************************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-use-layout-effect/dist/index.js ***!\n               \\*****************************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $caHyQ$react = __webpack_require__( /*! react */ \"react\");\n \n                 function $parcel$export(e, n, v, s) {\n                     Object.defineProperty(e, n, {\n                         get: v,\n@@ -11741,14 +11742,15 @@\n         \"../../../node_modules/@radix-ui/react-use-size/dist/index.js\":\n             /*!********************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-use-size/dist/index.js ***!\n               \\********************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $ksDzM$react = __webpack_require__( /*! react */ \"react\");\n                 var $ksDzM$radixuireactuselayouteffect = __webpack_require__( /*! @radix-ui/react-use-layout-effect */ \"../../../node_modules/@radix-ui/react-use-layout-effect/dist/index.js\");\n \n                 function $parcel$export(e, n, v, s) {\n                     Object.defineProperty(e, n, {\n@@ -11812,14 +11814,15 @@\n         \"../../../node_modules/@radix-ui/react-visually-hidden/dist/index.js\":\n             /*!***************************************************************************!*\\\n               !*** ../../../node_modules/@radix-ui/react-visually-hidden/dist/index.js ***!\n               \\***************************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 var $awrN2$babelruntimehelpersextends = __webpack_require__( /*! @babel/runtime/helpers/extends */ \"../../../node_modules/@babel/runtime/helpers/extends.js\");\n                 var $awrN2$react = __webpack_require__( /*! react */ \"react\");\n                 var $awrN2$radixuireactprimitive = __webpack_require__( /*! @radix-ui/react-primitive */ \"../../../node_modules/@radix-ui/react-primitive/dist/index.js\");\n \n                 function $parcel$export(e, n, v, s) {\n@@ -11874,14 +11877,15 @@\n         \"../../../node_modules/aria-hidden/dist/es2015/index.js\":\n             /*!**************************************************************!*\\\n               !*** ../../../node_modules/aria-hidden/dist/es2015/index.js ***!\n               \\**************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.suppressOthers = exports.supportsInert = exports.inertOthers = exports.hideOthers = void 0;\n                 var getDefaultParent = function(originalTarget) {\n@@ -12066,14 +12070,15 @@\n         \"../../../node_modules/clsx/dist/clsx.m.js\":\n             /*!*************************************************!*\\\n               !*** ../../../node_modules/clsx/dist/clsx.m.js ***!\n               \\*************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.clsx = clsx;\n                 exports[\"default\"] = void 0;\n@@ -12091,15268 +12096,33353 @@\n                     return n;\n                 }\n \n                 function clsx() {\n                     for (var e, t, f = 0, n = \"\"; f < arguments.length;)(e = arguments[f++]) && (t = r(e)) && (n && (n += \" \"), n += t);\n                     return n;\n                 }\n-                var _default = clsx;\n-                exports[\"default\"] = _default;\n+                var _default = exports[\"default\"] = clsx;\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/copy-to-clipboard/index.js\":\n-            /*!********************************************************!*\\\n-              !*** ../../../node_modules/copy-to-clipboard/index.js ***!\n-              \\********************************************************/\n+        \"../../../node_modules/codemirror/addon/comment/comment.js\":\n+            /*!*****************************************************************!*\\\n+              !*** ../../../node_modules/codemirror/addon/comment/comment.js ***!\n+              \\*****************************************************************/\n             /***/\n-            (function(module, __unused_webpack_exports, __webpack_require__) {\n-\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n-                var deselectCurrent = __webpack_require__( /*! toggle-selection */ \"../../../node_modules/toggle-selection/index.js\");\n-                var clipboardToIE11Formatting = {\n-                    \"text/plain\": \"Text\",\n-                    \"text/html\": \"Url\",\n-                    \"default\": \"Text\"\n-                };\n-                var defaultMessage = \"Copy to clipboard: #{key}, Enter\";\n \n-                function format(message) {\n-                    var copyKey = (/mac os x/i.test(navigator.userAgent) ? \"\u2318\" : \"Ctrl\") + \"+C\";\n-                    return message.replace(/#{\\s*key\\s*}/g, copyKey);\n-                }\n+                // CodeMirror, copyright (c) by Marijn Haverbeke and others\n+                // Distributed under an MIT license: https://codemirror.net/LICENSE\n \n-                function copy(text, options) {\n-                    var debug,\n-                        message,\n-                        reselectPrevious,\n-                        range,\n-                        selection,\n-                        mark,\n-                        success = false;\n-                    if (!options) {\n-                        options = {};\n-                    }\n-                    debug = options.debug || false;\n-                    try {\n-                        reselectPrevious = deselectCurrent();\n-                        range = document.createRange();\n-                        selection = document.getSelection();\n-                        mark = document.createElement(\"span\");\n-                        mark.textContent = text;\n-                        // avoid screen readers from reading out loud the text\n-                        mark.ariaHidden = \"true\";\n-                        // reset user styles for span element\n-                        mark.style.all = \"unset\";\n-                        // prevents scrolling to the end of the page\n-                        mark.style.position = \"fixed\";\n-                        mark.style.top = 0;\n-                        mark.style.clip = \"rect(0, 0, 0, 0)\";\n-                        // used to preserve spaces and line breaks\n-                        mark.style.whiteSpace = \"pre\";\n-                        // do not inherit user-select (it may be `none`)\n-                        mark.style.webkitUserSelect = \"text\";\n-                        mark.style.MozUserSelect = \"text\";\n-                        mark.style.msUserSelect = \"text\";\n-                        mark.style.userSelect = \"text\";\n-                        mark.addEventListener(\"copy\", function(e) {\n-                            e.stopPropagation();\n-                            if (options.format) {\n-                                e.preventDefault();\n-                                if (typeof e.clipboardData === \"undefined\") {\n-                                    // IE 11\n-                                    debug && console.warn(\"unable to use e.clipboardData\");\n-                                    debug && console.warn(\"trying IE specific stuff\");\n-                                    window.clipboardData.clearData();\n-                                    var format = clipboardToIE11Formatting[options.format] || clipboardToIE11Formatting[\"default\"];\n-                                    window.clipboardData.setData(format, text);\n-                                } else {\n-                                    // all other browsers\n-                                    e.clipboardData.clearData();\n-                                    e.clipboardData.setData(options.format, text);\n+                (function(mod) {\n+                    if (true)\n+                        // CommonJS\n+                        mod(__webpack_require__( /*! ../../lib/codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"));\n+                    else {}\n+                })(function(CodeMirror) {\n+                    \"use strict\";\n+\n+                    var noOptions = {};\n+                    var nonWS = /[^\\s\\u00a0]/;\n+                    var Pos = CodeMirror.Pos,\n+                        cmp = CodeMirror.cmpPos;\n+\n+                    function firstNonWS(str) {\n+                        var found = str.search(nonWS);\n+                        return found == -1 ? 0 : found;\n+                    }\n+                    CodeMirror.commands.toggleComment = function(cm) {\n+                        cm.toggleComment();\n+                    };\n+                    CodeMirror.defineExtension(\"toggleComment\", function(options) {\n+                        if (!options) options = noOptions;\n+                        var cm = this;\n+                        var minLine = Infinity,\n+                            ranges = this.listSelections(),\n+                            mode = null;\n+                        for (var i = ranges.length - 1; i >= 0; i--) {\n+                            var from = ranges[i].from(),\n+                                to = ranges[i].to();\n+                            if (from.line >= minLine) continue;\n+                            if (to.line >= minLine) to = Pos(minLine, 0);\n+                            minLine = from.line;\n+                            if (mode == null) {\n+                                if (cm.uncomment(from, to, options)) mode = \"un\";\n+                                else {\n+                                    cm.lineComment(from, to, options);\n+                                    mode = \"line\";\n                                 }\n+                            } else if (mode == \"un\") {\n+                                cm.uncomment(from, to, options);\n+                            } else {\n+                                cm.lineComment(from, to, options);\n                             }\n-                            if (options.onCopy) {\n-                                e.preventDefault();\n-                                options.onCopy(e.clipboardData);\n-                            }\n-                        });\n-                        document.body.appendChild(mark);\n-                        range.selectNodeContents(mark);\n-                        selection.addRange(range);\n-                        var successful = document.execCommand(\"copy\");\n-                        if (!successful) {\n-                            throw new Error(\"copy command was unsuccessful\");\n                         }\n-                        success = true;\n-                    } catch (err) {\n-                        debug && console.error(\"unable to copy using execCommand: \", err);\n-                        debug && console.warn(\"trying IE specific stuff\");\n-                        try {\n-                            window.clipboardData.setData(options.format || \"text\", text);\n-                            options.onCopy && options.onCopy(window.clipboardData);\n-                            success = true;\n-                        } catch (err) {\n-                            debug && console.error(\"unable to copy using clipboardData: \", err);\n-                            debug && console.error(\"falling back to prompt\");\n-                            message = format(\"message\" in options ? options.message : defaultMessage);\n-                            window.prompt(message, text);\n+                    });\n+\n+                    // Rough heuristic to try and detect lines that are part of multi-line string\n+                    function probablyInsideString(cm, pos, line) {\n+                        return /\\bstring\\b/.test(cm.getTokenTypeAt(Pos(pos.line, 0))) && !/^[\\'\\\"\\`]/.test(line);\n+                    }\n+\n+                    function getMode(cm, pos) {\n+                        var mode = cm.getMode();\n+                        return mode.useInnerComments === false || !mode.innerMode ? mode : cm.getModeAt(pos);\n+                    }\n+                    CodeMirror.defineExtension(\"lineComment\", function(from, to, options) {\n+                        if (!options) options = noOptions;\n+                        var self = this,\n+                            mode = getMode(self, from);\n+                        var firstLine = self.getLine(from.line);\n+                        if (firstLine == null || probablyInsideString(self, from, firstLine)) return;\n+                        var commentString = options.lineComment || mode.lineComment;\n+                        if (!commentString) {\n+                            if (options.blockCommentStart || mode.blockCommentStart) {\n+                                options.fullLines = true;\n+                                self.blockComment(from, to, options);\n+                            }\n+                            return;\n                         }\n-                    } finally {\n-                        if (selection) {\n-                            if (typeof selection.removeRange == \"function\") {\n-                                selection.removeRange(range);\n+                        var end = Math.min(to.ch != 0 || to.line == from.line ? to.line + 1 : to.line, self.lastLine() + 1);\n+                        var pad = options.padding == null ? \" \" : options.padding;\n+                        var blankLines = options.commentBlankLines || from.line == to.line;\n+                        self.operation(function() {\n+                            if (options.indent) {\n+                                var baseString = null;\n+                                for (var i = from.line; i < end; ++i) {\n+                                    var line = self.getLine(i);\n+                                    var whitespace = line.slice(0, firstNonWS(line));\n+                                    if (baseString == null || baseString.length > whitespace.length) {\n+                                        baseString = whitespace;\n+                                    }\n+                                }\n+                                for (var i = from.line; i < end; ++i) {\n+                                    var line = self.getLine(i),\n+                                        cut = baseString.length;\n+                                    if (!blankLines && !nonWS.test(line)) continue;\n+                                    if (line.slice(0, cut) != baseString) cut = firstNonWS(line);\n+                                    self.replaceRange(baseString + commentString + pad, Pos(i, 0), Pos(i, cut));\n+                                }\n                             } else {\n-                                selection.removeAllRanges();\n+                                for (var i = from.line; i < end; ++i) {\n+                                    if (blankLines || nonWS.test(self.getLine(i))) self.replaceRange(commentString + pad, Pos(i, 0));\n+                                }\n                             }\n+                        });\n+                    });\n+                    CodeMirror.defineExtension(\"blockComment\", function(from, to, options) {\n+                        if (!options) options = noOptions;\n+                        var self = this,\n+                            mode = getMode(self, from);\n+                        var startString = options.blockCommentStart || mode.blockCommentStart;\n+                        var endString = options.blockCommentEnd || mode.blockCommentEnd;\n+                        if (!startString || !endString) {\n+                            if ((options.lineComment || mode.lineComment) && options.fullLines != false) self.lineComment(from, to, options);\n+                            return;\n                         }\n-                        if (mark) {\n-                            document.body.removeChild(mark);\n-                        }\n-                        reselectPrevious();\n-                    }\n-                    return success;\n-                }\n-                module.exports = copy;\n+                        if (/\\bcomment\\b/.test(self.getTokenTypeAt(Pos(from.line, 0)))) return;\n+                        var end = Math.min(to.line, self.lastLine());\n+                        if (end != from.line && to.ch == 0 && nonWS.test(self.getLine(end))) --end;\n+                        var pad = options.padding == null ? \" \" : options.padding;\n+                        if (from.line > end) return;\n+                        self.operation(function() {\n+                            if (options.fullLines != false) {\n+                                var lastLineHasText = nonWS.test(self.getLine(end));\n+                                self.replaceRange(pad + endString, Pos(end));\n+                                self.replaceRange(startString + pad, Pos(from.line, 0));\n+                                var lead = options.blockCommentLead || mode.blockCommentLead;\n+                                if (lead != null)\n+                                    for (var i = from.line + 1; i <= end; ++i)\n+                                        if (i != end || lastLineHasText) self.replaceRange(lead + pad, Pos(i, 0));\n+                            } else {\n+                                var atCursor = cmp(self.getCursor(\"to\"), to) == 0,\n+                                    empty = !self.somethingSelected();\n+                                self.replaceRange(endString, to);\n+                                if (atCursor) self.setSelection(empty ? to : self.getCursor(\"from\"), to);\n+                                self.replaceRange(startString, from);\n+                            }\n+                        });\n+                    });\n+                    CodeMirror.defineExtension(\"uncomment\", function(from, to, options) {\n+                        if (!options) options = noOptions;\n+                        var self = this,\n+                            mode = getMode(self, from);\n+                        var end = Math.min(to.ch != 0 || to.line == from.line ? to.line : to.line - 1, self.lastLine()),\n+                            start = Math.min(from.line, end);\n+\n+                        // Try finding line comments\n+                        var lineString = options.lineComment || mode.lineComment,\n+                            lines = [];\n+                        var pad = options.padding == null ? \" \" : options.padding,\n+                            didSomething;\n+                        lineComment: {\n+                            if (!lineString) break lineComment;\n+                            for (var i = start; i <= end; ++i) {\n+                                var line = self.getLine(i);\n+                                var found = line.indexOf(lineString);\n+                                if (found > -1 && !/comment/.test(self.getTokenTypeAt(Pos(i, found + 1)))) found = -1;\n+                                if (found == -1 && nonWS.test(line)) break lineComment;\n+                                if (found > -1 && nonWS.test(line.slice(0, found))) break lineComment;\n+                                lines.push(line);\n+                            }\n+                            self.operation(function() {\n+                                for (var i = start; i <= end; ++i) {\n+                                    var line = lines[i - start];\n+                                    var pos = line.indexOf(lineString),\n+                                        endPos = pos + lineString.length;\n+                                    if (pos < 0) continue;\n+                                    if (line.slice(endPos, endPos + pad.length) == pad) endPos += pad.length;\n+                                    didSomething = true;\n+                                    self.replaceRange(\"\", Pos(i, pos), Pos(i, endPos));\n+                                }\n+                            });\n+                            if (didSomething) return true;\n+                        }\n+\n+                        // Try block comments\n+                        var startString = options.blockCommentStart || mode.blockCommentStart;\n+                        var endString = options.blockCommentEnd || mode.blockCommentEnd;\n+                        if (!startString || !endString) return false;\n+                        var lead = options.blockCommentLead || mode.blockCommentLead;\n+                        var startLine = self.getLine(start),\n+                            open = startLine.indexOf(startString);\n+                        if (open == -1) return false;\n+                        var endLine = end == start ? startLine : self.getLine(end);\n+                        var close = endLine.indexOf(endString, end == start ? open + startString.length : 0);\n+                        var insideStart = Pos(start, open + 1),\n+                            insideEnd = Pos(end, close + 1);\n+                        if (close == -1 || !/comment/.test(self.getTokenTypeAt(insideStart)) || !/comment/.test(self.getTokenTypeAt(insideEnd)) || self.getRange(insideStart, insideEnd, \"\\n\").indexOf(endString) > -1) return false;\n+\n+                        // Avoid killing block comments completely outside the selection.\n+                        // Positions of the last startString before the start of the selection, and the first endString after it.\n+                        var lastStart = startLine.lastIndexOf(startString, from.ch);\n+                        var firstEnd = lastStart == -1 ? -1 : startLine.slice(0, from.ch).indexOf(endString, lastStart + startString.length);\n+                        if (lastStart != -1 && firstEnd != -1 && firstEnd + endString.length != from.ch) return false;\n+                        // Positions of the first endString after the end of the selection, and the last startString before it.\n+                        firstEnd = endLine.indexOf(endString, to.ch);\n+                        var almostLastStart = endLine.slice(to.ch).lastIndexOf(startString, firstEnd - to.ch);\n+                        lastStart = firstEnd == -1 || almostLastStart == -1 ? -1 : to.ch + almostLastStart;\n+                        if (firstEnd != -1 && lastStart != -1 && lastStart != to.ch) return false;\n+                        self.operation(function() {\n+                            self.replaceRange(\"\", Pos(end, close - (pad && endLine.slice(close - pad.length, close) == pad ? pad.length : 0)), Pos(end, close + endString.length));\n+                            var openEnd = open + startString.length;\n+                            if (pad && startLine.slice(openEnd, openEnd + pad.length) == pad) openEnd += pad.length;\n+                            self.replaceRange(\"\", Pos(start, open), Pos(start, openEnd));\n+                            if (lead)\n+                                for (var i = start + 1; i <= end; ++i) {\n+                                    var line = self.getLine(i),\n+                                        found = line.indexOf(lead);\n+                                    if (found == -1 || nonWS.test(line.slice(0, found))) continue;\n+                                    var foundEnd = found + lead.length;\n+                                    if (pad && line.slice(foundEnd, foundEnd + pad.length) == pad) foundEnd += pad.length;\n+                                    self.replaceRange(\"\", Pos(i, found), Pos(i, foundEnd));\n+                                }\n+                        });\n+                        return true;\n+                    });\n+                });\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/detect-node-es/esm/browser.js\":\n-            /*!***********************************************************!*\\\n-              !*** ../../../node_modules/detect-node-es/esm/browser.js ***!\n-              \\***********************************************************/\n+        \"../../../node_modules/codemirror/addon/dialog/dialog.js\":\n+            /*!***************************************************************!*\\\n+              !*** ../../../node_modules/codemirror/addon/dialog/dialog.js ***!\n+              \\***************************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports) {\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.isNode = void 0;\n-                const isNode = false;\n-                exports.isNode = isNode;\n+                // CodeMirror, copyright (c) by Marijn Haverbeke and others\n+                // Distributed under an MIT license: https://codemirror.net/LICENSE\n+\n+                // Open simple dialogs on top of an editor. Relies on dialog.css.\n+\n+                (function(mod) {\n+                    if (true)\n+                        // CommonJS\n+                        mod(__webpack_require__( /*! ../../lib/codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"));\n+                    else {}\n+                })(function(CodeMirror) {\n+                    function dialogDiv(cm, template, bottom) {\n+                        var wrap = cm.getWrapperElement();\n+                        var dialog;\n+                        dialog = wrap.appendChild(document.createElement(\"div\"));\n+                        if (bottom) dialog.className = \"CodeMirror-dialog CodeMirror-dialog-bottom\";\n+                        else dialog.className = \"CodeMirror-dialog CodeMirror-dialog-top\";\n+                        if (typeof template == \"string\") {\n+                            dialog.innerHTML = template;\n+                        } else {\n+                            // Assuming it's a detached DOM element.\n+                            dialog.appendChild(template);\n+                        }\n+                        CodeMirror.addClass(wrap, 'dialog-opened');\n+                        return dialog;\n+                    }\n+\n+                    function closeNotification(cm, newVal) {\n+                        if (cm.state.currentNotificationClose) cm.state.currentNotificationClose();\n+                        cm.state.currentNotificationClose = newVal;\n+                    }\n+                    CodeMirror.defineExtension(\"openDialog\", function(template, callback, options) {\n+                        if (!options) options = {};\n+                        closeNotification(this, null);\n+                        var dialog = dialogDiv(this, template, options.bottom);\n+                        var closed = false,\n+                            me = this;\n+\n+                        function close(newVal) {\n+                            if (typeof newVal == 'string') {\n+                                inp.value = newVal;\n+                            } else {\n+                                if (closed) return;\n+                                closed = true;\n+                                CodeMirror.rmClass(dialog.parentNode, 'dialog-opened');\n+                                dialog.parentNode.removeChild(dialog);\n+                                me.focus();\n+                                if (options.onClose) options.onClose(dialog);\n+                            }\n+                        }\n+                        var inp = dialog.getElementsByTagName(\"input\")[0],\n+                            button;\n+                        if (inp) {\n+                            inp.focus();\n+                            if (options.value) {\n+                                inp.value = options.value;\n+                                if (options.selectValueOnOpen !== false) {\n+                                    inp.select();\n+                                }\n+                            }\n+                            if (options.onInput) CodeMirror.on(inp, \"input\", function(e) {\n+                                options.onInput(e, inp.value, close);\n+                            });\n+                            if (options.onKeyUp) CodeMirror.on(inp, \"keyup\", function(e) {\n+                                options.onKeyUp(e, inp.value, close);\n+                            });\n+                            CodeMirror.on(inp, \"keydown\", function(e) {\n+                                if (options && options.onKeyDown && options.onKeyDown(e, inp.value, close)) {\n+                                    return;\n+                                }\n+                                if (e.keyCode == 27 || options.closeOnEnter !== false && e.keyCode == 13) {\n+                                    inp.blur();\n+                                    CodeMirror.e_stop(e);\n+                                    close();\n+                                }\n+                                if (e.keyCode == 13) callback(inp.value, e);\n+                            });\n+                            if (options.closeOnBlur !== false) CodeMirror.on(dialog, \"focusout\", function(evt) {\n+                                if (evt.relatedTarget !== null) close();\n+                            });\n+                        } else if (button = dialog.getElementsByTagName(\"button\")[0]) {\n+                            CodeMirror.on(button, \"click\", function() {\n+                                close();\n+                                me.focus();\n+                            });\n+                            if (options.closeOnBlur !== false) CodeMirror.on(button, \"blur\", close);\n+                            button.focus();\n+                        }\n+                        return close;\n+                    });\n+                    CodeMirror.defineExtension(\"openConfirm\", function(template, callbacks, options) {\n+                        closeNotification(this, null);\n+                        var dialog = dialogDiv(this, template, options && options.bottom);\n+                        var buttons = dialog.getElementsByTagName(\"button\");\n+                        var closed = false,\n+                            me = this,\n+                            blurring = 1;\n+\n+                        function close() {\n+                            if (closed) return;\n+                            closed = true;\n+                            CodeMirror.rmClass(dialog.parentNode, 'dialog-opened');\n+                            dialog.parentNode.removeChild(dialog);\n+                            me.focus();\n+                        }\n+                        buttons[0].focus();\n+                        for (var i = 0; i < buttons.length; ++i) {\n+                            var b = buttons[i];\n+                            (function(callback) {\n+                                CodeMirror.on(b, \"click\", function(e) {\n+                                    CodeMirror.e_preventDefault(e);\n+                                    close();\n+                                    if (callback) callback(me);\n+                                });\n+                            })(callbacks[i]);\n+                            CodeMirror.on(b, \"blur\", function() {\n+                                --blurring;\n+                                setTimeout(function() {\n+                                    if (blurring <= 0) close();\n+                                }, 200);\n+                            });\n+                            CodeMirror.on(b, \"focus\", function() {\n+                                ++blurring;\n+                            });\n+                        }\n+                    });\n+\n+                    /*\n+                     * openNotification\n+                     * Opens a notification, that can be closed with an optional timer\n+                     * (default 5000ms timer) and always closes on click.\n+                     *\n+                     * If a notification is opened while another is opened, it will close the\n+                     * currently opened one and open the new one immediately.\n+                     */\n+                    CodeMirror.defineExtension(\"openNotification\", function(template, options) {\n+                        closeNotification(this, close);\n+                        var dialog = dialogDiv(this, template, options && options.bottom);\n+                        var closed = false,\n+                            doneTimer;\n+                        var duration = options && typeof options.duration !== \"undefined\" ? options.duration : 5000;\n+\n+                        function close() {\n+                            if (closed) return;\n+                            closed = true;\n+                            clearTimeout(doneTimer);\n+                            CodeMirror.rmClass(dialog.parentNode, 'dialog-opened');\n+                            dialog.parentNode.removeChild(dialog);\n+                        }\n+                        CodeMirror.on(dialog, 'click', function(e) {\n+                            CodeMirror.e_preventDefault(e);\n+                            close();\n+                        });\n+                        if (duration) doneTimer = setTimeout(close, duration);\n+                        return close;\n+                    });\n+                });\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/entities/lib/decode.js\":\n-            /*!****************************************************!*\\\n-              !*** ../../../node_modules/entities/lib/decode.js ***!\n-              \\****************************************************/\n+        \"../../../node_modules/codemirror/addon/edit/closebrackets.js\":\n+            /*!********************************************************************!*\\\n+              !*** ../../../node_modules/codemirror/addon/edit/closebrackets.js ***!\n+              \\********************************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                var __createBinding = void 0 && (void 0).__createBinding || (Object.create ? function(o, m, k, k2) {\n-                    if (k2 === undefined) k2 = k;\n-                    var desc = Object.getOwnPropertyDescriptor(m, k);\n-                    if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n-                        desc = {\n-                            enumerable: true,\n-                            get: function() {\n-                                return m[k];\n-                            }\n+                // CodeMirror, copyright (c) by Marijn Haverbeke and others\n+                // Distributed under an MIT license: https://codemirror.net/LICENSE\n+\n+                (function(mod) {\n+                    if (true)\n+                        // CommonJS\n+                        mod(__webpack_require__( /*! ../../lib/codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"));\n+                    else {}\n+                })(function(CodeMirror) {\n+                    var defaults = {\n+                        pairs: \"()[]{}''\\\"\\\"\",\n+                        closeBefore: \")]}'\\\":;>\",\n+                        triples: \"\",\n+                        explode: \"[]{}\"\n+                    };\n+                    var Pos = CodeMirror.Pos;\n+                    CodeMirror.defineOption(\"autoCloseBrackets\", false, function(cm, val, old) {\n+                        if (old && old != CodeMirror.Init) {\n+                            cm.removeKeyMap(keyMap);\n+                            cm.state.closeBrackets = null;\n+                        }\n+                        if (val) {\n+                            ensureBound(getOption(val, \"pairs\"));\n+                            cm.state.closeBrackets = val;\n+                            cm.addKeyMap(keyMap);\n+                        }\n+                    });\n+\n+                    function getOption(conf, name) {\n+                        if (name == \"pairs\" && typeof conf == \"string\") return conf;\n+                        if (typeof conf == \"object\" && conf[name] != null) return conf[name];\n+                        return defaults[name];\n+                    }\n+                    var keyMap = {\n+                        Backspace: handleBackspace,\n+                        Enter: handleEnter\n+                    };\n+\n+                    function ensureBound(chars) {\n+                        for (var i = 0; i < chars.length; i++) {\n+                            var ch = chars.charAt(i),\n+                                key = \"'\" + ch + \"'\";\n+                            if (!keyMap[key]) keyMap[key] = handler(ch);\n+                        }\n+                    }\n+                    ensureBound(defaults.pairs + \"`\");\n+\n+                    function handler(ch) {\n+                        return function(cm) {\n+                            return handleChar(cm, ch);\n+                        };\n+                    }\n+\n+                    function getConfig(cm) {\n+                        var deflt = cm.state.closeBrackets;\n+                        if (!deflt || deflt.override) return deflt;\n+                        var mode = cm.getModeAt(cm.getCursor());\n+                        return mode.closeBrackets || deflt;\n+                    }\n+\n+                    function handleBackspace(cm) {\n+                        var conf = getConfig(cm);\n+                        if (!conf || cm.getOption(\"disableInput\")) return CodeMirror.Pass;\n+                        var pairs = getOption(conf, \"pairs\");\n+                        var ranges = cm.listSelections();\n+                        for (var i = 0; i < ranges.length; i++) {\n+                            if (!ranges[i].empty()) return CodeMirror.Pass;\n+                            var around = charsAround(cm, ranges[i].head);\n+                            if (!around || pairs.indexOf(around) % 2 != 0) return CodeMirror.Pass;\n+                        }\n+                        for (var i = ranges.length - 1; i >= 0; i--) {\n+                            var cur = ranges[i].head;\n+                            cm.replaceRange(\"\", Pos(cur.line, cur.ch - 1), Pos(cur.line, cur.ch + 1), \"+delete\");\n+                        }\n+                    }\n+\n+                    function handleEnter(cm) {\n+                        var conf = getConfig(cm);\n+                        var explode = conf && getOption(conf, \"explode\");\n+                        if (!explode || cm.getOption(\"disableInput\")) return CodeMirror.Pass;\n+                        var ranges = cm.listSelections();\n+                        for (var i = 0; i < ranges.length; i++) {\n+                            if (!ranges[i].empty()) return CodeMirror.Pass;\n+                            var around = charsAround(cm, ranges[i].head);\n+                            if (!around || explode.indexOf(around) % 2 != 0) return CodeMirror.Pass;\n+                        }\n+                        cm.operation(function() {\n+                            var linesep = cm.lineSeparator() || \"\\n\";\n+                            cm.replaceSelection(linesep + linesep, null);\n+                            moveSel(cm, -1);\n+                            ranges = cm.listSelections();\n+                            for (var i = 0; i < ranges.length; i++) {\n+                                var line = ranges[i].head.line;\n+                                cm.indentLine(line, null, true);\n+                                cm.indentLine(line + 1, null, true);\n+                            }\n+                        });\n+                    }\n+\n+                    function moveSel(cm, dir) {\n+                        var newRanges = [],\n+                            ranges = cm.listSelections(),\n+                            primary = 0;\n+                        for (var i = 0; i < ranges.length; i++) {\n+                            var range = ranges[i];\n+                            if (range.head == cm.getCursor()) primary = i;\n+                            var pos = range.head.ch || dir > 0 ? {\n+                                line: range.head.line,\n+                                ch: range.head.ch + dir\n+                            } : {\n+                                line: range.head.line - 1\n+                            };\n+                            newRanges.push({\n+                                anchor: pos,\n+                                head: pos\n+                            });\n+                        }\n+                        cm.setSelections(newRanges, primary);\n+                    }\n+\n+                    function contractSelection(sel) {\n+                        var inverted = CodeMirror.cmpPos(sel.anchor, sel.head) > 0;\n+                        return {\n+                            anchor: new Pos(sel.anchor.line, sel.anchor.ch + (inverted ? -1 : 1)),\n+                            head: new Pos(sel.head.line, sel.head.ch + (inverted ? 1 : -1))\n                         };\n                     }\n-                    Object.defineProperty(o, k2, desc);\n-                } : function(o, m, k, k2) {\n-                    if (k2 === undefined) k2 = k;\n-                    o[k2] = m[k];\n-                });\n-                var __setModuleDefault = void 0 && (void 0).__setModuleDefault || (Object.create ? function(o, v) {\n-                    Object.defineProperty(o, \"default\", {\n-                        enumerable: true,\n-                        value: v\n-                    });\n-                } : function(o, v) {\n-                    o[\"default\"] = v;\n-                });\n-                var __importStar = void 0 && (void 0).__importStar || function(mod) {\n-                    if (mod && mod.__esModule) return mod;\n-                    var result = {};\n-                    if (mod != null)\n-                        for (var k in mod)\n-                            if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n-                    __setModuleDefault(result, mod);\n-                    return result;\n-                };\n-                var __importDefault = void 0 && (void 0).__importDefault || function(mod) {\n-                    return mod && mod.__esModule ? mod : {\n-                        \"default\": mod\n-                    };\n-                };\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.decodeXML = exports.decodeHTMLStrict = exports.decodeHTMLAttribute = exports.decodeHTML = exports.determineBranch = exports.EntityDecoder = exports.DecodingMode = exports.BinTrieFlags = exports.fromCodePoint = exports.replaceCodePoint = exports.decodeCodePoint = exports.xmlDecodeTree = exports.htmlDecodeTree = void 0;\n-                var decode_data_html_js_1 = __importDefault(__webpack_require__( /*! ./generated/decode-data-html.js */ \"../../../node_modules/entities/lib/generated/decode-data-html.js\"));\n-                exports.htmlDecodeTree = decode_data_html_js_1.default;\n-                var decode_data_xml_js_1 = __importDefault(__webpack_require__( /*! ./generated/decode-data-xml.js */ \"../../../node_modules/entities/lib/generated/decode-data-xml.js\"));\n-                exports.xmlDecodeTree = decode_data_xml_js_1.default;\n-                var decode_codepoint_js_1 = __importStar(__webpack_require__( /*! ./decode_codepoint.js */ \"../../../node_modules/entities/lib/decode_codepoint.js\"));\n-                exports.decodeCodePoint = decode_codepoint_js_1.default;\n-                var decode_codepoint_js_2 = __webpack_require__( /*! ./decode_codepoint.js */ \"../../../node_modules/entities/lib/decode_codepoint.js\");\n-                Object.defineProperty(exports, \"replaceCodePoint\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return decode_codepoint_js_2.replaceCodePoint;\n+\n+                    function handleChar(cm, ch) {\n+                        var conf = getConfig(cm);\n+                        if (!conf || cm.getOption(\"disableInput\")) return CodeMirror.Pass;\n+                        var pairs = getOption(conf, \"pairs\");\n+                        var pos = pairs.indexOf(ch);\n+                        if (pos == -1) return CodeMirror.Pass;\n+                        var closeBefore = getOption(conf, \"closeBefore\");\n+                        var triples = getOption(conf, \"triples\");\n+                        var identical = pairs.charAt(pos + 1) == ch;\n+                        var ranges = cm.listSelections();\n+                        var opening = pos % 2 == 0;\n+                        var type;\n+                        for (var i = 0; i < ranges.length; i++) {\n+                            var range = ranges[i],\n+                                cur = range.head,\n+                                curType;\n+                            var next = cm.getRange(cur, Pos(cur.line, cur.ch + 1));\n+                            if (opening && !range.empty()) {\n+                                curType = \"surround\";\n+                            } else if ((identical || !opening) && next == ch) {\n+                                if (identical && stringStartsAfter(cm, cur)) curType = \"both\";\n+                                else if (triples.indexOf(ch) >= 0 && cm.getRange(cur, Pos(cur.line, cur.ch + 3)) == ch + ch + ch) curType = \"skipThree\";\n+                                else curType = \"skip\";\n+                            } else if (identical && cur.ch > 1 && triples.indexOf(ch) >= 0 && cm.getRange(Pos(cur.line, cur.ch - 2), cur) == ch + ch) {\n+                                if (cur.ch > 2 && /\\bstring/.test(cm.getTokenTypeAt(Pos(cur.line, cur.ch - 2)))) return CodeMirror.Pass;\n+                                curType = \"addFour\";\n+                            } else if (identical) {\n+                                var prev = cur.ch == 0 ? \" \" : cm.getRange(Pos(cur.line, cur.ch - 1), cur);\n+                                if (!CodeMirror.isWordChar(next) && prev != ch && !CodeMirror.isWordChar(prev)) curType = \"both\";\n+                                else return CodeMirror.Pass;\n+                            } else if (opening && (next.length === 0 || /\\s/.test(next) || closeBefore.indexOf(next) > -1)) {\n+                                curType = \"both\";\n+                            } else {\n+                                return CodeMirror.Pass;\n+                            }\n+                            if (!type) type = curType;\n+                            else if (type != curType) return CodeMirror.Pass;\n+                        }\n+                        var left = pos % 2 ? pairs.charAt(pos - 1) : ch;\n+                        var right = pos % 2 ? ch : pairs.charAt(pos + 1);\n+                        cm.operation(function() {\n+                            if (type == \"skip\") {\n+                                moveSel(cm, 1);\n+                            } else if (type == \"skipThree\") {\n+                                moveSel(cm, 3);\n+                            } else if (type == \"surround\") {\n+                                var sels = cm.getSelections();\n+                                for (var i = 0; i < sels.length; i++) sels[i] = left + sels[i] + right;\n+                                cm.replaceSelections(sels, \"around\");\n+                                sels = cm.listSelections().slice();\n+                                for (var i = 0; i < sels.length; i++) sels[i] = contractSelection(sels[i]);\n+                                cm.setSelections(sels);\n+                            } else if (type == \"both\") {\n+                                cm.replaceSelection(left + right, null);\n+                                cm.triggerElectric(left + right);\n+                                moveSel(cm, -1);\n+                            } else if (type == \"addFour\") {\n+                                cm.replaceSelection(left + left + left + left, \"before\");\n+                                moveSel(cm, 1);\n+                            }\n+                        });\n                     }\n-                }));\n-                Object.defineProperty(exports, \"fromCodePoint\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return decode_codepoint_js_2.fromCodePoint;\n+\n+                    function charsAround(cm, pos) {\n+                        var str = cm.getRange(Pos(pos.line, pos.ch - 1), Pos(pos.line, pos.ch + 1));\n+                        return str.length == 2 ? str : null;\n                     }\n-                }));\n-                var CharCodes;\n-                (function(CharCodes) {\n-                    CharCodes[CharCodes[\"NUM\"] = 35] = \"NUM\";\n-                    CharCodes[CharCodes[\"SEMI\"] = 59] = \"SEMI\";\n-                    CharCodes[CharCodes[\"EQUALS\"] = 61] = \"EQUALS\";\n-                    CharCodes[CharCodes[\"ZERO\"] = 48] = \"ZERO\";\n-                    CharCodes[CharCodes[\"NINE\"] = 57] = \"NINE\";\n-                    CharCodes[CharCodes[\"LOWER_A\"] = 97] = \"LOWER_A\";\n-                    CharCodes[CharCodes[\"LOWER_F\"] = 102] = \"LOWER_F\";\n-                    CharCodes[CharCodes[\"LOWER_X\"] = 120] = \"LOWER_X\";\n-                    CharCodes[CharCodes[\"LOWER_Z\"] = 122] = \"LOWER_Z\";\n-                    CharCodes[CharCodes[\"UPPER_A\"] = 65] = \"UPPER_A\";\n-                    CharCodes[CharCodes[\"UPPER_F\"] = 70] = \"UPPER_F\";\n-                    CharCodes[CharCodes[\"UPPER_Z\"] = 90] = \"UPPER_Z\";\n-                })(CharCodes || (CharCodes = {}));\n-                /** Bit that needs to be set to convert an upper case ASCII character to lower case */\n-                var TO_LOWER_BIT = 32;\n-                var BinTrieFlags;\n-                (function(BinTrieFlags) {\n-                    BinTrieFlags[BinTrieFlags[\"VALUE_LENGTH\"] = 49152] = \"VALUE_LENGTH\";\n-                    BinTrieFlags[BinTrieFlags[\"BRANCH_LENGTH\"] = 16256] = \"BRANCH_LENGTH\";\n-                    BinTrieFlags[BinTrieFlags[\"JUMP_TABLE\"] = 127] = \"JUMP_TABLE\";\n-                })(BinTrieFlags = exports.BinTrieFlags || (exports.BinTrieFlags = {}));\n \n-                function isNumber(code) {\n-                    return code >= CharCodes.ZERO && code <= CharCodes.NINE;\n-                }\n+                    function stringStartsAfter(cm, pos) {\n+                        var token = cm.getTokenAt(Pos(pos.line, pos.ch + 1));\n+                        return /\\bstring/.test(token.type) && token.start == pos.ch && (pos.ch == 0 || !/\\bstring/.test(cm.getTokenTypeAt(pos)));\n+                    }\n+                });\n \n-                function isHexadecimalCharacter(code) {\n-                    return code >= CharCodes.UPPER_A && code <= CharCodes.UPPER_F || code >= CharCodes.LOWER_A && code <= CharCodes.LOWER_F;\n-                }\n+                /***/\n+            }),\n \n-                function isAsciiAlphaNumeric(code) {\n-                    return code >= CharCodes.UPPER_A && code <= CharCodes.UPPER_Z || code >= CharCodes.LOWER_A && code <= CharCodes.LOWER_Z || isNumber(code);\n-                }\n-                /**\n-                 * Checks if the given character is a valid end character for an entity in an attribute.\n-                 *\n-                 * Attribute values that aren't terminated properly aren't parsed, and shouldn't lead to a parser error.\n-                 * See the example in https://html.spec.whatwg.org/multipage/parsing.html#named-character-reference-state\n-                 */\n-                function isEntityInAttributeInvalidEnd(code) {\n-                    return code === CharCodes.EQUALS || isAsciiAlphaNumeric(code);\n-                }\n-                var EntityDecoderState;\n-                (function(EntityDecoderState) {\n-                    EntityDecoderState[EntityDecoderState[\"EntityStart\"] = 0] = \"EntityStart\";\n-                    EntityDecoderState[EntityDecoderState[\"NumericStart\"] = 1] = \"NumericStart\";\n-                    EntityDecoderState[EntityDecoderState[\"NumericDecimal\"] = 2] = \"NumericDecimal\";\n-                    EntityDecoderState[EntityDecoderState[\"NumericHex\"] = 3] = \"NumericHex\";\n-                    EntityDecoderState[EntityDecoderState[\"NamedEntity\"] = 4] = \"NamedEntity\";\n-                })(EntityDecoderState || (EntityDecoderState = {}));\n-                var DecodingMode;\n-                (function(DecodingMode) {\n-                    /** Entities in text nodes that can end with any character. */\n-                    DecodingMode[DecodingMode[\"Legacy\"] = 0] = \"Legacy\";\n-                    /** Only allow entities terminated with a semicolon. */\n-                    DecodingMode[DecodingMode[\"Strict\"] = 1] = \"Strict\";\n-                    /** Entities in attributes have limitations on ending characters. */\n-                    DecodingMode[DecodingMode[\"Attribute\"] = 2] = \"Attribute\";\n-                })(DecodingMode = exports.DecodingMode || (exports.DecodingMode = {}));\n-                /**\n-                 * Token decoder with support of writing partial entities.\n-                 */\n-                var EntityDecoder = /** @class */ function() {\n-                    function EntityDecoder( /** The tree used to decode entities. */\n-                        decodeTree,\n-                        /**\n-                         * The function that is called when a codepoint is decoded.\n-                         *\n-                         * For multi-byte named entities, this will be called multiple times,\n-                         * with the second codepoint, and the same `consumed` value.\n-                         *\n-                         * @param codepoint The decoded codepoint.\n-                         * @param consumed The number of bytes consumed by the decoder.\n-                         */\n-                        emitCodePoint, /** An object that is used to produce errors. */\n-                        errors) {\n-                        this.decodeTree = decodeTree;\n-                        this.emitCodePoint = emitCodePoint;\n-                        this.errors = errors;\n-                        /** The current state of the decoder. */\n-                        this.state = EntityDecoderState.EntityStart;\n-                        /** Characters that were consumed while parsing an entity. */\n-                        this.consumed = 1;\n-                        /**\n-                         * The result of the entity.\n-                         *\n-                         * Either the result index of a numeric entity, or the codepoint of a\n-                         * numeric entity.\n-                         */\n-                        this.result = 0;\n-                        /** The current index in the decode tree. */\n-                        this.treeIndex = 0;\n-                        /** The number of characters that were consumed in excess. */\n-                        this.excess = 1;\n-                        /** The mode in which the decoder is operating. */\n-                        this.decodeMode = DecodingMode.Strict;\n+        /***/\n+        \"../../../node_modules/codemirror/addon/edit/matchbrackets.js\":\n+            /*!********************************************************************!*\\\n+              !*** ../../../node_modules/codemirror/addon/edit/matchbrackets.js ***!\n+              \\********************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                // CodeMirror, copyright (c) by Marijn Haverbeke and others\n+                // Distributed under an MIT license: https://codemirror.net/LICENSE\n+\n+                (function(mod) {\n+                    if (true)\n+                        // CommonJS\n+                        mod(__webpack_require__( /*! ../../lib/codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"));\n+                    else {}\n+                })(function(CodeMirror) {\n+                    var ie_lt8 = /MSIE \\d/.test(navigator.userAgent) && (document.documentMode == null || document.documentMode < 8);\n+                    var Pos = CodeMirror.Pos;\n+                    var matching = {\n+                        \"(\": \")>\",\n+                        \")\": \"(<\",\n+                        \"[\": \"]>\",\n+                        \"]\": \"[<\",\n+                        \"{\": \"}>\",\n+                        \"}\": \"{<\",\n+                        \"<\": \">>\",\n+                        \">\": \"<<\"\n+                    };\n+\n+                    function bracketRegex(config) {\n+                        return config && config.bracketRegex || /[(){}[\\]]/;\n+                    }\n+\n+                    function findMatchingBracket(cm, where, config) {\n+                        var line = cm.getLineHandle(where.line),\n+                            pos = where.ch - 1;\n+                        var afterCursor = config && config.afterCursor;\n+                        if (afterCursor == null) afterCursor = /(^| )cm-fat-cursor($| )/.test(cm.getWrapperElement().className);\n+                        var re = bracketRegex(config);\n+\n+                        // A cursor is defined as between two characters, but in in vim command mode\n+                        // (i.e. not insert mode), the cursor is visually represented as a\n+                        // highlighted box on top of the 2nd character. Otherwise, we allow matches\n+                        // from before or after the cursor.\n+                        var match = !afterCursor && pos >= 0 && re.test(line.text.charAt(pos)) && matching[line.text.charAt(pos)] || re.test(line.text.charAt(pos + 1)) && matching[line.text.charAt(++pos)];\n+                        if (!match) return null;\n+                        var dir = match.charAt(1) == \">\" ? 1 : -1;\n+                        if (config && config.strict && dir > 0 != (pos == where.ch)) return null;\n+                        var style = cm.getTokenTypeAt(Pos(where.line, pos + 1));\n+                        var found = scanForBracket(cm, Pos(where.line, pos + (dir > 0 ? 1 : 0)), dir, style, config);\n+                        if (found == null) return null;\n+                        return {\n+                            from: Pos(where.line, pos),\n+                            to: found && found.pos,\n+                            match: found && found.ch == match.charAt(0),\n+                            forward: dir > 0\n+                        };\n                     }\n-                    /** Resets the instance to make it reusable. */\n-                    EntityDecoder.prototype.startEntity = function(decodeMode) {\n-                        this.decodeMode = decodeMode;\n-                        this.state = EntityDecoderState.EntityStart;\n-                        this.result = 0;\n-                        this.treeIndex = 0;\n-                        this.excess = 1;\n-                        this.consumed = 1;\n-                    };\n-                    /**\n-                     * Write an entity to the decoder. This can be called multiple times with partial entities.\n-                     * If the entity is incomplete, the decoder will return -1.\n-                     *\n-                     * Mirrors the implementation of `getDecoder`, but with the ability to stop decoding if the\n-                     * entity is incomplete, and resume when the next string is written.\n-                     *\n-                     * @param string The string containing the entity (or a continuation of the entity).\n-                     * @param offset The offset at which the entity begins. Should be 0 if this is not the first call.\n-                     * @returns The number of characters that were consumed, or -1 if the entity is incomplete.\n-                     */\n-                    EntityDecoder.prototype.write = function(str, offset) {\n-                        switch (this.state) {\n-                            case EntityDecoderState.EntityStart: {\n-                                if (str.charCodeAt(offset) === CharCodes.NUM) {\n-                                    this.state = EntityDecoderState.NumericStart;\n-                                    this.consumed += 1;\n-                                    return this.stateNumericStart(str, offset + 1);\n+\n+                    // bracketRegex is used to specify which type of bracket to scan\n+                    // should be a regexp, e.g. /[[\\]]/\n+                    //\n+                    // Note: If \"where\" is on an open bracket, then this bracket is ignored.\n+                    //\n+                    // Returns false when no bracket was found, null when it reached\n+                    // maxScanLines and gave up\n+                    function scanForBracket(cm, where, dir, style, config) {\n+                        var maxScanLen = config && config.maxScanLineLength || 10000;\n+                        var maxScanLines = config && config.maxScanLines || 1000;\n+                        var stack = [];\n+                        var re = bracketRegex(config);\n+                        var lineEnd = dir > 0 ? Math.min(where.line + maxScanLines, cm.lastLine() + 1) : Math.max(cm.firstLine() - 1, where.line - maxScanLines);\n+                        for (var lineNo = where.line; lineNo != lineEnd; lineNo += dir) {\n+                            var line = cm.getLine(lineNo);\n+                            if (!line) continue;\n+                            var pos = dir > 0 ? 0 : line.length - 1,\n+                                end = dir > 0 ? line.length : -1;\n+                            if (line.length > maxScanLen) continue;\n+                            if (lineNo == where.line) pos = where.ch - (dir < 0 ? 1 : 0);\n+                            for (; pos != end; pos += dir) {\n+                                var ch = line.charAt(pos);\n+                                if (re.test(ch) && (style === undefined || (cm.getTokenTypeAt(Pos(lineNo, pos + 1)) || \"\") == (style || \"\"))) {\n+                                    var match = matching[ch];\n+                                    if (match && match.charAt(1) == \">\" == dir > 0) stack.push(ch);\n+                                    else if (!stack.length) return {\n+                                        pos: Pos(lineNo, pos),\n+                                        ch: ch\n+                                    };\n+                                    else stack.pop();\n                                 }\n-                                this.state = EntityDecoderState.NamedEntity;\n-                                return this.stateNamedEntity(str, offset);\n-                            }\n-                            case EntityDecoderState.NumericStart: {\n-                                return this.stateNumericStart(str, offset);\n-                            }\n-                            case EntityDecoderState.NumericDecimal: {\n-                                return this.stateNumericDecimal(str, offset);\n-                            }\n-                            case EntityDecoderState.NumericHex: {\n-                                return this.stateNumericHex(str, offset);\n                             }\n-                            case EntityDecoderState.NamedEntity: {\n-                                return this.stateNamedEntity(str, offset);\n+                        }\n+                        return lineNo - dir == (dir > 0 ? cm.lastLine() : cm.firstLine()) ? false : null;\n+                    }\n+\n+                    function matchBrackets(cm, autoclear, config) {\n+                        // Disable brace matching in long lines, since it'll cause hugely slow updates\n+                        var maxHighlightLen = cm.state.matchBrackets.maxHighlightLineLength || 1000,\n+                            highlightNonMatching = config && config.highlightNonMatching;\n+                        var marks = [],\n+                            ranges = cm.listSelections();\n+                        for (var i = 0; i < ranges.length; i++) {\n+                            var match = ranges[i].empty() && findMatchingBracket(cm, ranges[i].head, config);\n+                            if (match && (match.match || highlightNonMatching !== false) && cm.getLine(match.from.line).length <= maxHighlightLen) {\n+                                var style = match.match ? \"CodeMirror-matchingbracket\" : \"CodeMirror-nonmatchingbracket\";\n+                                marks.push(cm.markText(match.from, Pos(match.from.line, match.from.ch + 1), {\n+                                    className: style\n+                                }));\n+                                if (match.to && cm.getLine(match.to.line).length <= maxHighlightLen) marks.push(cm.markText(match.to, Pos(match.to.line, match.to.ch + 1), {\n+                                    className: style\n+                                }));\n                             }\n                         }\n-                    };\n-                    /**\n-                     * Switches between the numeric decimal and hexadecimal states.\n-                     *\n-                     * Equivalent to the `Numeric character reference state` in the HTML spec.\n-                     *\n-                     * @param str The string containing the entity (or a continuation of the entity).\n-                     * @param offset The current offset.\n-                     * @returns The number of characters that were consumed, or -1 if the entity is incomplete.\n-                     */\n-                    EntityDecoder.prototype.stateNumericStart = function(str, offset) {\n-                        if (offset >= str.length) {\n-                            return -1;\n+                        if (marks.length) {\n+                            // Kludge to work around the IE bug from issue #1193, where text\n+                            // input stops going to the textarea whenever this fires.\n+                            if (ie_lt8 && cm.state.focused) cm.focus();\n+                            var clear = function() {\n+                                cm.operation(function() {\n+                                    for (var i = 0; i < marks.length; i++) marks[i].clear();\n+                                });\n+                            };\n+                            if (autoclear) setTimeout(clear, 800);\n+                            else return clear;\n                         }\n-                        if ((str.charCodeAt(offset) | TO_LOWER_BIT) === CharCodes.LOWER_X) {\n-                            this.state = EntityDecoderState.NumericHex;\n-                            this.consumed += 1;\n-                            return this.stateNumericHex(str, offset + 1);\n+                    }\n+\n+                    function doMatchBrackets(cm) {\n+                        cm.operation(function() {\n+                            if (cm.state.matchBrackets.currentlyHighlighted) {\n+                                cm.state.matchBrackets.currentlyHighlighted();\n+                                cm.state.matchBrackets.currentlyHighlighted = null;\n+                            }\n+                            cm.state.matchBrackets.currentlyHighlighted = matchBrackets(cm, false, cm.state.matchBrackets);\n+                        });\n+                    }\n+\n+                    function clearHighlighted(cm) {\n+                        if (cm.state.matchBrackets && cm.state.matchBrackets.currentlyHighlighted) {\n+                            cm.state.matchBrackets.currentlyHighlighted();\n+                            cm.state.matchBrackets.currentlyHighlighted = null;\n                         }\n-                        this.state = EntityDecoderState.NumericDecimal;\n-                        return this.stateNumericDecimal(str, offset);\n-                    };\n-                    EntityDecoder.prototype.addToNumericResult = function(str, start, end, base) {\n-                        if (start !== end) {\n-                            var digitCount = end - start;\n-                            this.result = this.result * Math.pow(base, digitCount) + parseInt(str.substr(start, digitCount), base);\n-                            this.consumed += digitCount;\n+                    }\n+                    CodeMirror.defineOption(\"matchBrackets\", false, function(cm, val, old) {\n+                        if (old && old != CodeMirror.Init) {\n+                            cm.off(\"cursorActivity\", doMatchBrackets);\n+                            cm.off(\"focus\", doMatchBrackets);\n+                            cm.off(\"blur\", clearHighlighted);\n+                            clearHighlighted(cm);\n                         }\n-                    };\n-                    /**\n-                     * Parses a hexadecimal numeric entity.\n-                     *\n-                     * Equivalent to the `Hexademical character reference state` in the HTML spec.\n-                     *\n-                     * @param str The string containing the entity (or a continuation of the entity).\n-                     * @param offset The current offset.\n-                     * @returns The number of characters that were consumed, or -1 if the entity is incomplete.\n-                     */\n-                    EntityDecoder.prototype.stateNumericHex = function(str, offset) {\n-                        var startIdx = offset;\n-                        while (offset < str.length) {\n-                            var char = str.charCodeAt(offset);\n-                            if (isNumber(char) || isHexadecimalCharacter(char)) {\n-                                offset += 1;\n+                        if (val) {\n+                            cm.state.matchBrackets = typeof val == \"object\" ? val : {};\n+                            cm.on(\"cursorActivity\", doMatchBrackets);\n+                            cm.on(\"focus\", doMatchBrackets);\n+                            cm.on(\"blur\", clearHighlighted);\n+                        }\n+                    });\n+                    CodeMirror.defineExtension(\"matchBrackets\", function() {\n+                        matchBrackets(this, true);\n+                    });\n+                    CodeMirror.defineExtension(\"findMatchingBracket\", function(pos, config, oldConfig) {\n+                        // Backwards-compatibility kludge\n+                        if (oldConfig || typeof config == \"boolean\") {\n+                            if (!oldConfig) {\n+                                config = config ? {\n+                                    strict: true\n+                                } : null;\n                             } else {\n-                                this.addToNumericResult(str, startIdx, offset, 16);\n-                                return this.emitNumericEntity(char, 3);\n+                                oldConfig.strict = config;\n+                                config = oldConfig;\n                             }\n                         }\n-                        this.addToNumericResult(str, startIdx, offset, 16);\n-                        return -1;\n-                    };\n-                    /**\n-                     * Parses a decimal numeric entity.\n-                     *\n-                     * Equivalent to the `Decimal character reference state` in the HTML spec.\n-                     *\n-                     * @param str The string containing the entity (or a continuation of the entity).\n-                     * @param offset The current offset.\n-                     * @returns The number of characters that were consumed, or -1 if the entity is incomplete.\n-                     */\n-                    EntityDecoder.prototype.stateNumericDecimal = function(str, offset) {\n-                        var startIdx = offset;\n-                        while (offset < str.length) {\n-                            var char = str.charCodeAt(offset);\n-                            if (isNumber(char)) {\n-                                offset += 1;\n-                            } else {\n-                                this.addToNumericResult(str, startIdx, offset, 10);\n-                                return this.emitNumericEntity(char, 2);\n+                        return findMatchingBracket(this, pos, config);\n+                    });\n+                    CodeMirror.defineExtension(\"scanForBracket\", function(pos, dir, style, config) {\n+                        return scanForBracket(this, pos, dir, style, config);\n+                    });\n+                });\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/codemirror/addon/fold/brace-fold.js\":\n+            /*!*****************************************************************!*\\\n+              !*** ../../../node_modules/codemirror/addon/fold/brace-fold.js ***!\n+              \\*****************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                // CodeMirror, copyright (c) by Marijn Haverbeke and others\n+                // Distributed under an MIT license: https://codemirror.net/LICENSE\n+\n+                (function(mod) {\n+                    if (true)\n+                        // CommonJS\n+                        mod(__webpack_require__( /*! ../../lib/codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"));\n+                    else {}\n+                })(function(CodeMirror) {\n+                    \"use strict\";\n+\n+                    function bracketFolding(pairs) {\n+                        return function(cm, start) {\n+                            var line = start.line,\n+                                lineText = cm.getLine(line);\n+\n+                            function findOpening(pair) {\n+                                var tokenType;\n+                                for (var at = start.ch, pass = 0;;) {\n+                                    var found = at <= 0 ? -1 : lineText.lastIndexOf(pair[0], at - 1);\n+                                    if (found == -1) {\n+                                        if (pass == 1) break;\n+                                        pass = 1;\n+                                        at = lineText.length;\n+                                        continue;\n+                                    }\n+                                    if (pass == 1 && found < start.ch) break;\n+                                    tokenType = cm.getTokenTypeAt(CodeMirror.Pos(line, found + 1));\n+                                    if (!/^(comment|string)/.test(tokenType)) return {\n+                                        ch: found + 1,\n+                                        tokenType: tokenType,\n+                                        pair: pair\n+                                    };\n+                                    at = found - 1;\n+                                }\n+                            }\n+\n+                            function findRange(found) {\n+                                var count = 1,\n+                                    lastLine = cm.lastLine(),\n+                                    end,\n+                                    startCh = found.ch,\n+                                    endCh;\n+                                outer: for (var i = line; i <= lastLine; ++i) {\n+                                    var text = cm.getLine(i),\n+                                        pos = i == line ? startCh : 0;\n+                                    for (;;) {\n+                                        var nextOpen = text.indexOf(found.pair[0], pos),\n+                                            nextClose = text.indexOf(found.pair[1], pos);\n+                                        if (nextOpen < 0) nextOpen = text.length;\n+                                        if (nextClose < 0) nextClose = text.length;\n+                                        pos = Math.min(nextOpen, nextClose);\n+                                        if (pos == text.length) break;\n+                                        if (cm.getTokenTypeAt(CodeMirror.Pos(i, pos + 1)) == found.tokenType) {\n+                                            if (pos == nextOpen) ++count;\n+                                            else if (!--count) {\n+                                                end = i;\n+                                                endCh = pos;\n+                                                break outer;\n+                                            }\n+                                        }\n+                                        ++pos;\n+                                    }\n+                                }\n+                                if (end == null || line == end) return null;\n+                                return {\n+                                    from: CodeMirror.Pos(line, startCh),\n+                                    to: CodeMirror.Pos(end, endCh)\n+                                };\n+                            }\n+                            var found = [];\n+                            for (var i = 0; i < pairs.length; i++) {\n+                                var open = findOpening(pairs[i]);\n+                                if (open) found.push(open);\n+                            }\n+                            found.sort(function(a, b) {\n+                                return a.ch - b.ch;\n+                            });\n+                            for (var i = 0; i < found.length; i++) {\n+                                var range = findRange(found[i]);\n+                                if (range) return range;\n+                            }\n+                            return null;\n+                        };\n+                    }\n+                    CodeMirror.registerHelper(\"fold\", \"brace\", bracketFolding([\n+                        [\"{\", \"}\"],\n+                        [\"[\", \"]\"]\n+                    ]));\n+                    CodeMirror.registerHelper(\"fold\", \"brace-paren\", bracketFolding([\n+                        [\"{\", \"}\"],\n+                        [\"[\", \"]\"],\n+                        [\"(\", \")\"]\n+                    ]));\n+                    CodeMirror.registerHelper(\"fold\", \"import\", function(cm, start) {\n+                        function hasImport(line) {\n+                            if (line < cm.firstLine() || line > cm.lastLine()) return null;\n+                            var start = cm.getTokenAt(CodeMirror.Pos(line, 1));\n+                            if (!/\\S/.test(start.string)) start = cm.getTokenAt(CodeMirror.Pos(line, start.end + 1));\n+                            if (start.type != \"keyword\" || start.string != \"import\") return null;\n+                            // Now find closing semicolon, return its position\n+                            for (var i = line, e = Math.min(cm.lastLine(), line + 10); i <= e; ++i) {\n+                                var text = cm.getLine(i),\n+                                    semi = text.indexOf(\";\");\n+                                if (semi != -1) return {\n+                                    startCh: start.end,\n+                                    end: CodeMirror.Pos(i, semi)\n+                                };\n                             }\n                         }\n-                        this.addToNumericResult(str, startIdx, offset, 10);\n-                        return -1;\n-                    };\n-                    /**\n-                     * Validate and emit a numeric entity.\n-                     *\n-                     * Implements the logic from the `Hexademical character reference start\n-                     * state` and `Numeric character reference end state` in the HTML spec.\n-                     *\n-                     * @param lastCp The last code point of the entity. Used to see if the\n-                     *               entity was terminated with a semicolon.\n-                     * @param expectedLength The minimum number of characters that should be\n-                     *                       consumed. Used to validate that at least one digit\n-                     *                       was consumed.\n-                     * @returns The number of characters that were consumed.\n-                     */\n-                    EntityDecoder.prototype.emitNumericEntity = function(lastCp, expectedLength) {\n-                        var _a;\n-                        // Ensure we consumed at least one digit.\n-                        if (this.consumed <= expectedLength) {\n-                            (_a = this.errors) === null || _a === void 0 ? void 0 : _a.absenceOfDigitsInNumericCharacterReference(this.consumed);\n-                            return 0;\n+                        var startLine = start.line,\n+                            has = hasImport(startLine),\n+                            prev;\n+                        if (!has || hasImport(startLine - 1) || (prev = hasImport(startLine - 2)) && prev.end.line == startLine - 1) return null;\n+                        for (var end = has.end;;) {\n+                            var next = hasImport(end.line + 1);\n+                            if (next == null) break;\n+                            end = next.end;\n                         }\n-                        // Figure out if this is a legit end of the entity\n-                        if (lastCp === CharCodes.SEMI) {\n-                            this.consumed += 1;\n-                        } else if (this.decodeMode === DecodingMode.Strict) {\n-                            return 0;\n+                        return {\n+                            from: cm.clipPos(CodeMirror.Pos(startLine, has.startCh + 1)),\n+                            to: end\n+                        };\n+                    });\n+                    CodeMirror.registerHelper(\"fold\", \"include\", function(cm, start) {\n+                        function hasInclude(line) {\n+                            if (line < cm.firstLine() || line > cm.lastLine()) return null;\n+                            var start = cm.getTokenAt(CodeMirror.Pos(line, 1));\n+                            if (!/\\S/.test(start.string)) start = cm.getTokenAt(CodeMirror.Pos(line, start.end + 1));\n+                            if (start.type == \"meta\" && start.string.slice(0, 8) == \"#include\") return start.start + 8;\n+                        }\n+                        var startLine = start.line,\n+                            has = hasInclude(startLine);\n+                        if (has == null || hasInclude(startLine - 1) != null) return null;\n+                        for (var end = startLine;;) {\n+                            var next = hasInclude(end + 1);\n+                            if (next == null) break;\n+                            ++end;\n                         }\n-                        this.emitCodePoint((0, decode_codepoint_js_1.replaceCodePoint)(this.result), this.consumed);\n-                        if (this.errors) {\n-                            if (lastCp !== CharCodes.SEMI) {\n-                                this.errors.missingSemicolonAfterCharacterReference();\n-                            }\n-                            this.errors.validateNumericCharacterReference(this.result);\n+                        return {\n+                            from: CodeMirror.Pos(startLine, has + 1),\n+                            to: cm.clipPos(CodeMirror.Pos(end))\n+                        };\n+                    });\n+                });\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/codemirror/addon/fold/foldcode.js\":\n+            /*!***************************************************************!*\\\n+              !*** ../../../node_modules/codemirror/addon/fold/foldcode.js ***!\n+              \\***************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                // CodeMirror, copyright (c) by Marijn Haverbeke and others\n+                // Distributed under an MIT license: https://codemirror.net/LICENSE\n+\n+                (function(mod) {\n+                    if (true)\n+                        // CommonJS\n+                        mod(__webpack_require__( /*! ../../lib/codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"));\n+                    else {}\n+                })(function(CodeMirror) {\n+                    \"use strict\";\n+\n+                    function doFold(cm, pos, options, force) {\n+                        if (options && options.call) {\n+                            var finder = options;\n+                            options = null;\n+                        } else {\n+                            var finder = getOption(cm, options, \"rangeFinder\");\n                         }\n-                        return this.consumed;\n-                    };\n-                    /**\n-                     * Parses a named entity.\n-                     *\n-                     * Equivalent to the `Named character reference state` in the HTML spec.\n-                     *\n-                     * @param str The string containing the entity (or a continuation of the entity).\n-                     * @param offset The current offset.\n-                     * @returns The number of characters that were consumed, or -1 if the entity is incomplete.\n-                     */\n-                    EntityDecoder.prototype.stateNamedEntity = function(str, offset) {\n-                        var decodeTree = this.decodeTree;\n-                        var current = decodeTree[this.treeIndex];\n-                        // The mask is the number of bytes of the value, including the current byte.\n-                        var valueLength = (current & BinTrieFlags.VALUE_LENGTH) >> 14;\n-                        for (; offset < str.length; offset++, this.excess++) {\n-                            var char = str.charCodeAt(offset);\n-                            this.treeIndex = determineBranch(decodeTree, current, this.treeIndex + Math.max(1, valueLength), char);\n-                            if (this.treeIndex < 0) {\n-                                return this.result === 0 ||\n-                                    // If we are parsing an attribute\n-                                    this.decodeMode === DecodingMode.Attribute && (\n-                                        // We shouldn't have consumed any characters after the entity,\n-                                        valueLength === 0 ||\n-                                        // And there should be no invalid characters.\n-                                        isEntityInAttributeInvalidEnd(char)) ? 0 : this.emitNotTerminatedNamedEntity();\n-                            }\n-                            current = decodeTree[this.treeIndex];\n-                            valueLength = (current & BinTrieFlags.VALUE_LENGTH) >> 14;\n-                            // If the branch is a value, store it and continue\n-                            if (valueLength !== 0) {\n-                                // If the entity is terminated by a semicolon, we are done.\n-                                if (char === CharCodes.SEMI) {\n-                                    return this.emitNamedEntityData(this.treeIndex, valueLength, this.consumed + this.excess);\n-                                }\n-                                // If we encounter a non-terminated (legacy) entity while parsing strictly, then ignore it.\n-                                if (this.decodeMode !== DecodingMode.Strict) {\n-                                    this.result = this.treeIndex;\n-                                    this.consumed += this.excess;\n-                                    this.excess = 0;\n+                        if (typeof pos == \"number\") pos = CodeMirror.Pos(pos, 0);\n+                        var minSize = getOption(cm, options, \"minFoldSize\");\n+\n+                        function getRange(allowFolded) {\n+                            var range = finder(cm, pos);\n+                            if (!range || range.to.line - range.from.line < minSize) return null;\n+                            if (force === \"fold\") return range;\n+                            var marks = cm.findMarksAt(range.from);\n+                            for (var i = 0; i < marks.length; ++i) {\n+                                if (marks[i].__isFold) {\n+                                    if (!allowFolded) return null;\n+                                    range.cleared = true;\n+                                    marks[i].clear();\n                                 }\n                             }\n+                            return range;\n                         }\n-                        return -1;\n-                    };\n-                    /**\n-                     * Emit a named entity that was not terminated with a semicolon.\n-                     *\n-                     * @returns The number of characters consumed.\n-                     */\n-                    EntityDecoder.prototype.emitNotTerminatedNamedEntity = function() {\n-                        var _a;\n-                        var _b = this,\n-                            result = _b.result,\n-                            decodeTree = _b.decodeTree;\n-                        var valueLength = (decodeTree[result] & BinTrieFlags.VALUE_LENGTH) >> 14;\n-                        this.emitNamedEntityData(result, valueLength, this.consumed);\n-                        (_a = this.errors) === null || _a === void 0 ? void 0 : _a.missingSemicolonAfterCharacterReference();\n-                        return this.consumed;\n-                    };\n-                    /**\n-                     * Emit a named entity.\n-                     *\n-                     * @param result The index of the entity in the decode tree.\n-                     * @param valueLength The number of bytes in the entity.\n-                     * @param consumed The number of characters consumed.\n-                     *\n-                     * @returns The number of characters consumed.\n-                     */\n-                    EntityDecoder.prototype.emitNamedEntityData = function(result, valueLength, consumed) {\n-                        var decodeTree = this.decodeTree;\n-                        this.emitCodePoint(valueLength === 1 ? decodeTree[result] & ~BinTrieFlags.VALUE_LENGTH : decodeTree[result + 1], consumed);\n-                        if (valueLength === 3) {\n-                            // For multi-byte values, we need to emit the second byte.\n-                            this.emitCodePoint(decodeTree[result + 2], consumed);\n-                        }\n-                        return consumed;\n-                    };\n-                    /**\n-                     * Signal to the parser that the end of the input was reached.\n-                     *\n-                     * Remaining data will be emitted and relevant errors will be produced.\n-                     *\n-                     * @returns The number of characters consumed.\n-                     */\n-                    EntityDecoder.prototype.end = function() {\n-                        var _a;\n-                        switch (this.state) {\n-                            case EntityDecoderState.NamedEntity: {\n-                                // Emit a named entity if we have one.\n-                                return this.result !== 0 && (this.decodeMode !== DecodingMode.Attribute || this.result === this.treeIndex) ? this.emitNotTerminatedNamedEntity() : 0;\n-                            }\n-                            // Otherwise, emit a numeric entity if we have one.\n-                            case EntityDecoderState.NumericDecimal: {\n-                                return this.emitNumericEntity(0, 2);\n-                            }\n-                            case EntityDecoderState.NumericHex: {\n-                                return this.emitNumericEntity(0, 3);\n-                            }\n-                            case EntityDecoderState.NumericStart: {\n-                                (_a = this.errors) === null || _a === void 0 ? void 0 : _a.absenceOfDigitsInNumericCharacterReference(this.consumed);\n-                                return 0;\n-                            }\n-                            case EntityDecoderState.EntityStart: {\n-                                // Return 0 if we have no entity.\n-                                return 0;\n+                        var range = getRange(true);\n+                        if (getOption(cm, options, \"scanUp\"))\n+                            while (!range && pos.line > cm.firstLine()) {\n+                                pos = CodeMirror.Pos(pos.line - 1, 0);\n+                                range = getRange(false);\n                             }\n+                        if (!range || range.cleared || force === \"unfold\") return;\n+                        var myWidget = makeWidget(cm, options, range);\n+                        CodeMirror.on(myWidget, \"mousedown\", function(e) {\n+                            myRange.clear();\n+                            CodeMirror.e_preventDefault(e);\n+                        });\n+                        var myRange = cm.markText(range.from, range.to, {\n+                            replacedWith: myWidget,\n+                            clearOnEnter: getOption(cm, options, \"clearOnEnter\"),\n+                            __isFold: true\n+                        });\n+                        myRange.on(\"clear\", function(from, to) {\n+                            CodeMirror.signal(cm, \"unfold\", cm, from, to);\n+                        });\n+                        CodeMirror.signal(cm, \"fold\", cm, range.from, range.to);\n+                    }\n+\n+                    function makeWidget(cm, options, range) {\n+                        var widget = getOption(cm, options, \"widget\");\n+                        if (typeof widget == \"function\") {\n+                            widget = widget(range.from, range.to);\n                         }\n+                        if (typeof widget == \"string\") {\n+                            var text = document.createTextNode(widget);\n+                            widget = document.createElement(\"span\");\n+                            widget.appendChild(text);\n+                            widget.className = \"CodeMirror-foldmarker\";\n+                        } else if (widget) {\n+                            widget = widget.cloneNode(true);\n+                        }\n+                        return widget;\n+                    }\n+\n+                    // Clumsy backwards-compatible interface\n+                    CodeMirror.newFoldFunction = function(rangeFinder, widget) {\n+                        return function(cm, pos) {\n+                            doFold(cm, pos, {\n+                                rangeFinder: rangeFinder,\n+                                widget: widget\n+                            });\n+                        };\n                     };\n-                    return EntityDecoder;\n-                }();\n-                exports.EntityDecoder = EntityDecoder;\n-                /**\n-                 * Creates a function that decodes entities in a string.\n-                 *\n-                 * @param decodeTree The decode tree.\n-                 * @returns A function that decodes entities in a string.\n-                 */\n-                function getDecoder(decodeTree) {\n-                    var ret = \"\";\n-                    var decoder = new EntityDecoder(decodeTree, function(str) {\n-                        return ret += (0, decode_codepoint_js_1.fromCodePoint)(str);\n+\n+                    // New-style interface\n+                    CodeMirror.defineExtension(\"foldCode\", function(pos, options, force) {\n+                        doFold(this, pos, options, force);\n                     });\n-                    return function decodeWithTrie(str, decodeMode) {\n-                        var lastIndex = 0;\n-                        var offset = 0;\n-                        while ((offset = str.indexOf(\"&\", offset)) >= 0) {\n-                            ret += str.slice(lastIndex, offset);\n-                            decoder.startEntity(decodeMode);\n-                            var len = decoder.write(str,\n-                                // Skip the \"&\"\n-                                offset + 1);\n-                            if (len < 0) {\n-                                lastIndex = offset + decoder.end();\n-                                break;\n+                    CodeMirror.defineExtension(\"isFolded\", function(pos) {\n+                        var marks = this.findMarksAt(pos);\n+                        for (var i = 0; i < marks.length; ++i)\n+                            if (marks[i].__isFold) return true;\n+                    });\n+                    CodeMirror.commands.toggleFold = function(cm) {\n+                        cm.foldCode(cm.getCursor());\n+                    };\n+                    CodeMirror.commands.fold = function(cm) {\n+                        cm.foldCode(cm.getCursor(), null, \"fold\");\n+                    };\n+                    CodeMirror.commands.unfold = function(cm) {\n+                        cm.foldCode(cm.getCursor(), {\n+                            scanUp: false\n+                        }, \"unfold\");\n+                    };\n+                    CodeMirror.commands.foldAll = function(cm) {\n+                        cm.operation(function() {\n+                            for (var i = cm.firstLine(), e = cm.lastLine(); i <= e; i++) cm.foldCode(CodeMirror.Pos(i, 0), {\n+                                scanUp: false\n+                            }, \"fold\");\n+                        });\n+                    };\n+                    CodeMirror.commands.unfoldAll = function(cm) {\n+                        cm.operation(function() {\n+                            for (var i = cm.firstLine(), e = cm.lastLine(); i <= e; i++) cm.foldCode(CodeMirror.Pos(i, 0), {\n+                                scanUp: false\n+                            }, \"unfold\");\n+                        });\n+                    };\n+                    CodeMirror.registerHelper(\"fold\", \"combine\", function() {\n+                        var funcs = Array.prototype.slice.call(arguments, 0);\n+                        return function(cm, start) {\n+                            for (var i = 0; i < funcs.length; ++i) {\n+                                var found = funcs[i](cm, start);\n+                                if (found) return found;\n                             }\n-                            lastIndex = offset + len;\n-                            // If `len` is 0, skip the current `&` and continue.\n-                            offset = len === 0 ? lastIndex + 1 : lastIndex;\n+                        };\n+                    });\n+                    CodeMirror.registerHelper(\"fold\", \"auto\", function(cm, start) {\n+                        var helpers = cm.getHelpers(start, \"fold\");\n+                        for (var i = 0; i < helpers.length; i++) {\n+                            var cur = helpers[i](cm, start);\n+                            if (cur) return cur;\n                         }\n-                        var result = ret + str.slice(lastIndex);\n-                        // Make sure we don't keep a reference to the final string.\n-                        ret = \"\";\n-                        return result;\n+                    });\n+                    var defaultOptions = {\n+                        rangeFinder: CodeMirror.fold.auto,\n+                        widget: \"\\u2194\",\n+                        minFoldSize: 0,\n+                        scanUp: false,\n+                        clearOnEnter: true\n                     };\n-                }\n-                /**\n-                 * Determines the branch of the current node that is taken given the current\n-                 * character. This function is used to traverse the trie.\n-                 *\n-                 * @param decodeTree The trie.\n-                 * @param current The current node.\n-                 * @param nodeIdx The index right after the current node and its value.\n-                 * @param char The current character.\n-                 * @returns The index of the next node, or -1 if no branch is taken.\n-                 */\n-                function determineBranch(decodeTree, current, nodeIdx, char) {\n-                    var branchCount = (current & BinTrieFlags.BRANCH_LENGTH) >> 7;\n-                    var jumpOffset = current & BinTrieFlags.JUMP_TABLE;\n-                    // Case 1: Single branch encoded in jump offset\n-                    if (branchCount === 0) {\n-                        return jumpOffset !== 0 && char === jumpOffset ? nodeIdx : -1;\n-                    }\n-                    // Case 2: Multiple branches encoded in jump table\n-                    if (jumpOffset) {\n-                        var value = char - jumpOffset;\n-                        return value < 0 || value >= branchCount ? -1 : decodeTree[nodeIdx + value] - 1;\n-                    }\n-                    // Case 3: Multiple branches encoded in dictionary\n-                    // Binary search for the character.\n-                    var lo = nodeIdx;\n-                    var hi = lo + branchCount - 1;\n-                    while (lo <= hi) {\n-                        var mid = lo + hi >>> 1;\n-                        var midVal = decodeTree[mid];\n-                        if (midVal < char) {\n-                            lo = mid + 1;\n-                        } else if (midVal > char) {\n-                            hi = mid - 1;\n-                        } else {\n-                            return decodeTree[mid + branchCount];\n-                        }\n-                    }\n-                    return -1;\n-                }\n-                exports.determineBranch = determineBranch;\n-                var htmlDecoder = getDecoder(decode_data_html_js_1.default);\n-                var xmlDecoder = getDecoder(decode_data_xml_js_1.default);\n-                /**\n-                 * Decodes an HTML string.\n-                 *\n-                 * @param str The string to decode.\n-                 * @param mode The decoding mode.\n-                 * @returns The decoded string.\n-                 */\n-                function decodeHTML(str, mode) {\n-                    if (mode === void 0) {\n-                        mode = DecodingMode.Legacy;\n+                    CodeMirror.defineOption(\"foldOptions\", null);\n+\n+                    function getOption(cm, options, name) {\n+                        if (options && options[name] !== undefined) return options[name];\n+                        var editorOptions = cm.options.foldOptions;\n+                        if (editorOptions && editorOptions[name] !== undefined) return editorOptions[name];\n+                        return defaultOptions[name];\n                     }\n-                    return htmlDecoder(str, mode);\n-                }\n-                exports.decodeHTML = decodeHTML;\n-                /**\n-                 * Decodes an HTML string in an attribute.\n-                 *\n-                 * @param str The string to decode.\n-                 * @returns The decoded string.\n-                 */\n-                function decodeHTMLAttribute(str) {\n-                    return htmlDecoder(str, DecodingMode.Attribute);\n-                }\n-                exports.decodeHTMLAttribute = decodeHTMLAttribute;\n-                /**\n-                 * Decodes an HTML string, requiring all entities to be terminated by a semicolon.\n-                 *\n-                 * @param str The string to decode.\n-                 * @returns The decoded string.\n-                 */\n-                function decodeHTMLStrict(str) {\n-                    return htmlDecoder(str, DecodingMode.Strict);\n-                }\n-                exports.decodeHTMLStrict = decodeHTMLStrict;\n-                /**\n-                 * Decodes an XML string, requiring all entities to be terminated by a semicolon.\n-                 *\n-                 * @param str The string to decode.\n-                 * @returns The decoded string.\n-                 */\n-                function decodeXML(str) {\n-                    return xmlDecoder(str, DecodingMode.Strict);\n-                }\n-                exports.decodeXML = decodeXML;\n+                    CodeMirror.defineExtension(\"foldOption\", function(options, name) {\n+                        return getOption(this, options, name);\n+                    });\n+                });\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/entities/lib/decode_codepoint.js\":\n-            /*!**************************************************************!*\\\n-              !*** ../../../node_modules/entities/lib/decode_codepoint.js ***!\n-              \\**************************************************************/\n+        \"../../../node_modules/codemirror/addon/fold/foldgutter.js\":\n+            /*!*****************************************************************!*\\\n+              !*** ../../../node_modules/codemirror/addon/fold/foldgutter.js ***!\n+              \\*****************************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports) {\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                // Adapted from https://github.com/mathiasbynens/he/blob/36afe179392226cf1b6ccdb16ebbb7a5a844d93a/src/he.js#L106-L134\n-                var _a;\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.replaceCodePoint = exports.fromCodePoint = void 0;\n-                var decodeMap = new Map([\n-                    [0, 65533],\n-                    // C1 Unicode control character reference replacements\n-                    [128, 8364],\n-                    [130, 8218],\n-                    [131, 402],\n-                    [132, 8222],\n-                    [133, 8230],\n-                    [134, 8224],\n-                    [135, 8225],\n-                    [136, 710],\n-                    [137, 8240],\n-                    [138, 352],\n-                    [139, 8249],\n-                    [140, 338],\n-                    [142, 381],\n-                    [145, 8216],\n-                    [146, 8217],\n-                    [147, 8220],\n-                    [148, 8221],\n-                    [149, 8226],\n-                    [150, 8211],\n-                    [151, 8212],\n-                    [152, 732],\n-                    [153, 8482],\n-                    [154, 353],\n-                    [155, 8250],\n-                    [156, 339],\n-                    [158, 382],\n-                    [159, 376]\n-                ]);\n-                /**\n-                 * Polyfill for `String.fromCodePoint`. It is used to create a string from a Unicode code point.\n-                 */\n-                exports.fromCodePoint =\n-                    // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition, node/no-unsupported-features/es-builtins\n-                    (_a = String.fromCodePoint) !== null && _a !== void 0 ? _a : function(codePoint) {\n-                        var output = \"\";\n-                        if (codePoint > 0xffff) {\n-                            codePoint -= 0x10000;\n-                            output += String.fromCharCode(codePoint >>> 10 & 0x3ff | 0xd800);\n-                            codePoint = 0xdc00 | codePoint & 0x3ff;\n+                // CodeMirror, copyright (c) by Marijn Haverbeke and others\n+                // Distributed under an MIT license: https://codemirror.net/LICENSE\n+\n+                (function(mod) {\n+                    if (true)\n+                        // CommonJS\n+                        mod(__webpack_require__( /*! ../../lib/codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"), __webpack_require__( /*! ./foldcode */ \"../../../node_modules/codemirror/addon/fold/foldcode.js\"));\n+                    else {}\n+                })(function(CodeMirror) {\n+                    \"use strict\";\n+\n+                    CodeMirror.defineOption(\"foldGutter\", false, function(cm, val, old) {\n+                        if (old && old != CodeMirror.Init) {\n+                            cm.clearGutter(cm.state.foldGutter.options.gutter);\n+                            cm.state.foldGutter = null;\n+                            cm.off(\"gutterClick\", onGutterClick);\n+                            cm.off(\"changes\", onChange);\n+                            cm.off(\"viewportChange\", onViewportChange);\n+                            cm.off(\"fold\", onFold);\n+                            cm.off(\"unfold\", onFold);\n+                            cm.off(\"swapDoc\", onChange);\n+                        }\n+                        if (val) {\n+                            cm.state.foldGutter = new State(parseOptions(val));\n+                            updateInViewport(cm);\n+                            cm.on(\"gutterClick\", onGutterClick);\n+                            cm.on(\"changes\", onChange);\n+                            cm.on(\"viewportChange\", onViewportChange);\n+                            cm.on(\"fold\", onFold);\n+                            cm.on(\"unfold\", onFold);\n+                            cm.on(\"swapDoc\", onChange);\n+                        }\n+                    });\n+                    var Pos = CodeMirror.Pos;\n+\n+                    function State(options) {\n+                        this.options = options;\n+                        this.from = this.to = 0;\n+                    }\n+\n+                    function parseOptions(opts) {\n+                        if (opts === true) opts = {};\n+                        if (opts.gutter == null) opts.gutter = \"CodeMirror-foldgutter\";\n+                        if (opts.indicatorOpen == null) opts.indicatorOpen = \"CodeMirror-foldgutter-open\";\n+                        if (opts.indicatorFolded == null) opts.indicatorFolded = \"CodeMirror-foldgutter-folded\";\n+                        return opts;\n+                    }\n+\n+                    function isFolded(cm, line) {\n+                        var marks = cm.findMarks(Pos(line, 0), Pos(line + 1, 0));\n+                        for (var i = 0; i < marks.length; ++i) {\n+                            if (marks[i].__isFold) {\n+                                var fromPos = marks[i].find(-1);\n+                                if (fromPos && fromPos.line === line) return marks[i];\n+                            }\n+                        }\n+                    }\n+\n+                    function marker(spec) {\n+                        if (typeof spec == \"string\") {\n+                            var elt = document.createElement(\"div\");\n+                            elt.className = spec + \" CodeMirror-guttermarker-subtle\";\n+                            return elt;\n+                        } else {\n+                            return spec.cloneNode(true);\n                         }\n-                        output += String.fromCharCode(codePoint);\n-                        return output;\n-                    };\n-                /**\n-                 * Replace the given code point with a replacement character if it is a\n-                 * surrogate or is outside the valid range. Otherwise return the code\n-                 * point unchanged.\n-                 */\n-                function replaceCodePoint(codePoint) {\n-                    var _a;\n-                    if (codePoint >= 0xd800 && codePoint <= 0xdfff || codePoint > 0x10ffff) {\n-                        return 0xfffd;\n                     }\n-                    return (_a = decodeMap.get(codePoint)) !== null && _a !== void 0 ? _a : codePoint;\n-                }\n-                exports.replaceCodePoint = replaceCodePoint;\n-                /**\n-                 * Replace the code point if relevant, then convert it to a string.\n-                 *\n-                 * @deprecated Use `fromCodePoint(replaceCodePoint(codePoint))` instead.\n-                 * @param codePoint The code point to decode.\n-                 * @returns The decoded code point.\n-                 */\n-                function decodeCodePoint(codePoint) {\n-                    return (0, exports.fromCodePoint)(replaceCodePoint(codePoint));\n-                }\n-                exports[\"default\"] = decodeCodePoint;\n+\n+                    function updateFoldInfo(cm, from, to) {\n+                        var opts = cm.state.foldGutter.options,\n+                            cur = from - 1;\n+                        var minSize = cm.foldOption(opts, \"minFoldSize\");\n+                        var func = cm.foldOption(opts, \"rangeFinder\");\n+                        // we can reuse the built-in indicator element if its className matches the new state\n+                        var clsFolded = typeof opts.indicatorFolded == \"string\" && classTest(opts.indicatorFolded);\n+                        var clsOpen = typeof opts.indicatorOpen == \"string\" && classTest(opts.indicatorOpen);\n+                        cm.eachLine(from, to, function(line) {\n+                            ++cur;\n+                            var mark = null;\n+                            var old = line.gutterMarkers;\n+                            if (old) old = old[opts.gutter];\n+                            if (isFolded(cm, cur)) {\n+                                if (clsFolded && old && clsFolded.test(old.className)) return;\n+                                mark = marker(opts.indicatorFolded);\n+                            } else {\n+                                var pos = Pos(cur, 0);\n+                                var range = func && func(cm, pos);\n+                                if (range && range.to.line - range.from.line >= minSize) {\n+                                    if (clsOpen && old && clsOpen.test(old.className)) return;\n+                                    mark = marker(opts.indicatorOpen);\n+                                }\n+                            }\n+                            if (!mark && !old) return;\n+                            cm.setGutterMarker(line, opts.gutter, mark);\n+                        });\n+                    }\n+\n+                    // copied from CodeMirror/src/util/dom.js\n+                    function classTest(cls) {\n+                        return new RegExp(\"(^|\\\\s)\" + cls + \"(?:$|\\\\s)\\\\s*\");\n+                    }\n+\n+                    function updateInViewport(cm) {\n+                        var vp = cm.getViewport(),\n+                            state = cm.state.foldGutter;\n+                        if (!state) return;\n+                        cm.operation(function() {\n+                            updateFoldInfo(cm, vp.from, vp.to);\n+                        });\n+                        state.from = vp.from;\n+                        state.to = vp.to;\n+                    }\n+\n+                    function onGutterClick(cm, line, gutter) {\n+                        var state = cm.state.foldGutter;\n+                        if (!state) return;\n+                        var opts = state.options;\n+                        if (gutter != opts.gutter) return;\n+                        var folded = isFolded(cm, line);\n+                        if (folded) folded.clear();\n+                        else cm.foldCode(Pos(line, 0), opts);\n+                    }\n+\n+                    function onChange(cm) {\n+                        var state = cm.state.foldGutter;\n+                        if (!state) return;\n+                        var opts = state.options;\n+                        state.from = state.to = 0;\n+                        clearTimeout(state.changeUpdate);\n+                        state.changeUpdate = setTimeout(function() {\n+                            updateInViewport(cm);\n+                        }, opts.foldOnChangeTimeSpan || 600);\n+                    }\n+\n+                    function onViewportChange(cm) {\n+                        var state = cm.state.foldGutter;\n+                        if (!state) return;\n+                        var opts = state.options;\n+                        clearTimeout(state.changeUpdate);\n+                        state.changeUpdate = setTimeout(function() {\n+                            var vp = cm.getViewport();\n+                            if (state.from == state.to || vp.from - state.to > 20 || state.from - vp.to > 20) {\n+                                updateInViewport(cm);\n+                            } else {\n+                                cm.operation(function() {\n+                                    if (vp.from < state.from) {\n+                                        updateFoldInfo(cm, vp.from, state.from);\n+                                        state.from = vp.from;\n+                                    }\n+                                    if (vp.to > state.to) {\n+                                        updateFoldInfo(cm, state.to, vp.to);\n+                                        state.to = vp.to;\n+                                    }\n+                                });\n+                            }\n+                        }, opts.updateViewportTimeSpan || 400);\n+                    }\n+\n+                    function onFold(cm, from) {\n+                        var state = cm.state.foldGutter;\n+                        if (!state) return;\n+                        var line = from.line;\n+                        if (line >= state.from && line < state.to) updateFoldInfo(cm, line, line + 1);\n+                    }\n+                });\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/entities/lib/encode.js\":\n-            /*!****************************************************!*\\\n-              !*** ../../../node_modules/entities/lib/encode.js ***!\n-              \\****************************************************/\n+        \"../../../node_modules/codemirror/addon/hint/show-hint.js\":\n+            /*!****************************************************************!*\\\n+              !*** ../../../node_modules/codemirror/addon/hint/show-hint.js ***!\n+              \\****************************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                var __importDefault = void 0 && (void 0).__importDefault || function(mod) {\n-                    return mod && mod.__esModule ? mod : {\n-                        \"default\": mod\n+                // CodeMirror, copyright (c) by Marijn Haverbeke and others\n+                // Distributed under an MIT license: https://codemirror.net/LICENSE\n+\n+                // declare global: DOMRect\n+\n+                (function(mod) {\n+                    if (true)\n+                        // CommonJS\n+                        mod(__webpack_require__( /*! ../../lib/codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"));\n+                    else {}\n+                })(function(CodeMirror) {\n+                    \"use strict\";\n+\n+                    var HINT_ELEMENT_CLASS = \"CodeMirror-hint\";\n+                    var ACTIVE_HINT_ELEMENT_CLASS = \"CodeMirror-hint-active\";\n+\n+                    // This is the old interface, kept around for now to stay\n+                    // backwards-compatible.\n+                    CodeMirror.showHint = function(cm, getHints, options) {\n+                        if (!getHints) return cm.showHint(options);\n+                        if (options && options.async) getHints.async = true;\n+                        var newOpts = {\n+                            hint: getHints\n+                        };\n+                        if (options)\n+                            for (var prop in options) newOpts[prop] = options[prop];\n+                        return cm.showHint(newOpts);\n+                    };\n+                    CodeMirror.defineExtension(\"showHint\", function(options) {\n+                        options = parseOptions(this, this.getCursor(\"start\"), options);\n+                        var selections = this.listSelections();\n+                        if (selections.length > 1) return;\n+                        // By default, don't allow completion when something is selected.\n+                        // A hint function can have a `supportsSelection` property to\n+                        // indicate that it can handle selections.\n+                        if (this.somethingSelected()) {\n+                            if (!options.hint.supportsSelection) return;\n+                            // Don't try with cross-line selections\n+                            for (var i = 0; i < selections.length; i++)\n+                                if (selections[i].head.line != selections[i].anchor.line) return;\n+                        }\n+                        if (this.state.completionActive) this.state.completionActive.close();\n+                        var completion = this.state.completionActive = new Completion(this, options);\n+                        if (!completion.options.hint) return;\n+                        CodeMirror.signal(this, \"startCompletion\", this);\n+                        completion.update(true);\n+                    });\n+                    CodeMirror.defineExtension(\"closeHint\", function() {\n+                        if (this.state.completionActive) this.state.completionActive.close();\n+                    });\n+\n+                    function Completion(cm, options) {\n+                        this.cm = cm;\n+                        this.options = options;\n+                        this.widget = null;\n+                        this.debounce = 0;\n+                        this.tick = 0;\n+                        this.startPos = this.cm.getCursor(\"start\");\n+                        this.startLen = this.cm.getLine(this.startPos.line).length - this.cm.getSelection().length;\n+                        if (this.options.updateOnCursorActivity) {\n+                            var self = this;\n+                            cm.on(\"cursorActivity\", this.activityFunc = function() {\n+                                self.cursorActivity();\n+                            });\n+                        }\n+                    }\n+                    var requestAnimationFrame = window.requestAnimationFrame || function(fn) {\n+                        return setTimeout(fn, 1000 / 60);\n+                    };\n+                    var cancelAnimationFrame = window.cancelAnimationFrame || clearTimeout;\n+                    Completion.prototype = {\n+                        close: function() {\n+                            if (!this.active()) return;\n+                            this.cm.state.completionActive = null;\n+                            this.tick = null;\n+                            if (this.options.updateOnCursorActivity) {\n+                                this.cm.off(\"cursorActivity\", this.activityFunc);\n+                            }\n+                            if (this.widget && this.data) CodeMirror.signal(this.data, \"close\");\n+                            if (this.widget) this.widget.close();\n+                            CodeMirror.signal(this.cm, \"endCompletion\", this.cm);\n+                        },\n+                        active: function() {\n+                            return this.cm.state.completionActive == this;\n+                        },\n+                        pick: function(data, i) {\n+                            var completion = data.list[i],\n+                                self = this;\n+                            this.cm.operation(function() {\n+                                if (completion.hint) completion.hint(self.cm, data, completion);\n+                                else self.cm.replaceRange(getText(completion), completion.from || data.from, completion.to || data.to, \"complete\");\n+                                CodeMirror.signal(data, \"pick\", completion);\n+                                self.cm.scrollIntoView();\n+                            });\n+                            if (this.options.closeOnPick) {\n+                                this.close();\n+                            }\n+                        },\n+                        cursorActivity: function() {\n+                            if (this.debounce) {\n+                                cancelAnimationFrame(this.debounce);\n+                                this.debounce = 0;\n+                            }\n+                            var identStart = this.startPos;\n+                            if (this.data) {\n+                                identStart = this.data.from;\n+                            }\n+                            var pos = this.cm.getCursor(),\n+                                line = this.cm.getLine(pos.line);\n+                            if (pos.line != this.startPos.line || line.length - pos.ch != this.startLen - this.startPos.ch || pos.ch < identStart.ch || this.cm.somethingSelected() || !pos.ch || this.options.closeCharacters.test(line.charAt(pos.ch - 1))) {\n+                                this.close();\n+                            } else {\n+                                var self = this;\n+                                this.debounce = requestAnimationFrame(function() {\n+                                    self.update();\n+                                });\n+                                if (this.widget) this.widget.disable();\n+                            }\n+                        },\n+                        update: function(first) {\n+                            if (this.tick == null) return;\n+                            var self = this,\n+                                myTick = ++this.tick;\n+                            fetchHints(this.options.hint, this.cm, this.options, function(data) {\n+                                if (self.tick == myTick) self.finishUpdate(data, first);\n+                            });\n+                        },\n+                        finishUpdate: function(data, first) {\n+                            if (this.data) CodeMirror.signal(this.data, \"update\");\n+                            var picked = this.widget && this.widget.picked || first && this.options.completeSingle;\n+                            if (this.widget) this.widget.close();\n+                            this.data = data;\n+                            if (data && data.list.length) {\n+                                if (picked && data.list.length == 1) {\n+                                    this.pick(data, 0);\n+                                } else {\n+                                    this.widget = new Widget(this, data);\n+                                    CodeMirror.signal(data, \"shown\");\n+                                }\n+                            }\n+                        }\n                     };\n-                };\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.encodeNonAsciiHTML = exports.encodeHTML = void 0;\n-                var encode_html_js_1 = __importDefault(__webpack_require__( /*! ./generated/encode-html.js */ \"../../../node_modules/entities/lib/generated/encode-html.js\"));\n-                var escape_js_1 = __webpack_require__( /*! ./escape.js */ \"../../../node_modules/entities/lib/escape.js\");\n-                var htmlReplacer = /[\\t\\n!-,./:-@[-`\\f{-}$\\x80-\\uFFFF]/g;\n-                /**\n-                 * Encodes all characters in the input using HTML entities. This includes\n-                 * characters that are valid ASCII characters in HTML documents, such as `#`.\n-                 *\n-                 * To get a more compact output, consider using the `encodeNonAsciiHTML`\n-                 * function, which will only encode characters that are not valid in HTML\n-                 * documents, as well as non-ASCII characters.\n-                 *\n-                 * If a character has no equivalent entity, a numeric hexadecimal reference\n-                 * (eg. `&#xfc;`) will be used.\n-                 */\n-                function encodeHTML(data) {\n-                    return encodeHTMLTrieRe(htmlReplacer, data);\n-                }\n-                exports.encodeHTML = encodeHTML;\n-                /**\n-                 * Encodes all non-ASCII characters, as well as characters not valid in HTML\n-                 * documents using HTML entities. This function will not encode characters that\n-                 * are valid in HTML documents, such as `#`.\n-                 *\n-                 * If a character has no equivalent entity, a numeric hexadecimal reference\n-                 * (eg. `&#xfc;`) will be used.\n-                 */\n-                function encodeNonAsciiHTML(data) {\n-                    return encodeHTMLTrieRe(escape_js_1.xmlReplacer, data);\n-                }\n-                exports.encodeNonAsciiHTML = encodeNonAsciiHTML;\n \n-                function encodeHTMLTrieRe(regExp, str) {\n-                    var ret = \"\";\n-                    var lastIdx = 0;\n-                    var match;\n-                    while ((match = regExp.exec(str)) !== null) {\n-                        var i = match.index;\n-                        ret += str.substring(lastIdx, i);\n-                        var char = str.charCodeAt(i);\n-                        var next = encode_html_js_1.default.get(char);\n-                        if (typeof next === \"object\") {\n-                            // We are in a branch. Try to match the next char.\n-                            if (i + 1 < str.length) {\n-                                var nextChar = str.charCodeAt(i + 1);\n-                                var value = typeof next.n === \"number\" ? next.n === nextChar ? next.o : undefined : next.n.get(nextChar);\n-                                if (value !== undefined) {\n-                                    ret += value;\n-                                    lastIdx = regExp.lastIndex += 1;\n-                                    continue;\n+                    function parseOptions(cm, pos, options) {\n+                        var editor = cm.options.hintOptions;\n+                        var out = {};\n+                        for (var prop in defaultOptions) out[prop] = defaultOptions[prop];\n+                        if (editor)\n+                            for (var prop in editor)\n+                                if (editor[prop] !== undefined) out[prop] = editor[prop];\n+                        if (options)\n+                            for (var prop in options)\n+                                if (options[prop] !== undefined) out[prop] = options[prop];\n+                        if (out.hint.resolve) out.hint = out.hint.resolve(cm, pos);\n+                        return out;\n+                    }\n+\n+                    function getText(completion) {\n+                        if (typeof completion == \"string\") return completion;\n+                        else return completion.text;\n+                    }\n+\n+                    function buildKeyMap(completion, handle) {\n+                        var baseMap = {\n+                            Up: function() {\n+                                handle.moveFocus(-1);\n+                            },\n+                            Down: function() {\n+                                handle.moveFocus(1);\n+                            },\n+                            PageUp: function() {\n+                                handle.moveFocus(-handle.menuSize() + 1, true);\n+                            },\n+                            PageDown: function() {\n+                                handle.moveFocus(handle.menuSize() - 1, true);\n+                            },\n+                            Home: function() {\n+                                handle.setFocus(0);\n+                            },\n+                            End: function() {\n+                                handle.setFocus(handle.length - 1);\n+                            },\n+                            Enter: handle.pick,\n+                            Tab: handle.pick,\n+                            Esc: handle.close\n+                        };\n+                        var mac = /Mac/.test(navigator.platform);\n+                        if (mac) {\n+                            baseMap[\"Ctrl-P\"] = function() {\n+                                handle.moveFocus(-1);\n+                            };\n+                            baseMap[\"Ctrl-N\"] = function() {\n+                                handle.moveFocus(1);\n+                            };\n+                        }\n+                        var custom = completion.options.customKeys;\n+                        var ourMap = custom ? {} : baseMap;\n+\n+                        function addBinding(key, val) {\n+                            var bound;\n+                            if (typeof val != \"string\") bound = function(cm) {\n+                                return val(cm, handle);\n+                            };\n+                            // This mechanism is deprecated\n+                            else if (baseMap.hasOwnProperty(val)) bound = baseMap[val];\n+                            else bound = val;\n+                            ourMap[key] = bound;\n+                        }\n+                        if (custom)\n+                            for (var key in custom)\n+                                if (custom.hasOwnProperty(key)) addBinding(key, custom[key]);\n+                        var extra = completion.options.extraKeys;\n+                        if (extra)\n+                            for (var key in extra)\n+                                if (extra.hasOwnProperty(key)) addBinding(key, extra[key]);\n+                        return ourMap;\n+                    }\n+\n+                    function getHintElement(hintsElement, el) {\n+                        while (el && el != hintsElement) {\n+                            if (el.nodeName.toUpperCase() === \"LI\" && el.parentNode == hintsElement) return el;\n+                            el = el.parentNode;\n+                        }\n+                    }\n+\n+                    function Widget(completion, data) {\n+                        this.id = \"cm-complete-\" + Math.floor(Math.random(1e6));\n+                        this.completion = completion;\n+                        this.data = data;\n+                        this.picked = false;\n+                        var widget = this,\n+                            cm = completion.cm;\n+                        var ownerDocument = cm.getInputField().ownerDocument;\n+                        var parentWindow = ownerDocument.defaultView || ownerDocument.parentWindow;\n+                        var hints = this.hints = ownerDocument.createElement(\"ul\");\n+                        hints.setAttribute(\"role\", \"listbox\");\n+                        hints.setAttribute(\"aria-expanded\", \"true\");\n+                        hints.id = this.id;\n+                        var theme = completion.cm.options.theme;\n+                        hints.className = \"CodeMirror-hints \" + theme;\n+                        this.selectedHint = data.selectedHint || 0;\n+                        var completions = data.list;\n+                        for (var i = 0; i < completions.length; ++i) {\n+                            var elt = hints.appendChild(ownerDocument.createElement(\"li\")),\n+                                cur = completions[i];\n+                            var className = HINT_ELEMENT_CLASS + (i != this.selectedHint ? \"\" : \" \" + ACTIVE_HINT_ELEMENT_CLASS);\n+                            if (cur.className != null) className = cur.className + \" \" + className;\n+                            elt.className = className;\n+                            if (i == this.selectedHint) elt.setAttribute(\"aria-selected\", \"true\");\n+                            elt.id = this.id + \"-\" + i;\n+                            elt.setAttribute(\"role\", \"option\");\n+                            if (cur.render) cur.render(elt, data, cur);\n+                            else elt.appendChild(ownerDocument.createTextNode(cur.displayText || getText(cur)));\n+                            elt.hintId = i;\n+                        }\n+                        var container = completion.options.container || ownerDocument.body;\n+                        var pos = cm.cursorCoords(completion.options.alignWithWord ? data.from : null);\n+                        var left = pos.left,\n+                            top = pos.bottom,\n+                            below = true;\n+                        var offsetLeft = 0,\n+                            offsetTop = 0;\n+                        if (container !== ownerDocument.body) {\n+                            // We offset the cursor position because left and top are relative to the offsetParent's top left corner.\n+                            var isContainerPositioned = ['absolute', 'relative', 'fixed'].indexOf(parentWindow.getComputedStyle(container).position) !== -1;\n+                            var offsetParent = isContainerPositioned ? container : container.offsetParent;\n+                            var offsetParentPosition = offsetParent.getBoundingClientRect();\n+                            var bodyPosition = ownerDocument.body.getBoundingClientRect();\n+                            offsetLeft = offsetParentPosition.left - bodyPosition.left - offsetParent.scrollLeft;\n+                            offsetTop = offsetParentPosition.top - bodyPosition.top - offsetParent.scrollTop;\n+                        }\n+                        hints.style.left = left - offsetLeft + \"px\";\n+                        hints.style.top = top - offsetTop + \"px\";\n+\n+                        // If we're at the edge of the screen, then we want the menu to appear on the left of the cursor.\n+                        var winW = parentWindow.innerWidth || Math.max(ownerDocument.body.offsetWidth, ownerDocument.documentElement.offsetWidth);\n+                        var winH = parentWindow.innerHeight || Math.max(ownerDocument.body.offsetHeight, ownerDocument.documentElement.offsetHeight);\n+                        container.appendChild(hints);\n+                        cm.getInputField().setAttribute(\"aria-autocomplete\", \"list\");\n+                        cm.getInputField().setAttribute(\"aria-owns\", this.id);\n+                        cm.getInputField().setAttribute(\"aria-activedescendant\", this.id + \"-\" + this.selectedHint);\n+                        var box = completion.options.moveOnOverlap ? hints.getBoundingClientRect() : new DOMRect();\n+                        var scrolls = completion.options.paddingForScrollbar ? hints.scrollHeight > hints.clientHeight + 1 : false;\n+\n+                        // Compute in the timeout to avoid reflow on init\n+                        var startScroll;\n+                        setTimeout(function() {\n+                            startScroll = cm.getScrollInfo();\n+                        });\n+                        var overlapY = box.bottom - winH;\n+                        if (overlapY > 0) {\n+                            var height = box.bottom - box.top,\n+                                curTop = pos.top - (pos.bottom - box.top);\n+                            if (curTop - height > 0) {\n+                                // Fits above cursor\n+                                hints.style.top = (top = pos.top - height - offsetTop) + \"px\";\n+                                below = false;\n+                            } else if (height > winH) {\n+                                hints.style.height = winH - 5 + \"px\";\n+                                hints.style.top = (top = pos.bottom - box.top - offsetTop) + \"px\";\n+                                var cursor = cm.getCursor();\n+                                if (data.from.ch != cursor.ch) {\n+                                    pos = cm.cursorCoords(cursor);\n+                                    hints.style.left = (left = pos.left - offsetLeft) + \"px\";\n+                                    box = hints.getBoundingClientRect();\n                                 }\n                             }\n-                            next = next.v;\n                         }\n-                        // We might have a tree node without a value; skip and use a numeric entity.\n-                        if (next !== undefined) {\n-                            ret += next;\n-                            lastIdx = i + 1;\n+                        var overlapX = box.right - winW;\n+                        if (scrolls) overlapX += cm.display.nativeBarWidth;\n+                        if (overlapX > 0) {\n+                            if (box.right - box.left > winW) {\n+                                hints.style.width = winW - 5 + \"px\";\n+                                overlapX -= box.right - box.left - winW;\n+                            }\n+                            hints.style.left = (left = pos.left - overlapX - offsetLeft) + \"px\";\n+                        }\n+                        if (scrolls)\n+                            for (var node = hints.firstChild; node; node = node.nextSibling) node.style.paddingRight = cm.display.nativeBarWidth + \"px\";\n+                        cm.addKeyMap(this.keyMap = buildKeyMap(completion, {\n+                            moveFocus: function(n, avoidWrap) {\n+                                widget.changeActive(widget.selectedHint + n, avoidWrap);\n+                            },\n+                            setFocus: function(n) {\n+                                widget.changeActive(n);\n+                            },\n+                            menuSize: function() {\n+                                return widget.screenAmount();\n+                            },\n+                            length: completions.length,\n+                            close: function() {\n+                                completion.close();\n+                            },\n+                            pick: function() {\n+                                widget.pick();\n+                            },\n+                            data: data\n+                        }));\n+                        if (completion.options.closeOnUnfocus) {\n+                            var closingOnBlur;\n+                            cm.on(\"blur\", this.onBlur = function() {\n+                                closingOnBlur = setTimeout(function() {\n+                                    completion.close();\n+                                }, 100);\n+                            });\n+                            cm.on(\"focus\", this.onFocus = function() {\n+                                clearTimeout(closingOnBlur);\n+                            });\n+                        }\n+                        cm.on(\"scroll\", this.onScroll = function() {\n+                            var curScroll = cm.getScrollInfo(),\n+                                editor = cm.getWrapperElement().getBoundingClientRect();\n+                            if (!startScroll) startScroll = cm.getScrollInfo();\n+                            var newTop = top + startScroll.top - curScroll.top;\n+                            var point = newTop - (parentWindow.pageYOffset || (ownerDocument.documentElement || ownerDocument.body).scrollTop);\n+                            if (!below) point += hints.offsetHeight;\n+                            if (point <= editor.top || point >= editor.bottom) return completion.close();\n+                            hints.style.top = newTop + \"px\";\n+                            hints.style.left = left + startScroll.left - curScroll.left + \"px\";\n+                        });\n+                        CodeMirror.on(hints, \"dblclick\", function(e) {\n+                            var t = getHintElement(hints, e.target || e.srcElement);\n+                            if (t && t.hintId != null) {\n+                                widget.changeActive(t.hintId);\n+                                widget.pick();\n+                            }\n+                        });\n+                        CodeMirror.on(hints, \"click\", function(e) {\n+                            var t = getHintElement(hints, e.target || e.srcElement);\n+                            if (t && t.hintId != null) {\n+                                widget.changeActive(t.hintId);\n+                                if (completion.options.completeOnSingleClick) widget.pick();\n+                            }\n+                        });\n+                        CodeMirror.on(hints, \"mousedown\", function() {\n+                            setTimeout(function() {\n+                                cm.focus();\n+                            }, 20);\n+                        });\n+\n+                        // The first hint doesn't need to be scrolled to on init\n+                        var selectedHintRange = this.getSelectedHintRange();\n+                        if (selectedHintRange.from !== 0 || selectedHintRange.to !== 0) {\n+                            this.scrollToActive();\n+                        }\n+                        CodeMirror.signal(data, \"select\", completions[this.selectedHint], hints.childNodes[this.selectedHint]);\n+                        return true;\n+                    }\n+                    Widget.prototype = {\n+                        close: function() {\n+                            if (this.completion.widget != this) return;\n+                            this.completion.widget = null;\n+                            if (this.hints.parentNode) this.hints.parentNode.removeChild(this.hints);\n+                            this.completion.cm.removeKeyMap(this.keyMap);\n+                            var input = this.completion.cm.getInputField();\n+                            input.removeAttribute(\"aria-activedescendant\");\n+                            input.removeAttribute(\"aria-owns\");\n+                            var cm = this.completion.cm;\n+                            if (this.completion.options.closeOnUnfocus) {\n+                                cm.off(\"blur\", this.onBlur);\n+                                cm.off(\"focus\", this.onFocus);\n+                            }\n+                            cm.off(\"scroll\", this.onScroll);\n+                        },\n+                        disable: function() {\n+                            this.completion.cm.removeKeyMap(this.keyMap);\n+                            var widget = this;\n+                            this.keyMap = {\n+                                Enter: function() {\n+                                    widget.picked = true;\n+                                }\n+                            };\n+                            this.completion.cm.addKeyMap(this.keyMap);\n+                        },\n+                        pick: function() {\n+                            this.completion.pick(this.data, this.selectedHint);\n+                        },\n+                        changeActive: function(i, avoidWrap) {\n+                            if (i >= this.data.list.length) i = avoidWrap ? this.data.list.length - 1 : 0;\n+                            else if (i < 0) i = avoidWrap ? 0 : this.data.list.length - 1;\n+                            if (this.selectedHint == i) return;\n+                            var node = this.hints.childNodes[this.selectedHint];\n+                            if (node) {\n+                                node.className = node.className.replace(\" \" + ACTIVE_HINT_ELEMENT_CLASS, \"\");\n+                                node.removeAttribute(\"aria-selected\");\n+                            }\n+                            node = this.hints.childNodes[this.selectedHint = i];\n+                            node.className += \" \" + ACTIVE_HINT_ELEMENT_CLASS;\n+                            node.setAttribute(\"aria-selected\", \"true\");\n+                            this.completion.cm.getInputField().setAttribute(\"aria-activedescendant\", node.id);\n+                            this.scrollToActive();\n+                            CodeMirror.signal(this.data, \"select\", this.data.list[this.selectedHint], node);\n+                        },\n+                        scrollToActive: function() {\n+                            var selectedHintRange = this.getSelectedHintRange();\n+                            var node1 = this.hints.childNodes[selectedHintRange.from];\n+                            var node2 = this.hints.childNodes[selectedHintRange.to];\n+                            var firstNode = this.hints.firstChild;\n+                            if (node1.offsetTop < this.hints.scrollTop) this.hints.scrollTop = node1.offsetTop - firstNode.offsetTop;\n+                            else if (node2.offsetTop + node2.offsetHeight > this.hints.scrollTop + this.hints.clientHeight) this.hints.scrollTop = node2.offsetTop + node2.offsetHeight - this.hints.clientHeight + firstNode.offsetTop;\n+                        },\n+                        screenAmount: function() {\n+                            return Math.floor(this.hints.clientHeight / this.hints.firstChild.offsetHeight) || 1;\n+                        },\n+                        getSelectedHintRange: function() {\n+                            var margin = this.completion.options.scrollMargin || 0;\n+                            return {\n+                                from: Math.max(0, this.selectedHint - margin),\n+                                to: Math.min(this.data.list.length - 1, this.selectedHint + margin)\n+                            };\n+                        }\n+                    };\n+\n+                    function applicableHelpers(cm, helpers) {\n+                        if (!cm.somethingSelected()) return helpers;\n+                        var result = [];\n+                        for (var i = 0; i < helpers.length; i++)\n+                            if (helpers[i].supportsSelection) result.push(helpers[i]);\n+                        return result;\n+                    }\n+\n+                    function fetchHints(hint, cm, options, callback) {\n+                        if (hint.async) {\n+                            hint(cm, callback, options);\n                         } else {\n-                            var cp = (0, escape_js_1.getCodePoint)(str, i);\n-                            ret += \"&#x\".concat(cp.toString(16), \";\");\n-                            // Increase by 1 if we have a surrogate pair\n-                            lastIdx = regExp.lastIndex += Number(cp !== char);\n+                            var result = hint(cm, options);\n+                            if (result && result.then) result.then(callback);\n+                            else callback(result);\n                         }\n                     }\n-                    return ret + str.substr(lastIdx);\n-                }\n+\n+                    function resolveAutoHints(cm, pos) {\n+                        var helpers = cm.getHelpers(pos, \"hint\"),\n+                            words;\n+                        if (helpers.length) {\n+                            var resolved = function(cm, callback, options) {\n+                                var app = applicableHelpers(cm, helpers);\n+\n+                                function run(i) {\n+                                    if (i == app.length) return callback(null);\n+                                    fetchHints(app[i], cm, options, function(result) {\n+                                        if (result && result.list.length > 0) callback(result);\n+                                        else run(i + 1);\n+                                    });\n+                                }\n+                                run(0);\n+                            };\n+                            resolved.async = true;\n+                            resolved.supportsSelection = true;\n+                            return resolved;\n+                        } else if (words = cm.getHelper(cm.getCursor(), \"hintWords\")) {\n+                            return function(cm) {\n+                                return CodeMirror.hint.fromList(cm, {\n+                                    words: words\n+                                });\n+                            };\n+                        } else if (CodeMirror.hint.anyword) {\n+                            return function(cm, options) {\n+                                return CodeMirror.hint.anyword(cm, options);\n+                            };\n+                        } else {\n+                            return function() {};\n+                        }\n+                    }\n+                    CodeMirror.registerHelper(\"hint\", \"auto\", {\n+                        resolve: resolveAutoHints\n+                    });\n+                    CodeMirror.registerHelper(\"hint\", \"fromList\", function(cm, options) {\n+                        var cur = cm.getCursor(),\n+                            token = cm.getTokenAt(cur);\n+                        var term,\n+                            from = CodeMirror.Pos(cur.line, token.start),\n+                            to = cur;\n+                        if (token.start < cur.ch && /\\w/.test(token.string.charAt(cur.ch - token.start - 1))) {\n+                            term = token.string.substr(0, cur.ch - token.start);\n+                        } else {\n+                            term = \"\";\n+                            from = cur;\n+                        }\n+                        var found = [];\n+                        for (var i = 0; i < options.words.length; i++) {\n+                            var word = options.words[i];\n+                            if (word.slice(0, term.length) == term) found.push(word);\n+                        }\n+                        if (found.length) return {\n+                            list: found,\n+                            from: from,\n+                            to: to\n+                        };\n+                    });\n+                    CodeMirror.commands.autocomplete = CodeMirror.showHint;\n+                    var defaultOptions = {\n+                        hint: CodeMirror.hint.auto,\n+                        completeSingle: true,\n+                        alignWithWord: true,\n+                        closeCharacters: /[\\s()\\[\\]{};:>,]/,\n+                        closeOnPick: true,\n+                        closeOnUnfocus: true,\n+                        updateOnCursorActivity: true,\n+                        completeOnSingleClick: true,\n+                        container: null,\n+                        customKeys: null,\n+                        extraKeys: null,\n+                        paddingForScrollbar: true,\n+                        moveOnOverlap: true\n+                    };\n+                    CodeMirror.defineOption(\"hintOptions\", null);\n+                });\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/entities/lib/escape.js\":\n-            /*!****************************************************!*\\\n-              !*** ../../../node_modules/entities/lib/escape.js ***!\n-              \\****************************************************/\n+        \"../../../node_modules/codemirror/addon/lint/lint.js\":\n+            /*!***********************************************************!*\\\n+              !*** ../../../node_modules/codemirror/addon/lint/lint.js ***!\n+              \\***********************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports) {\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.escapeText = exports.escapeAttribute = exports.escapeUTF8 = exports.escape = exports.encodeXML = exports.getCodePoint = exports.xmlReplacer = void 0;\n-                exports.xmlReplacer = /[\"&'<>$\\x80-\\uFFFF]/g;\n-                var xmlCodeMap = new Map([\n-                    [34, \"&quot;\"],\n-                    [38, \"&amp;\"],\n-                    [39, \"&apos;\"],\n-                    [60, \"&lt;\"],\n-                    [62, \"&gt;\"]\n-                ]);\n-                // For compatibility with node < 4, we wrap `codePointAt`\n-                exports.getCodePoint =\n-                    // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n-                    String.prototype.codePointAt != null ? function(str, index) {\n-                        return str.codePointAt(index);\n-                    } :\n-                    // http://mathiasbynens.be/notes/javascript-encoding#surrogate-formulae\n-                    function(c, index) {\n-                        return (c.charCodeAt(index) & 0xfc00) === 0xd800 ? (c.charCodeAt(index) - 0xd800) * 0x400 + c.charCodeAt(index + 1) - 0xdc00 + 0x10000 : c.charCodeAt(index);\n+                // CodeMirror, copyright (c) by Marijn Haverbeke and others\n+                // Distributed under an MIT license: https://codemirror.net/LICENSE\n+\n+                (function(mod) {\n+                    if (true)\n+                        // CommonJS\n+                        mod(__webpack_require__( /*! ../../lib/codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"));\n+                    else {}\n+                })(function(CodeMirror) {\n+                    \"use strict\";\n+\n+                    var GUTTER_ID = \"CodeMirror-lint-markers\";\n+                    var LINT_LINE_ID = \"CodeMirror-lint-line-\";\n+\n+                    function showTooltip(cm, e, content) {\n+                        var tt = document.createElement(\"div\");\n+                        tt.className = \"CodeMirror-lint-tooltip cm-s-\" + cm.options.theme;\n+                        tt.appendChild(content.cloneNode(true));\n+                        if (cm.state.lint.options.selfContain) cm.getWrapperElement().appendChild(tt);\n+                        else document.body.appendChild(tt);\n+\n+                        function position(e) {\n+                            if (!tt.parentNode) return CodeMirror.off(document, \"mousemove\", position);\n+                            tt.style.top = Math.max(0, e.clientY - tt.offsetHeight - 5) + \"px\";\n+                            tt.style.left = e.clientX + 5 + \"px\";\n+                        }\n+                        CodeMirror.on(document, \"mousemove\", position);\n+                        position(e);\n+                        if (tt.style.opacity != null) tt.style.opacity = 1;\n+                        return tt;\n+                    }\n+\n+                    function rm(elt) {\n+                        if (elt.parentNode) elt.parentNode.removeChild(elt);\n+                    }\n+\n+                    function hideTooltip(tt) {\n+                        if (!tt.parentNode) return;\n+                        if (tt.style.opacity == null) rm(tt);\n+                        tt.style.opacity = 0;\n+                        setTimeout(function() {\n+                            rm(tt);\n+                        }, 600);\n+                    }\n+\n+                    function showTooltipFor(cm, e, content, node) {\n+                        var tooltip = showTooltip(cm, e, content);\n+\n+                        function hide() {\n+                            CodeMirror.off(node, \"mouseout\", hide);\n+                            if (tooltip) {\n+                                hideTooltip(tooltip);\n+                                tooltip = null;\n+                            }\n+                        }\n+                        var poll = setInterval(function() {\n+                            if (tooltip)\n+                                for (var n = node;; n = n.parentNode) {\n+                                    if (n && n.nodeType == 11) n = n.host;\n+                                    if (n == document.body) return;\n+                                    if (!n) {\n+                                        hide();\n+                                        break;\n+                                    }\n+                                }\n+                            if (!tooltip) return clearInterval(poll);\n+                        }, 400);\n+                        CodeMirror.on(node, \"mouseout\", hide);\n+                    }\n+\n+                    function LintState(cm, conf, hasGutter) {\n+                        this.marked = [];\n+                        if (conf instanceof Function) conf = {\n+                            getAnnotations: conf\n+                        };\n+                        if (!conf || conf === true) conf = {};\n+                        this.options = {};\n+                        this.linterOptions = conf.options || {};\n+                        for (var prop in defaults) this.options[prop] = defaults[prop];\n+                        for (var prop in conf) {\n+                            if (defaults.hasOwnProperty(prop)) {\n+                                if (conf[prop] != null) this.options[prop] = conf[prop];\n+                            } else if (!conf.options) {\n+                                this.linterOptions[prop] = conf[prop];\n+                            }\n+                        }\n+                        this.timeout = null;\n+                        this.hasGutter = hasGutter;\n+                        this.onMouseOver = function(e) {\n+                            onMouseOver(cm, e);\n+                        };\n+                        this.waitingFor = 0;\n+                    }\n+                    var defaults = {\n+                        highlightLines: false,\n+                        tooltips: true,\n+                        delay: 500,\n+                        lintOnChange: true,\n+                        getAnnotations: null,\n+                        async: false,\n+                        selfContain: null,\n+                        formatAnnotation: null,\n+                        onUpdateLinting: null\n                     };\n-                /**\n-                 * Encodes all non-ASCII characters, as well as characters not valid in XML\n-                 * documents using XML entities.\n-                 *\n-                 * If a character has no equivalent entity, a\n-                 * numeric hexadecimal reference (eg. `&#xfc;`) will be used.\n-                 */\n-                function encodeXML(str) {\n-                    var ret = \"\";\n-                    var lastIdx = 0;\n-                    var match;\n-                    while ((match = exports.xmlReplacer.exec(str)) !== null) {\n-                        var i = match.index;\n-                        var char = str.charCodeAt(i);\n-                        var next = xmlCodeMap.get(char);\n-                        if (next !== undefined) {\n-                            ret += str.substring(lastIdx, i) + next;\n-                            lastIdx = i + 1;\n+\n+                    function clearMarks(cm) {\n+                        var state = cm.state.lint;\n+                        if (state.hasGutter) cm.clearGutter(GUTTER_ID);\n+                        if (state.options.highlightLines) clearErrorLines(cm);\n+                        for (var i = 0; i < state.marked.length; ++i) state.marked[i].clear();\n+                        state.marked.length = 0;\n+                    }\n+\n+                    function clearErrorLines(cm) {\n+                        cm.eachLine(function(line) {\n+                            var has = line.wrapClass && /\\bCodeMirror-lint-line-\\w+\\b/.exec(line.wrapClass);\n+                            if (has) cm.removeLineClass(line, \"wrap\", has[0]);\n+                        });\n+                    }\n+\n+                    function makeMarker(cm, labels, severity, multiple, tooltips) {\n+                        var marker = document.createElement(\"div\"),\n+                            inner = marker;\n+                        marker.className = \"CodeMirror-lint-marker CodeMirror-lint-marker-\" + severity;\n+                        if (multiple) {\n+                            inner = marker.appendChild(document.createElement(\"div\"));\n+                            inner.className = \"CodeMirror-lint-marker CodeMirror-lint-marker-multiple\";\n+                        }\n+                        if (tooltips != false) CodeMirror.on(inner, \"mouseover\", function(e) {\n+                            showTooltipFor(cm, e, labels, inner);\n+                        });\n+                        return marker;\n+                    }\n+\n+                    function getMaxSeverity(a, b) {\n+                        if (a == \"error\") return a;\n+                        else return b;\n+                    }\n+\n+                    function groupByLine(annotations) {\n+                        var lines = [];\n+                        for (var i = 0; i < annotations.length; ++i) {\n+                            var ann = annotations[i],\n+                                line = ann.from.line;\n+                            (lines[line] || (lines[line] = [])).push(ann);\n+                        }\n+                        return lines;\n+                    }\n+\n+                    function annotationTooltip(ann) {\n+                        var severity = ann.severity;\n+                        if (!severity) severity = \"error\";\n+                        var tip = document.createElement(\"div\");\n+                        tip.className = \"CodeMirror-lint-message CodeMirror-lint-message-\" + severity;\n+                        if (typeof ann.messageHTML != 'undefined') {\n+                            tip.innerHTML = ann.messageHTML;\n                         } else {\n-                            ret += \"\".concat(str.substring(lastIdx, i), \"&#x\").concat((0, exports.getCodePoint)(str, i).toString(16), \";\");\n-                            // Increase by 1 if we have a surrogate pair\n-                            lastIdx = exports.xmlReplacer.lastIndex += Number((char & 0xfc00) === 0xd800);\n+                            tip.appendChild(document.createTextNode(ann.message));\n                         }\n+                        return tip;\n                     }\n-                    return ret + str.substr(lastIdx);\n-                }\n-                exports.encodeXML = encodeXML;\n-                /**\n-                 * Encodes all non-ASCII characters, as well as characters not valid in XML\n-                 * documents using numeric hexadecimal reference (eg. `&#xfc;`).\n-                 *\n-                 * Have a look at `escapeUTF8` if you want a more concise output at the expense\n-                 * of reduced transportability.\n-                 *\n-                 * @param data String to escape.\n-                 */\n-                exports.escape = encodeXML;\n-                /**\n-                 * Creates a function that escapes all characters matched by the given regular\n-                 * expression using the given map of characters to escape to their entities.\n-                 *\n-                 * @param regex Regular expression to match characters to escape.\n-                 * @param map Map of characters to escape to their entities.\n-                 *\n-                 * @returns Function that escapes all characters matched by the given regular\n-                 * expression using the given map of characters to escape to their entities.\n-                 */\n-                function getEscaper(regex, map) {\n-                    return function escape(data) {\n-                        var match;\n-                        var lastIdx = 0;\n-                        var result = \"\";\n-                        while (match = regex.exec(data)) {\n-                            if (lastIdx !== match.index) {\n-                                result += data.substring(lastIdx, match.index);\n+\n+                    function lintAsync(cm, getAnnotations) {\n+                        var state = cm.state.lint;\n+                        var id = ++state.waitingFor;\n+\n+                        function abort() {\n+                            id = -1;\n+                            cm.off(\"change\", abort);\n+                        }\n+                        cm.on(\"change\", abort);\n+                        getAnnotations(cm.getValue(), function(annotations, arg2) {\n+                            cm.off(\"change\", abort);\n+                            if (state.waitingFor != id) return;\n+                            if (arg2 && annotations instanceof CodeMirror) annotations = arg2;\n+                            cm.operation(function() {\n+                                updateLinting(cm, annotations);\n+                            });\n+                        }, state.linterOptions, cm);\n+                    }\n+\n+                    function startLinting(cm) {\n+                        var state = cm.state.lint;\n+                        if (!state) return;\n+                        var options = state.options;\n+                        /*\n+                         * Passing rules in `options` property prevents JSHint (and other linters) from complaining\n+                         * about unrecognized rules like `onUpdateLinting`, `delay`, `lintOnChange`, etc.\n+                         */\n+                        var getAnnotations = options.getAnnotations || cm.getHelper(CodeMirror.Pos(0, 0), \"lint\");\n+                        if (!getAnnotations) return;\n+                        if (options.async || getAnnotations.async) {\n+                            lintAsync(cm, getAnnotations);\n+                        } else {\n+                            var annotations = getAnnotations(cm.getValue(), state.linterOptions, cm);\n+                            if (!annotations) return;\n+                            if (annotations.then) annotations.then(function(issues) {\n+                                cm.operation(function() {\n+                                    updateLinting(cm, issues);\n+                                });\n+                            });\n+                            else cm.operation(function() {\n+                                updateLinting(cm, annotations);\n+                            });\n+                        }\n+                    }\n+\n+                    function updateLinting(cm, annotationsNotSorted) {\n+                        var state = cm.state.lint;\n+                        if (!state) return;\n+                        var options = state.options;\n+                        clearMarks(cm);\n+                        var annotations = groupByLine(annotationsNotSorted);\n+                        for (var line = 0; line < annotations.length; ++line) {\n+                            var anns = annotations[line];\n+                            if (!anns) continue;\n+\n+                            // filter out duplicate messages\n+                            var message = [];\n+                            anns = anns.filter(function(item) {\n+                                return message.indexOf(item.message) > -1 ? false : message.push(item.message);\n+                            });\n+                            var maxSeverity = null;\n+                            var tipLabel = state.hasGutter && document.createDocumentFragment();\n+                            for (var i = 0; i < anns.length; ++i) {\n+                                var ann = anns[i];\n+                                var severity = ann.severity;\n+                                if (!severity) severity = \"error\";\n+                                maxSeverity = getMaxSeverity(maxSeverity, severity);\n+                                if (options.formatAnnotation) ann = options.formatAnnotation(ann);\n+                                if (state.hasGutter) tipLabel.appendChild(annotationTooltip(ann));\n+                                if (ann.to) state.marked.push(cm.markText(ann.from, ann.to, {\n+                                    className: \"CodeMirror-lint-mark CodeMirror-lint-mark-\" + severity,\n+                                    __annotation: ann\n+                                }));\n                             }\n-                            // We know that this character will be in the map.\n-                            result += map.get(match[0].charCodeAt(0));\n-                            // Every match will be of length 1\n-                            lastIdx = match.index + 1;\n+                            // use original annotations[line] to show multiple messages\n+                            if (state.hasGutter) cm.setGutterMarker(line, GUTTER_ID, makeMarker(cm, tipLabel, maxSeverity, annotations[line].length > 1, options.tooltips));\n+                            if (options.highlightLines) cm.addLineClass(line, \"wrap\", LINT_LINE_ID + maxSeverity);\n+                        }\n+                        if (options.onUpdateLinting) options.onUpdateLinting(annotationsNotSorted, annotations, cm);\n+                    }\n+\n+                    function onChange(cm) {\n+                        var state = cm.state.lint;\n+                        if (!state) return;\n+                        clearTimeout(state.timeout);\n+                        state.timeout = setTimeout(function() {\n+                            startLinting(cm);\n+                        }, state.options.delay);\n+                    }\n+\n+                    function popupTooltips(cm, annotations, e) {\n+                        var target = e.target || e.srcElement;\n+                        var tooltip = document.createDocumentFragment();\n+                        for (var i = 0; i < annotations.length; i++) {\n+                            var ann = annotations[i];\n+                            tooltip.appendChild(annotationTooltip(ann));\n+                        }\n+                        showTooltipFor(cm, e, tooltip, target);\n+                    }\n+\n+                    function onMouseOver(cm, e) {\n+                        var target = e.target || e.srcElement;\n+                        if (!/\\bCodeMirror-lint-mark-/.test(target.className)) return;\n+                        var box = target.getBoundingClientRect(),\n+                            x = (box.left + box.right) / 2,\n+                            y = (box.top + box.bottom) / 2;\n+                        var spans = cm.findMarksAt(cm.coordsChar({\n+                            left: x,\n+                            top: y\n+                        }, \"client\"));\n+                        var annotations = [];\n+                        for (var i = 0; i < spans.length; ++i) {\n+                            var ann = spans[i].__annotation;\n+                            if (ann) annotations.push(ann);\n                         }\n-                        return result + data.substring(lastIdx);\n-                    };\n-                }\n-                /**\n-                 * Encodes all characters not valid in XML documents using XML entities.\n-                 *\n-                 * Note that the output will be character-set dependent.\n-                 *\n-                 * @param data String to escape.\n-                 */\n-                exports.escapeUTF8 = getEscaper(/[&<>'\"]/g, xmlCodeMap);\n-                /**\n-                 * Encodes all characters that have to be escaped in HTML attributes,\n-                 * following {@link https://html.spec.whatwg.org/multipage/parsing.html#escapingString}.\n-                 *\n-                 * @param data String to escape.\n-                 */\n-                exports.escapeAttribute = getEscaper(/[\"&\\u00A0]/g, new Map([\n-                    [34, \"&quot;\"],\n-                    [38, \"&amp;\"],\n-                    [160, \"&nbsp;\"]\n-                ]));\n-                /**\n-                 * Encodes all characters that have to be escaped in HTML text,\n-                 * following {@link https://html.spec.whatwg.org/multipage/parsing.html#escapingString}.\n-                 *\n-                 * @param data String to escape.\n-                 */\n-                exports.escapeText = getEscaper(/[&<>\\u00A0]/g, new Map([\n-                    [38, \"&amp;\"],\n-                    [60, \"&lt;\"],\n-                    [62, \"&gt;\"],\n-                    [160, \"&nbsp;\"]\n-                ]));\n+                        if (annotations.length) popupTooltips(cm, annotations, e);\n+                    }\n+                    CodeMirror.defineOption(\"lint\", false, function(cm, val, old) {\n+                        if (old && old != CodeMirror.Init) {\n+                            clearMarks(cm);\n+                            if (cm.state.lint.options.lintOnChange !== false) cm.off(\"change\", onChange);\n+                            CodeMirror.off(cm.getWrapperElement(), \"mouseover\", cm.state.lint.onMouseOver);\n+                            clearTimeout(cm.state.lint.timeout);\n+                            delete cm.state.lint;\n+                        }\n+                        if (val) {\n+                            var gutters = cm.getOption(\"gutters\"),\n+                                hasLintGutter = false;\n+                            for (var i = 0; i < gutters.length; ++i)\n+                                if (gutters[i] == GUTTER_ID) hasLintGutter = true;\n+                            var state = cm.state.lint = new LintState(cm, val, hasLintGutter);\n+                            if (state.options.lintOnChange) cm.on(\"change\", onChange);\n+                            if (state.options.tooltips != false && state.options.tooltips != \"gutter\") CodeMirror.on(cm.getWrapperElement(), \"mouseover\", state.onMouseOver);\n+                            startLinting(cm);\n+                        }\n+                    });\n+                    CodeMirror.defineExtension(\"performLint\", function() {\n+                        startLinting(this);\n+                    });\n+                });\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/entities/lib/generated/decode-data-html.js\":\n-            /*!************************************************************************!*\\\n-              !*** ../../../node_modules/entities/lib/generated/decode-data-html.js ***!\n-              \\************************************************************************/\n+        \"../../../node_modules/codemirror/addon/search/jump-to-line.js\":\n+            /*!*********************************************************************!*\\\n+              !*** ../../../node_modules/codemirror/addon/search/jump-to-line.js ***!\n+              \\*********************************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports) {\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                // Generated using scripts/write-decode-map.ts\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports[\"default\"] = new Uint16Array(\n-                    // prettier-ignore\n-                    \"\\u1d41<\\xd5\\u0131\\u028a\\u049d\\u057b\\u05d0\\u0675\\u06de\\u07a2\\u07d6\\u080f\\u0a4a\\u0a91\\u0da1\\u0e6d\\u0f09\\u0f26\\u10ca\\u1228\\u12e1\\u1415\\u149d\\u14c3\\u14df\\u1525\\0\\0\\0\\0\\0\\0\\u156b\\u16cd\\u198d\\u1c12\\u1ddd\\u1f7e\\u2060\\u21b0\\u228d\\u23c0\\u23fb\\u2442\\u2824\\u2912\\u2d08\\u2e48\\u2fce\\u3016\\u32ba\\u3639\\u37ac\\u38fe\\u3a28\\u3a71\\u3ae0\\u3b2e\\u0800EMabcfglmnoprstu\\\\bfms\\x7f\\x84\\x8b\\x90\\x95\\x98\\xa6\\xb3\\xb9\\xc8\\xcflig\\u803b\\xc6\\u40c6P\\u803b&\\u4026cute\\u803b\\xc1\\u40c1reve;\\u4102\\u0100iyx}rc\\u803b\\xc2\\u40c2;\\u4410r;\\uc000\\ud835\\udd04rave\\u803b\\xc0\\u40c0pha;\\u4391acr;\\u4100d;\\u6a53\\u0100gp\\x9d\\xa1on;\\u4104f;\\uc000\\ud835\\udd38plyFunction;\\u6061ing\\u803b\\xc5\\u40c5\\u0100cs\\xbe\\xc3r;\\uc000\\ud835\\udc9cign;\\u6254ilde\\u803b\\xc3\\u40c3ml\\u803b\\xc4\\u40c4\\u0400aceforsu\\xe5\\xfb\\xfe\\u0117\\u011c\\u0122\\u0127\\u012a\\u0100cr\\xea\\xf2kslash;\\u6216\\u0176\\xf6\\xf8;\\u6ae7ed;\\u6306y;\\u4411\\u0180crt\\u0105\\u010b\\u0114ause;\\u6235noullis;\\u612ca;\\u4392r;\\uc000\\ud835\\udd05pf;\\uc000\\ud835\\udd39eve;\\u42d8c\\xf2\\u0113mpeq;\\u624e\\u0700HOacdefhilorsu\\u014d\\u0151\\u0156\\u0180\\u019e\\u01a2\\u01b5\\u01b7\\u01ba\\u01dc\\u0215\\u0273\\u0278\\u027ecy;\\u4427PY\\u803b\\xa9\\u40a9\\u0180cpy\\u015d\\u0162\\u017aute;\\u4106\\u0100;i\\u0167\\u0168\\u62d2talDifferentialD;\\u6145leys;\\u612d\\u0200aeio\\u0189\\u018e\\u0194\\u0198ron;\\u410cdil\\u803b\\xc7\\u40c7rc;\\u4108nint;\\u6230ot;\\u410a\\u0100dn\\u01a7\\u01adilla;\\u40b8terDot;\\u40b7\\xf2\\u017fi;\\u43a7rcle\\u0200DMPT\\u01c7\\u01cb\\u01d1\\u01d6ot;\\u6299inus;\\u6296lus;\\u6295imes;\\u6297o\\u0100cs\\u01e2\\u01f8kwiseContourIntegral;\\u6232eCurly\\u0100DQ\\u0203\\u020foubleQuote;\\u601duote;\\u6019\\u0200lnpu\\u021e\\u0228\\u0247\\u0255on\\u0100;e\\u0225\\u0226\\u6237;\\u6a74\\u0180git\\u022f\\u0236\\u023aruent;\\u6261nt;\\u622fourIntegral;\\u622e\\u0100fr\\u024c\\u024e;\\u6102oduct;\\u6210nterClockwiseContourIntegral;\\u6233oss;\\u6a2fcr;\\uc000\\ud835\\udc9ep\\u0100;C\\u0284\\u0285\\u62d3ap;\\u624d\\u0580DJSZacefios\\u02a0\\u02ac\\u02b0\\u02b4\\u02b8\\u02cb\\u02d7\\u02e1\\u02e6\\u0333\\u048d\\u0100;o\\u0179\\u02a5trahd;\\u6911cy;\\u4402cy;\\u4405cy;\\u440f\\u0180grs\\u02bf\\u02c4\\u02c7ger;\\u6021r;\\u61a1hv;\\u6ae4\\u0100ay\\u02d0\\u02d5ron;\\u410e;\\u4414l\\u0100;t\\u02dd\\u02de\\u6207a;\\u4394r;\\uc000\\ud835\\udd07\\u0100af\\u02eb\\u0327\\u0100cm\\u02f0\\u0322ritical\\u0200ADGT\\u0300\\u0306\\u0316\\u031ccute;\\u40b4o\\u0174\\u030b\\u030d;\\u42d9bleAcute;\\u42ddrave;\\u4060ilde;\\u42dcond;\\u62c4ferentialD;\\u6146\\u0470\\u033d\\0\\0\\0\\u0342\\u0354\\0\\u0405f;\\uc000\\ud835\\udd3b\\u0180;DE\\u0348\\u0349\\u034d\\u40a8ot;\\u60dcqual;\\u6250ble\\u0300CDLRUV\\u0363\\u0372\\u0382\\u03cf\\u03e2\\u03f8ontourIntegra\\xec\\u0239o\\u0274\\u0379\\0\\0\\u037b\\xbb\\u0349nArrow;\\u61d3\\u0100eo\\u0387\\u03a4ft\\u0180ART\\u0390\\u0396\\u03a1rrow;\\u61d0ightArrow;\\u61d4e\\xe5\\u02cang\\u0100LR\\u03ab\\u03c4eft\\u0100AR\\u03b3\\u03b9rrow;\\u67f8ightArrow;\\u67faightArrow;\\u67f9ight\\u0100AT\\u03d8\\u03derrow;\\u61d2ee;\\u62a8p\\u0241\\u03e9\\0\\0\\u03efrrow;\\u61d1ownArrow;\\u61d5erticalBar;\\u6225n\\u0300ABLRTa\\u0412\\u042a\\u0430\\u045e\\u047f\\u037crrow\\u0180;BU\\u041d\\u041e\\u0422\\u6193ar;\\u6913pArrow;\\u61f5reve;\\u4311eft\\u02d2\\u043a\\0\\u0446\\0\\u0450ightVector;\\u6950eeVector;\\u695eector\\u0100;B\\u0459\\u045a\\u61bdar;\\u6956ight\\u01d4\\u0467\\0\\u0471eeVector;\\u695fector\\u0100;B\\u047a\\u047b\\u61c1ar;\\u6957ee\\u0100;A\\u0486\\u0487\\u62a4rrow;\\u61a7\\u0100ct\\u0492\\u0497r;\\uc000\\ud835\\udc9frok;\\u4110\\u0800NTacdfglmopqstux\\u04bd\\u04c0\\u04c4\\u04cb\\u04de\\u04e2\\u04e7\\u04ee\\u04f5\\u0521\\u052f\\u0536\\u0552\\u055d\\u0560\\u0565G;\\u414aH\\u803b\\xd0\\u40d0cute\\u803b\\xc9\\u40c9\\u0180aiy\\u04d2\\u04d7\\u04dcron;\\u411arc\\u803b\\xca\\u40ca;\\u442dot;\\u4116r;\\uc000\\ud835\\udd08rave\\u803b\\xc8\\u40c8ement;\\u6208\\u0100ap\\u04fa\\u04fecr;\\u4112ty\\u0253\\u0506\\0\\0\\u0512mallSquare;\\u65fberySmallSquare;\\u65ab\\u0100gp\\u0526\\u052aon;\\u4118f;\\uc000\\ud835\\udd3csilon;\\u4395u\\u0100ai\\u053c\\u0549l\\u0100;T\\u0542\\u0543\\u6a75ilde;\\u6242librium;\\u61cc\\u0100ci\\u0557\\u055ar;\\u6130m;\\u6a73a;\\u4397ml\\u803b\\xcb\\u40cb\\u0100ip\\u056a\\u056fsts;\\u6203onentialE;\\u6147\\u0280cfios\\u0585\\u0588\\u058d\\u05b2\\u05ccy;\\u4424r;\\uc000\\ud835\\udd09lled\\u0253\\u0597\\0\\0\\u05a3mallSquare;\\u65fcerySmallSquare;\\u65aa\\u0370\\u05ba\\0\\u05bf\\0\\0\\u05c4f;\\uc000\\ud835\\udd3dAll;\\u6200riertrf;\\u6131c\\xf2\\u05cb\\u0600JTabcdfgorst\\u05e8\\u05ec\\u05ef\\u05fa\\u0600\\u0612\\u0616\\u061b\\u061d\\u0623\\u066c\\u0672cy;\\u4403\\u803b>\\u403emma\\u0100;d\\u05f7\\u05f8\\u4393;\\u43dcreve;\\u411e\\u0180eiy\\u0607\\u060c\\u0610dil;\\u4122rc;\\u411c;\\u4413ot;\\u4120r;\\uc000\\ud835\\udd0a;\\u62d9pf;\\uc000\\ud835\\udd3eeater\\u0300EFGLST\\u0635\\u0644\\u064e\\u0656\\u065b\\u0666qual\\u0100;L\\u063e\\u063f\\u6265ess;\\u62dbullEqual;\\u6267reater;\\u6aa2ess;\\u6277lantEqual;\\u6a7eilde;\\u6273cr;\\uc000\\ud835\\udca2;\\u626b\\u0400Aacfiosu\\u0685\\u068b\\u0696\\u069b\\u069e\\u06aa\\u06be\\u06caRDcy;\\u442a\\u0100ct\\u0690\\u0694ek;\\u42c7;\\u405eirc;\\u4124r;\\u610clbertSpace;\\u610b\\u01f0\\u06af\\0\\u06b2f;\\u610dizontalLine;\\u6500\\u0100ct\\u06c3\\u06c5\\xf2\\u06a9rok;\\u4126mp\\u0144\\u06d0\\u06d8ownHum\\xf0\\u012fqual;\\u624f\\u0700EJOacdfgmnostu\\u06fa\\u06fe\\u0703\\u0707\\u070e\\u071a\\u071e\\u0721\\u0728\\u0744\\u0778\\u078b\\u078f\\u0795cy;\\u4415lig;\\u4132cy;\\u4401cute\\u803b\\xcd\\u40cd\\u0100iy\\u0713\\u0718rc\\u803b\\xce\\u40ce;\\u4418ot;\\u4130r;\\u6111rave\\u803b\\xcc\\u40cc\\u0180;ap\\u0720\\u072f\\u073f\\u0100cg\\u0734\\u0737r;\\u412ainaryI;\\u6148lie\\xf3\\u03dd\\u01f4\\u0749\\0\\u0762\\u0100;e\\u074d\\u074e\\u622c\\u0100gr\\u0753\\u0758ral;\\u622bsection;\\u62c2isible\\u0100CT\\u076c\\u0772omma;\\u6063imes;\\u6062\\u0180gpt\\u077f\\u0783\\u0788on;\\u412ef;\\uc000\\ud835\\udd40a;\\u4399cr;\\u6110ilde;\\u4128\\u01eb\\u079a\\0\\u079ecy;\\u4406l\\u803b\\xcf\\u40cf\\u0280cfosu\\u07ac\\u07b7\\u07bc\\u07c2\\u07d0\\u0100iy\\u07b1\\u07b5rc;\\u4134;\\u4419r;\\uc000\\ud835\\udd0dpf;\\uc000\\ud835\\udd41\\u01e3\\u07c7\\0\\u07ccr;\\uc000\\ud835\\udca5rcy;\\u4408kcy;\\u4404\\u0380HJacfos\\u07e4\\u07e8\\u07ec\\u07f1\\u07fd\\u0802\\u0808cy;\\u4425cy;\\u440cppa;\\u439a\\u0100ey\\u07f6\\u07fbdil;\\u4136;\\u441ar;\\uc000\\ud835\\udd0epf;\\uc000\\ud835\\udd42cr;\\uc000\\ud835\\udca6\\u0580JTaceflmost\\u0825\\u0829\\u082c\\u0850\\u0863\\u09b3\\u09b8\\u09c7\\u09cd\\u0a37\\u0a47cy;\\u4409\\u803b<\\u403c\\u0280cmnpr\\u0837\\u083c\\u0841\\u0844\\u084dute;\\u4139bda;\\u439bg;\\u67ealacetrf;\\u6112r;\\u619e\\u0180aey\\u0857\\u085c\\u0861ron;\\u413ddil;\\u413b;\\u441b\\u0100fs\\u0868\\u0970t\\u0500ACDFRTUVar\\u087e\\u08a9\\u08b1\\u08e0\\u08e6\\u08fc\\u092f\\u095b\\u0390\\u096a\\u0100nr\\u0883\\u088fgleBracket;\\u67e8row\\u0180;BR\\u0899\\u089a\\u089e\\u6190ar;\\u61e4ightArrow;\\u61c6eiling;\\u6308o\\u01f5\\u08b7\\0\\u08c3bleBracket;\\u67e6n\\u01d4\\u08c8\\0\\u08d2eeVector;\\u6961ector\\u0100;B\\u08db\\u08dc\\u61c3ar;\\u6959loor;\\u630aight\\u0100AV\\u08ef\\u08f5rrow;\\u6194ector;\\u694e\\u0100er\\u0901\\u0917e\\u0180;AV\\u0909\\u090a\\u0910\\u62a3rrow;\\u61a4ector;\\u695aiangle\\u0180;BE\\u0924\\u0925\\u0929\\u62b2ar;\\u69cfqual;\\u62b4p\\u0180DTV\\u0937\\u0942\\u094cownVector;\\u6951eeVector;\\u6960ector\\u0100;B\\u0956\\u0957\\u61bfar;\\u6958ector\\u0100;B\\u0965\\u0966\\u61bcar;\\u6952ight\\xe1\\u039cs\\u0300EFGLST\\u097e\\u098b\\u0995\\u099d\\u09a2\\u09adqualGreater;\\u62daullEqual;\\u6266reater;\\u6276ess;\\u6aa1lantEqual;\\u6a7dilde;\\u6272r;\\uc000\\ud835\\udd0f\\u0100;e\\u09bd\\u09be\\u62d8ftarrow;\\u61daidot;\\u413f\\u0180npw\\u09d4\\u0a16\\u0a1bg\\u0200LRlr\\u09de\\u09f7\\u0a02\\u0a10eft\\u0100AR\\u09e6\\u09ecrrow;\\u67f5ightArrow;\\u67f7ightArrow;\\u67f6eft\\u0100ar\\u03b3\\u0a0aight\\xe1\\u03bfight\\xe1\\u03caf;\\uc000\\ud835\\udd43er\\u0100LR\\u0a22\\u0a2ceftArrow;\\u6199ightArrow;\\u6198\\u0180cht\\u0a3e\\u0a40\\u0a42\\xf2\\u084c;\\u61b0rok;\\u4141;\\u626a\\u0400acefiosu\\u0a5a\\u0a5d\\u0a60\\u0a77\\u0a7c\\u0a85\\u0a8b\\u0a8ep;\\u6905y;\\u441c\\u0100dl\\u0a65\\u0a6fiumSpace;\\u605flintrf;\\u6133r;\\uc000\\ud835\\udd10nusPlus;\\u6213pf;\\uc000\\ud835\\udd44c\\xf2\\u0a76;\\u439c\\u0480Jacefostu\\u0aa3\\u0aa7\\u0aad\\u0ac0\\u0b14\\u0b19\\u0d91\\u0d97\\u0d9ecy;\\u440acute;\\u4143\\u0180aey\\u0ab4\\u0ab9\\u0aberon;\\u4147dil;\\u4145;\\u441d\\u0180gsw\\u0ac7\\u0af0\\u0b0eative\\u0180MTV\\u0ad3\\u0adf\\u0ae8ediumSpace;\\u600bhi\\u0100cn\\u0ae6\\u0ad8\\xeb\\u0ad9eryThi\\xee\\u0ad9ted\\u0100GL\\u0af8\\u0b06reaterGreate\\xf2\\u0673essLes\\xf3\\u0a48Line;\\u400ar;\\uc000\\ud835\\udd11\\u0200Bnpt\\u0b22\\u0b28\\u0b37\\u0b3areak;\\u6060BreakingSpace;\\u40a0f;\\u6115\\u0680;CDEGHLNPRSTV\\u0b55\\u0b56\\u0b6a\\u0b7c\\u0ba1\\u0beb\\u0c04\\u0c5e\\u0c84\\u0ca6\\u0cd8\\u0d61\\u0d85\\u6aec\\u0100ou\\u0b5b\\u0b64ngruent;\\u6262pCap;\\u626doubleVerticalBar;\\u6226\\u0180lqx\\u0b83\\u0b8a\\u0b9bement;\\u6209ual\\u0100;T\\u0b92\\u0b93\\u6260ilde;\\uc000\\u2242\\u0338ists;\\u6204reater\\u0380;EFGLST\\u0bb6\\u0bb7\\u0bbd\\u0bc9\\u0bd3\\u0bd8\\u0be5\\u626fqual;\\u6271ullEqual;\\uc000\\u2267\\u0338reater;\\uc000\\u226b\\u0338ess;\\u6279lantEqual;\\uc000\\u2a7e\\u0338ilde;\\u6275ump\\u0144\\u0bf2\\u0bfdownHump;\\uc000\\u224e\\u0338qual;\\uc000\\u224f\\u0338e\\u0100fs\\u0c0a\\u0c27tTriangle\\u0180;BE\\u0c1a\\u0c1b\\u0c21\\u62eaar;\\uc000\\u29cf\\u0338qual;\\u62ecs\\u0300;EGLST\\u0c35\\u0c36\\u0c3c\\u0c44\\u0c4b\\u0c58\\u626equal;\\u6270reater;\\u6278ess;\\uc000\\u226a\\u0338lantEqual;\\uc000\\u2a7d\\u0338ilde;\\u6274ested\\u0100GL\\u0c68\\u0c79reaterGreater;\\uc000\\u2aa2\\u0338essLess;\\uc000\\u2aa1\\u0338recedes\\u0180;ES\\u0c92\\u0c93\\u0c9b\\u6280qual;\\uc000\\u2aaf\\u0338lantEqual;\\u62e0\\u0100ei\\u0cab\\u0cb9verseElement;\\u620cghtTriangle\\u0180;BE\\u0ccb\\u0ccc\\u0cd2\\u62ebar;\\uc000\\u29d0\\u0338qual;\\u62ed\\u0100qu\\u0cdd\\u0d0cuareSu\\u0100bp\\u0ce8\\u0cf9set\\u0100;E\\u0cf0\\u0cf3\\uc000\\u228f\\u0338qual;\\u62e2erset\\u0100;E\\u0d03\\u0d06\\uc000\\u2290\\u0338qual;\\u62e3\\u0180bcp\\u0d13\\u0d24\\u0d4eset\\u0100;E\\u0d1b\\u0d1e\\uc000\\u2282\\u20d2qual;\\u6288ceeds\\u0200;EST\\u0d32\\u0d33\\u0d3b\\u0d46\\u6281qual;\\uc000\\u2ab0\\u0338lantEqual;\\u62e1ilde;\\uc000\\u227f\\u0338erset\\u0100;E\\u0d58\\u0d5b\\uc000\\u2283\\u20d2qual;\\u6289ilde\\u0200;EFT\\u0d6e\\u0d6f\\u0d75\\u0d7f\\u6241qual;\\u6244ullEqual;\\u6247ilde;\\u6249erticalBar;\\u6224cr;\\uc000\\ud835\\udca9ilde\\u803b\\xd1\\u40d1;\\u439d\\u0700Eacdfgmoprstuv\\u0dbd\\u0dc2\\u0dc9\\u0dd5\\u0ddb\\u0de0\\u0de7\\u0dfc\\u0e02\\u0e20\\u0e22\\u0e32\\u0e3f\\u0e44lig;\\u4152cute\\u803b\\xd3\\u40d3\\u0100iy\\u0dce\\u0dd3rc\\u803b\\xd4\\u40d4;\\u441eblac;\\u4150r;\\uc000\\ud835\\udd12rave\\u803b\\xd2\\u40d2\\u0180aei\\u0dee\\u0df2\\u0df6cr;\\u414cga;\\u43a9cron;\\u439fpf;\\uc000\\ud835\\udd46enCurly\\u0100DQ\\u0e0e\\u0e1aoubleQuote;\\u601cuote;\\u6018;\\u6a54\\u0100cl\\u0e27\\u0e2cr;\\uc000\\ud835\\udcaaash\\u803b\\xd8\\u40d8i\\u016c\\u0e37\\u0e3cde\\u803b\\xd5\\u40d5es;\\u6a37ml\\u803b\\xd6\\u40d6er\\u0100BP\\u0e4b\\u0e60\\u0100ar\\u0e50\\u0e53r;\\u603eac\\u0100ek\\u0e5a\\u0e5c;\\u63deet;\\u63b4arenthesis;\\u63dc\\u0480acfhilors\\u0e7f\\u0e87\\u0e8a\\u0e8f\\u0e92\\u0e94\\u0e9d\\u0eb0\\u0efcrtialD;\\u6202y;\\u441fr;\\uc000\\ud835\\udd13i;\\u43a6;\\u43a0usMinus;\\u40b1\\u0100ip\\u0ea2\\u0eadncareplan\\xe5\\u069df;\\u6119\\u0200;eio\\u0eb9\\u0eba\\u0ee0\\u0ee4\\u6abbcedes\\u0200;EST\\u0ec8\\u0ec9\\u0ecf\\u0eda\\u627aqual;\\u6aaflantEqual;\\u627cilde;\\u627eme;\\u6033\\u0100dp\\u0ee9\\u0eeeuct;\\u620fortion\\u0100;a\\u0225\\u0ef9l;\\u621d\\u0100ci\\u0f01\\u0f06r;\\uc000\\ud835\\udcab;\\u43a8\\u0200Ufos\\u0f11\\u0f16\\u0f1b\\u0f1fOT\\u803b\\\"\\u4022r;\\uc000\\ud835\\udd14pf;\\u611acr;\\uc000\\ud835\\udcac\\u0600BEacefhiorsu\\u0f3e\\u0f43\\u0f47\\u0f60\\u0f73\\u0fa7\\u0faa\\u0fad\\u1096\\u10a9\\u10b4\\u10bearr;\\u6910G\\u803b\\xae\\u40ae\\u0180cnr\\u0f4e\\u0f53\\u0f56ute;\\u4154g;\\u67ebr\\u0100;t\\u0f5c\\u0f5d\\u61a0l;\\u6916\\u0180aey\\u0f67\\u0f6c\\u0f71ron;\\u4158dil;\\u4156;\\u4420\\u0100;v\\u0f78\\u0f79\\u611cerse\\u0100EU\\u0f82\\u0f99\\u0100lq\\u0f87\\u0f8eement;\\u620builibrium;\\u61cbpEquilibrium;\\u696fr\\xbb\\u0f79o;\\u43a1ght\\u0400ACDFTUVa\\u0fc1\\u0feb\\u0ff3\\u1022\\u1028\\u105b\\u1087\\u03d8\\u0100nr\\u0fc6\\u0fd2gleBracket;\\u67e9row\\u0180;BL\\u0fdc\\u0fdd\\u0fe1\\u6192ar;\\u61e5eftArrow;\\u61c4eiling;\\u6309o\\u01f5\\u0ff9\\0\\u1005bleBracket;\\u67e7n\\u01d4\\u100a\\0\\u1014eeVector;\\u695dector\\u0100;B\\u101d\\u101e\\u61c2ar;\\u6955loor;\\u630b\\u0100er\\u102d\\u1043e\\u0180;AV\\u1035\\u1036\\u103c\\u62a2rrow;\\u61a6ector;\\u695biangle\\u0180;BE\\u1050\\u1051\\u1055\\u62b3ar;\\u69d0qual;\\u62b5p\\u0180DTV\\u1063\\u106e\\u1078ownVector;\\u694feeVector;\\u695cector\\u0100;B\\u1082\\u1083\\u61bear;\\u6954ector\\u0100;B\\u1091\\u1092\\u61c0ar;\\u6953\\u0100pu\\u109b\\u109ef;\\u611dndImplies;\\u6970ightarrow;\\u61db\\u0100ch\\u10b9\\u10bcr;\\u611b;\\u61b1leDelayed;\\u69f4\\u0680HOacfhimoqstu\\u10e4\\u10f1\\u10f7\\u10fd\\u1119\\u111e\\u1151\\u1156\\u1161\\u1167\\u11b5\\u11bb\\u11bf\\u0100Cc\\u10e9\\u10eeHcy;\\u4429y;\\u4428FTcy;\\u442ccute;\\u415a\\u0280;aeiy\\u1108\\u1109\\u110e\\u1113\\u1117\\u6abcron;\\u4160dil;\\u415erc;\\u415c;\\u4421r;\\uc000\\ud835\\udd16ort\\u0200DLRU\\u112a\\u1134\\u113e\\u1149ownArrow\\xbb\\u041eeftArrow\\xbb\\u089aightArrow\\xbb\\u0fddpArrow;\\u6191gma;\\u43a3allCircle;\\u6218pf;\\uc000\\ud835\\udd4a\\u0272\\u116d\\0\\0\\u1170t;\\u621aare\\u0200;ISU\\u117b\\u117c\\u1189\\u11af\\u65a1ntersection;\\u6293u\\u0100bp\\u118f\\u119eset\\u0100;E\\u1197\\u1198\\u628fqual;\\u6291erset\\u0100;E\\u11a8\\u11a9\\u6290qual;\\u6292nion;\\u6294cr;\\uc000\\ud835\\udcaear;\\u62c6\\u0200bcmp\\u11c8\\u11db\\u1209\\u120b\\u0100;s\\u11cd\\u11ce\\u62d0et\\u0100;E\\u11cd\\u11d5qual;\\u6286\\u0100ch\\u11e0\\u1205eeds\\u0200;EST\\u11ed\\u11ee\\u11f4\\u11ff\\u627bqual;\\u6ab0lantEqual;\\u627dilde;\\u627fTh\\xe1\\u0f8c;\\u6211\\u0180;es\\u1212\\u1213\\u1223\\u62d1rset\\u0100;E\\u121c\\u121d\\u6283qual;\\u6287et\\xbb\\u1213\\u0580HRSacfhiors\\u123e\\u1244\\u1249\\u1255\\u125e\\u1271\\u1276\\u129f\\u12c2\\u12c8\\u12d1ORN\\u803b\\xde\\u40deADE;\\u6122\\u0100Hc\\u124e\\u1252cy;\\u440by;\\u4426\\u0100bu\\u125a\\u125c;\\u4009;\\u43a4\\u0180aey\\u1265\\u126a\\u126fron;\\u4164dil;\\u4162;\\u4422r;\\uc000\\ud835\\udd17\\u0100ei\\u127b\\u1289\\u01f2\\u1280\\0\\u1287efore;\\u6234a;\\u4398\\u0100cn\\u128e\\u1298kSpace;\\uc000\\u205f\\u200aSpace;\\u6009lde\\u0200;EFT\\u12ab\\u12ac\\u12b2\\u12bc\\u623cqual;\\u6243ullEqual;\\u6245ilde;\\u6248pf;\\uc000\\ud835\\udd4bipleDot;\\u60db\\u0100ct\\u12d6\\u12dbr;\\uc000\\ud835\\udcafrok;\\u4166\\u0ae1\\u12f7\\u130e\\u131a\\u1326\\0\\u132c\\u1331\\0\\0\\0\\0\\0\\u1338\\u133d\\u1377\\u1385\\0\\u13ff\\u1404\\u140a\\u1410\\u0100cr\\u12fb\\u1301ute\\u803b\\xda\\u40dar\\u0100;o\\u1307\\u1308\\u619fcir;\\u6949r\\u01e3\\u1313\\0\\u1316y;\\u440eve;\\u416c\\u0100iy\\u131e\\u1323rc\\u803b\\xdb\\u40db;\\u4423blac;\\u4170r;\\uc000\\ud835\\udd18rave\\u803b\\xd9\\u40d9acr;\\u416a\\u0100di\\u1341\\u1369er\\u0100BP\\u1348\\u135d\\u0100ar\\u134d\\u1350r;\\u405fac\\u0100ek\\u1357\\u1359;\\u63dfet;\\u63b5arenthesis;\\u63ddon\\u0100;P\\u1370\\u1371\\u62c3lus;\\u628e\\u0100gp\\u137b\\u137fon;\\u4172f;\\uc000\\ud835\\udd4c\\u0400ADETadps\\u1395\\u13ae\\u13b8\\u13c4\\u03e8\\u13d2\\u13d7\\u13f3rrow\\u0180;BD\\u1150\\u13a0\\u13a4ar;\\u6912ownArrow;\\u61c5ownArrow;\\u6195quilibrium;\\u696eee\\u0100;A\\u13cb\\u13cc\\u62a5rrow;\\u61a5own\\xe1\\u03f3er\\u0100LR\\u13de\\u13e8eftArrow;\\u6196ightArrow;\\u6197i\\u0100;l\\u13f9\\u13fa\\u43d2on;\\u43a5ing;\\u416ecr;\\uc000\\ud835\\udcb0ilde;\\u4168ml\\u803b\\xdc\\u40dc\\u0480Dbcdefosv\\u1427\\u142c\\u1430\\u1433\\u143e\\u1485\\u148a\\u1490\\u1496ash;\\u62abar;\\u6aeby;\\u4412ash\\u0100;l\\u143b\\u143c\\u62a9;\\u6ae6\\u0100er\\u1443\\u1445;\\u62c1\\u0180bty\\u144c\\u1450\\u147aar;\\u6016\\u0100;i\\u144f\\u1455cal\\u0200BLST\\u1461\\u1465\\u146a\\u1474ar;\\u6223ine;\\u407ceparator;\\u6758ilde;\\u6240ThinSpace;\\u600ar;\\uc000\\ud835\\udd19pf;\\uc000\\ud835\\udd4dcr;\\uc000\\ud835\\udcb1dash;\\u62aa\\u0280cefos\\u14a7\\u14ac\\u14b1\\u14b6\\u14bcirc;\\u4174dge;\\u62c0r;\\uc000\\ud835\\udd1apf;\\uc000\\ud835\\udd4ecr;\\uc000\\ud835\\udcb2\\u0200fios\\u14cb\\u14d0\\u14d2\\u14d8r;\\uc000\\ud835\\udd1b;\\u439epf;\\uc000\\ud835\\udd4fcr;\\uc000\\ud835\\udcb3\\u0480AIUacfosu\\u14f1\\u14f5\\u14f9\\u14fd\\u1504\\u150f\\u1514\\u151a\\u1520cy;\\u442fcy;\\u4407cy;\\u442ecute\\u803b\\xdd\\u40dd\\u0100iy\\u1509\\u150drc;\\u4176;\\u442br;\\uc000\\ud835\\udd1cpf;\\uc000\\ud835\\udd50cr;\\uc000\\ud835\\udcb4ml;\\u4178\\u0400Hacdefos\\u1535\\u1539\\u153f\\u154b\\u154f\\u155d\\u1560\\u1564cy;\\u4416cute;\\u4179\\u0100ay\\u1544\\u1549ron;\\u417d;\\u4417ot;\\u417b\\u01f2\\u1554\\0\\u155boWidt\\xe8\\u0ad9a;\\u4396r;\\u6128pf;\\u6124cr;\\uc000\\ud835\\udcb5\\u0be1\\u1583\\u158a\\u1590\\0\\u15b0\\u15b6\\u15bf\\0\\0\\0\\0\\u15c6\\u15db\\u15eb\\u165f\\u166d\\0\\u1695\\u169b\\u16b2\\u16b9\\0\\u16becute\\u803b\\xe1\\u40e1reve;\\u4103\\u0300;Ediuy\\u159c\\u159d\\u15a1\\u15a3\\u15a8\\u15ad\\u623e;\\uc000\\u223e\\u0333;\\u623frc\\u803b\\xe2\\u40e2te\\u80bb\\xb4\\u0306;\\u4430lig\\u803b\\xe6\\u40e6\\u0100;r\\xb2\\u15ba;\\uc000\\ud835\\udd1erave\\u803b\\xe0\\u40e0\\u0100ep\\u15ca\\u15d6\\u0100fp\\u15cf\\u15d4sym;\\u6135\\xe8\\u15d3ha;\\u43b1\\u0100ap\\u15dfc\\u0100cl\\u15e4\\u15e7r;\\u4101g;\\u6a3f\\u0264\\u15f0\\0\\0\\u160a\\u0280;adsv\\u15fa\\u15fb\\u15ff\\u1601\\u1607\\u6227nd;\\u6a55;\\u6a5clope;\\u6a58;\\u6a5a\\u0380;elmrsz\\u1618\\u1619\\u161b\\u161e\\u163f\\u164f\\u1659\\u6220;\\u69a4e\\xbb\\u1619sd\\u0100;a\\u1625\\u1626\\u6221\\u0461\\u1630\\u1632\\u1634\\u1636\\u1638\\u163a\\u163c\\u163e;\\u69a8;\\u69a9;\\u69aa;\\u69ab;\\u69ac;\\u69ad;\\u69ae;\\u69aft\\u0100;v\\u1645\\u1646\\u621fb\\u0100;d\\u164c\\u164d\\u62be;\\u699d\\u0100pt\\u1654\\u1657h;\\u6222\\xbb\\xb9arr;\\u637c\\u0100gp\\u1663\\u1667on;\\u4105f;\\uc000\\ud835\\udd52\\u0380;Eaeiop\\u12c1\\u167b\\u167d\\u1682\\u1684\\u1687\\u168a;\\u6a70cir;\\u6a6f;\\u624ad;\\u624bs;\\u4027rox\\u0100;e\\u12c1\\u1692\\xf1\\u1683ing\\u803b\\xe5\\u40e5\\u0180cty\\u16a1\\u16a6\\u16a8r;\\uc000\\ud835\\udcb6;\\u402amp\\u0100;e\\u12c1\\u16af\\xf1\\u0288ilde\\u803b\\xe3\\u40e3ml\\u803b\\xe4\\u40e4\\u0100ci\\u16c2\\u16c8onin\\xf4\\u0272nt;\\u6a11\\u0800Nabcdefiklnoprsu\\u16ed\\u16f1\\u1730\\u173c\\u1743\\u1748\\u1778\\u177d\\u17e0\\u17e6\\u1839\\u1850\\u170d\\u193d\\u1948\\u1970ot;\\u6aed\\u0100cr\\u16f6\\u171ek\\u0200ceps\\u1700\\u1705\\u170d\\u1713ong;\\u624cpsilon;\\u43f6rime;\\u6035im\\u0100;e\\u171a\\u171b\\u623dq;\\u62cd\\u0176\\u1722\\u1726ee;\\u62bded\\u0100;g\\u172c\\u172d\\u6305e\\xbb\\u172drk\\u0100;t\\u135c\\u1737brk;\\u63b6\\u0100oy\\u1701\\u1741;\\u4431quo;\\u601e\\u0280cmprt\\u1753\\u175b\\u1761\\u1764\\u1768aus\\u0100;e\\u010a\\u0109ptyv;\\u69b0s\\xe9\\u170cno\\xf5\\u0113\\u0180ahw\\u176f\\u1771\\u1773;\\u43b2;\\u6136een;\\u626cr;\\uc000\\ud835\\udd1fg\\u0380costuvw\\u178d\\u179d\\u17b3\\u17c1\\u17d5\\u17db\\u17de\\u0180aiu\\u1794\\u1796\\u179a\\xf0\\u0760rc;\\u65efp\\xbb\\u1371\\u0180dpt\\u17a4\\u17a8\\u17adot;\\u6a00lus;\\u6a01imes;\\u6a02\\u0271\\u17b9\\0\\0\\u17becup;\\u6a06ar;\\u6605riangle\\u0100du\\u17cd\\u17d2own;\\u65bdp;\\u65b3plus;\\u6a04e\\xe5\\u1444\\xe5\\u14adarow;\\u690d\\u0180ako\\u17ed\\u1826\\u1835\\u0100cn\\u17f2\\u1823k\\u0180lst\\u17fa\\u05ab\\u1802ozenge;\\u69ebriangle\\u0200;dlr\\u1812\\u1813\\u1818\\u181d\\u65b4own;\\u65beeft;\\u65c2ight;\\u65b8k;\\u6423\\u01b1\\u182b\\0\\u1833\\u01b2\\u182f\\0\\u1831;\\u6592;\\u65914;\\u6593ck;\\u6588\\u0100eo\\u183e\\u184d\\u0100;q\\u1843\\u1846\\uc000=\\u20e5uiv;\\uc000\\u2261\\u20e5t;\\u6310\\u0200ptwx\\u1859\\u185e\\u1867\\u186cf;\\uc000\\ud835\\udd53\\u0100;t\\u13cb\\u1863om\\xbb\\u13cctie;\\u62c8\\u0600DHUVbdhmptuv\\u1885\\u1896\\u18aa\\u18bb\\u18d7\\u18db\\u18ec\\u18ff\\u1905\\u190a\\u1910\\u1921\\u0200LRlr\\u188e\\u1890\\u1892\\u1894;\\u6557;\\u6554;\\u6556;\\u6553\\u0280;DUdu\\u18a1\\u18a2\\u18a4\\u18a6\\u18a8\\u6550;\\u6566;\\u6569;\\u6564;\\u6567\\u0200LRlr\\u18b3\\u18b5\\u18b7\\u18b9;\\u655d;\\u655a;\\u655c;\\u6559\\u0380;HLRhlr\\u18ca\\u18cb\\u18cd\\u18cf\\u18d1\\u18d3\\u18d5\\u6551;\\u656c;\\u6563;\\u6560;\\u656b;\\u6562;\\u655fox;\\u69c9\\u0200LRlr\\u18e4\\u18e6\\u18e8\\u18ea;\\u6555;\\u6552;\\u6510;\\u650c\\u0280;DUdu\\u06bd\\u18f7\\u18f9\\u18fb\\u18fd;\\u6565;\\u6568;\\u652c;\\u6534inus;\\u629flus;\\u629eimes;\\u62a0\\u0200LRlr\\u1919\\u191b\\u191d\\u191f;\\u655b;\\u6558;\\u6518;\\u6514\\u0380;HLRhlr\\u1930\\u1931\\u1933\\u1935\\u1937\\u1939\\u193b\\u6502;\\u656a;\\u6561;\\u655e;\\u653c;\\u6524;\\u651c\\u0100ev\\u0123\\u1942bar\\u803b\\xa6\\u40a6\\u0200ceio\\u1951\\u1956\\u195a\\u1960r;\\uc000\\ud835\\udcb7mi;\\u604fm\\u0100;e\\u171a\\u171cl\\u0180;bh\\u1968\\u1969\\u196b\\u405c;\\u69c5sub;\\u67c8\\u016c\\u1974\\u197el\\u0100;e\\u1979\\u197a\\u6022t\\xbb\\u197ap\\u0180;Ee\\u012f\\u1985\\u1987;\\u6aae\\u0100;q\\u06dc\\u06db\\u0ce1\\u19a7\\0\\u19e8\\u1a11\\u1a15\\u1a32\\0\\u1a37\\u1a50\\0\\0\\u1ab4\\0\\0\\u1ac1\\0\\0\\u1b21\\u1b2e\\u1b4d\\u1b52\\0\\u1bfd\\0\\u1c0c\\u0180cpr\\u19ad\\u19b2\\u19ddute;\\u4107\\u0300;abcds\\u19bf\\u19c0\\u19c4\\u19ca\\u19d5\\u19d9\\u6229nd;\\u6a44rcup;\\u6a49\\u0100au\\u19cf\\u19d2p;\\u6a4bp;\\u6a47ot;\\u6a40;\\uc000\\u2229\\ufe00\\u0100eo\\u19e2\\u19e5t;\\u6041\\xee\\u0693\\u0200aeiu\\u19f0\\u19fb\\u1a01\\u1a05\\u01f0\\u19f5\\0\\u19f8s;\\u6a4don;\\u410ddil\\u803b\\xe7\\u40e7rc;\\u4109ps\\u0100;s\\u1a0c\\u1a0d\\u6a4cm;\\u6a50ot;\\u410b\\u0180dmn\\u1a1b\\u1a20\\u1a26il\\u80bb\\xb8\\u01adptyv;\\u69b2t\\u8100\\xa2;e\\u1a2d\\u1a2e\\u40a2r\\xe4\\u01b2r;\\uc000\\ud835\\udd20\\u0180cei\\u1a3d\\u1a40\\u1a4dy;\\u4447ck\\u0100;m\\u1a47\\u1a48\\u6713ark\\xbb\\u1a48;\\u43c7r\\u0380;Ecefms\\u1a5f\\u1a60\\u1a62\\u1a6b\\u1aa4\\u1aaa\\u1aae\\u65cb;\\u69c3\\u0180;el\\u1a69\\u1a6a\\u1a6d\\u42c6q;\\u6257e\\u0261\\u1a74\\0\\0\\u1a88rrow\\u0100lr\\u1a7c\\u1a81eft;\\u61baight;\\u61bb\\u0280RSacd\\u1a92\\u1a94\\u1a96\\u1a9a\\u1a9f\\xbb\\u0f47;\\u64c8st;\\u629birc;\\u629aash;\\u629dnint;\\u6a10id;\\u6aefcir;\\u69c2ubs\\u0100;u\\u1abb\\u1abc\\u6663it\\xbb\\u1abc\\u02ec\\u1ac7\\u1ad4\\u1afa\\0\\u1b0aon\\u0100;e\\u1acd\\u1ace\\u403a\\u0100;q\\xc7\\xc6\\u026d\\u1ad9\\0\\0\\u1ae2a\\u0100;t\\u1ade\\u1adf\\u402c;\\u4040\\u0180;fl\\u1ae8\\u1ae9\\u1aeb\\u6201\\xee\\u1160e\\u0100mx\\u1af1\\u1af6ent\\xbb\\u1ae9e\\xf3\\u024d\\u01e7\\u1afe\\0\\u1b07\\u0100;d\\u12bb\\u1b02ot;\\u6a6dn\\xf4\\u0246\\u0180fry\\u1b10\\u1b14\\u1b17;\\uc000\\ud835\\udd54o\\xe4\\u0254\\u8100\\xa9;s\\u0155\\u1b1dr;\\u6117\\u0100ao\\u1b25\\u1b29rr;\\u61b5ss;\\u6717\\u0100cu\\u1b32\\u1b37r;\\uc000\\ud835\\udcb8\\u0100bp\\u1b3c\\u1b44\\u0100;e\\u1b41\\u1b42\\u6acf;\\u6ad1\\u0100;e\\u1b49\\u1b4a\\u6ad0;\\u6ad2dot;\\u62ef\\u0380delprvw\\u1b60\\u1b6c\\u1b77\\u1b82\\u1bac\\u1bd4\\u1bf9arr\\u0100lr\\u1b68\\u1b6a;\\u6938;\\u6935\\u0270\\u1b72\\0\\0\\u1b75r;\\u62dec;\\u62dfarr\\u0100;p\\u1b7f\\u1b80\\u61b6;\\u693d\\u0300;bcdos\\u1b8f\\u1b90\\u1b96\\u1ba1\\u1ba5\\u1ba8\\u622arcap;\\u6a48\\u0100au\\u1b9b\\u1b9ep;\\u6a46p;\\u6a4aot;\\u628dr;\\u6a45;\\uc000\\u222a\\ufe00\\u0200alrv\\u1bb5\\u1bbf\\u1bde\\u1be3rr\\u0100;m\\u1bbc\\u1bbd\\u61b7;\\u693cy\\u0180evw\\u1bc7\\u1bd4\\u1bd8q\\u0270\\u1bce\\0\\0\\u1bd2re\\xe3\\u1b73u\\xe3\\u1b75ee;\\u62ceedge;\\u62cfen\\u803b\\xa4\\u40a4earrow\\u0100lr\\u1bee\\u1bf3eft\\xbb\\u1b80ight\\xbb\\u1bbde\\xe4\\u1bdd\\u0100ci\\u1c01\\u1c07onin\\xf4\\u01f7nt;\\u6231lcty;\\u632d\\u0980AHabcdefhijlorstuwz\\u1c38\\u1c3b\\u1c3f\\u1c5d\\u1c69\\u1c75\\u1c8a\\u1c9e\\u1cac\\u1cb7\\u1cfb\\u1cff\\u1d0d\\u1d7b\\u1d91\\u1dab\\u1dbb\\u1dc6\\u1dcdr\\xf2\\u0381ar;\\u6965\\u0200glrs\\u1c48\\u1c4d\\u1c52\\u1c54ger;\\u6020eth;\\u6138\\xf2\\u1133h\\u0100;v\\u1c5a\\u1c5b\\u6010\\xbb\\u090a\\u016b\\u1c61\\u1c67arow;\\u690fa\\xe3\\u0315\\u0100ay\\u1c6e\\u1c73ron;\\u410f;\\u4434\\u0180;ao\\u0332\\u1c7c\\u1c84\\u0100gr\\u02bf\\u1c81r;\\u61catseq;\\u6a77\\u0180glm\\u1c91\\u1c94\\u1c98\\u803b\\xb0\\u40b0ta;\\u43b4ptyv;\\u69b1\\u0100ir\\u1ca3\\u1ca8sht;\\u697f;\\uc000\\ud835\\udd21ar\\u0100lr\\u1cb3\\u1cb5\\xbb\\u08dc\\xbb\\u101e\\u0280aegsv\\u1cc2\\u0378\\u1cd6\\u1cdc\\u1ce0m\\u0180;os\\u0326\\u1cca\\u1cd4nd\\u0100;s\\u0326\\u1cd1uit;\\u6666amma;\\u43ddin;\\u62f2\\u0180;io\\u1ce7\\u1ce8\\u1cf8\\u40f7de\\u8100\\xf7;o\\u1ce7\\u1cf0ntimes;\\u62c7n\\xf8\\u1cf7cy;\\u4452c\\u026f\\u1d06\\0\\0\\u1d0arn;\\u631eop;\\u630d\\u0280lptuw\\u1d18\\u1d1d\\u1d22\\u1d49\\u1d55lar;\\u4024f;\\uc000\\ud835\\udd55\\u0280;emps\\u030b\\u1d2d\\u1d37\\u1d3d\\u1d42q\\u0100;d\\u0352\\u1d33ot;\\u6251inus;\\u6238lus;\\u6214quare;\\u62a1blebarwedg\\xe5\\xfan\\u0180adh\\u112e\\u1d5d\\u1d67ownarrow\\xf3\\u1c83arpoon\\u0100lr\\u1d72\\u1d76ef\\xf4\\u1cb4igh\\xf4\\u1cb6\\u0162\\u1d7f\\u1d85karo\\xf7\\u0f42\\u026f\\u1d8a\\0\\0\\u1d8ern;\\u631fop;\\u630c\\u0180cot\\u1d98\\u1da3\\u1da6\\u0100ry\\u1d9d\\u1da1;\\uc000\\ud835\\udcb9;\\u4455l;\\u69f6rok;\\u4111\\u0100dr\\u1db0\\u1db4ot;\\u62f1i\\u0100;f\\u1dba\\u1816\\u65bf\\u0100ah\\u1dc0\\u1dc3r\\xf2\\u0429a\\xf2\\u0fa6angle;\\u69a6\\u0100ci\\u1dd2\\u1dd5y;\\u445fgrarr;\\u67ff\\u0900Dacdefglmnopqrstux\\u1e01\\u1e09\\u1e19\\u1e38\\u0578\\u1e3c\\u1e49\\u1e61\\u1e7e\\u1ea5\\u1eaf\\u1ebd\\u1ee1\\u1f2a\\u1f37\\u1f44\\u1f4e\\u1f5a\\u0100Do\\u1e06\\u1d34o\\xf4\\u1c89\\u0100cs\\u1e0e\\u1e14ute\\u803b\\xe9\\u40e9ter;\\u6a6e\\u0200aioy\\u1e22\\u1e27\\u1e31\\u1e36ron;\\u411br\\u0100;c\\u1e2d\\u1e2e\\u6256\\u803b\\xea\\u40ealon;\\u6255;\\u444dot;\\u4117\\u0100Dr\\u1e41\\u1e45ot;\\u6252;\\uc000\\ud835\\udd22\\u0180;rs\\u1e50\\u1e51\\u1e57\\u6a9aave\\u803b\\xe8\\u40e8\\u0100;d\\u1e5c\\u1e5d\\u6a96ot;\\u6a98\\u0200;ils\\u1e6a\\u1e6b\\u1e72\\u1e74\\u6a99nters;\\u63e7;\\u6113\\u0100;d\\u1e79\\u1e7a\\u6a95ot;\\u6a97\\u0180aps\\u1e85\\u1e89\\u1e97cr;\\u4113ty\\u0180;sv\\u1e92\\u1e93\\u1e95\\u6205et\\xbb\\u1e93p\\u01001;\\u1e9d\\u1ea4\\u0133\\u1ea1\\u1ea3;\\u6004;\\u6005\\u6003\\u0100gs\\u1eaa\\u1eac;\\u414bp;\\u6002\\u0100gp\\u1eb4\\u1eb8on;\\u4119f;\\uc000\\ud835\\udd56\\u0180als\\u1ec4\\u1ece\\u1ed2r\\u0100;s\\u1eca\\u1ecb\\u62d5l;\\u69e3us;\\u6a71i\\u0180;lv\\u1eda\\u1edb\\u1edf\\u43b5on\\xbb\\u1edb;\\u43f5\\u0200csuv\\u1eea\\u1ef3\\u1f0b\\u1f23\\u0100io\\u1eef\\u1e31rc\\xbb\\u1e2e\\u0269\\u1ef9\\0\\0\\u1efb\\xed\\u0548ant\\u0100gl\\u1f02\\u1f06tr\\xbb\\u1e5dess\\xbb\\u1e7a\\u0180aei\\u1f12\\u1f16\\u1f1als;\\u403dst;\\u625fv\\u0100;D\\u0235\\u1f20D;\\u6a78parsl;\\u69e5\\u0100Da\\u1f2f\\u1f33ot;\\u6253rr;\\u6971\\u0180cdi\\u1f3e\\u1f41\\u1ef8r;\\u612fo\\xf4\\u0352\\u0100ah\\u1f49\\u1f4b;\\u43b7\\u803b\\xf0\\u40f0\\u0100mr\\u1f53\\u1f57l\\u803b\\xeb\\u40ebo;\\u60ac\\u0180cip\\u1f61\\u1f64\\u1f67l;\\u4021s\\xf4\\u056e\\u0100eo\\u1f6c\\u1f74ctatio\\xee\\u0559nential\\xe5\\u0579\\u09e1\\u1f92\\0\\u1f9e\\0\\u1fa1\\u1fa7\\0\\0\\u1fc6\\u1fcc\\0\\u1fd3\\0\\u1fe6\\u1fea\\u2000\\0\\u2008\\u205allingdotse\\xf1\\u1e44y;\\u4444male;\\u6640\\u0180ilr\\u1fad\\u1fb3\\u1fc1lig;\\u8000\\ufb03\\u0269\\u1fb9\\0\\0\\u1fbdg;\\u8000\\ufb00ig;\\u8000\\ufb04;\\uc000\\ud835\\udd23lig;\\u8000\\ufb01lig;\\uc000fj\\u0180alt\\u1fd9\\u1fdc\\u1fe1t;\\u666dig;\\u8000\\ufb02ns;\\u65b1of;\\u4192\\u01f0\\u1fee\\0\\u1ff3f;\\uc000\\ud835\\udd57\\u0100ak\\u05bf\\u1ff7\\u0100;v\\u1ffc\\u1ffd\\u62d4;\\u6ad9artint;\\u6a0d\\u0100ao\\u200c\\u2055\\u0100cs\\u2011\\u2052\\u03b1\\u201a\\u2030\\u2038\\u2045\\u2048\\0\\u2050\\u03b2\\u2022\\u2025\\u2027\\u202a\\u202c\\0\\u202e\\u803b\\xbd\\u40bd;\\u6153\\u803b\\xbc\\u40bc;\\u6155;\\u6159;\\u615b\\u01b3\\u2034\\0\\u2036;\\u6154;\\u6156\\u02b4\\u203e\\u2041\\0\\0\\u2043\\u803b\\xbe\\u40be;\\u6157;\\u615c5;\\u6158\\u01b6\\u204c\\0\\u204e;\\u615a;\\u615d8;\\u615el;\\u6044wn;\\u6322cr;\\uc000\\ud835\\udcbb\\u0880Eabcdefgijlnorstv\\u2082\\u2089\\u209f\\u20a5\\u20b0\\u20b4\\u20f0\\u20f5\\u20fa\\u20ff\\u2103\\u2112\\u2138\\u0317\\u213e\\u2152\\u219e\\u0100;l\\u064d\\u2087;\\u6a8c\\u0180cmp\\u2090\\u2095\\u209dute;\\u41f5ma\\u0100;d\\u209c\\u1cda\\u43b3;\\u6a86reve;\\u411f\\u0100iy\\u20aa\\u20aerc;\\u411d;\\u4433ot;\\u4121\\u0200;lqs\\u063e\\u0642\\u20bd\\u20c9\\u0180;qs\\u063e\\u064c\\u20c4lan\\xf4\\u0665\\u0200;cdl\\u0665\\u20d2\\u20d5\\u20e5c;\\u6aa9ot\\u0100;o\\u20dc\\u20dd\\u6a80\\u0100;l\\u20e2\\u20e3\\u6a82;\\u6a84\\u0100;e\\u20ea\\u20ed\\uc000\\u22db\\ufe00s;\\u6a94r;\\uc000\\ud835\\udd24\\u0100;g\\u0673\\u061bmel;\\u6137cy;\\u4453\\u0200;Eaj\\u065a\\u210c\\u210e\\u2110;\\u6a92;\\u6aa5;\\u6aa4\\u0200Eaes\\u211b\\u211d\\u2129\\u2134;\\u6269p\\u0100;p\\u2123\\u2124\\u6a8arox\\xbb\\u2124\\u0100;q\\u212e\\u212f\\u6a88\\u0100;q\\u212e\\u211bim;\\u62e7pf;\\uc000\\ud835\\udd58\\u0100ci\\u2143\\u2146r;\\u610am\\u0180;el\\u066b\\u214e\\u2150;\\u6a8e;\\u6a90\\u8300>;cdlqr\\u05ee\\u2160\\u216a\\u216e\\u2173\\u2179\\u0100ci\\u2165\\u2167;\\u6aa7r;\\u6a7aot;\\u62d7Par;\\u6995uest;\\u6a7c\\u0280adels\\u2184\\u216a\\u2190\\u0656\\u219b\\u01f0\\u2189\\0\\u218epro\\xf8\\u209er;\\u6978q\\u0100lq\\u063f\\u2196les\\xf3\\u2088i\\xed\\u066b\\u0100en\\u21a3\\u21adrtneqq;\\uc000\\u2269\\ufe00\\xc5\\u21aa\\u0500Aabcefkosy\\u21c4\\u21c7\\u21f1\\u21f5\\u21fa\\u2218\\u221d\\u222f\\u2268\\u227dr\\xf2\\u03a0\\u0200ilmr\\u21d0\\u21d4\\u21d7\\u21dbrs\\xf0\\u1484f\\xbb\\u2024il\\xf4\\u06a9\\u0100dr\\u21e0\\u21e4cy;\\u444a\\u0180;cw\\u08f4\\u21eb\\u21efir;\\u6948;\\u61adar;\\u610firc;\\u4125\\u0180alr\\u2201\\u220e\\u2213rts\\u0100;u\\u2209\\u220a\\u6665it\\xbb\\u220alip;\\u6026con;\\u62b9r;\\uc000\\ud835\\udd25s\\u0100ew\\u2223\\u2229arow;\\u6925arow;\\u6926\\u0280amopr\\u223a\\u223e\\u2243\\u225e\\u2263rr;\\u61fftht;\\u623bk\\u0100lr\\u2249\\u2253eftarrow;\\u61a9ightarrow;\\u61aaf;\\uc000\\ud835\\udd59bar;\\u6015\\u0180clt\\u226f\\u2274\\u2278r;\\uc000\\ud835\\udcbdas\\xe8\\u21f4rok;\\u4127\\u0100bp\\u2282\\u2287ull;\\u6043hen\\xbb\\u1c5b\\u0ae1\\u22a3\\0\\u22aa\\0\\u22b8\\u22c5\\u22ce\\0\\u22d5\\u22f3\\0\\0\\u22f8\\u2322\\u2367\\u2362\\u237f\\0\\u2386\\u23aa\\u23b4cute\\u803b\\xed\\u40ed\\u0180;iy\\u0771\\u22b0\\u22b5rc\\u803b\\xee\\u40ee;\\u4438\\u0100cx\\u22bc\\u22bfy;\\u4435cl\\u803b\\xa1\\u40a1\\u0100fr\\u039f\\u22c9;\\uc000\\ud835\\udd26rave\\u803b\\xec\\u40ec\\u0200;ino\\u073e\\u22dd\\u22e9\\u22ee\\u0100in\\u22e2\\u22e6nt;\\u6a0ct;\\u622dfin;\\u69dcta;\\u6129lig;\\u4133\\u0180aop\\u22fe\\u231a\\u231d\\u0180cgt\\u2305\\u2308\\u2317r;\\u412b\\u0180elp\\u071f\\u230f\\u2313in\\xe5\\u078ear\\xf4\\u0720h;\\u4131f;\\u62b7ed;\\u41b5\\u0280;cfot\\u04f4\\u232c\\u2331\\u233d\\u2341are;\\u6105in\\u0100;t\\u2338\\u2339\\u621eie;\\u69dddo\\xf4\\u2319\\u0280;celp\\u0757\\u234c\\u2350\\u235b\\u2361al;\\u62ba\\u0100gr\\u2355\\u2359er\\xf3\\u1563\\xe3\\u234darhk;\\u6a17rod;\\u6a3c\\u0200cgpt\\u236f\\u2372\\u2376\\u237by;\\u4451on;\\u412ff;\\uc000\\ud835\\udd5aa;\\u43b9uest\\u803b\\xbf\\u40bf\\u0100ci\\u238a\\u238fr;\\uc000\\ud835\\udcben\\u0280;Edsv\\u04f4\\u239b\\u239d\\u23a1\\u04f3;\\u62f9ot;\\u62f5\\u0100;v\\u23a6\\u23a7\\u62f4;\\u62f3\\u0100;i\\u0777\\u23aelde;\\u4129\\u01eb\\u23b8\\0\\u23bccy;\\u4456l\\u803b\\xef\\u40ef\\u0300cfmosu\\u23cc\\u23d7\\u23dc\\u23e1\\u23e7\\u23f5\\u0100iy\\u23d1\\u23d5rc;\\u4135;\\u4439r;\\uc000\\ud835\\udd27ath;\\u4237pf;\\uc000\\ud835\\udd5b\\u01e3\\u23ec\\0\\u23f1r;\\uc000\\ud835\\udcbfrcy;\\u4458kcy;\\u4454\\u0400acfghjos\\u240b\\u2416\\u2422\\u2427\\u242d\\u2431\\u2435\\u243bppa\\u0100;v\\u2413\\u2414\\u43ba;\\u43f0\\u0100ey\\u241b\\u2420dil;\\u4137;\\u443ar;\\uc000\\ud835\\udd28reen;\\u4138cy;\\u4445cy;\\u445cpf;\\uc000\\ud835\\udd5ccr;\\uc000\\ud835\\udcc0\\u0b80ABEHabcdefghjlmnoprstuv\\u2470\\u2481\\u2486\\u248d\\u2491\\u250e\\u253d\\u255a\\u2580\\u264e\\u265e\\u2665\\u2679\\u267d\\u269a\\u26b2\\u26d8\\u275d\\u2768\\u278b\\u27c0\\u2801\\u2812\\u0180art\\u2477\\u247a\\u247cr\\xf2\\u09c6\\xf2\\u0395ail;\\u691barr;\\u690e\\u0100;g\\u0994\\u248b;\\u6a8bar;\\u6962\\u0963\\u24a5\\0\\u24aa\\0\\u24b1\\0\\0\\0\\0\\0\\u24b5\\u24ba\\0\\u24c6\\u24c8\\u24cd\\0\\u24f9ute;\\u413amptyv;\\u69b4ra\\xee\\u084cbda;\\u43bbg\\u0180;dl\\u088e\\u24c1\\u24c3;\\u6991\\xe5\\u088e;\\u6a85uo\\u803b\\xab\\u40abr\\u0400;bfhlpst\\u0899\\u24de\\u24e6\\u24e9\\u24eb\\u24ee\\u24f1\\u24f5\\u0100;f\\u089d\\u24e3s;\\u691fs;\\u691d\\xeb\\u2252p;\\u61abl;\\u6939im;\\u6973l;\\u61a2\\u0180;ae\\u24ff\\u2500\\u2504\\u6aabil;\\u6919\\u0100;s\\u2509\\u250a\\u6aad;\\uc000\\u2aad\\ufe00\\u0180abr\\u2515\\u2519\\u251drr;\\u690crk;\\u6772\\u0100ak\\u2522\\u252cc\\u0100ek\\u2528\\u252a;\\u407b;\\u405b\\u0100es\\u2531\\u2533;\\u698bl\\u0100du\\u2539\\u253b;\\u698f;\\u698d\\u0200aeuy\\u2546\\u254b\\u2556\\u2558ron;\\u413e\\u0100di\\u2550\\u2554il;\\u413c\\xec\\u08b0\\xe2\\u2529;\\u443b\\u0200cqrs\\u2563\\u2566\\u256d\\u257da;\\u6936uo\\u0100;r\\u0e19\\u1746\\u0100du\\u2572\\u2577har;\\u6967shar;\\u694bh;\\u61b2\\u0280;fgqs\\u258b\\u258c\\u0989\\u25f3\\u25ff\\u6264t\\u0280ahlrt\\u2598\\u25a4\\u25b7\\u25c2\\u25e8rrow\\u0100;t\\u0899\\u25a1a\\xe9\\u24f6arpoon\\u0100du\\u25af\\u25b4own\\xbb\\u045ap\\xbb\\u0966eftarrows;\\u61c7ight\\u0180ahs\\u25cd\\u25d6\\u25derrow\\u0100;s\\u08f4\\u08a7arpoon\\xf3\\u0f98quigarro\\xf7\\u21f0hreetimes;\\u62cb\\u0180;qs\\u258b\\u0993\\u25falan\\xf4\\u09ac\\u0280;cdgs\\u09ac\\u260a\\u260d\\u261d\\u2628c;\\u6aa8ot\\u0100;o\\u2614\\u2615\\u6a7f\\u0100;r\\u261a\\u261b\\u6a81;\\u6a83\\u0100;e\\u2622\\u2625\\uc000\\u22da\\ufe00s;\\u6a93\\u0280adegs\\u2633\\u2639\\u263d\\u2649\\u264bppro\\xf8\\u24c6ot;\\u62d6q\\u0100gq\\u2643\\u2645\\xf4\\u0989gt\\xf2\\u248c\\xf4\\u099bi\\xed\\u09b2\\u0180ilr\\u2655\\u08e1\\u265asht;\\u697c;\\uc000\\ud835\\udd29\\u0100;E\\u099c\\u2663;\\u6a91\\u0161\\u2669\\u2676r\\u0100du\\u25b2\\u266e\\u0100;l\\u0965\\u2673;\\u696alk;\\u6584cy;\\u4459\\u0280;acht\\u0a48\\u2688\\u268b\\u2691\\u2696r\\xf2\\u25c1orne\\xf2\\u1d08ard;\\u696bri;\\u65fa\\u0100io\\u269f\\u26a4dot;\\u4140ust\\u0100;a\\u26ac\\u26ad\\u63b0che\\xbb\\u26ad\\u0200Eaes\\u26bb\\u26bd\\u26c9\\u26d4;\\u6268p\\u0100;p\\u26c3\\u26c4\\u6a89rox\\xbb\\u26c4\\u0100;q\\u26ce\\u26cf\\u6a87\\u0100;q\\u26ce\\u26bbim;\\u62e6\\u0400abnoptwz\\u26e9\\u26f4\\u26f7\\u271a\\u272f\\u2741\\u2747\\u2750\\u0100nr\\u26ee\\u26f1g;\\u67ecr;\\u61fdr\\xeb\\u08c1g\\u0180lmr\\u26ff\\u270d\\u2714eft\\u0100ar\\u09e6\\u2707ight\\xe1\\u09f2apsto;\\u67fcight\\xe1\\u09fdparrow\\u0100lr\\u2725\\u2729ef\\xf4\\u24edight;\\u61ac\\u0180afl\\u2736\\u2739\\u273dr;\\u6985;\\uc000\\ud835\\udd5dus;\\u6a2dimes;\\u6a34\\u0161\\u274b\\u274fst;\\u6217\\xe1\\u134e\\u0180;ef\\u2757\\u2758\\u1800\\u65cange\\xbb\\u2758ar\\u0100;l\\u2764\\u2765\\u4028t;\\u6993\\u0280achmt\\u2773\\u2776\\u277c\\u2785\\u2787r\\xf2\\u08a8orne\\xf2\\u1d8car\\u0100;d\\u0f98\\u2783;\\u696d;\\u600eri;\\u62bf\\u0300achiqt\\u2798\\u279d\\u0a40\\u27a2\\u27ae\\u27bbquo;\\u6039r;\\uc000\\ud835\\udcc1m\\u0180;eg\\u09b2\\u27aa\\u27ac;\\u6a8d;\\u6a8f\\u0100bu\\u252a\\u27b3o\\u0100;r\\u0e1f\\u27b9;\\u601arok;\\u4142\\u8400<;cdhilqr\\u082b\\u27d2\\u2639\\u27dc\\u27e0\\u27e5\\u27ea\\u27f0\\u0100ci\\u27d7\\u27d9;\\u6aa6r;\\u6a79re\\xe5\\u25f2mes;\\u62c9arr;\\u6976uest;\\u6a7b\\u0100Pi\\u27f5\\u27f9ar;\\u6996\\u0180;ef\\u2800\\u092d\\u181b\\u65c3r\\u0100du\\u2807\\u280dshar;\\u694ahar;\\u6966\\u0100en\\u2817\\u2821rtneqq;\\uc000\\u2268\\ufe00\\xc5\\u281e\\u0700Dacdefhilnopsu\\u2840\\u2845\\u2882\\u288e\\u2893\\u28a0\\u28a5\\u28a8\\u28da\\u28e2\\u28e4\\u0a83\\u28f3\\u2902Dot;\\u623a\\u0200clpr\\u284e\\u2852\\u2863\\u287dr\\u803b\\xaf\\u40af\\u0100et\\u2857\\u2859;\\u6642\\u0100;e\\u285e\\u285f\\u6720se\\xbb\\u285f\\u0100;s\\u103b\\u2868to\\u0200;dlu\\u103b\\u2873\\u2877\\u287bow\\xee\\u048cef\\xf4\\u090f\\xf0\\u13d1ker;\\u65ae\\u0100oy\\u2887\\u288cmma;\\u6a29;\\u443cash;\\u6014asuredangle\\xbb\\u1626r;\\uc000\\ud835\\udd2ao;\\u6127\\u0180cdn\\u28af\\u28b4\\u28c9ro\\u803b\\xb5\\u40b5\\u0200;acd\\u1464\\u28bd\\u28c0\\u28c4s\\xf4\\u16a7ir;\\u6af0ot\\u80bb\\xb7\\u01b5us\\u0180;bd\\u28d2\\u1903\\u28d3\\u6212\\u0100;u\\u1d3c\\u28d8;\\u6a2a\\u0163\\u28de\\u28e1p;\\u6adb\\xf2\\u2212\\xf0\\u0a81\\u0100dp\\u28e9\\u28eeels;\\u62a7f;\\uc000\\ud835\\udd5e\\u0100ct\\u28f8\\u28fdr;\\uc000\\ud835\\udcc2pos\\xbb\\u159d\\u0180;lm\\u2909\\u290a\\u290d\\u43bctimap;\\u62b8\\u0c00GLRVabcdefghijlmoprstuvw\\u2942\\u2953\\u297e\\u2989\\u2998\\u29da\\u29e9\\u2a15\\u2a1a\\u2a58\\u2a5d\\u2a83\\u2a95\\u2aa4\\u2aa8\\u2b04\\u2b07\\u2b44\\u2b7f\\u2bae\\u2c34\\u2c67\\u2c7c\\u2ce9\\u0100gt\\u2947\\u294b;\\uc000\\u22d9\\u0338\\u0100;v\\u2950\\u0bcf\\uc000\\u226b\\u20d2\\u0180elt\\u295a\\u2972\\u2976ft\\u0100ar\\u2961\\u2967rrow;\\u61cdightarrow;\\u61ce;\\uc000\\u22d8\\u0338\\u0100;v\\u297b\\u0c47\\uc000\\u226a\\u20d2ightarrow;\\u61cf\\u0100Dd\\u298e\\u2993ash;\\u62afash;\\u62ae\\u0280bcnpt\\u29a3\\u29a7\\u29ac\\u29b1\\u29ccla\\xbb\\u02deute;\\u4144g;\\uc000\\u2220\\u20d2\\u0280;Eiop\\u0d84\\u29bc\\u29c0\\u29c5\\u29c8;\\uc000\\u2a70\\u0338d;\\uc000\\u224b\\u0338s;\\u4149ro\\xf8\\u0d84ur\\u0100;a\\u29d3\\u29d4\\u666el\\u0100;s\\u29d3\\u0b38\\u01f3\\u29df\\0\\u29e3p\\u80bb\\xa0\\u0b37mp\\u0100;e\\u0bf9\\u0c00\\u0280aeouy\\u29f4\\u29fe\\u2a03\\u2a10\\u2a13\\u01f0\\u29f9\\0\\u29fb;\\u6a43on;\\u4148dil;\\u4146ng\\u0100;d\\u0d7e\\u2a0aot;\\uc000\\u2a6d\\u0338p;\\u6a42;\\u443dash;\\u6013\\u0380;Aadqsx\\u0b92\\u2a29\\u2a2d\\u2a3b\\u2a41\\u2a45\\u2a50rr;\\u61d7r\\u0100hr\\u2a33\\u2a36k;\\u6924\\u0100;o\\u13f2\\u13f0ot;\\uc000\\u2250\\u0338ui\\xf6\\u0b63\\u0100ei\\u2a4a\\u2a4ear;\\u6928\\xed\\u0b98ist\\u0100;s\\u0ba0\\u0b9fr;\\uc000\\ud835\\udd2b\\u0200Eest\\u0bc5\\u2a66\\u2a79\\u2a7c\\u0180;qs\\u0bbc\\u2a6d\\u0be1\\u0180;qs\\u0bbc\\u0bc5\\u2a74lan\\xf4\\u0be2i\\xed\\u0bea\\u0100;r\\u0bb6\\u2a81\\xbb\\u0bb7\\u0180Aap\\u2a8a\\u2a8d\\u2a91r\\xf2\\u2971rr;\\u61aear;\\u6af2\\u0180;sv\\u0f8d\\u2a9c\\u0f8c\\u0100;d\\u2aa1\\u2aa2\\u62fc;\\u62facy;\\u445a\\u0380AEadest\\u2ab7\\u2aba\\u2abe\\u2ac2\\u2ac5\\u2af6\\u2af9r\\xf2\\u2966;\\uc000\\u2266\\u0338rr;\\u619ar;\\u6025\\u0200;fqs\\u0c3b\\u2ace\\u2ae3\\u2aeft\\u0100ar\\u2ad4\\u2ad9rro\\xf7\\u2ac1ightarro\\xf7\\u2a90\\u0180;qs\\u0c3b\\u2aba\\u2aealan\\xf4\\u0c55\\u0100;s\\u0c55\\u2af4\\xbb\\u0c36i\\xed\\u0c5d\\u0100;r\\u0c35\\u2afei\\u0100;e\\u0c1a\\u0c25i\\xe4\\u0d90\\u0100pt\\u2b0c\\u2b11f;\\uc000\\ud835\\udd5f\\u8180\\xac;in\\u2b19\\u2b1a\\u2b36\\u40acn\\u0200;Edv\\u0b89\\u2b24\\u2b28\\u2b2e;\\uc000\\u22f9\\u0338ot;\\uc000\\u22f5\\u0338\\u01e1\\u0b89\\u2b33\\u2b35;\\u62f7;\\u62f6i\\u0100;v\\u0cb8\\u2b3c\\u01e1\\u0cb8\\u2b41\\u2b43;\\u62fe;\\u62fd\\u0180aor\\u2b4b\\u2b63\\u2b69r\\u0200;ast\\u0b7b\\u2b55\\u2b5a\\u2b5flle\\xec\\u0b7bl;\\uc000\\u2afd\\u20e5;\\uc000\\u2202\\u0338lint;\\u6a14\\u0180;ce\\u0c92\\u2b70\\u2b73u\\xe5\\u0ca5\\u0100;c\\u0c98\\u2b78\\u0100;e\\u0c92\\u2b7d\\xf1\\u0c98\\u0200Aait\\u2b88\\u2b8b\\u2b9d\\u2ba7r\\xf2\\u2988rr\\u0180;cw\\u2b94\\u2b95\\u2b99\\u619b;\\uc000\\u2933\\u0338;\\uc000\\u219d\\u0338ghtarrow\\xbb\\u2b95ri\\u0100;e\\u0ccb\\u0cd6\\u0380chimpqu\\u2bbd\\u2bcd\\u2bd9\\u2b04\\u0b78\\u2be4\\u2bef\\u0200;cer\\u0d32\\u2bc6\\u0d37\\u2bc9u\\xe5\\u0d45;\\uc000\\ud835\\udcc3ort\\u026d\\u2b05\\0\\0\\u2bd6ar\\xe1\\u2b56m\\u0100;e\\u0d6e\\u2bdf\\u0100;q\\u0d74\\u0d73su\\u0100bp\\u2beb\\u2bed\\xe5\\u0cf8\\xe5\\u0d0b\\u0180bcp\\u2bf6\\u2c11\\u2c19\\u0200;Ees\\u2bff\\u2c00\\u0d22\\u2c04\\u6284;\\uc000\\u2ac5\\u0338et\\u0100;e\\u0d1b\\u2c0bq\\u0100;q\\u0d23\\u2c00c\\u0100;e\\u0d32\\u2c17\\xf1\\u0d38\\u0200;Ees\\u2c22\\u2c23\\u0d5f\\u2c27\\u6285;\\uc000\\u2ac6\\u0338et\\u0100;e\\u0d58\\u2c2eq\\u0100;q\\u0d60\\u2c23\\u0200gilr\\u2c3d\\u2c3f\\u2c45\\u2c47\\xec\\u0bd7lde\\u803b\\xf1\\u40f1\\xe7\\u0c43iangle\\u0100lr\\u2c52\\u2c5ceft\\u0100;e\\u0c1a\\u2c5a\\xf1\\u0c26ight\\u0100;e\\u0ccb\\u2c65\\xf1\\u0cd7\\u0100;m\\u2c6c\\u2c6d\\u43bd\\u0180;es\\u2c74\\u2c75\\u2c79\\u4023ro;\\u6116p;\\u6007\\u0480DHadgilrs\\u2c8f\\u2c94\\u2c99\\u2c9e\\u2ca3\\u2cb0\\u2cb6\\u2cd3\\u2ce3ash;\\u62adarr;\\u6904p;\\uc000\\u224d\\u20d2ash;\\u62ac\\u0100et\\u2ca8\\u2cac;\\uc000\\u2265\\u20d2;\\uc000>\\u20d2nfin;\\u69de\\u0180Aet\\u2cbd\\u2cc1\\u2cc5rr;\\u6902;\\uc000\\u2264\\u20d2\\u0100;r\\u2cca\\u2ccd\\uc000<\\u20d2ie;\\uc000\\u22b4\\u20d2\\u0100At\\u2cd8\\u2cdcrr;\\u6903rie;\\uc000\\u22b5\\u20d2im;\\uc000\\u223c\\u20d2\\u0180Aan\\u2cf0\\u2cf4\\u2d02rr;\\u61d6r\\u0100hr\\u2cfa\\u2cfdk;\\u6923\\u0100;o\\u13e7\\u13e5ear;\\u6927\\u1253\\u1a95\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\u2d2d\\0\\u2d38\\u2d48\\u2d60\\u2d65\\u2d72\\u2d84\\u1b07\\0\\0\\u2d8d\\u2dab\\0\\u2dc8\\u2dce\\0\\u2ddc\\u2e19\\u2e2b\\u2e3e\\u2e43\\u0100cs\\u2d31\\u1a97ute\\u803b\\xf3\\u40f3\\u0100iy\\u2d3c\\u2d45r\\u0100;c\\u1a9e\\u2d42\\u803b\\xf4\\u40f4;\\u443e\\u0280abios\\u1aa0\\u2d52\\u2d57\\u01c8\\u2d5alac;\\u4151v;\\u6a38old;\\u69bclig;\\u4153\\u0100cr\\u2d69\\u2d6dir;\\u69bf;\\uc000\\ud835\\udd2c\\u036f\\u2d79\\0\\0\\u2d7c\\0\\u2d82n;\\u42dbave\\u803b\\xf2\\u40f2;\\u69c1\\u0100bm\\u2d88\\u0df4ar;\\u69b5\\u0200acit\\u2d95\\u2d98\\u2da5\\u2da8r\\xf2\\u1a80\\u0100ir\\u2d9d\\u2da0r;\\u69beoss;\\u69bbn\\xe5\\u0e52;\\u69c0\\u0180aei\\u2db1\\u2db5\\u2db9cr;\\u414dga;\\u43c9\\u0180cdn\\u2dc0\\u2dc5\\u01cdron;\\u43bf;\\u69b6pf;\\uc000\\ud835\\udd60\\u0180ael\\u2dd4\\u2dd7\\u01d2r;\\u69b7rp;\\u69b9\\u0380;adiosv\\u2dea\\u2deb\\u2dee\\u2e08\\u2e0d\\u2e10\\u2e16\\u6228r\\xf2\\u1a86\\u0200;efm\\u2df7\\u2df8\\u2e02\\u2e05\\u6a5dr\\u0100;o\\u2dfe\\u2dff\\u6134f\\xbb\\u2dff\\u803b\\xaa\\u40aa\\u803b\\xba\\u40bagof;\\u62b6r;\\u6a56lope;\\u6a57;\\u6a5b\\u0180clo\\u2e1f\\u2e21\\u2e27\\xf2\\u2e01ash\\u803b\\xf8\\u40f8l;\\u6298i\\u016c\\u2e2f\\u2e34de\\u803b\\xf5\\u40f5es\\u0100;a\\u01db\\u2e3as;\\u6a36ml\\u803b\\xf6\\u40f6bar;\\u633d\\u0ae1\\u2e5e\\0\\u2e7d\\0\\u2e80\\u2e9d\\0\\u2ea2\\u2eb9\\0\\0\\u2ecb\\u0e9c\\0\\u2f13\\0\\0\\u2f2b\\u2fbc\\0\\u2fc8r\\u0200;ast\\u0403\\u2e67\\u2e72\\u0e85\\u8100\\xb6;l\\u2e6d\\u2e6e\\u40b6le\\xec\\u0403\\u0269\\u2e78\\0\\0\\u2e7bm;\\u6af3;\\u6afdy;\\u443fr\\u0280cimpt\\u2e8b\\u2e8f\\u2e93\\u1865\\u2e97nt;\\u4025od;\\u402eil;\\u6030enk;\\u6031r;\\uc000\\ud835\\udd2d\\u0180imo\\u2ea8\\u2eb0\\u2eb4\\u0100;v\\u2ead\\u2eae\\u43c6;\\u43d5ma\\xf4\\u0a76ne;\\u660e\\u0180;tv\\u2ebf\\u2ec0\\u2ec8\\u43c0chfork\\xbb\\u1ffd;\\u43d6\\u0100au\\u2ecf\\u2edfn\\u0100ck\\u2ed5\\u2eddk\\u0100;h\\u21f4\\u2edb;\\u610e\\xf6\\u21f4s\\u0480;abcdemst\\u2ef3\\u2ef4\\u1908\\u2ef9\\u2efd\\u2f04\\u2f06\\u2f0a\\u2f0e\\u402bcir;\\u6a23ir;\\u6a22\\u0100ou\\u1d40\\u2f02;\\u6a25;\\u6a72n\\u80bb\\xb1\\u0e9dim;\\u6a26wo;\\u6a27\\u0180ipu\\u2f19\\u2f20\\u2f25ntint;\\u6a15f;\\uc000\\ud835\\udd61nd\\u803b\\xa3\\u40a3\\u0500;Eaceinosu\\u0ec8\\u2f3f\\u2f41\\u2f44\\u2f47\\u2f81\\u2f89\\u2f92\\u2f7e\\u2fb6;\\u6ab3p;\\u6ab7u\\xe5\\u0ed9\\u0100;c\\u0ece\\u2f4c\\u0300;acens\\u0ec8\\u2f59\\u2f5f\\u2f66\\u2f68\\u2f7eppro\\xf8\\u2f43urlye\\xf1\\u0ed9\\xf1\\u0ece\\u0180aes\\u2f6f\\u2f76\\u2f7approx;\\u6ab9qq;\\u6ab5im;\\u62e8i\\xed\\u0edfme\\u0100;s\\u2f88\\u0eae\\u6032\\u0180Eas\\u2f78\\u2f90\\u2f7a\\xf0\\u2f75\\u0180dfp\\u0eec\\u2f99\\u2faf\\u0180als\\u2fa0\\u2fa5\\u2faalar;\\u632eine;\\u6312urf;\\u6313\\u0100;t\\u0efb\\u2fb4\\xef\\u0efbrel;\\u62b0\\u0100ci\\u2fc0\\u2fc5r;\\uc000\\ud835\\udcc5;\\u43c8ncsp;\\u6008\\u0300fiopsu\\u2fda\\u22e2\\u2fdf\\u2fe5\\u2feb\\u2ff1r;\\uc000\\ud835\\udd2epf;\\uc000\\ud835\\udd62rime;\\u6057cr;\\uc000\\ud835\\udcc6\\u0180aeo\\u2ff8\\u3009\\u3013t\\u0100ei\\u2ffe\\u3005rnion\\xf3\\u06b0nt;\\u6a16st\\u0100;e\\u3010\\u3011\\u403f\\xf1\\u1f19\\xf4\\u0f14\\u0a80ABHabcdefhilmnoprstux\\u3040\\u3051\\u3055\\u3059\\u30e0\\u310e\\u312b\\u3147\\u3162\\u3172\\u318e\\u3206\\u3215\\u3224\\u3229\\u3258\\u326e\\u3272\\u3290\\u32b0\\u32b7\\u0180art\\u3047\\u304a\\u304cr\\xf2\\u10b3\\xf2\\u03ddail;\\u691car\\xf2\\u1c65ar;\\u6964\\u0380cdenqrt\\u3068\\u3075\\u3078\\u307f\\u308f\\u3094\\u30cc\\u0100eu\\u306d\\u3071;\\uc000\\u223d\\u0331te;\\u4155i\\xe3\\u116emptyv;\\u69b3g\\u0200;del\\u0fd1\\u3089\\u308b\\u308d;\\u6992;\\u69a5\\xe5\\u0fd1uo\\u803b\\xbb\\u40bbr\\u0580;abcfhlpstw\\u0fdc\\u30ac\\u30af\\u30b7\\u30b9\\u30bc\\u30be\\u30c0\\u30c3\\u30c7\\u30cap;\\u6975\\u0100;f\\u0fe0\\u30b4s;\\u6920;\\u6933s;\\u691e\\xeb\\u225d\\xf0\\u272el;\\u6945im;\\u6974l;\\u61a3;\\u619d\\u0100ai\\u30d1\\u30d5il;\\u691ao\\u0100;n\\u30db\\u30dc\\u6236al\\xf3\\u0f1e\\u0180abr\\u30e7\\u30ea\\u30eer\\xf2\\u17e5rk;\\u6773\\u0100ak\\u30f3\\u30fdc\\u0100ek\\u30f9\\u30fb;\\u407d;\\u405d\\u0100es\\u3102\\u3104;\\u698cl\\u0100du\\u310a\\u310c;\\u698e;\\u6990\\u0200aeuy\\u3117\\u311c\\u3127\\u3129ron;\\u4159\\u0100di\\u3121\\u3125il;\\u4157\\xec\\u0ff2\\xe2\\u30fa;\\u4440\\u0200clqs\\u3134\\u3137\\u313d\\u3144a;\\u6937dhar;\\u6969uo\\u0100;r\\u020e\\u020dh;\\u61b3\\u0180acg\\u314e\\u315f\\u0f44l\\u0200;ips\\u0f78\\u3158\\u315b\\u109cn\\xe5\\u10bbar\\xf4\\u0fa9t;\\u65ad\\u0180ilr\\u3169\\u1023\\u316esht;\\u697d;\\uc000\\ud835\\udd2f\\u0100ao\\u3177\\u3186r\\u0100du\\u317d\\u317f\\xbb\\u047b\\u0100;l\\u1091\\u3184;\\u696c\\u0100;v\\u318b\\u318c\\u43c1;\\u43f1\\u0180gns\\u3195\\u31f9\\u31fcht\\u0300ahlrst\\u31a4\\u31b0\\u31c2\\u31d8\\u31e4\\u31eerrow\\u0100;t\\u0fdc\\u31ada\\xe9\\u30c8arpoon\\u0100du\\u31bb\\u31bfow\\xee\\u317ep\\xbb\\u1092eft\\u0100ah\\u31ca\\u31d0rrow\\xf3\\u0feaarpoon\\xf3\\u0551ightarrows;\\u61c9quigarro\\xf7\\u30cbhreetimes;\\u62ccg;\\u42daingdotse\\xf1\\u1f32\\u0180ahm\\u320d\\u3210\\u3213r\\xf2\\u0feaa\\xf2\\u0551;\\u600foust\\u0100;a\\u321e\\u321f\\u63b1che\\xbb\\u321fmid;\\u6aee\\u0200abpt\\u3232\\u323d\\u3240\\u3252\\u0100nr\\u3237\\u323ag;\\u67edr;\\u61fer\\xeb\\u1003\\u0180afl\\u3247\\u324a\\u324er;\\u6986;\\uc000\\ud835\\udd63us;\\u6a2eimes;\\u6a35\\u0100ap\\u325d\\u3267r\\u0100;g\\u3263\\u3264\\u4029t;\\u6994olint;\\u6a12ar\\xf2\\u31e3\\u0200achq\\u327b\\u3280\\u10bc\\u3285quo;\\u603ar;\\uc000\\ud835\\udcc7\\u0100bu\\u30fb\\u328ao\\u0100;r\\u0214\\u0213\\u0180hir\\u3297\\u329b\\u32a0re\\xe5\\u31f8mes;\\u62cai\\u0200;efl\\u32aa\\u1059\\u1821\\u32ab\\u65b9tri;\\u69celuhar;\\u6968;\\u611e\\u0d61\\u32d5\\u32db\\u32df\\u332c\\u3338\\u3371\\0\\u337a\\u33a4\\0\\0\\u33ec\\u33f0\\0\\u3428\\u3448\\u345a\\u34ad\\u34b1\\u34ca\\u34f1\\0\\u3616\\0\\0\\u3633cute;\\u415bqu\\xef\\u27ba\\u0500;Eaceinpsy\\u11ed\\u32f3\\u32f5\\u32ff\\u3302\\u330b\\u330f\\u331f\\u3326\\u3329;\\u6ab4\\u01f0\\u32fa\\0\\u32fc;\\u6ab8on;\\u4161u\\xe5\\u11fe\\u0100;d\\u11f3\\u3307il;\\u415frc;\\u415d\\u0180Eas\\u3316\\u3318\\u331b;\\u6ab6p;\\u6abaim;\\u62e9olint;\\u6a13i\\xed\\u1204;\\u4441ot\\u0180;be\\u3334\\u1d47\\u3335\\u62c5;\\u6a66\\u0380Aacmstx\\u3346\\u334a\\u3357\\u335b\\u335e\\u3363\\u336drr;\\u61d8r\\u0100hr\\u3350\\u3352\\xeb\\u2228\\u0100;o\\u0a36\\u0a34t\\u803b\\xa7\\u40a7i;\\u403bwar;\\u6929m\\u0100in\\u3369\\xf0nu\\xf3\\xf1t;\\u6736r\\u0100;o\\u3376\\u2055\\uc000\\ud835\\udd30\\u0200acoy\\u3382\\u3386\\u3391\\u33a0rp;\\u666f\\u0100hy\\u338b\\u338fcy;\\u4449;\\u4448rt\\u026d\\u3399\\0\\0\\u339ci\\xe4\\u1464ara\\xec\\u2e6f\\u803b\\xad\\u40ad\\u0100gm\\u33a8\\u33b4ma\\u0180;fv\\u33b1\\u33b2\\u33b2\\u43c3;\\u43c2\\u0400;deglnpr\\u12ab\\u33c5\\u33c9\\u33ce\\u33d6\\u33de\\u33e1\\u33e6ot;\\u6a6a\\u0100;q\\u12b1\\u12b0\\u0100;E\\u33d3\\u33d4\\u6a9e;\\u6aa0\\u0100;E\\u33db\\u33dc\\u6a9d;\\u6a9fe;\\u6246lus;\\u6a24arr;\\u6972ar\\xf2\\u113d\\u0200aeit\\u33f8\\u3408\\u340f\\u3417\\u0100ls\\u33fd\\u3404lsetm\\xe9\\u336ahp;\\u6a33parsl;\\u69e4\\u0100dl\\u1463\\u3414e;\\u6323\\u0100;e\\u341c\\u341d\\u6aaa\\u0100;s\\u3422\\u3423\\u6aac;\\uc000\\u2aac\\ufe00\\u0180flp\\u342e\\u3433\\u3442tcy;\\u444c\\u0100;b\\u3438\\u3439\\u402f\\u0100;a\\u343e\\u343f\\u69c4r;\\u633ff;\\uc000\\ud835\\udd64a\\u0100dr\\u344d\\u0402es\\u0100;u\\u3454\\u3455\\u6660it\\xbb\\u3455\\u0180csu\\u3460\\u3479\\u349f\\u0100au\\u3465\\u346fp\\u0100;s\\u1188\\u346b;\\uc000\\u2293\\ufe00p\\u0100;s\\u11b4\\u3475;\\uc000\\u2294\\ufe00u\\u0100bp\\u347f\\u348f\\u0180;es\\u1197\\u119c\\u3486et\\u0100;e\\u1197\\u348d\\xf1\\u119d\\u0180;es\\u11a8\\u11ad\\u3496et\\u0100;e\\u11a8\\u349d\\xf1\\u11ae\\u0180;af\\u117b\\u34a6\\u05b0r\\u0165\\u34ab\\u05b1\\xbb\\u117car\\xf2\\u1148\\u0200cemt\\u34b9\\u34be\\u34c2\\u34c5r;\\uc000\\ud835\\udcc8tm\\xee\\xf1i\\xec\\u3415ar\\xe6\\u11be\\u0100ar\\u34ce\\u34d5r\\u0100;f\\u34d4\\u17bf\\u6606\\u0100an\\u34da\\u34edight\\u0100ep\\u34e3\\u34eapsilo\\xee\\u1ee0h\\xe9\\u2eafs\\xbb\\u2852\\u0280bcmnp\\u34fb\\u355e\\u1209\\u358b\\u358e\\u0480;Edemnprs\\u350e\\u350f\\u3511\\u3515\\u351e\\u3523\\u352c\\u3531\\u3536\\u6282;\\u6ac5ot;\\u6abd\\u0100;d\\u11da\\u351aot;\\u6ac3ult;\\u6ac1\\u0100Ee\\u3528\\u352a;\\u6acb;\\u628alus;\\u6abfarr;\\u6979\\u0180eiu\\u353d\\u3552\\u3555t\\u0180;en\\u350e\\u3545\\u354bq\\u0100;q\\u11da\\u350feq\\u0100;q\\u352b\\u3528m;\\u6ac7\\u0100bp\\u355a\\u355c;\\u6ad5;\\u6ad3c\\u0300;acens\\u11ed\\u356c\\u3572\\u3579\\u357b\\u3326ppro\\xf8\\u32faurlye\\xf1\\u11fe\\xf1\\u11f3\\u0180aes\\u3582\\u3588\\u331bppro\\xf8\\u331aq\\xf1\\u3317g;\\u666a\\u0680123;Edehlmnps\\u35a9\\u35ac\\u35af\\u121c\\u35b2\\u35b4\\u35c0\\u35c9\\u35d5\\u35da\\u35df\\u35e8\\u35ed\\u803b\\xb9\\u40b9\\u803b\\xb2\\u40b2\\u803b\\xb3\\u40b3;\\u6ac6\\u0100os\\u35b9\\u35bct;\\u6abeub;\\u6ad8\\u0100;d\\u1222\\u35c5ot;\\u6ac4s\\u0100ou\\u35cf\\u35d2l;\\u67c9b;\\u6ad7arr;\\u697bult;\\u6ac2\\u0100Ee\\u35e4\\u35e6;\\u6acc;\\u628blus;\\u6ac0\\u0180eiu\\u35f4\\u3609\\u360ct\\u0180;en\\u121c\\u35fc\\u3602q\\u0100;q\\u1222\\u35b2eq\\u0100;q\\u35e7\\u35e4m;\\u6ac8\\u0100bp\\u3611\\u3613;\\u6ad4;\\u6ad6\\u0180Aan\\u361c\\u3620\\u362drr;\\u61d9r\\u0100hr\\u3626\\u3628\\xeb\\u222e\\u0100;o\\u0a2b\\u0a29war;\\u692alig\\u803b\\xdf\\u40df\\u0be1\\u3651\\u365d\\u3660\\u12ce\\u3673\\u3679\\0\\u367e\\u36c2\\0\\0\\0\\0\\0\\u36db\\u3703\\0\\u3709\\u376c\\0\\0\\0\\u3787\\u0272\\u3656\\0\\0\\u365bget;\\u6316;\\u43c4r\\xeb\\u0e5f\\u0180aey\\u3666\\u366b\\u3670ron;\\u4165dil;\\u4163;\\u4442lrec;\\u6315r;\\uc000\\ud835\\udd31\\u0200eiko\\u3686\\u369d\\u36b5\\u36bc\\u01f2\\u368b\\0\\u3691e\\u01004f\\u1284\\u1281a\\u0180;sv\\u3698\\u3699\\u369b\\u43b8ym;\\u43d1\\u0100cn\\u36a2\\u36b2k\\u0100as\\u36a8\\u36aeppro\\xf8\\u12c1im\\xbb\\u12acs\\xf0\\u129e\\u0100as\\u36ba\\u36ae\\xf0\\u12c1rn\\u803b\\xfe\\u40fe\\u01ec\\u031f\\u36c6\\u22e7es\\u8180\\xd7;bd\\u36cf\\u36d0\\u36d8\\u40d7\\u0100;a\\u190f\\u36d5r;\\u6a31;\\u6a30\\u0180eps\\u36e1\\u36e3\\u3700\\xe1\\u2a4d\\u0200;bcf\\u0486\\u36ec\\u36f0\\u36f4ot;\\u6336ir;\\u6af1\\u0100;o\\u36f9\\u36fc\\uc000\\ud835\\udd65rk;\\u6ada\\xe1\\u3362rime;\\u6034\\u0180aip\\u370f\\u3712\\u3764d\\xe5\\u1248\\u0380adempst\\u3721\\u374d\\u3740\\u3751\\u3757\\u375c\\u375fngle\\u0280;dlqr\\u3730\\u3731\\u3736\\u3740\\u3742\\u65b5own\\xbb\\u1dbbeft\\u0100;e\\u2800\\u373e\\xf1\\u092e;\\u625cight\\u0100;e\\u32aa\\u374b\\xf1\\u105aot;\\u65ecinus;\\u6a3alus;\\u6a39b;\\u69cdime;\\u6a3bezium;\\u63e2\\u0180cht\\u3772\\u377d\\u3781\\u0100ry\\u3777\\u377b;\\uc000\\ud835\\udcc9;\\u4446cy;\\u445brok;\\u4167\\u0100io\\u378b\\u378ex\\xf4\\u1777head\\u0100lr\\u3797\\u37a0eftarro\\xf7\\u084fightarrow\\xbb\\u0f5d\\u0900AHabcdfghlmoprstuw\\u37d0\\u37d3\\u37d7\\u37e4\\u37f0\\u37fc\\u380e\\u381c\\u3823\\u3834\\u3851\\u385d\\u386b\\u38a9\\u38cc\\u38d2\\u38ea\\u38f6r\\xf2\\u03edar;\\u6963\\u0100cr\\u37dc\\u37e2ute\\u803b\\xfa\\u40fa\\xf2\\u1150r\\u01e3\\u37ea\\0\\u37edy;\\u445eve;\\u416d\\u0100iy\\u37f5\\u37farc\\u803b\\xfb\\u40fb;\\u4443\\u0180abh\\u3803\\u3806\\u380br\\xf2\\u13adlac;\\u4171a\\xf2\\u13c3\\u0100ir\\u3813\\u3818sht;\\u697e;\\uc000\\ud835\\udd32rave\\u803b\\xf9\\u40f9\\u0161\\u3827\\u3831r\\u0100lr\\u382c\\u382e\\xbb\\u0957\\xbb\\u1083lk;\\u6580\\u0100ct\\u3839\\u384d\\u026f\\u383f\\0\\0\\u384arn\\u0100;e\\u3845\\u3846\\u631cr\\xbb\\u3846op;\\u630fri;\\u65f8\\u0100al\\u3856\\u385acr;\\u416b\\u80bb\\xa8\\u0349\\u0100gp\\u3862\\u3866on;\\u4173f;\\uc000\\ud835\\udd66\\u0300adhlsu\\u114b\\u3878\\u387d\\u1372\\u3891\\u38a0own\\xe1\\u13b3arpoon\\u0100lr\\u3888\\u388cef\\xf4\\u382digh\\xf4\\u382fi\\u0180;hl\\u3899\\u389a\\u389c\\u43c5\\xbb\\u13faon\\xbb\\u389aparrows;\\u61c8\\u0180cit\\u38b0\\u38c4\\u38c8\\u026f\\u38b6\\0\\0\\u38c1rn\\u0100;e\\u38bc\\u38bd\\u631dr\\xbb\\u38bdop;\\u630eng;\\u416fri;\\u65f9cr;\\uc000\\ud835\\udcca\\u0180dir\\u38d9\\u38dd\\u38e2ot;\\u62f0lde;\\u4169i\\u0100;f\\u3730\\u38e8\\xbb\\u1813\\u0100am\\u38ef\\u38f2r\\xf2\\u38a8l\\u803b\\xfc\\u40fcangle;\\u69a7\\u0780ABDacdeflnoprsz\\u391c\\u391f\\u3929\\u392d\\u39b5\\u39b8\\u39bd\\u39df\\u39e4\\u39e8\\u39f3\\u39f9\\u39fd\\u3a01\\u3a20r\\xf2\\u03f7ar\\u0100;v\\u3926\\u3927\\u6ae8;\\u6ae9as\\xe8\\u03e1\\u0100nr\\u3932\\u3937grt;\\u699c\\u0380eknprst\\u34e3\\u3946\\u394b\\u3952\\u395d\\u3964\\u3996app\\xe1\\u2415othin\\xe7\\u1e96\\u0180hir\\u34eb\\u2ec8\\u3959op\\xf4\\u2fb5\\u0100;h\\u13b7\\u3962\\xef\\u318d\\u0100iu\\u3969\\u396dgm\\xe1\\u33b3\\u0100bp\\u3972\\u3984setneq\\u0100;q\\u397d\\u3980\\uc000\\u228a\\ufe00;\\uc000\\u2acb\\ufe00setneq\\u0100;q\\u398f\\u3992\\uc000\\u228b\\ufe00;\\uc000\\u2acc\\ufe00\\u0100hr\\u399b\\u399fet\\xe1\\u369ciangle\\u0100lr\\u39aa\\u39afeft\\xbb\\u0925ight\\xbb\\u1051y;\\u4432ash\\xbb\\u1036\\u0180elr\\u39c4\\u39d2\\u39d7\\u0180;be\\u2dea\\u39cb\\u39cfar;\\u62bbq;\\u625alip;\\u62ee\\u0100bt\\u39dc\\u1468a\\xf2\\u1469r;\\uc000\\ud835\\udd33tr\\xe9\\u39aesu\\u0100bp\\u39ef\\u39f1\\xbb\\u0d1c\\xbb\\u0d59pf;\\uc000\\ud835\\udd67ro\\xf0\\u0efbtr\\xe9\\u39b4\\u0100cu\\u3a06\\u3a0br;\\uc000\\ud835\\udccb\\u0100bp\\u3a10\\u3a18n\\u0100Ee\\u3980\\u3a16\\xbb\\u397en\\u0100Ee\\u3992\\u3a1e\\xbb\\u3990igzag;\\u699a\\u0380cefoprs\\u3a36\\u3a3b\\u3a56\\u3a5b\\u3a54\\u3a61\\u3a6airc;\\u4175\\u0100di\\u3a40\\u3a51\\u0100bg\\u3a45\\u3a49ar;\\u6a5fe\\u0100;q\\u15fa\\u3a4f;\\u6259erp;\\u6118r;\\uc000\\ud835\\udd34pf;\\uc000\\ud835\\udd68\\u0100;e\\u1479\\u3a66at\\xe8\\u1479cr;\\uc000\\ud835\\udccc\\u0ae3\\u178e\\u3a87\\0\\u3a8b\\0\\u3a90\\u3a9b\\0\\0\\u3a9d\\u3aa8\\u3aab\\u3aaf\\0\\0\\u3ac3\\u3ace\\0\\u3ad8\\u17dc\\u17dftr\\xe9\\u17d1r;\\uc000\\ud835\\udd35\\u0100Aa\\u3a94\\u3a97r\\xf2\\u03c3r\\xf2\\u09f6;\\u43be\\u0100Aa\\u3aa1\\u3aa4r\\xf2\\u03b8r\\xf2\\u09eba\\xf0\\u2713is;\\u62fb\\u0180dpt\\u17a4\\u3ab5\\u3abe\\u0100fl\\u3aba\\u17a9;\\uc000\\ud835\\udd69im\\xe5\\u17b2\\u0100Aa\\u3ac7\\u3acar\\xf2\\u03cer\\xf2\\u0a01\\u0100cq\\u3ad2\\u17b8r;\\uc000\\ud835\\udccd\\u0100pt\\u17d6\\u3adcr\\xe9\\u17d4\\u0400acefiosu\\u3af0\\u3afd\\u3b08\\u3b0c\\u3b11\\u3b15\\u3b1b\\u3b21c\\u0100uy\\u3af6\\u3afbte\\u803b\\xfd\\u40fd;\\u444f\\u0100iy\\u3b02\\u3b06rc;\\u4177;\\u444bn\\u803b\\xa5\\u40a5r;\\uc000\\ud835\\udd36cy;\\u4457pf;\\uc000\\ud835\\udd6acr;\\uc000\\ud835\\udcce\\u0100cm\\u3b26\\u3b29y;\\u444el\\u803b\\xff\\u40ff\\u0500acdefhiosw\\u3b42\\u3b48\\u3b54\\u3b58\\u3b64\\u3b69\\u3b6d\\u3b74\\u3b7a\\u3b80cute;\\u417a\\u0100ay\\u3b4d\\u3b52ron;\\u417e;\\u4437ot;\\u417c\\u0100et\\u3b5d\\u3b61tr\\xe6\\u155fa;\\u43b6r;\\uc000\\ud835\\udd37cy;\\u4436grarr;\\u61ddpf;\\uc000\\ud835\\udd6bcr;\\uc000\\ud835\\udccf\\u0100jn\\u3b85\\u3b87;\\u600dj;\\u600c\".split(\"\").map(function(c) {\n-                        return c.charCodeAt(0);\n-                    }));\n+                // CodeMirror, copyright (c) by Marijn Haverbeke and others\n+                // Distributed under an MIT license: https://codemirror.net/LICENSE\n \n-                /***/\n-            }),\n+                // Defines jumpToLine command. Uses dialog.js if present.\n \n-        /***/\n-        \"../../../node_modules/entities/lib/generated/decode-data-xml.js\":\n-            /*!***********************************************************************!*\\\n-              !*** ../../../node_modules/entities/lib/generated/decode-data-xml.js ***!\n-              \\***********************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports) {\n+                (function(mod) {\n+                    if (true)\n+                        // CommonJS\n+                        mod(__webpack_require__( /*! ../../lib/codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"), __webpack_require__( /*! ../dialog/dialog */ \"../../../node_modules/codemirror/addon/dialog/dialog.js\"));\n+                    else {}\n+                })(function(CodeMirror) {\n+                    \"use strict\";\n \n+                    // default search panel location\n+                    CodeMirror.defineOption(\"search\", {\n+                        bottom: false\n+                    });\n \n+                    function dialog(cm, text, shortText, deflt, f) {\n+                        if (cm.openDialog) cm.openDialog(text, f, {\n+                            value: deflt,\n+                            selectValueOnOpen: true,\n+                            bottom: cm.options.search.bottom\n+                        });\n+                        else f(prompt(shortText, deflt));\n+                    }\n \n-                // Generated using scripts/write-decode-map.ts\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports[\"default\"] = new Uint16Array(\n-                    // prettier-ignore\n-                    \"\\u0200aglq\\t\\x15\\x18\\x1b\\u026d\\x0f\\0\\0\\x12p;\\u4026os;\\u4027t;\\u403et;\\u403cuot;\\u4022\".split(\"\").map(function(c) {\n-                        return c.charCodeAt(0);\n-                    }));\n+                    function getJumpDialog(cm) {\n+                        return cm.phrase(\"Jump to line:\") + ' <input type=\"text\" style=\"width: 10em\" class=\"CodeMirror-search-field\"/> <span style=\"color: #888\" class=\"CodeMirror-search-hint\">' + cm.phrase(\"(Use line:column or scroll% syntax)\") + '</span>';\n+                    }\n+\n+                    function interpretLine(cm, string) {\n+                        var num = Number(string);\n+                        if (/^[-+]/.test(string)) return cm.getCursor().line + num;\n+                        else return num - 1;\n+                    }\n+                    CodeMirror.commands.jumpToLine = function(cm) {\n+                        var cur = cm.getCursor();\n+                        dialog(cm, getJumpDialog(cm), cm.phrase(\"Jump to line:\"), cur.line + 1 + \":\" + cur.ch, function(posStr) {\n+                            if (!posStr) return;\n+                            var match;\n+                            if (match = /^\\s*([\\+\\-]?\\d+)\\s*\\:\\s*(\\d+)\\s*$/.exec(posStr)) {\n+                                cm.setCursor(interpretLine(cm, match[1]), Number(match[2]));\n+                            } else if (match = /^\\s*([\\+\\-]?\\d+(\\.\\d+)?)\\%\\s*/.exec(posStr)) {\n+                                var line = Math.round(cm.lineCount() * Number(match[1]) / 100);\n+                                if (/^[-+]/.test(match[1])) line = cur.line + line + 1;\n+                                cm.setCursor(line - 1, cur.ch);\n+                            } else if (match = /^\\s*\\:?\\s*([\\+\\-]?\\d+)\\s*/.exec(posStr)) {\n+                                cm.setCursor(interpretLine(cm, match[1]), cur.ch);\n+                            }\n+                        });\n+                    };\n+                    CodeMirror.keyMap[\"default\"][\"Alt-G\"] = \"jumpToLine\";\n+                });\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/entities/lib/generated/encode-html.js\":\n-            /*!*******************************************************************!*\\\n-              !*** ../../../node_modules/entities/lib/generated/encode-html.js ***!\n-              \\*******************************************************************/\n+        \"../../../node_modules/codemirror/addon/search/search.js\":\n+            /*!***************************************************************!*\\\n+              !*** ../../../node_modules/codemirror/addon/search/search.js ***!\n+              \\***************************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports) {\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                // Generated using scripts/write-encode-map.ts\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n+                // CodeMirror, copyright (c) by Marijn Haverbeke and others\n+                // Distributed under an MIT license: https://codemirror.net/LICENSE\n \n-                function restoreDiff(arr) {\n-                    for (var i = 1; i < arr.length; i++) {\n-                        arr[i][0] += arr[i - 1][0] + 1;\n+                // Define search commands. Depends on dialog.js or another\n+                // implementation of the openDialog method.\n+\n+                // Replace works a little oddly -- it will do the replace on the next\n+                // Ctrl-G (or whatever is bound to findNext) press. You prevent a\n+                // replace by making sure the match is no longer selected when hitting\n+                // Ctrl-G.\n+\n+                (function(mod) {\n+                    if (true)\n+                        // CommonJS\n+                        mod(__webpack_require__( /*! ../../lib/codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"), __webpack_require__( /*! ./searchcursor */ \"../../../node_modules/codemirror/addon/search/searchcursor.js\"), __webpack_require__( /*! ../dialog/dialog */ \"../../../node_modules/codemirror/addon/dialog/dialog.js\"));\n+                    else {}\n+                })(function(CodeMirror) {\n+                    \"use strict\";\n+\n+                    // default search panel location\n+                    CodeMirror.defineOption(\"search\", {\n+                        bottom: false\n+                    });\n+\n+                    function searchOverlay(query, caseInsensitive) {\n+                        if (typeof query == \"string\") query = new RegExp(query.replace(/[\\-\\[\\]\\/\\{\\}\\(\\)\\*\\+\\?\\.\\\\\\^\\$\\|]/g, \"\\\\$&\"), caseInsensitive ? \"gi\" : \"g\");\n+                        else if (!query.global) query = new RegExp(query.source, query.ignoreCase ? \"gi\" : \"g\");\n+                        return {\n+                            token: function(stream) {\n+                                query.lastIndex = stream.pos;\n+                                var match = query.exec(stream.string);\n+                                if (match && match.index == stream.pos) {\n+                                    stream.pos += match[0].length || 1;\n+                                    return \"searching\";\n+                                } else if (match) {\n+                                    stream.pos = match.index;\n+                                } else {\n+                                    stream.skipToEnd();\n+                                }\n+                            }\n+                        };\n                     }\n-                    return arr;\n-                }\n-                // prettier-ignore\n-                exports[\"default\"] = new Map( /* #__PURE__ */ restoreDiff([\n-                    [9, \"&Tab;\"],\n-                    [0, \"&NewLine;\"],\n-                    [22, \"&excl;\"],\n-                    [0, \"&quot;\"],\n-                    [0, \"&num;\"],\n-                    [0, \"&dollar;\"],\n-                    [0, \"&percnt;\"],\n-                    [0, \"&amp;\"],\n-                    [0, \"&apos;\"],\n-                    [0, \"&lpar;\"],\n-                    [0, \"&rpar;\"],\n-                    [0, \"&ast;\"],\n-                    [0, \"&plus;\"],\n-                    [0, \"&comma;\"],\n-                    [1, \"&period;\"],\n-                    [0, \"&sol;\"],\n-                    [10, \"&colon;\"],\n-                    [0, \"&semi;\"],\n-                    [0, {\n-                        v: \"&lt;\",\n-                        n: 8402,\n-                        o: \"&nvlt;\"\n-                    }],\n-                    [0, {\n-                        v: \"&equals;\",\n-                        n: 8421,\n-                        o: \"&bne;\"\n-                    }],\n-                    [0, {\n-                        v: \"&gt;\",\n-                        n: 8402,\n-                        o: \"&nvgt;\"\n-                    }],\n-                    [0, \"&quest;\"],\n-                    [0, \"&commat;\"],\n-                    [26, \"&lbrack;\"],\n-                    [0, \"&bsol;\"],\n-                    [0, \"&rbrack;\"],\n-                    [0, \"&Hat;\"],\n-                    [0, \"&lowbar;\"],\n-                    [0, \"&DiacriticalGrave;\"],\n-                    [5, {\n-                        n: 106,\n-                        o: \"&fjlig;\"\n-                    }],\n-                    [20, \"&lbrace;\"],\n-                    [0, \"&verbar;\"],\n-                    [0, \"&rbrace;\"],\n-                    [34, \"&nbsp;\"],\n-                    [0, \"&iexcl;\"],\n-                    [0, \"&cent;\"],\n-                    [0, \"&pound;\"],\n-                    [0, \"&curren;\"],\n-                    [0, \"&yen;\"],\n-                    [0, \"&brvbar;\"],\n-                    [0, \"&sect;\"],\n-                    [0, \"&die;\"],\n-                    [0, \"&copy;\"],\n-                    [0, \"&ordf;\"],\n-                    [0, \"&laquo;\"],\n-                    [0, \"&not;\"],\n-                    [0, \"&shy;\"],\n-                    [0, \"&circledR;\"],\n-                    [0, \"&macr;\"],\n-                    [0, \"&deg;\"],\n-                    [0, \"&PlusMinus;\"],\n-                    [0, \"&sup2;\"],\n-                    [0, \"&sup3;\"],\n-                    [0, \"&acute;\"],\n-                    [0, \"&micro;\"],\n-                    [0, \"&para;\"],\n-                    [0, \"&centerdot;\"],\n-                    [0, \"&cedil;\"],\n-                    [0, \"&sup1;\"],\n-                    [0, \"&ordm;\"],\n-                    [0, \"&raquo;\"],\n-                    [0, \"&frac14;\"],\n-                    [0, \"&frac12;\"],\n-                    [0, \"&frac34;\"],\n-                    [0, \"&iquest;\"],\n-                    [0, \"&Agrave;\"],\n-                    [0, \"&Aacute;\"],\n-                    [0, \"&Acirc;\"],\n-                    [0, \"&Atilde;\"],\n-                    [0, \"&Auml;\"],\n-                    [0, \"&angst;\"],\n-                    [0, \"&AElig;\"],\n-                    [0, \"&Ccedil;\"],\n-                    [0, \"&Egrave;\"],\n-                    [0, \"&Eacute;\"],\n-                    [0, \"&Ecirc;\"],\n-                    [0, \"&Euml;\"],\n-                    [0, \"&Igrave;\"],\n-                    [0, \"&Iacute;\"],\n-                    [0, \"&Icirc;\"],\n-                    [0, \"&Iuml;\"],\n-                    [0, \"&ETH;\"],\n-                    [0, \"&Ntilde;\"],\n-                    [0, \"&Ograve;\"],\n-                    [0, \"&Oacute;\"],\n-                    [0, \"&Ocirc;\"],\n-                    [0, \"&Otilde;\"],\n-                    [0, \"&Ouml;\"],\n-                    [0, \"&times;\"],\n-                    [0, \"&Oslash;\"],\n-                    [0, \"&Ugrave;\"],\n-                    [0, \"&Uacute;\"],\n-                    [0, \"&Ucirc;\"],\n-                    [0, \"&Uuml;\"],\n-                    [0, \"&Yacute;\"],\n-                    [0, \"&THORN;\"],\n-                    [0, \"&szlig;\"],\n-                    [0, \"&agrave;\"],\n-                    [0, \"&aacute;\"],\n-                    [0, \"&acirc;\"],\n-                    [0, \"&atilde;\"],\n-                    [0, \"&auml;\"],\n-                    [0, \"&aring;\"],\n-                    [0, \"&aelig;\"],\n-                    [0, \"&ccedil;\"],\n-                    [0, \"&egrave;\"],\n-                    [0, \"&eacute;\"],\n-                    [0, \"&ecirc;\"],\n-                    [0, \"&euml;\"],\n-                    [0, \"&igrave;\"],\n-                    [0, \"&iacute;\"],\n-                    [0, \"&icirc;\"],\n-                    [0, \"&iuml;\"],\n-                    [0, \"&eth;\"],\n-                    [0, \"&ntilde;\"],\n-                    [0, \"&ograve;\"],\n-                    [0, \"&oacute;\"],\n-                    [0, \"&ocirc;\"],\n-                    [0, \"&otilde;\"],\n-                    [0, \"&ouml;\"],\n-                    [0, \"&div;\"],\n-                    [0, \"&oslash;\"],\n-                    [0, \"&ugrave;\"],\n-                    [0, \"&uacute;\"],\n-                    [0, \"&ucirc;\"],\n-                    [0, \"&uuml;\"],\n-                    [0, \"&yacute;\"],\n-                    [0, \"&thorn;\"],\n-                    [0, \"&yuml;\"],\n-                    [0, \"&Amacr;\"],\n-                    [0, \"&amacr;\"],\n-                    [0, \"&Abreve;\"],\n-                    [0, \"&abreve;\"],\n-                    [0, \"&Aogon;\"],\n-                    [0, \"&aogon;\"],\n-                    [0, \"&Cacute;\"],\n-                    [0, \"&cacute;\"],\n-                    [0, \"&Ccirc;\"],\n-                    [0, \"&ccirc;\"],\n-                    [0, \"&Cdot;\"],\n-                    [0, \"&cdot;\"],\n-                    [0, \"&Ccaron;\"],\n-                    [0, \"&ccaron;\"],\n-                    [0, \"&Dcaron;\"],\n-                    [0, \"&dcaron;\"],\n-                    [0, \"&Dstrok;\"],\n-                    [0, \"&dstrok;\"],\n-                    [0, \"&Emacr;\"],\n-                    [0, \"&emacr;\"],\n-                    [2, \"&Edot;\"],\n-                    [0, \"&edot;\"],\n-                    [0, \"&Eogon;\"],\n-                    [0, \"&eogon;\"],\n-                    [0, \"&Ecaron;\"],\n-                    [0, \"&ecaron;\"],\n-                    [0, \"&Gcirc;\"],\n-                    [0, \"&gcirc;\"],\n-                    [0, \"&Gbreve;\"],\n-                    [0, \"&gbreve;\"],\n-                    [0, \"&Gdot;\"],\n-                    [0, \"&gdot;\"],\n-                    [0, \"&Gcedil;\"],\n-                    [1, \"&Hcirc;\"],\n-                    [0, \"&hcirc;\"],\n-                    [0, \"&Hstrok;\"],\n-                    [0, \"&hstrok;\"],\n-                    [0, \"&Itilde;\"],\n-                    [0, \"&itilde;\"],\n-                    [0, \"&Imacr;\"],\n-                    [0, \"&imacr;\"],\n-                    [2, \"&Iogon;\"],\n-                    [0, \"&iogon;\"],\n-                    [0, \"&Idot;\"],\n-                    [0, \"&imath;\"],\n-                    [0, \"&IJlig;\"],\n-                    [0, \"&ijlig;\"],\n-                    [0, \"&Jcirc;\"],\n-                    [0, \"&jcirc;\"],\n-                    [0, \"&Kcedil;\"],\n-                    [0, \"&kcedil;\"],\n-                    [0, \"&kgreen;\"],\n-                    [0, \"&Lacute;\"],\n-                    [0, \"&lacute;\"],\n-                    [0, \"&Lcedil;\"],\n-                    [0, \"&lcedil;\"],\n-                    [0, \"&Lcaron;\"],\n-                    [0, \"&lcaron;\"],\n-                    [0, \"&Lmidot;\"],\n-                    [0, \"&lmidot;\"],\n-                    [0, \"&Lstrok;\"],\n-                    [0, \"&lstrok;\"],\n-                    [0, \"&Nacute;\"],\n-                    [0, \"&nacute;\"],\n-                    [0, \"&Ncedil;\"],\n-                    [0, \"&ncedil;\"],\n-                    [0, \"&Ncaron;\"],\n-                    [0, \"&ncaron;\"],\n-                    [0, \"&napos;\"],\n-                    [0, \"&ENG;\"],\n-                    [0, \"&eng;\"],\n-                    [0, \"&Omacr;\"],\n-                    [0, \"&omacr;\"],\n-                    [2, \"&Odblac;\"],\n-                    [0, \"&odblac;\"],\n-                    [0, \"&OElig;\"],\n-                    [0, \"&oelig;\"],\n-                    [0, \"&Racute;\"],\n-                    [0, \"&racute;\"],\n-                    [0, \"&Rcedil;\"],\n-                    [0, \"&rcedil;\"],\n-                    [0, \"&Rcaron;\"],\n-                    [0, \"&rcaron;\"],\n-                    [0, \"&Sacute;\"],\n-                    [0, \"&sacute;\"],\n-                    [0, \"&Scirc;\"],\n-                    [0, \"&scirc;\"],\n-                    [0, \"&Scedil;\"],\n-                    [0, \"&scedil;\"],\n-                    [0, \"&Scaron;\"],\n-                    [0, \"&scaron;\"],\n-                    [0, \"&Tcedil;\"],\n-                    [0, \"&tcedil;\"],\n-                    [0, \"&Tcaron;\"],\n-                    [0, \"&tcaron;\"],\n-                    [0, \"&Tstrok;\"],\n-                    [0, \"&tstrok;\"],\n-                    [0, \"&Utilde;\"],\n-                    [0, \"&utilde;\"],\n-                    [0, \"&Umacr;\"],\n-                    [0, \"&umacr;\"],\n-                    [0, \"&Ubreve;\"],\n-                    [0, \"&ubreve;\"],\n-                    [0, \"&Uring;\"],\n-                    [0, \"&uring;\"],\n-                    [0, \"&Udblac;\"],\n-                    [0, \"&udblac;\"],\n-                    [0, \"&Uogon;\"],\n-                    [0, \"&uogon;\"],\n-                    [0, \"&Wcirc;\"],\n-                    [0, \"&wcirc;\"],\n-                    [0, \"&Ycirc;\"],\n-                    [0, \"&ycirc;\"],\n-                    [0, \"&Yuml;\"],\n-                    [0, \"&Zacute;\"],\n-                    [0, \"&zacute;\"],\n-                    [0, \"&Zdot;\"],\n-                    [0, \"&zdot;\"],\n-                    [0, \"&Zcaron;\"],\n-                    [0, \"&zcaron;\"],\n-                    [19, \"&fnof;\"],\n-                    [34, \"&imped;\"],\n-                    [63, \"&gacute;\"],\n-                    [65, \"&jmath;\"],\n-                    [142, \"&circ;\"],\n-                    [0, \"&caron;\"],\n-                    [16, \"&breve;\"],\n-                    [0, \"&DiacriticalDot;\"],\n-                    [0, \"&ring;\"],\n-                    [0, \"&ogon;\"],\n-                    [0, \"&DiacriticalTilde;\"],\n-                    [0, \"&dblac;\"],\n-                    [51, \"&DownBreve;\"],\n-                    [127, \"&Alpha;\"],\n-                    [0, \"&Beta;\"],\n-                    [0, \"&Gamma;\"],\n-                    [0, \"&Delta;\"],\n-                    [0, \"&Epsilon;\"],\n-                    [0, \"&Zeta;\"],\n-                    [0, \"&Eta;\"],\n-                    [0, \"&Theta;\"],\n-                    [0, \"&Iota;\"],\n-                    [0, \"&Kappa;\"],\n-                    [0, \"&Lambda;\"],\n-                    [0, \"&Mu;\"],\n-                    [0, \"&Nu;\"],\n-                    [0, \"&Xi;\"],\n-                    [0, \"&Omicron;\"],\n-                    [0, \"&Pi;\"],\n-                    [0, \"&Rho;\"],\n-                    [1, \"&Sigma;\"],\n-                    [0, \"&Tau;\"],\n-                    [0, \"&Upsilon;\"],\n-                    [0, \"&Phi;\"],\n-                    [0, \"&Chi;\"],\n-                    [0, \"&Psi;\"],\n-                    [0, \"&ohm;\"],\n-                    [7, \"&alpha;\"],\n-                    [0, \"&beta;\"],\n-                    [0, \"&gamma;\"],\n-                    [0, \"&delta;\"],\n-                    [0, \"&epsi;\"],\n-                    [0, \"&zeta;\"],\n-                    [0, \"&eta;\"],\n-                    [0, \"&theta;\"],\n-                    [0, \"&iota;\"],\n-                    [0, \"&kappa;\"],\n-                    [0, \"&lambda;\"],\n-                    [0, \"&mu;\"],\n-                    [0, \"&nu;\"],\n-                    [0, \"&xi;\"],\n-                    [0, \"&omicron;\"],\n-                    [0, \"&pi;\"],\n-                    [0, \"&rho;\"],\n-                    [0, \"&sigmaf;\"],\n-                    [0, \"&sigma;\"],\n-                    [0, \"&tau;\"],\n-                    [0, \"&upsi;\"],\n-                    [0, \"&phi;\"],\n-                    [0, \"&chi;\"],\n-                    [0, \"&psi;\"],\n-                    [0, \"&omega;\"],\n-                    [7, \"&thetasym;\"],\n-                    [0, \"&Upsi;\"],\n-                    [2, \"&phiv;\"],\n-                    [0, \"&piv;\"],\n-                    [5, \"&Gammad;\"],\n-                    [0, \"&digamma;\"],\n-                    [18, \"&kappav;\"],\n-                    [0, \"&rhov;\"],\n-                    [3, \"&epsiv;\"],\n-                    [0, \"&backepsilon;\"],\n-                    [10, \"&IOcy;\"],\n-                    [0, \"&DJcy;\"],\n-                    [0, \"&GJcy;\"],\n-                    [0, \"&Jukcy;\"],\n-                    [0, \"&DScy;\"],\n-                    [0, \"&Iukcy;\"],\n-                    [0, \"&YIcy;\"],\n-                    [0, \"&Jsercy;\"],\n-                    [0, \"&LJcy;\"],\n-                    [0, \"&NJcy;\"],\n-                    [0, \"&TSHcy;\"],\n-                    [0, \"&KJcy;\"],\n-                    [1, \"&Ubrcy;\"],\n-                    [0, \"&DZcy;\"],\n-                    [0, \"&Acy;\"],\n-                    [0, \"&Bcy;\"],\n-                    [0, \"&Vcy;\"],\n-                    [0, \"&Gcy;\"],\n-                    [0, \"&Dcy;\"],\n-                    [0, \"&IEcy;\"],\n-                    [0, \"&ZHcy;\"],\n-                    [0, \"&Zcy;\"],\n-                    [0, \"&Icy;\"],\n-                    [0, \"&Jcy;\"],\n-                    [0, \"&Kcy;\"],\n-                    [0, \"&Lcy;\"],\n-                    [0, \"&Mcy;\"],\n-                    [0, \"&Ncy;\"],\n-                    [0, \"&Ocy;\"],\n-                    [0, \"&Pcy;\"],\n-                    [0, \"&Rcy;\"],\n-                    [0, \"&Scy;\"],\n-                    [0, \"&Tcy;\"],\n-                    [0, \"&Ucy;\"],\n-                    [0, \"&Fcy;\"],\n-                    [0, \"&KHcy;\"],\n-                    [0, \"&TScy;\"],\n-                    [0, \"&CHcy;\"],\n-                    [0, \"&SHcy;\"],\n-                    [0, \"&SHCHcy;\"],\n-                    [0, \"&HARDcy;\"],\n-                    [0, \"&Ycy;\"],\n-                    [0, \"&SOFTcy;\"],\n-                    [0, \"&Ecy;\"],\n-                    [0, \"&YUcy;\"],\n-                    [0, \"&YAcy;\"],\n-                    [0, \"&acy;\"],\n-                    [0, \"&bcy;\"],\n-                    [0, \"&vcy;\"],\n-                    [0, \"&gcy;\"],\n-                    [0, \"&dcy;\"],\n-                    [0, \"&iecy;\"],\n-                    [0, \"&zhcy;\"],\n-                    [0, \"&zcy;\"],\n-                    [0, \"&icy;\"],\n-                    [0, \"&jcy;\"],\n-                    [0, \"&kcy;\"],\n-                    [0, \"&lcy;\"],\n-                    [0, \"&mcy;\"],\n-                    [0, \"&ncy;\"],\n-                    [0, \"&ocy;\"],\n-                    [0, \"&pcy;\"],\n-                    [0, \"&rcy;\"],\n-                    [0, \"&scy;\"],\n-                    [0, \"&tcy;\"],\n-                    [0, \"&ucy;\"],\n-                    [0, \"&fcy;\"],\n-                    [0, \"&khcy;\"],\n-                    [0, \"&tscy;\"],\n-                    [0, \"&chcy;\"],\n-                    [0, \"&shcy;\"],\n-                    [0, \"&shchcy;\"],\n-                    [0, \"&hardcy;\"],\n-                    [0, \"&ycy;\"],\n-                    [0, \"&softcy;\"],\n-                    [0, \"&ecy;\"],\n-                    [0, \"&yucy;\"],\n-                    [0, \"&yacy;\"],\n-                    [1, \"&iocy;\"],\n-                    [0, \"&djcy;\"],\n-                    [0, \"&gjcy;\"],\n-                    [0, \"&jukcy;\"],\n-                    [0, \"&dscy;\"],\n-                    [0, \"&iukcy;\"],\n-                    [0, \"&yicy;\"],\n-                    [0, \"&jsercy;\"],\n-                    [0, \"&ljcy;\"],\n-                    [0, \"&njcy;\"],\n-                    [0, \"&tshcy;\"],\n-                    [0, \"&kjcy;\"],\n-                    [1, \"&ubrcy;\"],\n-                    [0, \"&dzcy;\"],\n-                    [7074, \"&ensp;\"],\n-                    [0, \"&emsp;\"],\n-                    [0, \"&emsp13;\"],\n-                    [0, \"&emsp14;\"],\n-                    [1, \"&numsp;\"],\n-                    [0, \"&puncsp;\"],\n-                    [0, \"&ThinSpace;\"],\n-                    [0, \"&hairsp;\"],\n-                    [0, \"&NegativeMediumSpace;\"],\n-                    [0, \"&zwnj;\"],\n-                    [0, \"&zwj;\"],\n-                    [0, \"&lrm;\"],\n-                    [0, \"&rlm;\"],\n-                    [0, \"&dash;\"],\n-                    [2, \"&ndash;\"],\n-                    [0, \"&mdash;\"],\n-                    [0, \"&horbar;\"],\n-                    [0, \"&Verbar;\"],\n-                    [1, \"&lsquo;\"],\n-                    [0, \"&CloseCurlyQuote;\"],\n-                    [0, \"&lsquor;\"],\n-                    [1, \"&ldquo;\"],\n-                    [0, \"&CloseCurlyDoubleQuote;\"],\n-                    [0, \"&bdquo;\"],\n-                    [1, \"&dagger;\"],\n-                    [0, \"&Dagger;\"],\n-                    [0, \"&bull;\"],\n-                    [2, \"&nldr;\"],\n-                    [0, \"&hellip;\"],\n-                    [9, \"&permil;\"],\n-                    [0, \"&pertenk;\"],\n-                    [0, \"&prime;\"],\n-                    [0, \"&Prime;\"],\n-                    [0, \"&tprime;\"],\n-                    [0, \"&backprime;\"],\n-                    [3, \"&lsaquo;\"],\n-                    [0, \"&rsaquo;\"],\n-                    [3, \"&oline;\"],\n-                    [2, \"&caret;\"],\n-                    [1, \"&hybull;\"],\n-                    [0, \"&frasl;\"],\n-                    [10, \"&bsemi;\"],\n-                    [7, \"&qprime;\"],\n-                    [7, {\n-                        v: \"&MediumSpace;\",\n-                        n: 8202,\n-                        o: \"&ThickSpace;\"\n-                    }],\n-                    [0, \"&NoBreak;\"],\n-                    [0, \"&af;\"],\n-                    [0, \"&InvisibleTimes;\"],\n-                    [0, \"&ic;\"],\n-                    [72, \"&euro;\"],\n-                    [46, \"&tdot;\"],\n-                    [0, \"&DotDot;\"],\n-                    [37, \"&complexes;\"],\n-                    [2, \"&incare;\"],\n-                    [4, \"&gscr;\"],\n-                    [0, \"&hamilt;\"],\n-                    [0, \"&Hfr;\"],\n-                    [0, \"&Hopf;\"],\n-                    [0, \"&planckh;\"],\n-                    [0, \"&hbar;\"],\n-                    [0, \"&imagline;\"],\n-                    [0, \"&Ifr;\"],\n-                    [0, \"&lagran;\"],\n-                    [0, \"&ell;\"],\n-                    [1, \"&naturals;\"],\n-                    [0, \"&numero;\"],\n-                    [0, \"&copysr;\"],\n-                    [0, \"&weierp;\"],\n-                    [0, \"&Popf;\"],\n-                    [0, \"&Qopf;\"],\n-                    [0, \"&realine;\"],\n-                    [0, \"&real;\"],\n-                    [0, \"&reals;\"],\n-                    [0, \"&rx;\"],\n-                    [3, \"&trade;\"],\n-                    [1, \"&integers;\"],\n-                    [2, \"&mho;\"],\n-                    [0, \"&zeetrf;\"],\n-                    [0, \"&iiota;\"],\n-                    [2, \"&bernou;\"],\n-                    [0, \"&Cayleys;\"],\n-                    [1, \"&escr;\"],\n-                    [0, \"&Escr;\"],\n-                    [0, \"&Fouriertrf;\"],\n-                    [1, \"&Mellintrf;\"],\n-                    [0, \"&order;\"],\n-                    [0, \"&alefsym;\"],\n-                    [0, \"&beth;\"],\n-                    [0, \"&gimel;\"],\n-                    [0, \"&daleth;\"],\n-                    [12, \"&CapitalDifferentialD;\"],\n-                    [0, \"&dd;\"],\n-                    [0, \"&ee;\"],\n-                    [0, \"&ii;\"],\n-                    [10, \"&frac13;\"],\n-                    [0, \"&frac23;\"],\n-                    [0, \"&frac15;\"],\n-                    [0, \"&frac25;\"],\n-                    [0, \"&frac35;\"],\n-                    [0, \"&frac45;\"],\n-                    [0, \"&frac16;\"],\n-                    [0, \"&frac56;\"],\n-                    [0, \"&frac18;\"],\n-                    [0, \"&frac38;\"],\n-                    [0, \"&frac58;\"],\n-                    [0, \"&frac78;\"],\n-                    [49, \"&larr;\"],\n-                    [0, \"&ShortUpArrow;\"],\n-                    [0, \"&rarr;\"],\n-                    [0, \"&darr;\"],\n-                    [0, \"&harr;\"],\n-                    [0, \"&updownarrow;\"],\n-                    [0, \"&nwarr;\"],\n-                    [0, \"&nearr;\"],\n-                    [0, \"&LowerRightArrow;\"],\n-                    [0, \"&LowerLeftArrow;\"],\n-                    [0, \"&nlarr;\"],\n-                    [0, \"&nrarr;\"],\n-                    [1, {\n-                        v: \"&rarrw;\",\n-                        n: 824,\n-                        o: \"&nrarrw;\"\n-                    }],\n-                    [0, \"&Larr;\"],\n-                    [0, \"&Uarr;\"],\n-                    [0, \"&Rarr;\"],\n-                    [0, \"&Darr;\"],\n-                    [0, \"&larrtl;\"],\n-                    [0, \"&rarrtl;\"],\n-                    [0, \"&LeftTeeArrow;\"],\n-                    [0, \"&mapstoup;\"],\n-                    [0, \"&map;\"],\n-                    [0, \"&DownTeeArrow;\"],\n-                    [1, \"&hookleftarrow;\"],\n-                    [0, \"&hookrightarrow;\"],\n-                    [0, \"&larrlp;\"],\n-                    [0, \"&looparrowright;\"],\n-                    [0, \"&harrw;\"],\n-                    [0, \"&nharr;\"],\n-                    [1, \"&lsh;\"],\n-                    [0, \"&rsh;\"],\n-                    [0, \"&ldsh;\"],\n-                    [0, \"&rdsh;\"],\n-                    [1, \"&crarr;\"],\n-                    [0, \"&cularr;\"],\n-                    [0, \"&curarr;\"],\n-                    [2, \"&circlearrowleft;\"],\n-                    [0, \"&circlearrowright;\"],\n-                    [0, \"&leftharpoonup;\"],\n-                    [0, \"&DownLeftVector;\"],\n-                    [0, \"&RightUpVector;\"],\n-                    [0, \"&LeftUpVector;\"],\n-                    [0, \"&rharu;\"],\n-                    [0, \"&DownRightVector;\"],\n-                    [0, \"&dharr;\"],\n-                    [0, \"&dharl;\"],\n-                    [0, \"&RightArrowLeftArrow;\"],\n-                    [0, \"&udarr;\"],\n-                    [0, \"&LeftArrowRightArrow;\"],\n-                    [0, \"&leftleftarrows;\"],\n-                    [0, \"&upuparrows;\"],\n-                    [0, \"&rightrightarrows;\"],\n-                    [0, \"&ddarr;\"],\n-                    [0, \"&leftrightharpoons;\"],\n-                    [0, \"&Equilibrium;\"],\n-                    [0, \"&nlArr;\"],\n-                    [0, \"&nhArr;\"],\n-                    [0, \"&nrArr;\"],\n-                    [0, \"&DoubleLeftArrow;\"],\n-                    [0, \"&DoubleUpArrow;\"],\n-                    [0, \"&DoubleRightArrow;\"],\n-                    [0, \"&dArr;\"],\n-                    [0, \"&DoubleLeftRightArrow;\"],\n-                    [0, \"&DoubleUpDownArrow;\"],\n-                    [0, \"&nwArr;\"],\n-                    [0, \"&neArr;\"],\n-                    [0, \"&seArr;\"],\n-                    [0, \"&swArr;\"],\n-                    [0, \"&lAarr;\"],\n-                    [0, \"&rAarr;\"],\n-                    [1, \"&zigrarr;\"],\n-                    [6, \"&larrb;\"],\n-                    [0, \"&rarrb;\"],\n-                    [15, \"&DownArrowUpArrow;\"],\n-                    [7, \"&loarr;\"],\n-                    [0, \"&roarr;\"],\n-                    [0, \"&hoarr;\"],\n-                    [0, \"&forall;\"],\n-                    [0, \"&comp;\"],\n-                    [0, {\n-                        v: \"&part;\",\n-                        n: 824,\n-                        o: \"&npart;\"\n-                    }],\n-                    [0, \"&exist;\"],\n-                    [0, \"&nexist;\"],\n-                    [0, \"&empty;\"],\n-                    [1, \"&Del;\"],\n-                    [0, \"&Element;\"],\n-                    [0, \"&NotElement;\"],\n-                    [1, \"&ni;\"],\n-                    [0, \"&notni;\"],\n-                    [2, \"&prod;\"],\n-                    [0, \"&coprod;\"],\n-                    [0, \"&sum;\"],\n-                    [0, \"&minus;\"],\n-                    [0, \"&MinusPlus;\"],\n-                    [0, \"&dotplus;\"],\n-                    [1, \"&Backslash;\"],\n-                    [0, \"&lowast;\"],\n-                    [0, \"&compfn;\"],\n-                    [1, \"&radic;\"],\n-                    [2, \"&prop;\"],\n-                    [0, \"&infin;\"],\n-                    [0, \"&angrt;\"],\n-                    [0, {\n-                        v: \"&ang;\",\n-                        n: 8402,\n-                        o: \"&nang;\"\n-                    }],\n-                    [0, \"&angmsd;\"],\n-                    [0, \"&angsph;\"],\n-                    [0, \"&mid;\"],\n-                    [0, \"&nmid;\"],\n-                    [0, \"&DoubleVerticalBar;\"],\n-                    [0, \"&NotDoubleVerticalBar;\"],\n-                    [0, \"&and;\"],\n-                    [0, \"&or;\"],\n-                    [0, {\n-                        v: \"&cap;\",\n-                        n: 65024,\n-                        o: \"&caps;\"\n-                    }],\n-                    [0, {\n-                        v: \"&cup;\",\n-                        n: 65024,\n-                        o: \"&cups;\"\n-                    }],\n-                    [0, \"&int;\"],\n-                    [0, \"&Int;\"],\n-                    [0, \"&iiint;\"],\n-                    [0, \"&conint;\"],\n-                    [0, \"&Conint;\"],\n-                    [0, \"&Cconint;\"],\n-                    [0, \"&cwint;\"],\n-                    [0, \"&ClockwiseContourIntegral;\"],\n-                    [0, \"&awconint;\"],\n-                    [0, \"&there4;\"],\n-                    [0, \"&becaus;\"],\n-                    [0, \"&ratio;\"],\n-                    [0, \"&Colon;\"],\n-                    [0, \"&dotminus;\"],\n-                    [1, \"&mDDot;\"],\n-                    [0, \"&homtht;\"],\n-                    [0, {\n-                        v: \"&sim;\",\n-                        n: 8402,\n-                        o: \"&nvsim;\"\n-                    }],\n-                    [0, {\n-                        v: \"&backsim;\",\n-                        n: 817,\n-                        o: \"&race;\"\n-                    }],\n-                    [0, {\n-                        v: \"&ac;\",\n-                        n: 819,\n-                        o: \"&acE;\"\n-                    }],\n-                    [0, \"&acd;\"],\n-                    [0, \"&VerticalTilde;\"],\n-                    [0, \"&NotTilde;\"],\n-                    [0, {\n-                        v: \"&eqsim;\",\n-                        n: 824,\n-                        o: \"&nesim;\"\n-                    }],\n-                    [0, \"&sime;\"],\n-                    [0, \"&NotTildeEqual;\"],\n-                    [0, \"&cong;\"],\n-                    [0, \"&simne;\"],\n-                    [0, \"&ncong;\"],\n-                    [0, \"&ap;\"],\n-                    [0, \"&nap;\"],\n-                    [0, \"&ape;\"],\n-                    [0, {\n-                        v: \"&apid;\",\n-                        n: 824,\n-                        o: \"&napid;\"\n-                    }],\n-                    [0, \"&backcong;\"],\n-                    [0, {\n-                        v: \"&asympeq;\",\n-                        n: 8402,\n-                        o: \"&nvap;\"\n-                    }],\n-                    [0, {\n-                        v: \"&bump;\",\n-                        n: 824,\n-                        o: \"&nbump;\"\n-                    }],\n-                    [0, {\n-                        v: \"&bumpe;\",\n-                        n: 824,\n-                        o: \"&nbumpe;\"\n-                    }],\n-                    [0, {\n-                        v: \"&doteq;\",\n-                        n: 824,\n-                        o: \"&nedot;\"\n-                    }],\n-                    [0, \"&doteqdot;\"],\n-                    [0, \"&efDot;\"],\n-                    [0, \"&erDot;\"],\n-                    [0, \"&Assign;\"],\n-                    [0, \"&ecolon;\"],\n-                    [0, \"&ecir;\"],\n-                    [0, \"&circeq;\"],\n-                    [1, \"&wedgeq;\"],\n-                    [0, \"&veeeq;\"],\n-                    [1, \"&triangleq;\"],\n-                    [2, \"&equest;\"],\n-                    [0, \"&ne;\"],\n-                    [0, {\n-                        v: \"&Congruent;\",\n-                        n: 8421,\n-                        o: \"&bnequiv;\"\n-                    }],\n-                    [0, \"&nequiv;\"],\n-                    [1, {\n-                        v: \"&le;\",\n-                        n: 8402,\n-                        o: \"&nvle;\"\n-                    }],\n-                    [0, {\n-                        v: \"&ge;\",\n-                        n: 8402,\n-                        o: \"&nvge;\"\n-                    }],\n-                    [0, {\n-                        v: \"&lE;\",\n-                        n: 824,\n-                        o: \"&nlE;\"\n-                    }],\n-                    [0, {\n-                        v: \"&gE;\",\n-                        n: 824,\n-                        o: \"&ngE;\"\n-                    }],\n-                    [0, {\n-                        v: \"&lnE;\",\n-                        n: 65024,\n-                        o: \"&lvertneqq;\"\n-                    }],\n-                    [0, {\n-                        v: \"&gnE;\",\n-                        n: 65024,\n-                        o: \"&gvertneqq;\"\n-                    }],\n-                    [0, {\n-                        v: \"&ll;\",\n-                        n: new Map( /* #__PURE__ */ restoreDiff([\n-                            [824, \"&nLtv;\"],\n-                            [7577, \"&nLt;\"]\n-                        ]))\n-                    }],\n-                    [0, {\n-                        v: \"&gg;\",\n-                        n: new Map( /* #__PURE__ */ restoreDiff([\n-                            [824, \"&nGtv;\"],\n-                            [7577, \"&nGt;\"]\n-                        ]))\n-                    }],\n-                    [0, \"&between;\"],\n-                    [0, \"&NotCupCap;\"],\n-                    [0, \"&nless;\"],\n-                    [0, \"&ngt;\"],\n-                    [0, \"&nle;\"],\n-                    [0, \"&nge;\"],\n-                    [0, \"&lesssim;\"],\n-                    [0, \"&GreaterTilde;\"],\n-                    [0, \"&nlsim;\"],\n-                    [0, \"&ngsim;\"],\n-                    [0, \"&LessGreater;\"],\n-                    [0, \"&gl;\"],\n-                    [0, \"&NotLessGreater;\"],\n-                    [0, \"&NotGreaterLess;\"],\n-                    [0, \"&pr;\"],\n-                    [0, \"&sc;\"],\n-                    [0, \"&prcue;\"],\n-                    [0, \"&sccue;\"],\n-                    [0, \"&PrecedesTilde;\"],\n-                    [0, {\n-                        v: \"&scsim;\",\n-                        n: 824,\n-                        o: \"&NotSucceedsTilde;\"\n-                    }],\n-                    [0, \"&NotPrecedes;\"],\n-                    [0, \"&NotSucceeds;\"],\n-                    [0, {\n-                        v: \"&sub;\",\n-                        n: 8402,\n-                        o: \"&NotSubset;\"\n-                    }],\n-                    [0, {\n-                        v: \"&sup;\",\n-                        n: 8402,\n-                        o: \"&NotSuperset;\"\n-                    }],\n-                    [0, \"&nsub;\"],\n-                    [0, \"&nsup;\"],\n-                    [0, \"&sube;\"],\n-                    [0, \"&supe;\"],\n-                    [0, \"&NotSubsetEqual;\"],\n-                    [0, \"&NotSupersetEqual;\"],\n-                    [0, {\n-                        v: \"&subne;\",\n-                        n: 65024,\n-                        o: \"&varsubsetneq;\"\n-                    }],\n-                    [0, {\n-                        v: \"&supne;\",\n-                        n: 65024,\n-                        o: \"&varsupsetneq;\"\n-                    }],\n-                    [1, \"&cupdot;\"],\n-                    [0, \"&UnionPlus;\"],\n-                    [0, {\n-                        v: \"&sqsub;\",\n-                        n: 824,\n-                        o: \"&NotSquareSubset;\"\n-                    }],\n-                    [0, {\n-                        v: \"&sqsup;\",\n-                        n: 824,\n-                        o: \"&NotSquareSuperset;\"\n-                    }],\n-                    [0, \"&sqsube;\"],\n-                    [0, \"&sqsupe;\"],\n-                    [0, {\n-                        v: \"&sqcap;\",\n-                        n: 65024,\n-                        o: \"&sqcaps;\"\n-                    }],\n-                    [0, {\n-                        v: \"&sqcup;\",\n-                        n: 65024,\n-                        o: \"&sqcups;\"\n-                    }],\n-                    [0, \"&CirclePlus;\"],\n-                    [0, \"&CircleMinus;\"],\n-                    [0, \"&CircleTimes;\"],\n-                    [0, \"&osol;\"],\n-                    [0, \"&CircleDot;\"],\n-                    [0, \"&circledcirc;\"],\n-                    [0, \"&circledast;\"],\n-                    [1, \"&circleddash;\"],\n-                    [0, \"&boxplus;\"],\n-                    [0, \"&boxminus;\"],\n-                    [0, \"&boxtimes;\"],\n-                    [0, \"&dotsquare;\"],\n-                    [0, \"&RightTee;\"],\n-                    [0, \"&dashv;\"],\n-                    [0, \"&DownTee;\"],\n-                    [0, \"&bot;\"],\n-                    [1, \"&models;\"],\n-                    [0, \"&DoubleRightTee;\"],\n-                    [0, \"&Vdash;\"],\n-                    [0, \"&Vvdash;\"],\n-                    [0, \"&VDash;\"],\n-                    [0, \"&nvdash;\"],\n-                    [0, \"&nvDash;\"],\n-                    [0, \"&nVdash;\"],\n-                    [0, \"&nVDash;\"],\n-                    [0, \"&prurel;\"],\n-                    [1, \"&LeftTriangle;\"],\n-                    [0, \"&RightTriangle;\"],\n-                    [0, {\n-                        v: \"&LeftTriangleEqual;\",\n-                        n: 8402,\n-                        o: \"&nvltrie;\"\n-                    }],\n-                    [0, {\n-                        v: \"&RightTriangleEqual;\",\n-                        n: 8402,\n-                        o: \"&nvrtrie;\"\n-                    }],\n-                    [0, \"&origof;\"],\n-                    [0, \"&imof;\"],\n-                    [0, \"&multimap;\"],\n-                    [0, \"&hercon;\"],\n-                    [0, \"&intcal;\"],\n-                    [0, \"&veebar;\"],\n-                    [1, \"&barvee;\"],\n-                    [0, \"&angrtvb;\"],\n-                    [0, \"&lrtri;\"],\n-                    [0, \"&bigwedge;\"],\n-                    [0, \"&bigvee;\"],\n-                    [0, \"&bigcap;\"],\n-                    [0, \"&bigcup;\"],\n-                    [0, \"&diam;\"],\n-                    [0, \"&sdot;\"],\n-                    [0, \"&sstarf;\"],\n-                    [0, \"&divideontimes;\"],\n-                    [0, \"&bowtie;\"],\n-                    [0, \"&ltimes;\"],\n-                    [0, \"&rtimes;\"],\n-                    [0, \"&leftthreetimes;\"],\n-                    [0, \"&rightthreetimes;\"],\n-                    [0, \"&backsimeq;\"],\n-                    [0, \"&curlyvee;\"],\n-                    [0, \"&curlywedge;\"],\n-                    [0, \"&Sub;\"],\n-                    [0, \"&Sup;\"],\n-                    [0, \"&Cap;\"],\n-                    [0, \"&Cup;\"],\n-                    [0, \"&fork;\"],\n-                    [0, \"&epar;\"],\n-                    [0, \"&lessdot;\"],\n-                    [0, \"&gtdot;\"],\n-                    [0, {\n-                        v: \"&Ll;\",\n-                        n: 824,\n-                        o: \"&nLl;\"\n-                    }],\n-                    [0, {\n-                        v: \"&Gg;\",\n-                        n: 824,\n-                        o: \"&nGg;\"\n-                    }],\n-                    [0, {\n-                        v: \"&leg;\",\n-                        n: 65024,\n-                        o: \"&lesg;\"\n-                    }],\n-                    [0, {\n-                        v: \"&gel;\",\n-                        n: 65024,\n-                        o: \"&gesl;\"\n-                    }],\n-                    [2, \"&cuepr;\"],\n-                    [0, \"&cuesc;\"],\n-                    [0, \"&NotPrecedesSlantEqual;\"],\n-                    [0, \"&NotSucceedsSlantEqual;\"],\n-                    [0, \"&NotSquareSubsetEqual;\"],\n-                    [0, \"&NotSquareSupersetEqual;\"],\n-                    [2, \"&lnsim;\"],\n-                    [0, \"&gnsim;\"],\n-                    [0, \"&precnsim;\"],\n-                    [0, \"&scnsim;\"],\n-                    [0, \"&nltri;\"],\n-                    [0, \"&NotRightTriangle;\"],\n-                    [0, \"&nltrie;\"],\n-                    [0, \"&NotRightTriangleEqual;\"],\n-                    [0, \"&vellip;\"],\n-                    [0, \"&ctdot;\"],\n-                    [0, \"&utdot;\"],\n-                    [0, \"&dtdot;\"],\n-                    [0, \"&disin;\"],\n-                    [0, \"&isinsv;\"],\n-                    [0, \"&isins;\"],\n-                    [0, {\n-                        v: \"&isindot;\",\n-                        n: 824,\n-                        o: \"&notindot;\"\n-                    }],\n-                    [0, \"&notinvc;\"],\n-                    [0, \"&notinvb;\"],\n-                    [1, {\n-                        v: \"&isinE;\",\n-                        n: 824,\n-                        o: \"&notinE;\"\n-                    }],\n-                    [0, \"&nisd;\"],\n-                    [0, \"&xnis;\"],\n-                    [0, \"&nis;\"],\n-                    [0, \"&notnivc;\"],\n-                    [0, \"&notnivb;\"],\n-                    [6, \"&barwed;\"],\n-                    [0, \"&Barwed;\"],\n-                    [1, \"&lceil;\"],\n-                    [0, \"&rceil;\"],\n-                    [0, \"&LeftFloor;\"],\n-                    [0, \"&rfloor;\"],\n-                    [0, \"&drcrop;\"],\n-                    [0, \"&dlcrop;\"],\n-                    [0, \"&urcrop;\"],\n-                    [0, \"&ulcrop;\"],\n-                    [0, \"&bnot;\"],\n-                    [1, \"&profline;\"],\n-                    [0, \"&profsurf;\"],\n-                    [1, \"&telrec;\"],\n-                    [0, \"&target;\"],\n-                    [5, \"&ulcorn;\"],\n-                    [0, \"&urcorn;\"],\n-                    [0, \"&dlcorn;\"],\n-                    [0, \"&drcorn;\"],\n-                    [2, \"&frown;\"],\n-                    [0, \"&smile;\"],\n-                    [9, \"&cylcty;\"],\n-                    [0, \"&profalar;\"],\n-                    [7, \"&topbot;\"],\n-                    [6, \"&ovbar;\"],\n-                    [1, \"&solbar;\"],\n-                    [60, \"&angzarr;\"],\n-                    [51, \"&lmoustache;\"],\n-                    [0, \"&rmoustache;\"],\n-                    [2, \"&OverBracket;\"],\n-                    [0, \"&bbrk;\"],\n-                    [0, \"&bbrktbrk;\"],\n-                    [37, \"&OverParenthesis;\"],\n-                    [0, \"&UnderParenthesis;\"],\n-                    [0, \"&OverBrace;\"],\n-                    [0, \"&UnderBrace;\"],\n-                    [2, \"&trpezium;\"],\n-                    [4, \"&elinters;\"],\n-                    [59, \"&blank;\"],\n-                    [164, \"&circledS;\"],\n-                    [55, \"&boxh;\"],\n-                    [1, \"&boxv;\"],\n-                    [9, \"&boxdr;\"],\n-                    [3, \"&boxdl;\"],\n-                    [3, \"&boxur;\"],\n-                    [3, \"&boxul;\"],\n-                    [3, \"&boxvr;\"],\n-                    [7, \"&boxvl;\"],\n-                    [7, \"&boxhd;\"],\n-                    [7, \"&boxhu;\"],\n-                    [7, \"&boxvh;\"],\n-                    [19, \"&boxH;\"],\n-                    [0, \"&boxV;\"],\n-                    [0, \"&boxdR;\"],\n-                    [0, \"&boxDr;\"],\n-                    [0, \"&boxDR;\"],\n-                    [0, \"&boxdL;\"],\n-                    [0, \"&boxDl;\"],\n-                    [0, \"&boxDL;\"],\n-                    [0, \"&boxuR;\"],\n-                    [0, \"&boxUr;\"],\n-                    [0, \"&boxUR;\"],\n-                    [0, \"&boxuL;\"],\n-                    [0, \"&boxUl;\"],\n-                    [0, \"&boxUL;\"],\n-                    [0, \"&boxvR;\"],\n-                    [0, \"&boxVr;\"],\n-                    [0, \"&boxVR;\"],\n-                    [0, \"&boxvL;\"],\n-                    [0, \"&boxVl;\"],\n-                    [0, \"&boxVL;\"],\n-                    [0, \"&boxHd;\"],\n-                    [0, \"&boxhD;\"],\n-                    [0, \"&boxHD;\"],\n-                    [0, \"&boxHu;\"],\n-                    [0, \"&boxhU;\"],\n-                    [0, \"&boxHU;\"],\n-                    [0, \"&boxvH;\"],\n-                    [0, \"&boxVh;\"],\n-                    [0, \"&boxVH;\"],\n-                    [19, \"&uhblk;\"],\n-                    [3, \"&lhblk;\"],\n-                    [3, \"&block;\"],\n-                    [8, \"&blk14;\"],\n-                    [0, \"&blk12;\"],\n-                    [0, \"&blk34;\"],\n-                    [13, \"&square;\"],\n-                    [8, \"&blacksquare;\"],\n-                    [0, \"&EmptyVerySmallSquare;\"],\n-                    [1, \"&rect;\"],\n-                    [0, \"&marker;\"],\n-                    [2, \"&fltns;\"],\n-                    [1, \"&bigtriangleup;\"],\n-                    [0, \"&blacktriangle;\"],\n-                    [0, \"&triangle;\"],\n-                    [2, \"&blacktriangleright;\"],\n-                    [0, \"&rtri;\"],\n-                    [3, \"&bigtriangledown;\"],\n-                    [0, \"&blacktriangledown;\"],\n-                    [0, \"&dtri;\"],\n-                    [2, \"&blacktriangleleft;\"],\n-                    [0, \"&ltri;\"],\n-                    [6, \"&loz;\"],\n-                    [0, \"&cir;\"],\n-                    [32, \"&tridot;\"],\n-                    [2, \"&bigcirc;\"],\n-                    [8, \"&ultri;\"],\n-                    [0, \"&urtri;\"],\n-                    [0, \"&lltri;\"],\n-                    [0, \"&EmptySmallSquare;\"],\n-                    [0, \"&FilledSmallSquare;\"],\n-                    [8, \"&bigstar;\"],\n-                    [0, \"&star;\"],\n-                    [7, \"&phone;\"],\n-                    [49, \"&female;\"],\n-                    [1, \"&male;\"],\n-                    [29, \"&spades;\"],\n-                    [2, \"&clubs;\"],\n-                    [1, \"&hearts;\"],\n-                    [0, \"&diamondsuit;\"],\n-                    [3, \"&sung;\"],\n-                    [2, \"&flat;\"],\n-                    [0, \"&natural;\"],\n-                    [0, \"&sharp;\"],\n-                    [163, \"&check;\"],\n-                    [3, \"&cross;\"],\n-                    [8, \"&malt;\"],\n-                    [21, \"&sext;\"],\n-                    [33, \"&VerticalSeparator;\"],\n-                    [25, \"&lbbrk;\"],\n-                    [0, \"&rbbrk;\"],\n-                    [84, \"&bsolhsub;\"],\n-                    [0, \"&suphsol;\"],\n-                    [28, \"&LeftDoubleBracket;\"],\n-                    [0, \"&RightDoubleBracket;\"],\n-                    [0, \"&lang;\"],\n-                    [0, \"&rang;\"],\n-                    [0, \"&Lang;\"],\n-                    [0, \"&Rang;\"],\n-                    [0, \"&loang;\"],\n-                    [0, \"&roang;\"],\n-                    [7, \"&longleftarrow;\"],\n-                    [0, \"&longrightarrow;\"],\n-                    [0, \"&longleftrightarrow;\"],\n-                    [0, \"&DoubleLongLeftArrow;\"],\n-                    [0, \"&DoubleLongRightArrow;\"],\n-                    [0, \"&DoubleLongLeftRightArrow;\"],\n-                    [1, \"&longmapsto;\"],\n-                    [2, \"&dzigrarr;\"],\n-                    [258, \"&nvlArr;\"],\n-                    [0, \"&nvrArr;\"],\n-                    [0, \"&nvHarr;\"],\n-                    [0, \"&Map;\"],\n-                    [6, \"&lbarr;\"],\n-                    [0, \"&bkarow;\"],\n-                    [0, \"&lBarr;\"],\n-                    [0, \"&dbkarow;\"],\n-                    [0, \"&drbkarow;\"],\n-                    [0, \"&DDotrahd;\"],\n-                    [0, \"&UpArrowBar;\"],\n-                    [0, \"&DownArrowBar;\"],\n-                    [2, \"&Rarrtl;\"],\n-                    [2, \"&latail;\"],\n-                    [0, \"&ratail;\"],\n-                    [0, \"&lAtail;\"],\n-                    [0, \"&rAtail;\"],\n-                    [0, \"&larrfs;\"],\n-                    [0, \"&rarrfs;\"],\n-                    [0, \"&larrbfs;\"],\n-                    [0, \"&rarrbfs;\"],\n-                    [2, \"&nwarhk;\"],\n-                    [0, \"&nearhk;\"],\n-                    [0, \"&hksearow;\"],\n-                    [0, \"&hkswarow;\"],\n-                    [0, \"&nwnear;\"],\n-                    [0, \"&nesear;\"],\n-                    [0, \"&seswar;\"],\n-                    [0, \"&swnwar;\"],\n-                    [8, {\n-                        v: \"&rarrc;\",\n-                        n: 824,\n-                        o: \"&nrarrc;\"\n-                    }],\n-                    [1, \"&cudarrr;\"],\n-                    [0, \"&ldca;\"],\n-                    [0, \"&rdca;\"],\n-                    [0, \"&cudarrl;\"],\n-                    [0, \"&larrpl;\"],\n-                    [2, \"&curarrm;\"],\n-                    [0, \"&cularrp;\"],\n-                    [7, \"&rarrpl;\"],\n-                    [2, \"&harrcir;\"],\n-                    [0, \"&Uarrocir;\"],\n-                    [0, \"&lurdshar;\"],\n-                    [0, \"&ldrushar;\"],\n-                    [2, \"&LeftRightVector;\"],\n-                    [0, \"&RightUpDownVector;\"],\n-                    [0, \"&DownLeftRightVector;\"],\n-                    [0, \"&LeftUpDownVector;\"],\n-                    [0, \"&LeftVectorBar;\"],\n-                    [0, \"&RightVectorBar;\"],\n-                    [0, \"&RightUpVectorBar;\"],\n-                    [0, \"&RightDownVectorBar;\"],\n-                    [0, \"&DownLeftVectorBar;\"],\n-                    [0, \"&DownRightVectorBar;\"],\n-                    [0, \"&LeftUpVectorBar;\"],\n-                    [0, \"&LeftDownVectorBar;\"],\n-                    [0, \"&LeftTeeVector;\"],\n-                    [0, \"&RightTeeVector;\"],\n-                    [0, \"&RightUpTeeVector;\"],\n-                    [0, \"&RightDownTeeVector;\"],\n-                    [0, \"&DownLeftTeeVector;\"],\n-                    [0, \"&DownRightTeeVector;\"],\n-                    [0, \"&LeftUpTeeVector;\"],\n-                    [0, \"&LeftDownTeeVector;\"],\n-                    [0, \"&lHar;\"],\n-                    [0, \"&uHar;\"],\n-                    [0, \"&rHar;\"],\n-                    [0, \"&dHar;\"],\n-                    [0, \"&luruhar;\"],\n-                    [0, \"&ldrdhar;\"],\n-                    [0, \"&ruluhar;\"],\n-                    [0, \"&rdldhar;\"],\n-                    [0, \"&lharul;\"],\n-                    [0, \"&llhard;\"],\n-                    [0, \"&rharul;\"],\n-                    [0, \"&lrhard;\"],\n-                    [0, \"&udhar;\"],\n-                    [0, \"&duhar;\"],\n-                    [0, \"&RoundImplies;\"],\n-                    [0, \"&erarr;\"],\n-                    [0, \"&simrarr;\"],\n-                    [0, \"&larrsim;\"],\n-                    [0, \"&rarrsim;\"],\n-                    [0, \"&rarrap;\"],\n-                    [0, \"&ltlarr;\"],\n-                    [1, \"&gtrarr;\"],\n-                    [0, \"&subrarr;\"],\n-                    [1, \"&suplarr;\"],\n-                    [0, \"&lfisht;\"],\n-                    [0, \"&rfisht;\"],\n-                    [0, \"&ufisht;\"],\n-                    [0, \"&dfisht;\"],\n-                    [5, \"&lopar;\"],\n-                    [0, \"&ropar;\"],\n-                    [4, \"&lbrke;\"],\n-                    [0, \"&rbrke;\"],\n-                    [0, \"&lbrkslu;\"],\n-                    [0, \"&rbrksld;\"],\n-                    [0, \"&lbrksld;\"],\n-                    [0, \"&rbrkslu;\"],\n-                    [0, \"&langd;\"],\n-                    [0, \"&rangd;\"],\n-                    [0, \"&lparlt;\"],\n-                    [0, \"&rpargt;\"],\n-                    [0, \"&gtlPar;\"],\n-                    [0, \"&ltrPar;\"],\n-                    [3, \"&vzigzag;\"],\n-                    [1, \"&vangrt;\"],\n-                    [0, \"&angrtvbd;\"],\n-                    [6, \"&ange;\"],\n-                    [0, \"&range;\"],\n-                    [0, \"&dwangle;\"],\n-                    [0, \"&uwangle;\"],\n-                    [0, \"&angmsdaa;\"],\n-                    [0, \"&angmsdab;\"],\n-                    [0, \"&angmsdac;\"],\n-                    [0, \"&angmsdad;\"],\n-                    [0, \"&angmsdae;\"],\n-                    [0, \"&angmsdaf;\"],\n-                    [0, \"&angmsdag;\"],\n-                    [0, \"&angmsdah;\"],\n-                    [0, \"&bemptyv;\"],\n-                    [0, \"&demptyv;\"],\n-                    [0, \"&cemptyv;\"],\n-                    [0, \"&raemptyv;\"],\n-                    [0, \"&laemptyv;\"],\n-                    [0, \"&ohbar;\"],\n-                    [0, \"&omid;\"],\n-                    [0, \"&opar;\"],\n-                    [1, \"&operp;\"],\n-                    [1, \"&olcross;\"],\n-                    [0, \"&odsold;\"],\n-                    [1, \"&olcir;\"],\n-                    [0, \"&ofcir;\"],\n-                    [0, \"&olt;\"],\n-                    [0, \"&ogt;\"],\n-                    [0, \"&cirscir;\"],\n-                    [0, \"&cirE;\"],\n-                    [0, \"&solb;\"],\n-                    [0, \"&bsolb;\"],\n-                    [3, \"&boxbox;\"],\n-                    [3, \"&trisb;\"],\n-                    [0, \"&rtriltri;\"],\n-                    [0, {\n-                        v: \"&LeftTriangleBar;\",\n-                        n: 824,\n-                        o: \"&NotLeftTriangleBar;\"\n-                    }],\n-                    [0, {\n-                        v: \"&RightTriangleBar;\",\n-                        n: 824,\n-                        o: \"&NotRightTriangleBar;\"\n-                    }],\n-                    [11, \"&iinfin;\"],\n-                    [0, \"&infintie;\"],\n-                    [0, \"&nvinfin;\"],\n-                    [4, \"&eparsl;\"],\n-                    [0, \"&smeparsl;\"],\n-                    [0, \"&eqvparsl;\"],\n-                    [5, \"&blacklozenge;\"],\n-                    [8, \"&RuleDelayed;\"],\n-                    [1, \"&dsol;\"],\n-                    [9, \"&bigodot;\"],\n-                    [0, \"&bigoplus;\"],\n-                    [0, \"&bigotimes;\"],\n-                    [1, \"&biguplus;\"],\n-                    [1, \"&bigsqcup;\"],\n-                    [5, \"&iiiint;\"],\n-                    [0, \"&fpartint;\"],\n-                    [2, \"&cirfnint;\"],\n-                    [0, \"&awint;\"],\n-                    [0, \"&rppolint;\"],\n-                    [0, \"&scpolint;\"],\n-                    [0, \"&npolint;\"],\n-                    [0, \"&pointint;\"],\n-                    [0, \"&quatint;\"],\n-                    [0, \"&intlarhk;\"],\n-                    [10, \"&pluscir;\"],\n-                    [0, \"&plusacir;\"],\n-                    [0, \"&simplus;\"],\n-                    [0, \"&plusdu;\"],\n-                    [0, \"&plussim;\"],\n-                    [0, \"&plustwo;\"],\n-                    [1, \"&mcomma;\"],\n-                    [0, \"&minusdu;\"],\n-                    [2, \"&loplus;\"],\n-                    [0, \"&roplus;\"],\n-                    [0, \"&Cross;\"],\n-                    [0, \"&timesd;\"],\n-                    [0, \"&timesbar;\"],\n-                    [1, \"&smashp;\"],\n-                    [0, \"&lotimes;\"],\n-                    [0, \"&rotimes;\"],\n-                    [0, \"&otimesas;\"],\n-                    [0, \"&Otimes;\"],\n-                    [0, \"&odiv;\"],\n-                    [0, \"&triplus;\"],\n-                    [0, \"&triminus;\"],\n-                    [0, \"&tritime;\"],\n-                    [0, \"&intprod;\"],\n-                    [2, \"&amalg;\"],\n-                    [0, \"&capdot;\"],\n-                    [1, \"&ncup;\"],\n-                    [0, \"&ncap;\"],\n-                    [0, \"&capand;\"],\n-                    [0, \"&cupor;\"],\n-                    [0, \"&cupcap;\"],\n-                    [0, \"&capcup;\"],\n-                    [0, \"&cupbrcap;\"],\n-                    [0, \"&capbrcup;\"],\n-                    [0, \"&cupcup;\"],\n-                    [0, \"&capcap;\"],\n-                    [0, \"&ccups;\"],\n-                    [0, \"&ccaps;\"],\n-                    [2, \"&ccupssm;\"],\n-                    [2, \"&And;\"],\n-                    [0, \"&Or;\"],\n-                    [0, \"&andand;\"],\n-                    [0, \"&oror;\"],\n-                    [0, \"&orslope;\"],\n-                    [0, \"&andslope;\"],\n-                    [1, \"&andv;\"],\n-                    [0, \"&orv;\"],\n-                    [0, \"&andd;\"],\n-                    [0, \"&ord;\"],\n-                    [1, \"&wedbar;\"],\n-                    [6, \"&sdote;\"],\n-                    [3, \"&simdot;\"],\n-                    [2, {\n-                        v: \"&congdot;\",\n-                        n: 824,\n-                        o: \"&ncongdot;\"\n-                    }],\n-                    [0, \"&easter;\"],\n-                    [0, \"&apacir;\"],\n-                    [0, {\n-                        v: \"&apE;\",\n-                        n: 824,\n-                        o: \"&napE;\"\n-                    }],\n-                    [0, \"&eplus;\"],\n-                    [0, \"&pluse;\"],\n-                    [0, \"&Esim;\"],\n-                    [0, \"&Colone;\"],\n-                    [0, \"&Equal;\"],\n-                    [1, \"&ddotseq;\"],\n-                    [0, \"&equivDD;\"],\n-                    [0, \"&ltcir;\"],\n-                    [0, \"&gtcir;\"],\n-                    [0, \"&ltquest;\"],\n-                    [0, \"&gtquest;\"],\n-                    [0, {\n-                        v: \"&leqslant;\",\n-                        n: 824,\n-                        o: \"&nleqslant;\"\n-                    }],\n-                    [0, {\n-                        v: \"&geqslant;\",\n-                        n: 824,\n-                        o: \"&ngeqslant;\"\n-                    }],\n-                    [0, \"&lesdot;\"],\n-                    [0, \"&gesdot;\"],\n-                    [0, \"&lesdoto;\"],\n-                    [0, \"&gesdoto;\"],\n-                    [0, \"&lesdotor;\"],\n-                    [0, \"&gesdotol;\"],\n-                    [0, \"&lap;\"],\n-                    [0, \"&gap;\"],\n-                    [0, \"&lne;\"],\n-                    [0, \"&gne;\"],\n-                    [0, \"&lnap;\"],\n-                    [0, \"&gnap;\"],\n-                    [0, \"&lEg;\"],\n-                    [0, \"&gEl;\"],\n-                    [0, \"&lsime;\"],\n-                    [0, \"&gsime;\"],\n-                    [0, \"&lsimg;\"],\n-                    [0, \"&gsiml;\"],\n-                    [0, \"&lgE;\"],\n-                    [0, \"&glE;\"],\n-                    [0, \"&lesges;\"],\n-                    [0, \"&gesles;\"],\n-                    [0, \"&els;\"],\n-                    [0, \"&egs;\"],\n-                    [0, \"&elsdot;\"],\n-                    [0, \"&egsdot;\"],\n-                    [0, \"&el;\"],\n-                    [0, \"&eg;\"],\n-                    [2, \"&siml;\"],\n-                    [0, \"&simg;\"],\n-                    [0, \"&simlE;\"],\n-                    [0, \"&simgE;\"],\n-                    [0, {\n-                        v: \"&LessLess;\",\n-                        n: 824,\n-                        o: \"&NotNestedLessLess;\"\n-                    }],\n-                    [0, {\n-                        v: \"&GreaterGreater;\",\n-                        n: 824,\n-                        o: \"&NotNestedGreaterGreater;\"\n-                    }],\n-                    [1, \"&glj;\"],\n-                    [0, \"&gla;\"],\n-                    [0, \"&ltcc;\"],\n-                    [0, \"&gtcc;\"],\n-                    [0, \"&lescc;\"],\n-                    [0, \"&gescc;\"],\n-                    [0, \"&smt;\"],\n-                    [0, \"&lat;\"],\n-                    [0, {\n-                        v: \"&smte;\",\n-                        n: 65024,\n-                        o: \"&smtes;\"\n-                    }],\n-                    [0, {\n-                        v: \"&late;\",\n-                        n: 65024,\n-                        o: \"&lates;\"\n-                    }],\n-                    [0, \"&bumpE;\"],\n-                    [0, {\n-                        v: \"&PrecedesEqual;\",\n-                        n: 824,\n-                        o: \"&NotPrecedesEqual;\"\n-                    }],\n-                    [0, {\n-                        v: \"&sce;\",\n-                        n: 824,\n-                        o: \"&NotSucceedsEqual;\"\n-                    }],\n-                    [2, \"&prE;\"],\n-                    [0, \"&scE;\"],\n-                    [0, \"&precneqq;\"],\n-                    [0, \"&scnE;\"],\n-                    [0, \"&prap;\"],\n-                    [0, \"&scap;\"],\n-                    [0, \"&precnapprox;\"],\n-                    [0, \"&scnap;\"],\n-                    [0, \"&Pr;\"],\n-                    [0, \"&Sc;\"],\n-                    [0, \"&subdot;\"],\n-                    [0, \"&supdot;\"],\n-                    [0, \"&subplus;\"],\n-                    [0, \"&supplus;\"],\n-                    [0, \"&submult;\"],\n-                    [0, \"&supmult;\"],\n-                    [0, \"&subedot;\"],\n-                    [0, \"&supedot;\"],\n-                    [0, {\n-                        v: \"&subE;\",\n-                        n: 824,\n-                        o: \"&nsubE;\"\n-                    }],\n-                    [0, {\n-                        v: \"&supE;\",\n-                        n: 824,\n-                        o: \"&nsupE;\"\n-                    }],\n-                    [0, \"&subsim;\"],\n-                    [0, \"&supsim;\"],\n-                    [2, {\n-                        v: \"&subnE;\",\n-                        n: 65024,\n-                        o: \"&varsubsetneqq;\"\n-                    }],\n-                    [0, {\n-                        v: \"&supnE;\",\n-                        n: 65024,\n-                        o: \"&varsupsetneqq;\"\n-                    }],\n-                    [2, \"&csub;\"],\n-                    [0, \"&csup;\"],\n-                    [0, \"&csube;\"],\n-                    [0, \"&csupe;\"],\n-                    [0, \"&subsup;\"],\n-                    [0, \"&supsub;\"],\n-                    [0, \"&subsub;\"],\n-                    [0, \"&supsup;\"],\n-                    [0, \"&suphsub;\"],\n-                    [0, \"&supdsub;\"],\n-                    [0, \"&forkv;\"],\n-                    [0, \"&topfork;\"],\n-                    [0, \"&mlcp;\"],\n-                    [8, \"&Dashv;\"],\n-                    [1, \"&Vdashl;\"],\n-                    [0, \"&Barv;\"],\n-                    [0, \"&vBar;\"],\n-                    [0, \"&vBarv;\"],\n-                    [1, \"&Vbar;\"],\n-                    [0, \"&Not;\"],\n-                    [0, \"&bNot;\"],\n-                    [0, \"&rnmid;\"],\n-                    [0, \"&cirmid;\"],\n-                    [0, \"&midcir;\"],\n-                    [0, \"&topcir;\"],\n-                    [0, \"&nhpar;\"],\n-                    [0, \"&parsim;\"],\n-                    [9, {\n-                        v: \"&parsl;\",\n-                        n: 8421,\n-                        o: \"&nparsl;\"\n-                    }],\n-                    [44343, {\n-                        n: new Map( /* #__PURE__ */ restoreDiff([\n-                            [56476, \"&Ascr;\"],\n-                            [1, \"&Cscr;\"],\n-                            [0, \"&Dscr;\"],\n-                            [2, \"&Gscr;\"],\n-                            [2, \"&Jscr;\"],\n-                            [0, \"&Kscr;\"],\n-                            [2, \"&Nscr;\"],\n-                            [0, \"&Oscr;\"],\n-                            [0, \"&Pscr;\"],\n-                            [0, \"&Qscr;\"],\n-                            [1, \"&Sscr;\"],\n-                            [0, \"&Tscr;\"],\n-                            [0, \"&Uscr;\"],\n-                            [0, \"&Vscr;\"],\n-                            [0, \"&Wscr;\"],\n-                            [0, \"&Xscr;\"],\n-                            [0, \"&Yscr;\"],\n-                            [0, \"&Zscr;\"],\n-                            [0, \"&ascr;\"],\n-                            [0, \"&bscr;\"],\n-                            [0, \"&cscr;\"],\n-                            [0, \"&dscr;\"],\n-                            [1, \"&fscr;\"],\n-                            [1, \"&hscr;\"],\n-                            [0, \"&iscr;\"],\n-                            [0, \"&jscr;\"],\n-                            [0, \"&kscr;\"],\n-                            [0, \"&lscr;\"],\n-                            [0, \"&mscr;\"],\n-                            [0, \"&nscr;\"],\n-                            [1, \"&pscr;\"],\n-                            [0, \"&qscr;\"],\n-                            [0, \"&rscr;\"],\n-                            [0, \"&sscr;\"],\n-                            [0, \"&tscr;\"],\n-                            [0, \"&uscr;\"],\n-                            [0, \"&vscr;\"],\n-                            [0, \"&wscr;\"],\n-                            [0, \"&xscr;\"],\n-                            [0, \"&yscr;\"],\n-                            [0, \"&zscr;\"],\n-                            [52, \"&Afr;\"],\n-                            [0, \"&Bfr;\"],\n-                            [1, \"&Dfr;\"],\n-                            [0, \"&Efr;\"],\n-                            [0, \"&Ffr;\"],\n-                            [0, \"&Gfr;\"],\n-                            [2, \"&Jfr;\"],\n-                            [0, \"&Kfr;\"],\n-                            [0, \"&Lfr;\"],\n-                            [0, \"&Mfr;\"],\n-                            [0, \"&Nfr;\"],\n-                            [0, \"&Ofr;\"],\n-                            [0, \"&Pfr;\"],\n-                            [0, \"&Qfr;\"],\n-                            [1, \"&Sfr;\"],\n-                            [0, \"&Tfr;\"],\n-                            [0, \"&Ufr;\"],\n-                            [0, \"&Vfr;\"],\n-                            [0, \"&Wfr;\"],\n-                            [0, \"&Xfr;\"],\n-                            [0, \"&Yfr;\"],\n-                            [1, \"&afr;\"],\n-                            [0, \"&bfr;\"],\n-                            [0, \"&cfr;\"],\n-                            [0, \"&dfr;\"],\n-                            [0, \"&efr;\"],\n-                            [0, \"&ffr;\"],\n-                            [0, \"&gfr;\"],\n-                            [0, \"&hfr;\"],\n-                            [0, \"&ifr;\"],\n-                            [0, \"&jfr;\"],\n-                            [0, \"&kfr;\"],\n-                            [0, \"&lfr;\"],\n-                            [0, \"&mfr;\"],\n-                            [0, \"&nfr;\"],\n-                            [0, \"&ofr;\"],\n-                            [0, \"&pfr;\"],\n-                            [0, \"&qfr;\"],\n-                            [0, \"&rfr;\"],\n-                            [0, \"&sfr;\"],\n-                            [0, \"&tfr;\"],\n-                            [0, \"&ufr;\"],\n-                            [0, \"&vfr;\"],\n-                            [0, \"&wfr;\"],\n-                            [0, \"&xfr;\"],\n-                            [0, \"&yfr;\"],\n-                            [0, \"&zfr;\"],\n-                            [0, \"&Aopf;\"],\n-                            [0, \"&Bopf;\"],\n-                            [1, \"&Dopf;\"],\n-                            [0, \"&Eopf;\"],\n-                            [0, \"&Fopf;\"],\n-                            [0, \"&Gopf;\"],\n-                            [1, \"&Iopf;\"],\n-                            [0, \"&Jopf;\"],\n-                            [0, \"&Kopf;\"],\n-                            [0, \"&Lopf;\"],\n-                            [0, \"&Mopf;\"],\n-                            [1, \"&Oopf;\"],\n-                            [3, \"&Sopf;\"],\n-                            [0, \"&Topf;\"],\n-                            [0, \"&Uopf;\"],\n-                            [0, \"&Vopf;\"],\n-                            [0, \"&Wopf;\"],\n-                            [0, \"&Xopf;\"],\n-                            [0, \"&Yopf;\"],\n-                            [1, \"&aopf;\"],\n-                            [0, \"&bopf;\"],\n-                            [0, \"&copf;\"],\n-                            [0, \"&dopf;\"],\n-                            [0, \"&eopf;\"],\n-                            [0, \"&fopf;\"],\n-                            [0, \"&gopf;\"],\n-                            [0, \"&hopf;\"],\n-                            [0, \"&iopf;\"],\n-                            [0, \"&jopf;\"],\n-                            [0, \"&kopf;\"],\n-                            [0, \"&lopf;\"],\n-                            [0, \"&mopf;\"],\n-                            [0, \"&nopf;\"],\n-                            [0, \"&oopf;\"],\n-                            [0, \"&popf;\"],\n-                            [0, \"&qopf;\"],\n-                            [0, \"&ropf;\"],\n-                            [0, \"&sopf;\"],\n-                            [0, \"&topf;\"],\n-                            [0, \"&uopf;\"],\n-                            [0, \"&vopf;\"],\n-                            [0, \"&wopf;\"],\n-                            [0, \"&xopf;\"],\n-                            [0, \"&yopf;\"],\n-                            [0, \"&zopf;\"]\n-                        ]))\n-                    }],\n-                    [8906, \"&fflig;\"],\n-                    [0, \"&filig;\"],\n-                    [0, \"&fllig;\"],\n-                    [0, \"&ffilig;\"],\n-                    [0, \"&ffllig;\"]\n-                ]));\n \n-                /***/\n-            }),\n+                    function SearchState() {\n+                        this.posFrom = this.posTo = this.lastQuery = this.query = null;\n+                        this.overlay = null;\n+                    }\n \n-        /***/\n-        \"../../../node_modules/entities/lib/index.js\":\n-            /*!***************************************************!*\\\n-              !*** ../../../node_modules/entities/lib/index.js ***!\n-              \\***************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                    function getSearchState(cm) {\n+                        return cm.state.search || (cm.state.search = new SearchState());\n+                    }\n \n+                    function queryCaseInsensitive(query) {\n+                        return typeof query == \"string\" && query == query.toLowerCase();\n+                    }\n \n+                    function getSearchCursor(cm, query, pos) {\n+                        // Heuristic: if the query string is all lowercase, do a case insensitive search.\n+                        return cm.getSearchCursor(query, pos, {\n+                            caseFold: queryCaseInsensitive(query),\n+                            multiline: true\n+                        });\n+                    }\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.decodeXMLStrict = exports.decodeHTML5Strict = exports.decodeHTML4Strict = exports.decodeHTML5 = exports.decodeHTML4 = exports.decodeHTMLAttribute = exports.decodeHTMLStrict = exports.decodeHTML = exports.decodeXML = exports.DecodingMode = exports.EntityDecoder = exports.encodeHTML5 = exports.encodeHTML4 = exports.encodeNonAsciiHTML = exports.encodeHTML = exports.escapeText = exports.escapeAttribute = exports.escapeUTF8 = exports.escape = exports.encodeXML = exports.encode = exports.decodeStrict = exports.decode = exports.EncodingMode = exports.EntityLevel = void 0;\n-                var decode_js_1 = __webpack_require__( /*! ./decode.js */ \"../../../node_modules/entities/lib/decode.js\");\n-                var encode_js_1 = __webpack_require__( /*! ./encode.js */ \"../../../node_modules/entities/lib/encode.js\");\n-                var escape_js_1 = __webpack_require__( /*! ./escape.js */ \"../../../node_modules/entities/lib/escape.js\");\n-                /** The level of entities to support. */\n-                var EntityLevel;\n-                (function(EntityLevel) {\n-                    /** Support only XML entities. */\n-                    EntityLevel[EntityLevel[\"XML\"] = 0] = \"XML\";\n-                    /** Support HTML entities, which are a superset of XML entities. */\n-                    EntityLevel[EntityLevel[\"HTML\"] = 1] = \"HTML\";\n-                })(EntityLevel = exports.EntityLevel || (exports.EntityLevel = {}));\n-                var EncodingMode;\n-                (function(EncodingMode) {\n-                    /**\n-                     * The output is UTF-8 encoded. Only characters that need escaping within\n-                     * XML will be escaped.\n-                     */\n-                    EncodingMode[EncodingMode[\"UTF8\"] = 0] = \"UTF8\";\n-                    /**\n-                     * The output consists only of ASCII characters. Characters that need\n-                     * escaping within HTML, and characters that aren't ASCII characters will\n-                     * be escaped.\n-                     */\n-                    EncodingMode[EncodingMode[\"ASCII\"] = 1] = \"ASCII\";\n-                    /**\n-                     * Encode all characters that have an equivalent entity, as well as all\n-                     * characters that are not ASCII characters.\n-                     */\n-                    EncodingMode[EncodingMode[\"Extensive\"] = 2] = \"Extensive\";\n-                    /**\n-                     * Encode all characters that have to be escaped in HTML attributes,\n-                     * following {@link https://html.spec.whatwg.org/multipage/parsing.html#escapingString}.\n-                     */\n-                    EncodingMode[EncodingMode[\"Attribute\"] = 3] = \"Attribute\";\n-                    /**\n-                     * Encode all characters that have to be escaped in HTML text,\n-                     * following {@link https://html.spec.whatwg.org/multipage/parsing.html#escapingString}.\n-                     */\n-                    EncodingMode[EncodingMode[\"Text\"] = 4] = \"Text\";\n-                })(EncodingMode = exports.EncodingMode || (exports.EncodingMode = {}));\n-                /**\n-                 * Decodes a string with entities.\n-                 *\n-                 * @param data String to decode.\n-                 * @param options Decoding options.\n-                 */\n-                function decode(data, options) {\n-                    if (options === void 0) {\n-                        options = EntityLevel.XML;\n+                    function persistentDialog(cm, text, deflt, onEnter, onKeyDown) {\n+                        cm.openDialog(text, onEnter, {\n+                            value: deflt,\n+                            selectValueOnOpen: true,\n+                            closeOnEnter: false,\n+                            onClose: function() {\n+                                clearSearch(cm);\n+                            },\n+                            onKeyDown: onKeyDown,\n+                            bottom: cm.options.search.bottom\n+                        });\n                     }\n-                    var level = typeof options === \"number\" ? options : options.level;\n-                    if (level === EntityLevel.HTML) {\n-                        var mode = typeof options === \"object\" ? options.mode : undefined;\n-                        return (0, decode_js_1.decodeHTML)(data, mode);\n+\n+                    function dialog(cm, text, shortText, deflt, f) {\n+                        if (cm.openDialog) cm.openDialog(text, f, {\n+                            value: deflt,\n+                            selectValueOnOpen: true,\n+                            bottom: cm.options.search.bottom\n+                        });\n+                        else f(prompt(shortText, deflt));\n                     }\n-                    return (0, decode_js_1.decodeXML)(data);\n-                }\n-                exports.decode = decode;\n-                /**\n-                 * Decodes a string with entities. Does not allow missing trailing semicolons for entities.\n-                 *\n-                 * @param data String to decode.\n-                 * @param options Decoding options.\n-                 * @deprecated Use `decode` with the `mode` set to `Strict`.\n-                 */\n-                function decodeStrict(data, options) {\n-                    var _a;\n-                    if (options === void 0) {\n-                        options = EntityLevel.XML;\n+\n+                    function confirmDialog(cm, text, shortText, fs) {\n+                        if (cm.openConfirm) cm.openConfirm(text, fs);\n+                        else if (confirm(shortText)) fs[0]();\n                     }\n-                    var opts = typeof options === \"number\" ? {\n-                        level: options\n-                    } : options;\n-                    (_a = opts.mode) !== null && _a !== void 0 ? _a : opts.mode = decode_js_1.DecodingMode.Strict;\n-                    return decode(data, opts);\n-                }\n-                exports.decodeStrict = decodeStrict;\n-                /**\n-                 * Encodes a string with entities.\n-                 *\n-                 * @param data String to encode.\n-                 * @param options Encoding options.\n-                 */\n-                function encode(data, options) {\n-                    if (options === void 0) {\n-                        options = EntityLevel.XML;\n+\n+                    function parseString(string) {\n+                        return string.replace(/\\\\([nrt\\\\])/g, function(match, ch) {\n+                            if (ch == \"n\") return \"\\n\";\n+                            if (ch == \"r\") return \"\\r\";\n+                            if (ch == \"t\") return \"\\t\";\n+                            if (ch == \"\\\\\") return \"\\\\\";\n+                            return match;\n+                        });\n                     }\n-                    var opts = typeof options === \"number\" ? {\n-                        level: options\n-                    } : options;\n-                    // Mode `UTF8` just escapes XML entities\n-                    if (opts.mode === EncodingMode.UTF8) return (0, escape_js_1.escapeUTF8)(data);\n-                    if (opts.mode === EncodingMode.Attribute) return (0, escape_js_1.escapeAttribute)(data);\n-                    if (opts.mode === EncodingMode.Text) return (0, escape_js_1.escapeText)(data);\n-                    if (opts.level === EntityLevel.HTML) {\n-                        if (opts.mode === EncodingMode.ASCII) {\n-                            return (0, encode_js_1.encodeNonAsciiHTML)(data);\n+\n+                    function parseQuery(query) {\n+                        var isRE = query.match(/^\\/(.*)\\/([a-z]*)$/);\n+                        if (isRE) {\n+                            try {\n+                                query = new RegExp(isRE[1], isRE[2].indexOf(\"i\") == -1 ? \"\" : \"i\");\n+                            } catch (e) {} // Not a regular expression after all, do a string search\n+                        } else {\n+                            query = parseString(query);\n                         }\n-                        return (0, encode_js_1.encodeHTML)(data);\n+                        if (typeof query == \"string\" ? query == \"\" : query.test(\"\")) query = /x^/;\n+                        return query;\n                     }\n-                    // ASCII and Extensive are equivalent\n-                    return (0, escape_js_1.encodeXML)(data);\n-                }\n-                exports.encode = encode;\n-                var escape_js_2 = __webpack_require__( /*! ./escape.js */ \"../../../node_modules/entities/lib/escape.js\");\n-                Object.defineProperty(exports, \"encodeXML\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return escape_js_2.encodeXML;\n+\n+                    function startSearch(cm, state, query) {\n+                        state.queryText = query;\n+                        state.query = parseQuery(query);\n+                        cm.removeOverlay(state.overlay, queryCaseInsensitive(state.query));\n+                        state.overlay = searchOverlay(state.query, queryCaseInsensitive(state.query));\n+                        cm.addOverlay(state.overlay);\n+                        if (cm.showMatchesOnScrollbar) {\n+                            if (state.annotate) {\n+                                state.annotate.clear();\n+                                state.annotate = null;\n+                            }\n+                            state.annotate = cm.showMatchesOnScrollbar(state.query, queryCaseInsensitive(state.query));\n+                        }\n                     }\n-                }));\n-                Object.defineProperty(exports, \"escape\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return escape_js_2.escape;\n+\n+                    function doSearch(cm, rev, persistent, immediate) {\n+                        var state = getSearchState(cm);\n+                        if (state.query) return findNext(cm, rev);\n+                        var q = cm.getSelection() || state.lastQuery;\n+                        if (q instanceof RegExp && q.source == \"x^\") q = null;\n+                        if (persistent && cm.openDialog) {\n+                            var hiding = null;\n+                            var searchNext = function(query, event) {\n+                                CodeMirror.e_stop(event);\n+                                if (!query) return;\n+                                if (query != state.queryText) {\n+                                    startSearch(cm, state, query);\n+                                    state.posFrom = state.posTo = cm.getCursor();\n+                                }\n+                                if (hiding) hiding.style.opacity = 1;\n+                                findNext(cm, event.shiftKey, function(_, to) {\n+                                    var dialog;\n+                                    if (to.line < 3 && document.querySelector && (dialog = cm.display.wrapper.querySelector(\".CodeMirror-dialog\")) && dialog.getBoundingClientRect().bottom - 4 > cm.cursorCoords(to, \"window\").top)(hiding = dialog).style.opacity = .4;\n+                                });\n+                            };\n+                            persistentDialog(cm, getQueryDialog(cm), q, searchNext, function(event, query) {\n+                                var keyName = CodeMirror.keyName(event);\n+                                var extra = cm.getOption('extraKeys'),\n+                                    cmd = extra && extra[keyName] || CodeMirror.keyMap[cm.getOption(\"keyMap\")][keyName];\n+                                if (cmd == \"findNext\" || cmd == \"findPrev\" || cmd == \"findPersistentNext\" || cmd == \"findPersistentPrev\") {\n+                                    CodeMirror.e_stop(event);\n+                                    startSearch(cm, getSearchState(cm), query);\n+                                    cm.execCommand(cmd);\n+                                } else if (cmd == \"find\" || cmd == \"findPersistent\") {\n+                                    CodeMirror.e_stop(event);\n+                                    searchNext(query, event);\n+                                }\n+                            });\n+                            if (immediate && q) {\n+                                startSearch(cm, state, q);\n+                                findNext(cm, rev);\n+                            }\n+                        } else {\n+                            dialog(cm, getQueryDialog(cm), \"Search for:\", q, function(query) {\n+                                if (query && !state.query) cm.operation(function() {\n+                                    startSearch(cm, state, query);\n+                                    state.posFrom = state.posTo = cm.getCursor();\n+                                    findNext(cm, rev);\n+                                });\n+                            });\n+                        }\n                     }\n-                }));\n-                Object.defineProperty(exports, \"escapeUTF8\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return escape_js_2.escapeUTF8;\n+\n+                    function findNext(cm, rev, callback) {\n+                        cm.operation(function() {\n+                            var state = getSearchState(cm);\n+                            var cursor = getSearchCursor(cm, state.query, rev ? state.posFrom : state.posTo);\n+                            if (!cursor.find(rev)) {\n+                                cursor = getSearchCursor(cm, state.query, rev ? CodeMirror.Pos(cm.lastLine()) : CodeMirror.Pos(cm.firstLine(), 0));\n+                                if (!cursor.find(rev)) return;\n+                            }\n+                            cm.setSelection(cursor.from(), cursor.to());\n+                            cm.scrollIntoView({\n+                                from: cursor.from(),\n+                                to: cursor.to()\n+                            }, 20);\n+                            state.posFrom = cursor.from();\n+                            state.posTo = cursor.to();\n+                            if (callback) callback(cursor.from(), cursor.to());\n+                        });\n                     }\n-                }));\n-                Object.defineProperty(exports, \"escapeAttribute\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return escape_js_2.escapeAttribute;\n+\n+                    function clearSearch(cm) {\n+                        cm.operation(function() {\n+                            var state = getSearchState(cm);\n+                            state.lastQuery = state.query;\n+                            if (!state.query) return;\n+                            state.query = state.queryText = null;\n+                            cm.removeOverlay(state.overlay);\n+                            if (state.annotate) {\n+                                state.annotate.clear();\n+                                state.annotate = null;\n+                            }\n+                        });\n                     }\n-                }));\n-                Object.defineProperty(exports, \"escapeText\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return escape_js_2.escapeText;\n+\n+                    function el(tag, attrs) {\n+                        var element = tag ? document.createElement(tag) : document.createDocumentFragment();\n+                        for (var key in attrs) {\n+                            element[key] = attrs[key];\n+                        }\n+                        for (var i = 2; i < arguments.length; i++) {\n+                            var child = arguments[i];\n+                            element.appendChild(typeof child == \"string\" ? document.createTextNode(child) : child);\n+                        }\n+                        return element;\n                     }\n-                }));\n-                var encode_js_2 = __webpack_require__( /*! ./encode.js */ \"../../../node_modules/entities/lib/encode.js\");\n-                Object.defineProperty(exports, \"encodeHTML\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return encode_js_2.encodeHTML;\n+\n+                    function getQueryDialog(cm) {\n+                        return el(\"\", null, el(\"span\", {\n+                            className: \"CodeMirror-search-label\"\n+                        }, cm.phrase(\"Search:\")), \" \", el(\"input\", {\n+                            type: \"text\",\n+                            \"style\": \"width: 10em\",\n+                            className: \"CodeMirror-search-field\"\n+                        }), \" \", el(\"span\", {\n+                            style: \"color: #888\",\n+                            className: \"CodeMirror-search-hint\"\n+                        }, cm.phrase(\"(Use /re/ syntax for regexp search)\")));\n+                    }\n+\n+                    function getReplaceQueryDialog(cm) {\n+                        return el(\"\", null, \" \", el(\"input\", {\n+                            type: \"text\",\n+                            \"style\": \"width: 10em\",\n+                            className: \"CodeMirror-search-field\"\n+                        }), \" \", el(\"span\", {\n+                            style: \"color: #888\",\n+                            className: \"CodeMirror-search-hint\"\n+                        }, cm.phrase(\"(Use /re/ syntax for regexp search)\")));\n+                    }\n+\n+                    function getReplacementQueryDialog(cm) {\n+                        return el(\"\", null, el(\"span\", {\n+                            className: \"CodeMirror-search-label\"\n+                        }, cm.phrase(\"With:\")), \" \", el(\"input\", {\n+                            type: \"text\",\n+                            \"style\": \"width: 10em\",\n+                            className: \"CodeMirror-search-field\"\n+                        }));\n                     }\n-                }));\n-                Object.defineProperty(exports, \"encodeNonAsciiHTML\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return encode_js_2.encodeNonAsciiHTML;\n+\n+                    function getDoReplaceConfirm(cm) {\n+                        return el(\"\", null, el(\"span\", {\n+                            className: \"CodeMirror-search-label\"\n+                        }, cm.phrase(\"Replace?\")), \" \", el(\"button\", {}, cm.phrase(\"Yes\")), \" \", el(\"button\", {}, cm.phrase(\"No\")), \" \", el(\"button\", {}, cm.phrase(\"All\")), \" \", el(\"button\", {}, cm.phrase(\"Stop\")));\n                     }\n-                }));\n-                // Legacy aliases (deprecated)\n-                Object.defineProperty(exports, \"encodeHTML4\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return encode_js_2.encodeHTML;\n+\n+                    function replaceAll(cm, query, text) {\n+                        cm.operation(function() {\n+                            for (var cursor = getSearchCursor(cm, query); cursor.findNext();) {\n+                                if (typeof query != \"string\") {\n+                                    var match = cm.getRange(cursor.from(), cursor.to()).match(query);\n+                                    cursor.replace(text.replace(/\\$(\\d)/g, function(_, i) {\n+                                        return match[i];\n+                                    }));\n+                                } else cursor.replace(text);\n+                            }\n+                        });\n                     }\n-                }));\n-                Object.defineProperty(exports, \"encodeHTML5\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return encode_js_2.encodeHTML;\n+\n+                    function replace(cm, all) {\n+                        if (cm.getOption(\"readOnly\")) return;\n+                        var query = cm.getSelection() || getSearchState(cm).lastQuery;\n+                        var dialogText = all ? cm.phrase(\"Replace all:\") : cm.phrase(\"Replace:\");\n+                        var fragment = el(\"\", null, el(\"span\", {\n+                            className: \"CodeMirror-search-label\"\n+                        }, dialogText), getReplaceQueryDialog(cm));\n+                        dialog(cm, fragment, dialogText, query, function(query) {\n+                            if (!query) return;\n+                            query = parseQuery(query);\n+                            dialog(cm, getReplacementQueryDialog(cm), cm.phrase(\"Replace with:\"), \"\", function(text) {\n+                                text = parseString(text);\n+                                if (all) {\n+                                    replaceAll(cm, query, text);\n+                                } else {\n+                                    clearSearch(cm);\n+                                    var cursor = getSearchCursor(cm, query, cm.getCursor(\"from\"));\n+                                    var advance = function() {\n+                                        var start = cursor.from(),\n+                                            match;\n+                                        if (!(match = cursor.findNext())) {\n+                                            cursor = getSearchCursor(cm, query);\n+                                            if (!(match = cursor.findNext()) || start && cursor.from().line == start.line && cursor.from().ch == start.ch) return;\n+                                        }\n+                                        cm.setSelection(cursor.from(), cursor.to());\n+                                        cm.scrollIntoView({\n+                                            from: cursor.from(),\n+                                            to: cursor.to()\n+                                        });\n+                                        confirmDialog(cm, getDoReplaceConfirm(cm), cm.phrase(\"Replace?\"), [function() {\n+                                            doReplace(match);\n+                                        }, advance, function() {\n+                                            replaceAll(cm, query, text);\n+                                        }]);\n+                                    };\n+                                    var doReplace = function(match) {\n+                                        cursor.replace(typeof query == \"string\" ? text : text.replace(/\\$(\\d)/g, function(_, i) {\n+                                            return match[i];\n+                                        }));\n+                                        advance();\n+                                    };\n+                                    advance();\n+                                }\n+                            });\n+                        });\n                     }\n-                }));\n-                var decode_js_2 = __webpack_require__( /*! ./decode.js */ \"../../../node_modules/entities/lib/decode.js\");\n-                Object.defineProperty(exports, \"EntityDecoder\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return decode_js_2.EntityDecoder;\n+                    CodeMirror.commands.find = function(cm) {\n+                        clearSearch(cm);\n+                        doSearch(cm);\n+                    };\n+                    CodeMirror.commands.findPersistent = function(cm) {\n+                        clearSearch(cm);\n+                        doSearch(cm, false, true);\n+                    };\n+                    CodeMirror.commands.findPersistentNext = function(cm) {\n+                        doSearch(cm, false, true, true);\n+                    };\n+                    CodeMirror.commands.findPersistentPrev = function(cm) {\n+                        doSearch(cm, true, true, true);\n+                    };\n+                    CodeMirror.commands.findNext = doSearch;\n+                    CodeMirror.commands.findPrev = function(cm) {\n+                        doSearch(cm, true);\n+                    };\n+                    CodeMirror.commands.clearSearch = clearSearch;\n+                    CodeMirror.commands.replace = replace;\n+                    CodeMirror.commands.replaceAll = function(cm) {\n+                        replace(cm, true);\n+                    };\n+                });\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/codemirror/addon/search/searchcursor.js\":\n+            /*!*********************************************************************!*\\\n+              !*** ../../../node_modules/codemirror/addon/search/searchcursor.js ***!\n+              \\*********************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                // CodeMirror, copyright (c) by Marijn Haverbeke and others\n+                // Distributed under an MIT license: https://codemirror.net/LICENSE\n+\n+                (function(mod) {\n+                    if (true)\n+                        // CommonJS\n+                        mod(__webpack_require__( /*! ../../lib/codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"));\n+                    else {}\n+                })(function(CodeMirror) {\n+                    \"use strict\";\n+\n+                    var Pos = CodeMirror.Pos;\n+\n+                    function regexpFlags(regexp) {\n+                        var flags = regexp.flags;\n+                        return flags != null ? flags : (regexp.ignoreCase ? \"i\" : \"\") + (regexp.global ? \"g\" : \"\") + (regexp.multiline ? \"m\" : \"\");\n                     }\n-                }));\n-                Object.defineProperty(exports, \"DecodingMode\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return decode_js_2.DecodingMode;\n+\n+                    function ensureFlags(regexp, flags) {\n+                        var current = regexpFlags(regexp),\n+                            target = current;\n+                        for (var i = 0; i < flags.length; i++)\n+                            if (target.indexOf(flags.charAt(i)) == -1) target += flags.charAt(i);\n+                        return current == target ? regexp : new RegExp(regexp.source, target);\n                     }\n-                }));\n-                Object.defineProperty(exports, \"decodeXML\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return decode_js_2.decodeXML;\n+\n+                    function maybeMultiline(regexp) {\n+                        return /\\\\s|\\\\n|\\n|\\\\W|\\\\D|\\[\\^/.test(regexp.source);\n                     }\n-                }));\n-                Object.defineProperty(exports, \"decodeHTML\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return decode_js_2.decodeHTML;\n+\n+                    function searchRegexpForward(doc, regexp, start) {\n+                        regexp = ensureFlags(regexp, \"g\");\n+                        for (var line = start.line, ch = start.ch, last = doc.lastLine(); line <= last; line++, ch = 0) {\n+                            regexp.lastIndex = ch;\n+                            var string = doc.getLine(line),\n+                                match = regexp.exec(string);\n+                            if (match) return {\n+                                from: Pos(line, match.index),\n+                                to: Pos(line, match.index + match[0].length),\n+                                match: match\n+                            };\n+                        }\n                     }\n-                }));\n-                Object.defineProperty(exports, \"decodeHTMLStrict\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return decode_js_2.decodeHTMLStrict;\n+\n+                    function searchRegexpForwardMultiline(doc, regexp, start) {\n+                        if (!maybeMultiline(regexp)) return searchRegexpForward(doc, regexp, start);\n+                        regexp = ensureFlags(regexp, \"gm\");\n+                        var string,\n+                            chunk = 1;\n+                        for (var line = start.line, last = doc.lastLine(); line <= last;) {\n+                            // This grows the search buffer in exponentially-sized chunks\n+                            // between matches, so that nearby matches are fast and don't\n+                            // require concatenating the whole document (in case we're\n+                            // searching for something that has tons of matches), but at the\n+                            // same time, the amount of retries is limited.\n+                            for (var i = 0; i < chunk; i++) {\n+                                if (line > last) break;\n+                                var curLine = doc.getLine(line++);\n+                                string = string == null ? curLine : string + \"\\n\" + curLine;\n+                            }\n+                            chunk = chunk * 2;\n+                            regexp.lastIndex = start.ch;\n+                            var match = regexp.exec(string);\n+                            if (match) {\n+                                var before = string.slice(0, match.index).split(\"\\n\"),\n+                                    inside = match[0].split(\"\\n\");\n+                                var startLine = start.line + before.length - 1,\n+                                    startCh = before[before.length - 1].length;\n+                                return {\n+                                    from: Pos(startLine, startCh),\n+                                    to: Pos(startLine + inside.length - 1, inside.length == 1 ? startCh + inside[0].length : inside[inside.length - 1].length),\n+                                    match: match\n+                                };\n+                            }\n+                        }\n                     }\n-                }));\n-                Object.defineProperty(exports, \"decodeHTMLAttribute\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return decode_js_2.decodeHTMLAttribute;\n+\n+                    function lastMatchIn(string, regexp, endMargin) {\n+                        var match,\n+                            from = 0;\n+                        while (from <= string.length) {\n+                            regexp.lastIndex = from;\n+                            var newMatch = regexp.exec(string);\n+                            if (!newMatch) break;\n+                            var end = newMatch.index + newMatch[0].length;\n+                            if (end > string.length - endMargin) break;\n+                            if (!match || end > match.index + match[0].length) match = newMatch;\n+                            from = newMatch.index + 1;\n+                        }\n+                        return match;\n                     }\n-                }));\n-                // Legacy aliases (deprecated)\n-                Object.defineProperty(exports, \"decodeHTML4\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return decode_js_2.decodeHTML;\n+\n+                    function searchRegexpBackward(doc, regexp, start) {\n+                        regexp = ensureFlags(regexp, \"g\");\n+                        for (var line = start.line, ch = start.ch, first = doc.firstLine(); line >= first; line--, ch = -1) {\n+                            var string = doc.getLine(line);\n+                            var match = lastMatchIn(string, regexp, ch < 0 ? 0 : string.length - ch);\n+                            if (match) return {\n+                                from: Pos(line, match.index),\n+                                to: Pos(line, match.index + match[0].length),\n+                                match: match\n+                            };\n+                        }\n                     }\n-                }));\n-                Object.defineProperty(exports, \"decodeHTML5\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return decode_js_2.decodeHTML;\n+\n+                    function searchRegexpBackwardMultiline(doc, regexp, start) {\n+                        if (!maybeMultiline(regexp)) return searchRegexpBackward(doc, regexp, start);\n+                        regexp = ensureFlags(regexp, \"gm\");\n+                        var string,\n+                            chunkSize = 1,\n+                            endMargin = doc.getLine(start.line).length - start.ch;\n+                        for (var line = start.line, first = doc.firstLine(); line >= first;) {\n+                            for (var i = 0; i < chunkSize && line >= first; i++) {\n+                                var curLine = doc.getLine(line--);\n+                                string = string == null ? curLine : curLine + \"\\n\" + string;\n+                            }\n+                            chunkSize *= 2;\n+                            var match = lastMatchIn(string, regexp, endMargin);\n+                            if (match) {\n+                                var before = string.slice(0, match.index).split(\"\\n\"),\n+                                    inside = match[0].split(\"\\n\");\n+                                var startLine = line + before.length,\n+                                    startCh = before[before.length - 1].length;\n+                                return {\n+                                    from: Pos(startLine, startCh),\n+                                    to: Pos(startLine + inside.length - 1, inside.length == 1 ? startCh + inside[0].length : inside[inside.length - 1].length),\n+                                    match: match\n+                                };\n+                            }\n+                        }\n                     }\n-                }));\n-                Object.defineProperty(exports, \"decodeHTML4Strict\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return decode_js_2.decodeHTMLStrict;\n+                    var doFold, noFold;\n+                    if (String.prototype.normalize) {\n+                        doFold = function(str) {\n+                            return str.normalize(\"NFD\").toLowerCase();\n+                        };\n+                        noFold = function(str) {\n+                            return str.normalize(\"NFD\");\n+                        };\n+                    } else {\n+                        doFold = function(str) {\n+                            return str.toLowerCase();\n+                        };\n+                        noFold = function(str) {\n+                            return str;\n+                        };\n                     }\n-                }));\n-                Object.defineProperty(exports, \"decodeHTML5Strict\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return decode_js_2.decodeHTMLStrict;\n+\n+                    // Maps a position in a case-folded line back to a position in the original line\n+                    // (compensating for codepoints increasing in number during folding)\n+                    function adjustPos(orig, folded, pos, foldFunc) {\n+                        if (orig.length == folded.length) return pos;\n+                        for (var min = 0, max = pos + Math.max(0, orig.length - folded.length);;) {\n+                            if (min == max) return min;\n+                            var mid = min + max >> 1;\n+                            var len = foldFunc(orig.slice(0, mid)).length;\n+                            if (len == pos) return mid;\n+                            else if (len > pos) max = mid;\n+                            else min = mid + 1;\n+                        }\n                     }\n-                }));\n-                Object.defineProperty(exports, \"decodeXMLStrict\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return decode_js_2.decodeXML;\n+\n+                    function searchStringForward(doc, query, start, caseFold) {\n+                        // Empty string would match anything and never progress, so we\n+                        // define it to match nothing instead.\n+                        if (!query.length) return null;\n+                        var fold = caseFold ? doFold : noFold;\n+                        var lines = fold(query).split(/\\r|\\n\\r?/);\n+                        search: for (var line = start.line, ch = start.ch, last = doc.lastLine() + 1 - lines.length; line <= last; line++, ch = 0) {\n+                            var orig = doc.getLine(line).slice(ch),\n+                                string = fold(orig);\n+                            if (lines.length == 1) {\n+                                var found = string.indexOf(lines[0]);\n+                                if (found == -1) continue search;\n+                                var start = adjustPos(orig, string, found, fold) + ch;\n+                                return {\n+                                    from: Pos(line, adjustPos(orig, string, found, fold) + ch),\n+                                    to: Pos(line, adjustPos(orig, string, found + lines[0].length, fold) + ch)\n+                                };\n+                            } else {\n+                                var cutFrom = string.length - lines[0].length;\n+                                if (string.slice(cutFrom) != lines[0]) continue search;\n+                                for (var i = 1; i < lines.length - 1; i++)\n+                                    if (fold(doc.getLine(line + i)) != lines[i]) continue search;\n+                                var end = doc.getLine(line + lines.length - 1),\n+                                    endString = fold(end),\n+                                    lastLine = lines[lines.length - 1];\n+                                if (endString.slice(0, lastLine.length) != lastLine) continue search;\n+                                return {\n+                                    from: Pos(line, adjustPos(orig, string, cutFrom, fold) + ch),\n+                                    to: Pos(line + lines.length - 1, adjustPos(end, endString, lastLine.length, fold))\n+                                };\n+                            }\n+                        }\n                     }\n-                }));\n+\n+                    function searchStringBackward(doc, query, start, caseFold) {\n+                        if (!query.length) return null;\n+                        var fold = caseFold ? doFold : noFold;\n+                        var lines = fold(query).split(/\\r|\\n\\r?/);\n+                        search: for (var line = start.line, ch = start.ch, first = doc.firstLine() - 1 + lines.length; line >= first; line--, ch = -1) {\n+                            var orig = doc.getLine(line);\n+                            if (ch > -1) orig = orig.slice(0, ch);\n+                            var string = fold(orig);\n+                            if (lines.length == 1) {\n+                                var found = string.lastIndexOf(lines[0]);\n+                                if (found == -1) continue search;\n+                                return {\n+                                    from: Pos(line, adjustPos(orig, string, found, fold)),\n+                                    to: Pos(line, adjustPos(orig, string, found + lines[0].length, fold))\n+                                };\n+                            } else {\n+                                var lastLine = lines[lines.length - 1];\n+                                if (string.slice(0, lastLine.length) != lastLine) continue search;\n+                                for (var i = 1, start = line - lines.length + 1; i < lines.length - 1; i++)\n+                                    if (fold(doc.getLine(start + i)) != lines[i]) continue search;\n+                                var top = doc.getLine(line + 1 - lines.length),\n+                                    topString = fold(top);\n+                                if (topString.slice(topString.length - lines[0].length) != lines[0]) continue search;\n+                                return {\n+                                    from: Pos(line + 1 - lines.length, adjustPos(top, topString, top.length - lines[0].length, fold)),\n+                                    to: Pos(line, adjustPos(orig, string, lastLine.length, fold))\n+                                };\n+                            }\n+                        }\n+                    }\n+\n+                    function SearchCursor(doc, query, pos, options) {\n+                        this.atOccurrence = false;\n+                        this.afterEmptyMatch = false;\n+                        this.doc = doc;\n+                        pos = pos ? doc.clipPos(pos) : Pos(0, 0);\n+                        this.pos = {\n+                            from: pos,\n+                            to: pos\n+                        };\n+                        var caseFold;\n+                        if (typeof options == \"object\") {\n+                            caseFold = options.caseFold;\n+                        } else {\n+                            // Backwards compat for when caseFold was the 4th argument\n+                            caseFold = options;\n+                            options = null;\n+                        }\n+                        if (typeof query == \"string\") {\n+                            if (caseFold == null) caseFold = false;\n+                            this.matches = function(reverse, pos) {\n+                                return (reverse ? searchStringBackward : searchStringForward)(doc, query, pos, caseFold);\n+                            };\n+                        } else {\n+                            query = ensureFlags(query, \"gm\");\n+                            if (!options || options.multiline !== false) this.matches = function(reverse, pos) {\n+                                return (reverse ? searchRegexpBackwardMultiline : searchRegexpForwardMultiline)(doc, query, pos);\n+                            };\n+                            else this.matches = function(reverse, pos) {\n+                                return (reverse ? searchRegexpBackward : searchRegexpForward)(doc, query, pos);\n+                            };\n+                        }\n+                    }\n+                    SearchCursor.prototype = {\n+                        findNext: function() {\n+                            return this.find(false);\n+                        },\n+                        findPrevious: function() {\n+                            return this.find(true);\n+                        },\n+                        find: function(reverse) {\n+                            var head = this.doc.clipPos(reverse ? this.pos.from : this.pos.to);\n+                            if (this.afterEmptyMatch && this.atOccurrence) {\n+                                // do not return the same 0 width match twice\n+                                head = Pos(head.line, head.ch);\n+                                if (reverse) {\n+                                    head.ch--;\n+                                    if (head.ch < 0) {\n+                                        head.line--;\n+                                        head.ch = (this.doc.getLine(head.line) || \"\").length;\n+                                    }\n+                                } else {\n+                                    head.ch++;\n+                                    if (head.ch > (this.doc.getLine(head.line) || \"\").length) {\n+                                        head.ch = 0;\n+                                        head.line++;\n+                                    }\n+                                }\n+                                if (CodeMirror.cmpPos(head, this.doc.clipPos(head)) != 0) {\n+                                    return this.atOccurrence = false;\n+                                }\n+                            }\n+                            var result = this.matches(reverse, head);\n+                            this.afterEmptyMatch = result && CodeMirror.cmpPos(result.from, result.to) == 0;\n+                            if (result) {\n+                                this.pos = result;\n+                                this.atOccurrence = true;\n+                                return this.pos.match || true;\n+                            } else {\n+                                var end = Pos(reverse ? this.doc.firstLine() : this.doc.lastLine() + 1, 0);\n+                                this.pos = {\n+                                    from: end,\n+                                    to: end\n+                                };\n+                                return this.atOccurrence = false;\n+                            }\n+                        },\n+                        from: function() {\n+                            if (this.atOccurrence) return this.pos.from;\n+                        },\n+                        to: function() {\n+                            if (this.atOccurrence) return this.pos.to;\n+                        },\n+                        replace: function(newText, origin) {\n+                            if (!this.atOccurrence) return;\n+                            var lines = CodeMirror.splitLines(newText);\n+                            this.doc.replaceRange(lines, this.pos.from, this.pos.to, origin);\n+                            this.pos.to = Pos(this.pos.from.line + lines.length - 1, lines[lines.length - 1].length + (lines.length == 1 ? this.pos.from.ch : 0));\n+                        }\n+                    };\n+                    CodeMirror.defineExtension(\"getSearchCursor\", function(query, pos, caseFold) {\n+                        return new SearchCursor(this.doc, query, pos, caseFold);\n+                    });\n+                    CodeMirror.defineDocExtension(\"getSearchCursor\", function(query, pos, caseFold) {\n+                        return new SearchCursor(this, query, pos, caseFold);\n+                    });\n+                    CodeMirror.defineExtension(\"selectMatches\", function(query, caseFold) {\n+                        var ranges = [];\n+                        var cur = this.getSearchCursor(query, this.getCursor(\"from\"), caseFold);\n+                        while (cur.findNext()) {\n+                            if (CodeMirror.cmpPos(cur.to(), this.getCursor(\"to\")) > 0) break;\n+                            ranges.push({\n+                                anchor: cur.from(),\n+                                head: cur.to()\n+                            });\n+                        }\n+                        if (ranges.length) this.setSelections(ranges, 0);\n+                    });\n+                });\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/framer-motion/dist/cjs/index.js\":\n-            /*!*************************************************************!*\\\n-              !*** ../../../node_modules/framer-motion/dist/cjs/index.js ***!\n-              \\*************************************************************/\n+        \"../../../node_modules/codemirror/keymap/sublime.js\":\n+            /*!**********************************************************!*\\\n+              !*** ../../../node_modules/codemirror/keymap/sublime.js ***!\n+              \\**********************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                var tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.js\");\n-                var React = __webpack_require__( /*! react */ \"react\");\n-                var heyListen = __webpack_require__( /*! hey-listen */ \"../../../node_modules/hey-listen/dist/hey-listen.es.js\");\n-                var styleValueTypes = __webpack_require__( /*! style-value-types */ \"../../../node_modules/style-value-types/dist/valueTypes.cjs.js\");\n-                var popmotion = __webpack_require__( /*! popmotion */ \"../../../node_modules/popmotion/dist/popmotion.cjs.js\");\n-                var sync = __webpack_require__( /*! framesync */ \"../../../node_modules/framesync/dist/framesync.cjs.js\");\n-                var dom = __webpack_require__( /*! @motionone/dom */ \"../../../node_modules/@motionone/dom/dist/index.es.js\");\n+                // CodeMirror, copyright (c) by Marijn Haverbeke and others\n+                // Distributed under an MIT license: https://codemirror.net/LICENSE\n \n-                function _interopDefaultLegacy(e) {\n-                    return e && typeof e === 'object' && 'default' in e ? e : {\n-                        'default': e\n-                    };\n-                }\n+                // A rough approximation of Sublime Text's keybindings\n+                // Depends on addon/search/searchcursor.js and optionally addon/dialog/dialogs.js\n \n-                function _interopNamespace(e) {\n-                    if (e && e.__esModule) return e;\n-                    var n = Object.create(null);\n-                    if (e) {\n-                        Object.keys(e).forEach(function(k) {\n-                            if (k !== 'default') {\n-                                var d = Object.getOwnPropertyDescriptor(e, k);\n-                                Object.defineProperty(n, k, d.get ? d : {\n-                                    enumerable: true,\n-                                    get: function() {\n-                                        return e[k];\n+                (function(mod) {\n+                    if (true)\n+                        // CommonJS\n+                        mod(__webpack_require__( /*! ../lib/codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"), __webpack_require__( /*! ../addon/search/searchcursor */ \"../../../node_modules/codemirror/addon/search/searchcursor.js\"), __webpack_require__( /*! ../addon/edit/matchbrackets */ \"../../../node_modules/codemirror/addon/edit/matchbrackets.js\"));\n+                    else {}\n+                })(function(CodeMirror) {\n+                    \"use strict\";\n+\n+                    var cmds = CodeMirror.commands;\n+                    var Pos = CodeMirror.Pos;\n+\n+                    // This is not exactly Sublime's algorithm. I couldn't make heads or tails of that.\n+                    function findPosSubword(doc, start, dir) {\n+                        if (dir < 0 && start.ch == 0) return doc.clipPos(Pos(start.line - 1));\n+                        var line = doc.getLine(start.line);\n+                        if (dir > 0 && start.ch >= line.length) return doc.clipPos(Pos(start.line + 1, 0));\n+                        var state = \"start\",\n+                            type,\n+                            startPos = start.ch;\n+                        for (var pos = startPos, e = dir < 0 ? 0 : line.length, i = 0; pos != e; pos += dir, i++) {\n+                            var next = line.charAt(dir < 0 ? pos - 1 : pos);\n+                            var cat = next != \"_\" && CodeMirror.isWordChar(next) ? \"w\" : \"o\";\n+                            if (cat == \"w\" && next.toUpperCase() == next) cat = \"W\";\n+                            if (state == \"start\") {\n+                                if (cat != \"o\") {\n+                                    state = \"in\";\n+                                    type = cat;\n+                                } else startPos = pos + dir;\n+                            } else if (state == \"in\") {\n+                                if (type != cat) {\n+                                    if (type == \"w\" && cat == \"W\" && dir < 0) pos--;\n+                                    if (type == \"W\" && cat == \"w\" && dir > 0) {\n+                                        // From uppercase to lowercase\n+                                        if (pos == startPos + 1) {\n+                                            type = \"w\";\n+                                            continue;\n+                                        } else pos--;\n                                     }\n+                                    break;\n+                                }\n+                            }\n+                        }\n+                        return Pos(start.line, pos);\n+                    }\n+\n+                    function moveSubword(cm, dir) {\n+                        cm.extendSelectionsBy(function(range) {\n+                            if (cm.display.shift || cm.doc.extend || range.empty()) return findPosSubword(cm.doc, range.head, dir);\n+                            else return dir < 0 ? range.from() : range.to();\n+                        });\n+                    }\n+                    cmds.goSubwordLeft = function(cm) {\n+                        moveSubword(cm, -1);\n+                    };\n+                    cmds.goSubwordRight = function(cm) {\n+                        moveSubword(cm, 1);\n+                    };\n+                    cmds.scrollLineUp = function(cm) {\n+                        var info = cm.getScrollInfo();\n+                        if (!cm.somethingSelected()) {\n+                            var visibleBottomLine = cm.lineAtHeight(info.top + info.clientHeight, \"local\");\n+                            if (cm.getCursor().line >= visibleBottomLine) cm.execCommand(\"goLineUp\");\n+                        }\n+                        cm.scrollTo(null, info.top - cm.defaultTextHeight());\n+                    };\n+                    cmds.scrollLineDown = function(cm) {\n+                        var info = cm.getScrollInfo();\n+                        if (!cm.somethingSelected()) {\n+                            var visibleTopLine = cm.lineAtHeight(info.top, \"local\") + 1;\n+                            if (cm.getCursor().line <= visibleTopLine) cm.execCommand(\"goLineDown\");\n+                        }\n+                        cm.scrollTo(null, info.top + cm.defaultTextHeight());\n+                    };\n+                    cmds.splitSelectionByLine = function(cm) {\n+                        var ranges = cm.listSelections(),\n+                            lineRanges = [];\n+                        for (var i = 0; i < ranges.length; i++) {\n+                            var from = ranges[i].from(),\n+                                to = ranges[i].to();\n+                            for (var line = from.line; line <= to.line; ++line)\n+                                if (!(to.line > from.line && line == to.line && to.ch == 0)) lineRanges.push({\n+                                    anchor: line == from.line ? from : Pos(line, 0),\n+                                    head: line == to.line ? to : Pos(line)\n+                                });\n+                        }\n+                        cm.setSelections(lineRanges, 0);\n+                    };\n+                    cmds.singleSelectionTop = function(cm) {\n+                        var range = cm.listSelections()[0];\n+                        cm.setSelection(range.anchor, range.head, {\n+                            scroll: false\n+                        });\n+                    };\n+                    cmds.selectLine = function(cm) {\n+                        var ranges = cm.listSelections(),\n+                            extended = [];\n+                        for (var i = 0; i < ranges.length; i++) {\n+                            var range = ranges[i];\n+                            extended.push({\n+                                anchor: Pos(range.from().line, 0),\n+                                head: Pos(range.to().line + 1, 0)\n+                            });\n+                        }\n+                        cm.setSelections(extended);\n+                    };\n+\n+                    function insertLine(cm, above) {\n+                        if (cm.isReadOnly()) return CodeMirror.Pass;\n+                        cm.operation(function() {\n+                            var len = cm.listSelections().length,\n+                                newSelection = [],\n+                                last = -1;\n+                            for (var i = 0; i < len; i++) {\n+                                var head = cm.listSelections()[i].head;\n+                                if (head.line <= last) continue;\n+                                var at = Pos(head.line + (above ? 0 : 1), 0);\n+                                cm.replaceRange(\"\\n\", at, null, \"+insertLine\");\n+                                cm.indentLine(at.line, null, true);\n+                                newSelection.push({\n+                                    head: at,\n+                                    anchor: at\n                                 });\n+                                last = head.line + 1;\n                             }\n+                            cm.setSelections(newSelection);\n                         });\n+                        cm.execCommand(\"indentAuto\");\n                     }\n-                    n[\"default\"] = e;\n-                    return Object.freeze(n);\n-                }\n-                var React__namespace = /*#__PURE__*/ _interopNamespace(React);\n-                var React__default = /*#__PURE__*/ _interopDefaultLegacy(React);\n-                var sync__default = /*#__PURE__*/ _interopDefaultLegacy(sync);\n+                    cmds.insertLineAfter = function(cm) {\n+                        return insertLine(cm, false);\n+                    };\n+                    cmds.insertLineBefore = function(cm) {\n+                        return insertLine(cm, true);\n+                    };\n \n-                /**\n-                 * Browser-safe usage of process\n-                 */\n-                var defaultEnvironment = \"production\";\n-                var env = typeof process === \"undefined\" || process.env === undefined ? defaultEnvironment : \"development\" || 0;\n-                var createDefinition = function(propNames) {\n-                    return {\n-                        isEnabled: function(props) {\n-                            return propNames.some(function(name) {\n-                                return !!props[name];\n-                            });\n+                    function wordAt(cm, pos) {\n+                        var start = pos.ch,\n+                            end = start,\n+                            line = cm.getLine(pos.line);\n+                        while (start && CodeMirror.isWordChar(line.charAt(start - 1))) --start;\n+                        while (end < line.length && CodeMirror.isWordChar(line.charAt(end))) ++end;\n+                        return {\n+                            from: Pos(pos.line, start),\n+                            to: Pos(pos.line, end),\n+                            word: line.slice(start, end)\n+                        };\n+                    }\n+                    cmds.selectNextOccurrence = function(cm) {\n+                        var from = cm.getCursor(\"from\"),\n+                            to = cm.getCursor(\"to\");\n+                        var fullWord = cm.state.sublimeFindFullWord == cm.doc.sel;\n+                        if (CodeMirror.cmpPos(from, to) == 0) {\n+                            var word = wordAt(cm, from);\n+                            if (!word.word) return;\n+                            cm.setSelection(word.from, word.to);\n+                            fullWord = true;\n+                        } else {\n+                            var text = cm.getRange(from, to);\n+                            var query = fullWord ? new RegExp(\"\\\\b\" + text + \"\\\\b\") : text;\n+                            var cur = cm.getSearchCursor(query, to);\n+                            var found = cur.findNext();\n+                            if (!found) {\n+                                cur = cm.getSearchCursor(query, Pos(cm.firstLine(), 0));\n+                                found = cur.findNext();\n+                            }\n+                            if (!found || isSelectedRange(cm.listSelections(), cur.from(), cur.to())) return;\n+                            cm.addSelection(cur.from(), cur.to());\n+                        }\n+                        if (fullWord) cm.state.sublimeFindFullWord = cm.doc.sel;\n+                    };\n+                    cmds.skipAndSelectNextOccurrence = function(cm) {\n+                        var prevAnchor = cm.getCursor(\"anchor\"),\n+                            prevHead = cm.getCursor(\"head\");\n+                        cmds.selectNextOccurrence(cm);\n+                        if (CodeMirror.cmpPos(prevAnchor, prevHead) != 0) {\n+                            cm.doc.setSelections(cm.doc.listSelections().filter(function(sel) {\n+                                return sel.anchor != prevAnchor || sel.head != prevHead;\n+                            }));\n                         }\n                     };\n-                };\n-                var featureDefinitions = {\n-                    measureLayout: createDefinition([\"layout\", \"layoutId\", \"drag\"]),\n-                    animation: createDefinition([\"animate\", \"exit\", \"variants\", \"whileHover\", \"whileTap\", \"whileFocus\", \"whileDrag\", \"whileInView\"]),\n-                    exit: createDefinition([\"exit\"]),\n-                    drag: createDefinition([\"drag\", \"dragControls\"]),\n-                    focus: createDefinition([\"whileFocus\"]),\n-                    hover: createDefinition([\"whileHover\", \"onHoverStart\", \"onHoverEnd\"]),\n-                    tap: createDefinition([\"whileTap\", \"onTap\", \"onTapStart\", \"onTapCancel\"]),\n-                    pan: createDefinition([\"onPan\", \"onPanStart\", \"onPanSessionStart\", \"onPanEnd\"]),\n-                    inView: createDefinition([\"whileInView\", \"onViewportEnter\", \"onViewportLeave\"])\n-                };\n \n-                function loadFeatures(features) {\n-                    for (var key in features) {\n-                        if (features[key] === null) continue;\n-                        if (key === \"projectionNodeConstructor\") {\n-                            featureDefinitions.projectionNodeConstructor = features[key];\n-                        } else {\n-                            featureDefinitions[key].Component = features[key];\n+                    function addCursorToSelection(cm, dir) {\n+                        var ranges = cm.listSelections(),\n+                            newRanges = [];\n+                        for (var i = 0; i < ranges.length; i++) {\n+                            var range = ranges[i];\n+                            var newAnchor = cm.findPosV(range.anchor, dir, \"line\", range.anchor.goalColumn);\n+                            var newHead = cm.findPosV(range.head, dir, \"line\", range.head.goalColumn);\n+                            newAnchor.goalColumn = range.anchor.goalColumn != null ? range.anchor.goalColumn : cm.cursorCoords(range.anchor, \"div\").left;\n+                            newHead.goalColumn = range.head.goalColumn != null ? range.head.goalColumn : cm.cursorCoords(range.head, \"div\").left;\n+                            var newRange = {\n+                                anchor: newAnchor,\n+                                head: newHead\n+                            };\n+                            newRanges.push(range);\n+                            newRanges.push(newRange);\n                         }\n+                        cm.setSelections(newRanges);\n                     }\n-                }\n-                var LazyContext = React.createContext({\n-                    strict: false\n-                });\n-                var featureNames = Object.keys(featureDefinitions);\n-                var numFeatures = featureNames.length;\n-                /**\n-                 * Load features via renderless components based on the provided MotionProps.\n-                 */\n-                function useFeatures(props, visualElement, preloadedFeatures) {\n-                    var features = [];\n-                    var lazyContext = React.useContext(LazyContext);\n-                    if (!visualElement) return null;\n-                    /**\n-                     * If we're in development mode, check to make sure we're not rendering a motion component\n-                     * as a child of LazyMotion, as this will break the file-size benefits of using it.\n-                     */\n-                    if (env !== \"production\" && preloadedFeatures && lazyContext.strict) {\n-                        heyListen.invariant(false, \"You have rendered a `motion` component within a `LazyMotion` component. This will break tree shaking. Import and render a `m` component instead.\");\n+                    cmds.addCursorToPrevLine = function(cm) {\n+                        addCursorToSelection(cm, -1);\n+                    };\n+                    cmds.addCursorToNextLine = function(cm) {\n+                        addCursorToSelection(cm, 1);\n+                    };\n+\n+                    function isSelectedRange(ranges, from, to) {\n+                        for (var i = 0; i < ranges.length; i++)\n+                            if (CodeMirror.cmpPos(ranges[i].from(), from) == 0 && CodeMirror.cmpPos(ranges[i].to(), to) == 0) return true;\n+                        return false;\n                     }\n-                    for (var i = 0; i < numFeatures; i++) {\n-                        var name_1 = featureNames[i];\n-                        var _a = featureDefinitions[name_1],\n-                            isEnabled = _a.isEnabled,\n-                            Component = _a.Component;\n-                        /**\n-                         * It might be possible in the future to use this moment to\n-                         * dynamically request functionality. In initial tests this\n-                         * was producing a lot of duplication amongst bundles.\n-                         */\n-                        if (isEnabled(props) && Component) {\n-                            features.push(React__namespace.createElement(Component, tslib.__assign({\n-                                key: name_1\n-                            }, props, {\n-                                visualElement: visualElement\n-                            })));\n+                    var mirror = \"(){}[]\";\n+\n+                    function selectBetweenBrackets(cm) {\n+                        var ranges = cm.listSelections(),\n+                            newRanges = [];\n+                        for (var i = 0; i < ranges.length; i++) {\n+                            var range = ranges[i],\n+                                pos = range.head,\n+                                opening = cm.scanForBracket(pos, -1);\n+                            if (!opening) return false;\n+                            for (;;) {\n+                                var closing = cm.scanForBracket(pos, 1);\n+                                if (!closing) return false;\n+                                if (closing.ch == mirror.charAt(mirror.indexOf(opening.ch) + 1)) {\n+                                    var startPos = Pos(opening.pos.line, opening.pos.ch + 1);\n+                                    if (CodeMirror.cmpPos(startPos, range.from()) == 0 && CodeMirror.cmpPos(closing.pos, range.to()) == 0) {\n+                                        opening = cm.scanForBracket(opening.pos, -1);\n+                                        if (!opening) return false;\n+                                    } else {\n+                                        newRanges.push({\n+                                            anchor: startPos,\n+                                            head: closing.pos\n+                                        });\n+                                        break;\n+                                    }\n+                                }\n+                                pos = Pos(closing.pos.line, closing.pos.ch + 1);\n+                            }\n                         }\n+                        cm.setSelections(newRanges);\n+                        return true;\n                     }\n-                    return features;\n-                }\n+                    cmds.selectScope = function(cm) {\n+                        selectBetweenBrackets(cm) || cm.execCommand(\"selectAll\");\n+                    };\n+                    cmds.selectBetweenBrackets = function(cm) {\n+                        if (!selectBetweenBrackets(cm)) return CodeMirror.Pass;\n+                    };\n \n-                /**\n-                 * @public\n-                 */\n-                var MotionConfigContext = React.createContext({\n-                    transformPagePoint: function(p) {\n-                        return p;\n-                    },\n-                    isStatic: false,\n-                    reducedMotion: \"never\"\n+                    function puncType(type) {\n+                        return !type ? null : /\\bpunctuation\\b/.test(type) ? type : undefined;\n+                    }\n+                    cmds.goToBracket = function(cm) {\n+                        cm.extendSelectionsBy(function(range) {\n+                            var next = cm.scanForBracket(range.head, 1, puncType(cm.getTokenTypeAt(range.head)));\n+                            if (next && CodeMirror.cmpPos(next.pos, range.head) != 0) return next.pos;\n+                            var prev = cm.scanForBracket(range.head, -1, puncType(cm.getTokenTypeAt(Pos(range.head.line, range.head.ch + 1))));\n+                            return prev && Pos(prev.pos.line, prev.pos.ch + 1) || range.head;\n+                        });\n+                    };\n+                    cmds.swapLineUp = function(cm) {\n+                        if (cm.isReadOnly()) return CodeMirror.Pass;\n+                        var ranges = cm.listSelections(),\n+                            linesToMove = [],\n+                            at = cm.firstLine() - 1,\n+                            newSels = [];\n+                        for (var i = 0; i < ranges.length; i++) {\n+                            var range = ranges[i],\n+                                from = range.from().line - 1,\n+                                to = range.to().line;\n+                            newSels.push({\n+                                anchor: Pos(range.anchor.line - 1, range.anchor.ch),\n+                                head: Pos(range.head.line - 1, range.head.ch)\n+                            });\n+                            if (range.to().ch == 0 && !range.empty()) --to;\n+                            if (from > at) linesToMove.push(from, to);\n+                            else if (linesToMove.length) linesToMove[linesToMove.length - 1] = to;\n+                            at = to;\n+                        }\n+                        cm.operation(function() {\n+                            for (var i = 0; i < linesToMove.length; i += 2) {\n+                                var from = linesToMove[i],\n+                                    to = linesToMove[i + 1];\n+                                var line = cm.getLine(from);\n+                                cm.replaceRange(\"\", Pos(from, 0), Pos(from + 1, 0), \"+swapLine\");\n+                                if (to > cm.lastLine()) cm.replaceRange(\"\\n\" + line, Pos(cm.lastLine()), null, \"+swapLine\");\n+                                else cm.replaceRange(line + \"\\n\", Pos(to, 0), null, \"+swapLine\");\n+                            }\n+                            cm.setSelections(newSels);\n+                            cm.scrollIntoView();\n+                        });\n+                    };\n+                    cmds.swapLineDown = function(cm) {\n+                        if (cm.isReadOnly()) return CodeMirror.Pass;\n+                        var ranges = cm.listSelections(),\n+                            linesToMove = [],\n+                            at = cm.lastLine() + 1;\n+                        for (var i = ranges.length - 1; i >= 0; i--) {\n+                            var range = ranges[i],\n+                                from = range.to().line + 1,\n+                                to = range.from().line;\n+                            if (range.to().ch == 0 && !range.empty()) from--;\n+                            if (from < at) linesToMove.push(from, to);\n+                            else if (linesToMove.length) linesToMove[linesToMove.length - 1] = to;\n+                            at = to;\n+                        }\n+                        cm.operation(function() {\n+                            for (var i = linesToMove.length - 2; i >= 0; i -= 2) {\n+                                var from = linesToMove[i],\n+                                    to = linesToMove[i + 1];\n+                                var line = cm.getLine(from);\n+                                if (from == cm.lastLine()) cm.replaceRange(\"\", Pos(from - 1), Pos(from), \"+swapLine\");\n+                                else cm.replaceRange(\"\", Pos(from, 0), Pos(from + 1, 0), \"+swapLine\");\n+                                cm.replaceRange(line + \"\\n\", Pos(to, 0), null, \"+swapLine\");\n+                            }\n+                            cm.scrollIntoView();\n+                        });\n+                    };\n+                    cmds.toggleCommentIndented = function(cm) {\n+                        cm.toggleComment({\n+                            indent: true\n+                        });\n+                    };\n+                    cmds.joinLines = function(cm) {\n+                        var ranges = cm.listSelections(),\n+                            joined = [];\n+                        for (var i = 0; i < ranges.length; i++) {\n+                            var range = ranges[i],\n+                                from = range.from();\n+                            var start = from.line,\n+                                end = range.to().line;\n+                            while (i < ranges.length - 1 && ranges[i + 1].from().line == end) end = ranges[++i].to().line;\n+                            joined.push({\n+                                start: start,\n+                                end: end,\n+                                anchor: !range.empty() && from\n+                            });\n+                        }\n+                        cm.operation(function() {\n+                            var offset = 0,\n+                                ranges = [];\n+                            for (var i = 0; i < joined.length; i++) {\n+                                var obj = joined[i];\n+                                var anchor = obj.anchor && Pos(obj.anchor.line - offset, obj.anchor.ch),\n+                                    head;\n+                                for (var line = obj.start; line <= obj.end; line++) {\n+                                    var actual = line - offset;\n+                                    if (line == obj.end) head = Pos(actual, cm.getLine(actual).length + 1);\n+                                    if (actual < cm.lastLine()) {\n+                                        cm.replaceRange(\" \", Pos(actual), Pos(actual + 1, /^\\s*/.exec(cm.getLine(actual + 1))[0].length));\n+                                        ++offset;\n+                                    }\n+                                }\n+                                ranges.push({\n+                                    anchor: anchor || head,\n+                                    head: head\n+                                });\n+                            }\n+                            cm.setSelections(ranges, 0);\n+                        });\n+                    };\n+                    cmds.duplicateLine = function(cm) {\n+                        cm.operation(function() {\n+                            var rangeCount = cm.listSelections().length;\n+                            for (var i = 0; i < rangeCount; i++) {\n+                                var range = cm.listSelections()[i];\n+                                if (range.empty()) cm.replaceRange(cm.getLine(range.head.line) + \"\\n\", Pos(range.head.line, 0));\n+                                else cm.replaceRange(cm.getRange(range.from(), range.to()), range.from());\n+                            }\n+                            cm.scrollIntoView();\n+                        });\n+                    };\n+\n+                    function sortLines(cm, caseSensitive, direction) {\n+                        if (cm.isReadOnly()) return CodeMirror.Pass;\n+                        var ranges = cm.listSelections(),\n+                            toSort = [],\n+                            selected;\n+                        for (var i = 0; i < ranges.length; i++) {\n+                            var range = ranges[i];\n+                            if (range.empty()) continue;\n+                            var from = range.from().line,\n+                                to = range.to().line;\n+                            while (i < ranges.length - 1 && ranges[i + 1].from().line == to) to = ranges[++i].to().line;\n+                            if (!ranges[i].to().ch) to--;\n+                            toSort.push(from, to);\n+                        }\n+                        if (toSort.length) selected = true;\n+                        else toSort.push(cm.firstLine(), cm.lastLine());\n+                        cm.operation(function() {\n+                            var ranges = [];\n+                            for (var i = 0; i < toSort.length; i += 2) {\n+                                var from = toSort[i],\n+                                    to = toSort[i + 1];\n+                                var start = Pos(from, 0),\n+                                    end = Pos(to);\n+                                var lines = cm.getRange(start, end, false);\n+                                if (caseSensitive) lines.sort(function(a, b) {\n+                                    return a < b ? -direction : a == b ? 0 : direction;\n+                                });\n+                                else lines.sort(function(a, b) {\n+                                    var au = a.toUpperCase(),\n+                                        bu = b.toUpperCase();\n+                                    if (au != bu) {\n+                                        a = au;\n+                                        b = bu;\n+                                    }\n+                                    return a < b ? -direction : a == b ? 0 : direction;\n+                                });\n+                                cm.replaceRange(lines, start, end);\n+                                if (selected) ranges.push({\n+                                    anchor: start,\n+                                    head: Pos(to + 1, 0)\n+                                });\n+                            }\n+                            if (selected) cm.setSelections(ranges, 0);\n+                        });\n+                    }\n+                    cmds.sortLines = function(cm) {\n+                        sortLines(cm, true, 1);\n+                    };\n+                    cmds.reverseSortLines = function(cm) {\n+                        sortLines(cm, true, -1);\n+                    };\n+                    cmds.sortLinesInsensitive = function(cm) {\n+                        sortLines(cm, false, 1);\n+                    };\n+                    cmds.reverseSortLinesInsensitive = function(cm) {\n+                        sortLines(cm, false, -1);\n+                    };\n+                    cmds.nextBookmark = function(cm) {\n+                        var marks = cm.state.sublimeBookmarks;\n+                        if (marks)\n+                            while (marks.length) {\n+                                var current = marks.shift();\n+                                var found = current.find();\n+                                if (found) {\n+                                    marks.push(current);\n+                                    return cm.setSelection(found.from, found.to);\n+                                }\n+                            }\n+                    };\n+                    cmds.prevBookmark = function(cm) {\n+                        var marks = cm.state.sublimeBookmarks;\n+                        if (marks)\n+                            while (marks.length) {\n+                                marks.unshift(marks.pop());\n+                                var found = marks[marks.length - 1].find();\n+                                if (!found) marks.pop();\n+                                else return cm.setSelection(found.from, found.to);\n+                            }\n+                    };\n+                    cmds.toggleBookmark = function(cm) {\n+                        var ranges = cm.listSelections();\n+                        var marks = cm.state.sublimeBookmarks || (cm.state.sublimeBookmarks = []);\n+                        for (var i = 0; i < ranges.length; i++) {\n+                            var from = ranges[i].from(),\n+                                to = ranges[i].to();\n+                            var found = ranges[i].empty() ? cm.findMarksAt(from) : cm.findMarks(from, to);\n+                            for (var j = 0; j < found.length; j++) {\n+                                if (found[j].sublimeBookmark) {\n+                                    found[j].clear();\n+                                    for (var k = 0; k < marks.length; k++)\n+                                        if (marks[k] == found[j]) marks.splice(k--, 1);\n+                                    break;\n+                                }\n+                            }\n+                            if (j == found.length) marks.push(cm.markText(from, to, {\n+                                sublimeBookmark: true,\n+                                clearWhenEmpty: false\n+                            }));\n+                        }\n+                    };\n+                    cmds.clearBookmarks = function(cm) {\n+                        var marks = cm.state.sublimeBookmarks;\n+                        if (marks)\n+                            for (var i = 0; i < marks.length; i++) marks[i].clear();\n+                        marks.length = 0;\n+                    };\n+                    cmds.selectBookmarks = function(cm) {\n+                        var marks = cm.state.sublimeBookmarks,\n+                            ranges = [];\n+                        if (marks)\n+                            for (var i = 0; i < marks.length; i++) {\n+                                var found = marks[i].find();\n+                                if (!found) marks.splice(i--, 0);\n+                                else ranges.push({\n+                                    anchor: found.from,\n+                                    head: found.to\n+                                });\n+                            }\n+                        if (ranges.length) cm.setSelections(ranges, 0);\n+                    };\n+\n+                    function modifyWordOrSelection(cm, mod) {\n+                        cm.operation(function() {\n+                            var ranges = cm.listSelections(),\n+                                indices = [],\n+                                replacements = [];\n+                            for (var i = 0; i < ranges.length; i++) {\n+                                var range = ranges[i];\n+                                if (range.empty()) {\n+                                    indices.push(i);\n+                                    replacements.push(\"\");\n+                                } else replacements.push(mod(cm.getRange(range.from(), range.to())));\n+                            }\n+                            cm.replaceSelections(replacements, \"around\", \"case\");\n+                            for (var i = indices.length - 1, at; i >= 0; i--) {\n+                                var range = ranges[indices[i]];\n+                                if (at && CodeMirror.cmpPos(range.head, at) > 0) continue;\n+                                var word = wordAt(cm, range.head);\n+                                at = word.from;\n+                                cm.replaceRange(mod(word.word), word.from, word.to);\n+                            }\n+                        });\n+                    }\n+                    cmds.smartBackspace = function(cm) {\n+                        if (cm.somethingSelected()) return CodeMirror.Pass;\n+                        cm.operation(function() {\n+                            var cursors = cm.listSelections();\n+                            var indentUnit = cm.getOption(\"indentUnit\");\n+                            for (var i = cursors.length - 1; i >= 0; i--) {\n+                                var cursor = cursors[i].head;\n+                                var toStartOfLine = cm.getRange({\n+                                    line: cursor.line,\n+                                    ch: 0\n+                                }, cursor);\n+                                var column = CodeMirror.countColumn(toStartOfLine, null, cm.getOption(\"tabSize\"));\n+\n+                                // Delete by one character by default\n+                                var deletePos = cm.findPosH(cursor, -1, \"char\", false);\n+                                if (toStartOfLine && !/\\S/.test(toStartOfLine) && column % indentUnit == 0) {\n+                                    var prevIndent = new Pos(cursor.line, CodeMirror.findColumn(toStartOfLine, column - indentUnit, indentUnit));\n+\n+                                    // Smart delete only if we found a valid prevIndent location\n+                                    if (prevIndent.ch != cursor.ch) deletePos = prevIndent;\n+                                }\n+                                cm.replaceRange(\"\", deletePos, cursor, \"+delete\");\n+                            }\n+                        });\n+                    };\n+                    cmds.delLineRight = function(cm) {\n+                        cm.operation(function() {\n+                            var ranges = cm.listSelections();\n+                            for (var i = ranges.length - 1; i >= 0; i--) cm.replaceRange(\"\", ranges[i].anchor, Pos(ranges[i].to().line), \"+delete\");\n+                            cm.scrollIntoView();\n+                        });\n+                    };\n+                    cmds.upcaseAtCursor = function(cm) {\n+                        modifyWordOrSelection(cm, function(str) {\n+                            return str.toUpperCase();\n+                        });\n+                    };\n+                    cmds.downcaseAtCursor = function(cm) {\n+                        modifyWordOrSelection(cm, function(str) {\n+                            return str.toLowerCase();\n+                        });\n+                    };\n+                    cmds.setSublimeMark = function(cm) {\n+                        if (cm.state.sublimeMark) cm.state.sublimeMark.clear();\n+                        cm.state.sublimeMark = cm.setBookmark(cm.getCursor());\n+                    };\n+                    cmds.selectToSublimeMark = function(cm) {\n+                        var found = cm.state.sublimeMark && cm.state.sublimeMark.find();\n+                        if (found) cm.setSelection(cm.getCursor(), found);\n+                    };\n+                    cmds.deleteToSublimeMark = function(cm) {\n+                        var found = cm.state.sublimeMark && cm.state.sublimeMark.find();\n+                        if (found) {\n+                            var from = cm.getCursor(),\n+                                to = found;\n+                            if (CodeMirror.cmpPos(from, to) > 0) {\n+                                var tmp = to;\n+                                to = from;\n+                                from = tmp;\n+                            }\n+                            cm.state.sublimeKilled = cm.getRange(from, to);\n+                            cm.replaceRange(\"\", from, to);\n+                        }\n+                    };\n+                    cmds.swapWithSublimeMark = function(cm) {\n+                        var found = cm.state.sublimeMark && cm.state.sublimeMark.find();\n+                        if (found) {\n+                            cm.state.sublimeMark.clear();\n+                            cm.state.sublimeMark = cm.setBookmark(cm.getCursor());\n+                            cm.setCursor(found);\n+                        }\n+                    };\n+                    cmds.sublimeYank = function(cm) {\n+                        if (cm.state.sublimeKilled != null) cm.replaceSelection(cm.state.sublimeKilled, null, \"paste\");\n+                    };\n+                    cmds.showInCenter = function(cm) {\n+                        var pos = cm.cursorCoords(null, \"local\");\n+                        cm.scrollTo(null, (pos.top + pos.bottom) / 2 - cm.getScrollInfo().clientHeight / 2);\n+                    };\n+\n+                    function getTarget(cm) {\n+                        var from = cm.getCursor(\"from\"),\n+                            to = cm.getCursor(\"to\");\n+                        if (CodeMirror.cmpPos(from, to) == 0) {\n+                            var word = wordAt(cm, from);\n+                            if (!word.word) return;\n+                            from = word.from;\n+                            to = word.to;\n+                        }\n+                        return {\n+                            from: from,\n+                            to: to,\n+                            query: cm.getRange(from, to),\n+                            word: word\n+                        };\n+                    }\n+\n+                    function findAndGoTo(cm, forward) {\n+                        var target = getTarget(cm);\n+                        if (!target) return;\n+                        var query = target.query;\n+                        var cur = cm.getSearchCursor(query, forward ? target.to : target.from);\n+                        if (forward ? cur.findNext() : cur.findPrevious()) {\n+                            cm.setSelection(cur.from(), cur.to());\n+                        } else {\n+                            cur = cm.getSearchCursor(query, forward ? Pos(cm.firstLine(), 0) : cm.clipPos(Pos(cm.lastLine())));\n+                            if (forward ? cur.findNext() : cur.findPrevious()) cm.setSelection(cur.from(), cur.to());\n+                            else if (target.word) cm.setSelection(target.from, target.to);\n+                        }\n+                    };\n+                    cmds.findUnder = function(cm) {\n+                        findAndGoTo(cm, true);\n+                    };\n+                    cmds.findUnderPrevious = function(cm) {\n+                        findAndGoTo(cm, false);\n+                    };\n+                    cmds.findAllUnder = function(cm) {\n+                        var target = getTarget(cm);\n+                        if (!target) return;\n+                        var cur = cm.getSearchCursor(target.query);\n+                        var matches = [];\n+                        var primaryIndex = -1;\n+                        while (cur.findNext()) {\n+                            matches.push({\n+                                anchor: cur.from(),\n+                                head: cur.to()\n+                            });\n+                            if (cur.from().line <= target.from.line && cur.from().ch <= target.from.ch) primaryIndex++;\n+                        }\n+                        cm.setSelections(matches, primaryIndex);\n+                    };\n+                    var keyMap = CodeMirror.keyMap;\n+                    keyMap.macSublime = {\n+                        \"Cmd-Left\": \"goLineStartSmart\",\n+                        \"Shift-Tab\": \"indentLess\",\n+                        \"Shift-Ctrl-K\": \"deleteLine\",\n+                        \"Alt-Q\": \"wrapLines\",\n+                        \"Ctrl-Left\": \"goSubwordLeft\",\n+                        \"Ctrl-Right\": \"goSubwordRight\",\n+                        \"Ctrl-Alt-Up\": \"scrollLineUp\",\n+                        \"Ctrl-Alt-Down\": \"scrollLineDown\",\n+                        \"Cmd-L\": \"selectLine\",\n+                        \"Shift-Cmd-L\": \"splitSelectionByLine\",\n+                        \"Esc\": \"singleSelectionTop\",\n+                        \"Cmd-Enter\": \"insertLineAfter\",\n+                        \"Shift-Cmd-Enter\": \"insertLineBefore\",\n+                        \"Cmd-D\": \"selectNextOccurrence\",\n+                        \"Shift-Cmd-Space\": \"selectScope\",\n+                        \"Shift-Cmd-M\": \"selectBetweenBrackets\",\n+                        \"Cmd-M\": \"goToBracket\",\n+                        \"Cmd-Ctrl-Up\": \"swapLineUp\",\n+                        \"Cmd-Ctrl-Down\": \"swapLineDown\",\n+                        \"Cmd-/\": \"toggleCommentIndented\",\n+                        \"Cmd-J\": \"joinLines\",\n+                        \"Shift-Cmd-D\": \"duplicateLine\",\n+                        \"F5\": \"sortLines\",\n+                        \"Shift-F5\": \"reverseSortLines\",\n+                        \"Cmd-F5\": \"sortLinesInsensitive\",\n+                        \"Shift-Cmd-F5\": \"reverseSortLinesInsensitive\",\n+                        \"F2\": \"nextBookmark\",\n+                        \"Shift-F2\": \"prevBookmark\",\n+                        \"Cmd-F2\": \"toggleBookmark\",\n+                        \"Shift-Cmd-F2\": \"clearBookmarks\",\n+                        \"Alt-F2\": \"selectBookmarks\",\n+                        \"Backspace\": \"smartBackspace\",\n+                        \"Cmd-K Cmd-D\": \"skipAndSelectNextOccurrence\",\n+                        \"Cmd-K Cmd-K\": \"delLineRight\",\n+                        \"Cmd-K Cmd-U\": \"upcaseAtCursor\",\n+                        \"Cmd-K Cmd-L\": \"downcaseAtCursor\",\n+                        \"Cmd-K Cmd-Space\": \"setSublimeMark\",\n+                        \"Cmd-K Cmd-A\": \"selectToSublimeMark\",\n+                        \"Cmd-K Cmd-W\": \"deleteToSublimeMark\",\n+                        \"Cmd-K Cmd-X\": \"swapWithSublimeMark\",\n+                        \"Cmd-K Cmd-Y\": \"sublimeYank\",\n+                        \"Cmd-K Cmd-C\": \"showInCenter\",\n+                        \"Cmd-K Cmd-G\": \"clearBookmarks\",\n+                        \"Cmd-K Cmd-Backspace\": \"delLineLeft\",\n+                        \"Cmd-K Cmd-1\": \"foldAll\",\n+                        \"Cmd-K Cmd-0\": \"unfoldAll\",\n+                        \"Cmd-K Cmd-J\": \"unfoldAll\",\n+                        \"Ctrl-Shift-Up\": \"addCursorToPrevLine\",\n+                        \"Ctrl-Shift-Down\": \"addCursorToNextLine\",\n+                        \"Cmd-F3\": \"findUnder\",\n+                        \"Shift-Cmd-F3\": \"findUnderPrevious\",\n+                        \"Alt-F3\": \"findAllUnder\",\n+                        \"Shift-Cmd-[\": \"fold\",\n+                        \"Shift-Cmd-]\": \"unfold\",\n+                        \"Cmd-I\": \"findIncremental\",\n+                        \"Shift-Cmd-I\": \"findIncrementalReverse\",\n+                        \"Cmd-H\": \"replace\",\n+                        \"F3\": \"findNext\",\n+                        \"Shift-F3\": \"findPrev\",\n+                        \"fallthrough\": \"macDefault\"\n+                    };\n+                    CodeMirror.normalizeKeyMap(keyMap.macSublime);\n+                    keyMap.pcSublime = {\n+                        \"Shift-Tab\": \"indentLess\",\n+                        \"Shift-Ctrl-K\": \"deleteLine\",\n+                        \"Alt-Q\": \"wrapLines\",\n+                        \"Ctrl-T\": \"transposeChars\",\n+                        \"Alt-Left\": \"goSubwordLeft\",\n+                        \"Alt-Right\": \"goSubwordRight\",\n+                        \"Ctrl-Up\": \"scrollLineUp\",\n+                        \"Ctrl-Down\": \"scrollLineDown\",\n+                        \"Ctrl-L\": \"selectLine\",\n+                        \"Shift-Ctrl-L\": \"splitSelectionByLine\",\n+                        \"Esc\": \"singleSelectionTop\",\n+                        \"Ctrl-Enter\": \"insertLineAfter\",\n+                        \"Shift-Ctrl-Enter\": \"insertLineBefore\",\n+                        \"Ctrl-D\": \"selectNextOccurrence\",\n+                        \"Shift-Ctrl-Space\": \"selectScope\",\n+                        \"Shift-Ctrl-M\": \"selectBetweenBrackets\",\n+                        \"Ctrl-M\": \"goToBracket\",\n+                        \"Shift-Ctrl-Up\": \"swapLineUp\",\n+                        \"Shift-Ctrl-Down\": \"swapLineDown\",\n+                        \"Ctrl-/\": \"toggleCommentIndented\",\n+                        \"Ctrl-J\": \"joinLines\",\n+                        \"Shift-Ctrl-D\": \"duplicateLine\",\n+                        \"F9\": \"sortLines\",\n+                        \"Shift-F9\": \"reverseSortLines\",\n+                        \"Ctrl-F9\": \"sortLinesInsensitive\",\n+                        \"Shift-Ctrl-F9\": \"reverseSortLinesInsensitive\",\n+                        \"F2\": \"nextBookmark\",\n+                        \"Shift-F2\": \"prevBookmark\",\n+                        \"Ctrl-F2\": \"toggleBookmark\",\n+                        \"Shift-Ctrl-F2\": \"clearBookmarks\",\n+                        \"Alt-F2\": \"selectBookmarks\",\n+                        \"Backspace\": \"smartBackspace\",\n+                        \"Ctrl-K Ctrl-D\": \"skipAndSelectNextOccurrence\",\n+                        \"Ctrl-K Ctrl-K\": \"delLineRight\",\n+                        \"Ctrl-K Ctrl-U\": \"upcaseAtCursor\",\n+                        \"Ctrl-K Ctrl-L\": \"downcaseAtCursor\",\n+                        \"Ctrl-K Ctrl-Space\": \"setSublimeMark\",\n+                        \"Ctrl-K Ctrl-A\": \"selectToSublimeMark\",\n+                        \"Ctrl-K Ctrl-W\": \"deleteToSublimeMark\",\n+                        \"Ctrl-K Ctrl-X\": \"swapWithSublimeMark\",\n+                        \"Ctrl-K Ctrl-Y\": \"sublimeYank\",\n+                        \"Ctrl-K Ctrl-C\": \"showInCenter\",\n+                        \"Ctrl-K Ctrl-G\": \"clearBookmarks\",\n+                        \"Ctrl-K Ctrl-Backspace\": \"delLineLeft\",\n+                        \"Ctrl-K Ctrl-1\": \"foldAll\",\n+                        \"Ctrl-K Ctrl-0\": \"unfoldAll\",\n+                        \"Ctrl-K Ctrl-J\": \"unfoldAll\",\n+                        \"Ctrl-Alt-Up\": \"addCursorToPrevLine\",\n+                        \"Ctrl-Alt-Down\": \"addCursorToNextLine\",\n+                        \"Ctrl-F3\": \"findUnder\",\n+                        \"Shift-Ctrl-F3\": \"findUnderPrevious\",\n+                        \"Alt-F3\": \"findAllUnder\",\n+                        \"Shift-Ctrl-[\": \"fold\",\n+                        \"Shift-Ctrl-]\": \"unfold\",\n+                        \"Ctrl-I\": \"findIncremental\",\n+                        \"Shift-Ctrl-I\": \"findIncrementalReverse\",\n+                        \"Ctrl-H\": \"replace\",\n+                        \"F3\": \"findNext\",\n+                        \"Shift-F3\": \"findPrev\",\n+                        \"fallthrough\": \"pcDefault\"\n+                    };\n+                    CodeMirror.normalizeKeyMap(keyMap.pcSublime);\n+                    var mac = keyMap.default == keyMap.macDefault;\n+                    keyMap.sublime = mac ? keyMap.macSublime : keyMap.pcSublime;\n                 });\n-                var MotionContext = React.createContext({});\n \n-                function useVisualElementContext() {\n-                    return React.useContext(MotionContext).visualElement;\n-                }\n+                /***/\n+            }),\n \n-                /**\n-                 * @public\n-                 */\n-                var PresenceContext = React.createContext(null);\n-                var isBrowser = typeof document !== \"undefined\";\n-                var useIsomorphicLayoutEffect = isBrowser ? React.useLayoutEffect : React.useEffect;\n+        /***/\n+        \"../../../node_modules/codemirror/lib/codemirror.js\":\n+            /*!**********************************************************!*\\\n+              !*** ../../../node_modules/codemirror/lib/codemirror.js ***!\n+              \\**********************************************************/\n+            /***/\n+            (function(module) {\n \n-                // Does this device prefer reduced motion? Returns `null` server-side.\n-                var prefersReducedMotion = {\n-                    current: null\n-                };\n-                var hasDetected = false;\n+                \"use strict\";\n \n-                function initPrefersReducedMotion() {\n-                    hasDetected = true;\n-                    if (!isBrowser) return;\n-                    if (window.matchMedia) {\n-                        var motionMediaQuery_1 = window.matchMedia(\"(prefers-reduced-motion)\");\n-                        var setReducedMotionPreferences = function() {\n-                            return prefersReducedMotion.current = motionMediaQuery_1.matches;\n-                        };\n-                        motionMediaQuery_1.addListener(setReducedMotionPreferences);\n-                        setReducedMotionPreferences();\n-                    } else {\n-                        prefersReducedMotion.current = false;\n+\n+                // CodeMirror, copyright (c) by Marijn Haverbeke and others\n+                // Distributed under an MIT license: https://codemirror.net/LICENSE\n+\n+                // This is CodeMirror (https://codemirror.net), a code editor\n+                // implemented in JavaScript on top of the browser's DOM.\n+                //\n+                // You can find some technical background for some of the code below\n+                // at http://marijnhaverbeke.nl/blog/#cm-internals .\n+\n+                (function(global, factory) {\n+                    true ? module.exports = factory() : 0;\n+                })(void 0, function() {\n+                    'use strict';\n+\n+                    // Kludges for bugs and behavior differences that can't be feature\n+                    // detected are enabled based on userAgent etc sniffing.\n+                    var userAgent = navigator.userAgent;\n+                    var platform = navigator.platform;\n+                    var gecko = /gecko\\/\\d/i.test(userAgent);\n+                    var ie_upto10 = /MSIE \\d/.test(userAgent);\n+                    var ie_11up = /Trident\\/(?:[7-9]|\\d{2,})\\..*rv:(\\d+)/.exec(userAgent);\n+                    var edge = /Edge\\/(\\d+)/.exec(userAgent);\n+                    var ie = ie_upto10 || ie_11up || edge;\n+                    var ie_version = ie && (ie_upto10 ? document.documentMode || 6 : +(edge || ie_11up)[1]);\n+                    var webkit = !edge && /WebKit\\//.test(userAgent);\n+                    var qtwebkit = webkit && /Qt\\/\\d+\\.\\d+/.test(userAgent);\n+                    var chrome = !edge && /Chrome\\//.test(userAgent);\n+                    var presto = /Opera\\//.test(userAgent);\n+                    var safari = /Apple Computer/.test(navigator.vendor);\n+                    var mac_geMountainLion = /Mac OS X 1\\d\\D([8-9]|\\d\\d)\\D/.test(userAgent);\n+                    var phantom = /PhantomJS/.test(userAgent);\n+                    var ios = safari && (/Mobile\\/\\w+/.test(userAgent) || navigator.maxTouchPoints > 2);\n+                    var android = /Android/.test(userAgent);\n+                    // This is woefully incomplete. Suggestions for alternative methods welcome.\n+                    var mobile = ios || android || /webOS|BlackBerry|Opera Mini|Opera Mobi|IEMobile/i.test(userAgent);\n+                    var mac = ios || /Mac/.test(platform);\n+                    var chromeOS = /\\bCrOS\\b/.test(userAgent);\n+                    var windows = /win/i.test(platform);\n+                    var presto_version = presto && userAgent.match(/Version\\/(\\d*\\.\\d*)/);\n+                    if (presto_version) {\n+                        presto_version = Number(presto_version[1]);\n+                    }\n+                    if (presto_version && presto_version >= 15) {\n+                        presto = false;\n+                        webkit = true;\n+                    }\n+                    // Some browsers use the wrong event properties to signal cmd/ctrl on OS X\n+                    var flipCtrlCmd = mac && (qtwebkit || presto && (presto_version == null || presto_version < 12.11));\n+                    var captureRightClick = gecko || ie && ie_version >= 9;\n+\n+                    function classTest(cls) {\n+                        return new RegExp(\"(^|\\\\s)\" + cls + \"(?:$|\\\\s)\\\\s*\");\n+                    }\n+                    var rmClass = function(node, cls) {\n+                        var current = node.className;\n+                        var match = classTest(cls).exec(current);\n+                        if (match) {\n+                            var after = current.slice(match.index + match[0].length);\n+                            node.className = current.slice(0, match.index) + (after ? match[1] + after : \"\");\n+                        }\n+                    };\n+\n+                    function removeChildren(e) {\n+                        for (var count = e.childNodes.length; count > 0; --count) {\n+                            e.removeChild(e.firstChild);\n+                        }\n+                        return e;\n                     }\n-                }\n-                /**\n-                 * A hook that returns `true` if we should be using reduced motion based on the current device's Reduced Motion setting.\n-                 *\n-                 * This can be used to implement changes to your UI based on Reduced Motion. For instance, replacing motion-sickness inducing\n-                 * `x`/`y` animations with `opacity`, disabling the autoplay of background videos, or turning off parallax motion.\n-                 *\n-                 * It will actively respond to changes and re-render your components with the latest setting.\n-                 *\n-                 * ```jsx\n-                 * export function Sidebar({ isOpen }) {\n-                 *   const shouldReduceMotion = useReducedMotion()\n-                 *   const closedX = shouldReduceMotion ? 0 : \"-100%\"\n-                 *\n-                 *   return (\n-                 *     <motion.div animate={{\n-                 *       opacity: isOpen ? 1 : 0,\n-                 *       x: isOpen ? 0 : closedX\n-                 *     }} />\n-                 *   )\n-                 * }\n-                 * ```\n-                 *\n-                 * @return boolean\n-                 *\n-                 * @public\n-                 */\n-                function useReducedMotion() {\n-                    /**\n-                     * Lazy initialisation of prefersReducedMotion\n-                     */\n-                    !hasDetected && initPrefersReducedMotion();\n-                    var _a = tslib.__read(React.useState(prefersReducedMotion.current), 1),\n-                        shouldReduceMotion = _a[0];\n-                    /**\n-                     * TODO See if people miss automatically updating shouldReduceMotion setting\n-                     */\n-                    return shouldReduceMotion;\n-                }\n \n-                function useReducedMotionConfig() {\n-                    var reducedMotionPreference = useReducedMotion();\n-                    var reducedMotion = React.useContext(MotionConfigContext).reducedMotion;\n-                    if (reducedMotion === \"never\") {\n-                        return false;\n-                    } else if (reducedMotion === \"always\") {\n-                        return true;\n-                    } else {\n-                        return reducedMotionPreference;\n+                    function removeChildrenAndAdd(parent, e) {\n+                        return removeChildren(parent).appendChild(e);\n                     }\n-                }\n \n-                function useVisualElement(Component, visualState, props, createVisualElement) {\n-                    var lazyContext = React.useContext(LazyContext);\n-                    var parent = useVisualElementContext();\n-                    var presenceContext = React.useContext(PresenceContext);\n-                    var shouldReduceMotion = useReducedMotionConfig();\n-                    var visualElementRef = React.useRef(undefined);\n-                    /**\n-                     * If we haven't preloaded a renderer, check to see if we have one lazy-loaded\n-                     */\n-                    if (!createVisualElement) createVisualElement = lazyContext.renderer;\n-                    if (!visualElementRef.current && createVisualElement) {\n-                        visualElementRef.current = createVisualElement(Component, {\n-                            visualState: visualState,\n-                            parent: parent,\n-                            props: props,\n-                            presenceId: presenceContext === null || presenceContext === void 0 ? void 0 : presenceContext.id,\n-                            blockInitialAnimation: (presenceContext === null || presenceContext === void 0 ? void 0 : presenceContext.initial) === false,\n-                            shouldReduceMotion: shouldReduceMotion\n-                        });\n+                    function elt(tag, content, className, style) {\n+                        var e = document.createElement(tag);\n+                        if (className) {\n+                            e.className = className;\n+                        }\n+                        if (style) {\n+                            e.style.cssText = style;\n+                        }\n+                        if (typeof content == \"string\") {\n+                            e.appendChild(document.createTextNode(content));\n+                        } else if (content) {\n+                            for (var i = 0; i < content.length; ++i) {\n+                                e.appendChild(content[i]);\n+                            }\n+                        }\n+                        return e;\n                     }\n-                    var visualElement = visualElementRef.current;\n-                    useIsomorphicLayoutEffect(function() {\n-                        visualElement === null || visualElement === void 0 ? void 0 : visualElement.syncRender();\n-                    });\n-                    React.useEffect(function() {\n-                        var _a;\n-                        (_a = visualElement === null || visualElement === void 0 ? void 0 : visualElement.animationState) === null || _a === void 0 ? void 0 : _a.animateChanges();\n-                    });\n-                    useIsomorphicLayoutEffect(function() {\n-                        return function() {\n-                            return visualElement === null || visualElement === void 0 ? void 0 : visualElement.notifyUnmount();\n+                    // wrapper for elt, which removes the elt from the accessibility tree\n+                    function eltP(tag, content, className, style) {\n+                        var e = elt(tag, content, className, style);\n+                        e.setAttribute(\"role\", \"presentation\");\n+                        return e;\n+                    }\n+                    var range;\n+                    if (document.createRange) {\n+                        range = function(node, start, end, endNode) {\n+                            var r = document.createRange();\n+                            r.setEnd(endNode || node, end);\n+                            r.setStart(node, start);\n+                            return r;\n                         };\n-                    }, []);\n-                    return visualElement;\n-                }\n-\n-                function isRefObject(ref) {\n-                    return typeof ref === \"object\" && Object.prototype.hasOwnProperty.call(ref, \"current\");\n-                }\n+                    } else {\n+                        range = function(node, start, end) {\n+                            var r = document.body.createTextRange();\n+                            try {\n+                                r.moveToElementText(node.parentNode);\n+                            } catch (e) {\n+                                return r;\n+                            }\n+                            r.collapse(true);\n+                            r.moveEnd(\"character\", end);\n+                            r.moveStart(\"character\", start);\n+                            return r;\n+                        };\n+                    }\n \n-                /**\n-                 * Creates a ref function that, when called, hydrates the provided\n-                 * external ref and VisualElement.\n-                 */\n-                function useMotionRef(visualState, visualElement, externalRef) {\n-                    return React.useCallback(function(instance) {\n-                            var _a;\n-                            instance && ((_a = visualState.mount) === null || _a === void 0 ? void 0 : _a.call(visualState, instance));\n-                            if (visualElement) {\n-                                instance ? visualElement.mount(instance) : visualElement.unmount();\n+                    function contains(parent, child) {\n+                        if (child.nodeType == 3)\n+                        // Android browser always returns false when child is a textnode\n+                        {\n+                            child = child.parentNode;\n+                        }\n+                        if (parent.contains) {\n+                            return parent.contains(child);\n+                        }\n+                        do {\n+                            if (child.nodeType == 11) {\n+                                child = child.host;\n                             }\n-                            if (externalRef) {\n-                                if (typeof externalRef === \"function\") {\n-                                    externalRef(instance);\n-                                } else if (isRefObject(externalRef)) {\n-                                    externalRef.current = instance;\n-                                }\n+                            if (child == parent) {\n+                                return true;\n                             }\n-                        },\n-                        /**\n-                         * Only pass a new ref callback to React if we've received a visual element\n-                         * factory. Otherwise we'll be mounting/remounting every time externalRef\n-                         * or other dependencies change.\n-                         */\n-                        [visualElement]);\n-                }\n+                        } while (child = child.parentNode);\n+                    }\n \n-                /**\n-                 * Decides if the supplied variable is an array of variant labels\n-                 */\n-                function isVariantLabels(v) {\n-                    return Array.isArray(v);\n-                }\n-                /**\n-                 * Decides if the supplied variable is variant label\n-                 */\n-                function isVariantLabel(v) {\n-                    return typeof v === \"string\" || isVariantLabels(v);\n-                }\n-                /**\n-                 * Creates an object containing the latest state of every MotionValue on a VisualElement\n-                 */\n-                function getCurrent(visualElement) {\n-                    var current = {};\n-                    visualElement.forEachValue(function(value, key) {\n-                        return current[key] = value.get();\n-                    });\n-                    return current;\n-                }\n-                /**\n-                 * Creates an object containing the latest velocity of every MotionValue on a VisualElement\n-                 */\n-                function getVelocity$1(visualElement) {\n-                    var velocity = {};\n-                    visualElement.forEachValue(function(value, key) {\n-                        return velocity[key] = value.getVelocity();\n-                    });\n-                    return velocity;\n-                }\n+                    function activeElt() {\n+                        // IE and Edge may throw an \"Unspecified Error\" when accessing document.activeElement.\n+                        // IE < 10 will throw when accessed while the page is loading or in an iframe.\n+                        // IE > 9 and Edge will throw when accessed in an iframe if document.body is unavailable.\n+                        var activeElement;\n+                        try {\n+                            activeElement = document.activeElement;\n+                        } catch (e) {\n+                            activeElement = document.body || null;\n+                        }\n+                        while (activeElement && activeElement.shadowRoot && activeElement.shadowRoot.activeElement) {\n+                            activeElement = activeElement.shadowRoot.activeElement;\n+                        }\n+                        return activeElement;\n+                    }\n \n-                function resolveVariantFromProps(props, definition, custom, currentValues, currentVelocity) {\n-                    var _a;\n-                    if (currentValues === void 0) {\n-                        currentValues = {};\n+                    function addClass(node, cls) {\n+                        var current = node.className;\n+                        if (!classTest(cls).test(current)) {\n+                            node.className += (current ? \" \" : \"\") + cls;\n+                        }\n                     }\n-                    if (currentVelocity === void 0) {\n-                        currentVelocity = {};\n+\n+                    function joinClasses(a, b) {\n+                        var as = a.split(\" \");\n+                        for (var i = 0; i < as.length; i++) {\n+                            if (as[i] && !classTest(as[i]).test(b)) {\n+                                b += \" \" + as[i];\n+                            }\n+                        }\n+                        return b;\n                     }\n-                    /**\n-                     * If the variant definition is a function, resolve.\n-                     */\n-                    if (typeof definition === \"function\") {\n-                        definition = definition(custom !== null && custom !== void 0 ? custom : props.custom, currentValues, currentVelocity);\n+                    var selectInput = function(node) {\n+                        node.select();\n+                    };\n+                    if (ios)\n+                    // Mobile Safari apparently has a bug where select() is broken.\n+                    {\n+                        selectInput = function(node) {\n+                            node.selectionStart = 0;\n+                            node.selectionEnd = node.value.length;\n+                        };\n+                    } else if (ie)\n+                    // Suppress mysterious IE10 errors\n+                    {\n+                        selectInput = function(node) {\n+                            try {\n+                                node.select();\n+                            } catch (_e) {}\n+                        };\n                     }\n-                    /**\n-                     * If the variant definition is a variant label, or\n-                     * the function returned a variant label, resolve.\n-                     */\n-                    if (typeof definition === \"string\") {\n-                        definition = (_a = props.variants) === null || _a === void 0 ? void 0 : _a[definition];\n+\n+                    function bind(f) {\n+                        var args = Array.prototype.slice.call(arguments, 1);\n+                        return function() {\n+                            return f.apply(null, args);\n+                        };\n                     }\n-                    /**\n-                     * At this point we've resolved both functions and variant labels,\n-                     * but the resolved variant label might itself have been a function.\n-                     * If so, resolve. This can only have returned a valid target object.\n-                     */\n-                    if (typeof definition === \"function\") {\n-                        definition = definition(custom !== null && custom !== void 0 ? custom : props.custom, currentValues, currentVelocity);\n+\n+                    function copyObj(obj, target, overwrite) {\n+                        if (!target) {\n+                            target = {};\n+                        }\n+                        for (var prop in obj) {\n+                            if (obj.hasOwnProperty(prop) && (overwrite !== false || !target.hasOwnProperty(prop))) {\n+                                target[prop] = obj[prop];\n+                            }\n+                        }\n+                        return target;\n                     }\n-                    return definition;\n-                }\n \n-                function resolveVariant(visualElement, definition, custom) {\n-                    var props = visualElement.getProps();\n-                    return resolveVariantFromProps(props, definition, custom !== null && custom !== void 0 ? custom : props.custom, getCurrent(visualElement), getVelocity$1(visualElement));\n-                }\n+                    // Counts the column offset in a string, taking tabs into account.\n+                    // Used mostly to find indentation.\n+                    function countColumn(string, end, tabSize, startIndex, startValue) {\n+                        if (end == null) {\n+                            end = string.search(/[^\\s\\u00a0]/);\n+                            if (end == -1) {\n+                                end = string.length;\n+                            }\n+                        }\n+                        for (var i = startIndex || 0, n = startValue || 0;;) {\n+                            var nextTab = string.indexOf(\"\\t\", i);\n+                            if (nextTab < 0 || nextTab >= end) {\n+                                return n + (end - i);\n+                            }\n+                            n += nextTab - i;\n+                            n += tabSize - n % tabSize;\n+                            i = nextTab + 1;\n+                        }\n+                    }\n+                    var Delayed = function() {\n+                        this.id = null;\n+                        this.f = null;\n+                        this.time = 0;\n+                        this.handler = bind(this.onTimeout, this);\n+                    };\n+                    Delayed.prototype.onTimeout = function(self) {\n+                        self.id = 0;\n+                        if (self.time <= +new Date()) {\n+                            self.f();\n+                        } else {\n+                            setTimeout(self.handler, self.time - +new Date());\n+                        }\n+                    };\n+                    Delayed.prototype.set = function(ms, f) {\n+                        this.f = f;\n+                        var time = +new Date() + ms;\n+                        if (!this.id || time < this.time) {\n+                            clearTimeout(this.id);\n+                            this.id = setTimeout(this.handler, ms);\n+                            this.time = time;\n+                        }\n+                    };\n \n-                function checkIfControllingVariants(props) {\n-                    var _a;\n-                    return typeof((_a = props.animate) === null || _a === void 0 ? void 0 : _a.start) === \"function\" || isVariantLabel(props.initial) || isVariantLabel(props.animate) || isVariantLabel(props.whileHover) || isVariantLabel(props.whileDrag) || isVariantLabel(props.whileTap) || isVariantLabel(props.whileFocus) || isVariantLabel(props.exit);\n-                }\n+                    function indexOf(array, elt) {\n+                        for (var i = 0; i < array.length; ++i) {\n+                            if (array[i] == elt) {\n+                                return i;\n+                            }\n+                        }\n+                        return -1;\n+                    }\n \n-                function checkIfVariantNode(props) {\n-                    return Boolean(checkIfControllingVariants(props) || props.variants);\n-                }\n+                    // Number of pixels added to scroller and sizer to hide scrollbar\n+                    var scrollerGap = 50;\n \n-                function getCurrentTreeVariants(props, context) {\n-                    if (checkIfControllingVariants(props)) {\n-                        var initial = props.initial,\n-                            animate = props.animate;\n-                        return {\n-                            initial: initial === false || isVariantLabel(initial) ? initial : undefined,\n-                            animate: isVariantLabel(animate) ? animate : undefined\n+                    // Returned or thrown by various protocols to signal 'I'm not\n+                    // handling this'.\n+                    var Pass = {\n+                        toString: function() {\n+                            return \"CodeMirror.Pass\";\n+                        }\n+                    };\n+\n+                    // Reused option objects for setSelection & friends\n+                    var sel_dontScroll = {\n+                            scroll: false\n+                        },\n+                        sel_mouse = {\n+                            origin: \"*mouse\"\n+                        },\n+                        sel_move = {\n+                            origin: \"+move\"\n                         };\n+\n+                    // The inverse of countColumn -- find the offset that corresponds to\n+                    // a particular column.\n+                    function findColumn(string, goal, tabSize) {\n+                        for (var pos = 0, col = 0;;) {\n+                            var nextTab = string.indexOf(\"\\t\", pos);\n+                            if (nextTab == -1) {\n+                                nextTab = string.length;\n+                            }\n+                            var skipped = nextTab - pos;\n+                            if (nextTab == string.length || col + skipped >= goal) {\n+                                return pos + Math.min(skipped, goal - col);\n+                            }\n+                            col += nextTab - pos;\n+                            col += tabSize - col % tabSize;\n+                            pos = nextTab + 1;\n+                            if (col >= goal) {\n+                                return pos;\n+                            }\n+                        }\n                     }\n-                    return props.inherit !== false ? context : {};\n-                }\n+                    var spaceStrs = [\"\"];\n \n-                function useCreateMotionContext(props) {\n-                    var _a = getCurrentTreeVariants(props, React.useContext(MotionContext)),\n-                        initial = _a.initial,\n-                        animate = _a.animate;\n-                    return React.useMemo(function() {\n-                        return {\n-                            initial: initial,\n-                            animate: animate\n-                        };\n-                    }, [variantLabelsAsDependency(initial), variantLabelsAsDependency(animate)]);\n-                }\n+                    function spaceStr(n) {\n+                        while (spaceStrs.length <= n) {\n+                            spaceStrs.push(lst(spaceStrs) + \" \");\n+                        }\n+                        return spaceStrs[n];\n+                    }\n \n-                function variantLabelsAsDependency(prop) {\n-                    return Array.isArray(prop) ? prop.join(\" \") : prop;\n-                }\n+                    function lst(arr) {\n+                        return arr[arr.length - 1];\n+                    }\n \n-                /**\n-                 * Creates a constant value over the lifecycle of a component.\n-                 *\n-                 * Even if `useMemo` is provided an empty array as its final argument, it doesn't offer\n-                 * a guarantee that it won't re-run for performance reasons later on. By using `useConstant`\n-                 * you can ensure that initialisers don't execute twice or more.\n-                 */\n-                function useConstant(init) {\n-                    var ref = React.useRef(null);\n-                    if (ref.current === null) {\n-                        ref.current = init();\n+                    function map(array, f) {\n+                        var out = [];\n+                        for (var i = 0; i < array.length; i++) {\n+                            out[i] = f(array[i], i);\n+                        }\n+                        return out;\n                     }\n-                    return ref.current;\n-                }\n \n-                /**\n-                 * This should only ever be modified on the client otherwise it'll\n-                 * persist through server requests. If we need instanced states we\n-                 * could lazy-init via root.\n-                 */\n-                var globalProjectionState = {\n-                    /**\n-                     * Global flag as to whether the tree has animated since the last time\n-                     * we resized the window\n-                     */\n-                    hasAnimatedSinceResize: true,\n-                    /**\n-                     * We set this to true once, on the first update. Any nodes added to the tree beyond that\n-                     * update will be given a `data-projection-id` attribute.\n-                     */\n-                    hasEverUpdated: false\n-                };\n-                var id$1 = 1;\n+                    function insertSorted(array, value, score) {\n+                        var pos = 0,\n+                            priority = score(value);\n+                        while (pos < array.length && score(array[pos]) <= priority) {\n+                            pos++;\n+                        }\n+                        array.splice(pos, 0, value);\n+                    }\n \n-                function useProjectionId() {\n-                    return useConstant(function() {\n-                        if (globalProjectionState.hasEverUpdated) {\n-                            return id$1++;\n+                    function nothing() {}\n+\n+                    function createObj(base, props) {\n+                        var inst;\n+                        if (Object.create) {\n+                            inst = Object.create(base);\n+                        } else {\n+                            nothing.prototype = base;\n+                            inst = new nothing();\n                         }\n-                    });\n-                }\n-                var LayoutGroupContext = React.createContext({});\n+                        if (props) {\n+                            copyObj(props, inst);\n+                        }\n+                        return inst;\n+                    }\n+                    var nonASCIISingleCaseWordChar = /[\\u00df\\u0587\\u0590-\\u05f4\\u0600-\\u06ff\\u3040-\\u309f\\u30a0-\\u30ff\\u3400-\\u4db5\\u4e00-\\u9fcc\\uac00-\\ud7af]/;\n \n-                /**\n-                 * Internal, exported only for usage in Framer\n-                 */\n-                var SwitchLayoutGroupContext = React.createContext({});\n+                    function isWordCharBasic(ch) {\n+                        return /\\w/.test(ch) || ch > \"\\x80\" && (ch.toUpperCase() != ch.toLowerCase() || nonASCIISingleCaseWordChar.test(ch));\n+                    }\n \n-                function useProjection(projectionId, _a, visualElement, ProjectionNodeConstructor) {\n-                    var _b;\n-                    var layoutId = _a.layoutId,\n-                        layout = _a.layout,\n-                        drag = _a.drag,\n-                        dragConstraints = _a.dragConstraints,\n-                        layoutScroll = _a.layoutScroll;\n-                    var initialPromotionConfig = React.useContext(SwitchLayoutGroupContext);\n-                    if (!ProjectionNodeConstructor || !visualElement || (visualElement === null || visualElement === void 0 ? void 0 : visualElement.projection)) {\n-                        return;\n+                    function isWordChar(ch, helper) {\n+                        if (!helper) {\n+                            return isWordCharBasic(ch);\n+                        }\n+                        if (helper.source.indexOf(\"\\\\w\") > -1 && isWordCharBasic(ch)) {\n+                            return true;\n+                        }\n+                        return helper.test(ch);\n                     }\n-                    visualElement.projection = new ProjectionNodeConstructor(projectionId, visualElement.getLatestValues(), (_b = visualElement.parent) === null || _b === void 0 ? void 0 : _b.projection);\n-                    visualElement.projection.setOptions({\n-                        layoutId: layoutId,\n-                        layout: layout,\n-                        alwaysMeasureLayout: Boolean(drag) || dragConstraints && isRefObject(dragConstraints),\n-                        visualElement: visualElement,\n-                        scheduleRender: function() {\n-                            return visualElement.scheduleRender();\n-                        },\n-                        /**\n-                         * TODO: Update options in an effect. This could be tricky as it'll be too late\n-                         * to update by the time layout animations run.\n-                         * We also need to fix this safeToRemove by linking it up to the one returned by usePresence,\n-                         * ensuring it gets called if there's no potential layout animations.\n-                         *\n-                         */\n-                        animationType: typeof layout === \"string\" ? layout : \"both\",\n-                        initialPromotionConfig: initialPromotionConfig,\n-                        layoutScroll: layoutScroll\n-                    });\n-                }\n-                var VisualElementHandler = /** @class */ function(_super) {\n-                    tslib.__extends(VisualElementHandler, _super);\n \n-                    function VisualElementHandler() {\n-                        return _super !== null && _super.apply(this, arguments) || this;\n+                    function isEmpty(obj) {\n+                        for (var n in obj) {\n+                            if (obj.hasOwnProperty(n) && obj[n]) {\n+                                return false;\n+                            }\n+                        }\n+                        return true;\n                     }\n-                    /**\n-                     * Update visual element props as soon as we know this update is going to be commited.\n-                     */\n-                    VisualElementHandler.prototype.getSnapshotBeforeUpdate = function() {\n-                        this.updateProps();\n-                        return null;\n-                    };\n-                    VisualElementHandler.prototype.componentDidUpdate = function() {};\n-                    VisualElementHandler.prototype.updateProps = function() {\n-                        var _a = this.props,\n-                            visualElement = _a.visualElement,\n-                            props = _a.props;\n-                        if (visualElement) visualElement.setProps(props);\n-                    };\n-                    VisualElementHandler.prototype.render = function() {\n-                        return this.props.children;\n-                    };\n-                    return VisualElementHandler;\n-                }(React__default[\"default\"].Component);\n \n-                /**\n-                 * Create a `motion` component.\n-                 *\n-                 * This function accepts a Component argument, which can be either a string (ie \"div\"\n-                 * for `motion.div`), or an actual React component.\n-                 *\n-                 * Alongside this is a config option which provides a way of rendering the provided\n-                 * component \"offline\", or outside the React render cycle.\n-                 */\n-                function createMotionComponent(_a) {\n-                    var preloadedFeatures = _a.preloadedFeatures,\n-                        createVisualElement = _a.createVisualElement,\n-                        projectionNodeConstructor = _a.projectionNodeConstructor,\n-                        useRender = _a.useRender,\n-                        useVisualState = _a.useVisualState,\n-                        Component = _a.Component;\n-                    preloadedFeatures && loadFeatures(preloadedFeatures);\n+                    // Extending unicode characters. A series of a non-extending char +\n+                    // any number of extending chars is treated as a single unit as far\n+                    // as editing and measuring is concerned. This is not fully correct,\n+                    // since some scripts/fonts/browsers also treat other configurations\n+                    // of code points as a group.\n+                    var extendingChars = /[\\u0300-\\u036f\\u0483-\\u0489\\u0591-\\u05bd\\u05bf\\u05c1\\u05c2\\u05c4\\u05c5\\u05c7\\u0610-\\u061a\\u064b-\\u065e\\u0670\\u06d6-\\u06dc\\u06de-\\u06e4\\u06e7\\u06e8\\u06ea-\\u06ed\\u0711\\u0730-\\u074a\\u07a6-\\u07b0\\u07eb-\\u07f3\\u0816-\\u0819\\u081b-\\u0823\\u0825-\\u0827\\u0829-\\u082d\\u0900-\\u0902\\u093c\\u0941-\\u0948\\u094d\\u0951-\\u0955\\u0962\\u0963\\u0981\\u09bc\\u09be\\u09c1-\\u09c4\\u09cd\\u09d7\\u09e2\\u09e3\\u0a01\\u0a02\\u0a3c\\u0a41\\u0a42\\u0a47\\u0a48\\u0a4b-\\u0a4d\\u0a51\\u0a70\\u0a71\\u0a75\\u0a81\\u0a82\\u0abc\\u0ac1-\\u0ac5\\u0ac7\\u0ac8\\u0acd\\u0ae2\\u0ae3\\u0b01\\u0b3c\\u0b3e\\u0b3f\\u0b41-\\u0b44\\u0b4d\\u0b56\\u0b57\\u0b62\\u0b63\\u0b82\\u0bbe\\u0bc0\\u0bcd\\u0bd7\\u0c3e-\\u0c40\\u0c46-\\u0c48\\u0c4a-\\u0c4d\\u0c55\\u0c56\\u0c62\\u0c63\\u0cbc\\u0cbf\\u0cc2\\u0cc6\\u0ccc\\u0ccd\\u0cd5\\u0cd6\\u0ce2\\u0ce3\\u0d3e\\u0d41-\\u0d44\\u0d4d\\u0d57\\u0d62\\u0d63\\u0dca\\u0dcf\\u0dd2-\\u0dd4\\u0dd6\\u0ddf\\u0e31\\u0e34-\\u0e3a\\u0e47-\\u0e4e\\u0eb1\\u0eb4-\\u0eb9\\u0ebb\\u0ebc\\u0ec8-\\u0ecd\\u0f18\\u0f19\\u0f35\\u0f37\\u0f39\\u0f71-\\u0f7e\\u0f80-\\u0f84\\u0f86\\u0f87\\u0f90-\\u0f97\\u0f99-\\u0fbc\\u0fc6\\u102d-\\u1030\\u1032-\\u1037\\u1039\\u103a\\u103d\\u103e\\u1058\\u1059\\u105e-\\u1060\\u1071-\\u1074\\u1082\\u1085\\u1086\\u108d\\u109d\\u135f\\u1712-\\u1714\\u1732-\\u1734\\u1752\\u1753\\u1772\\u1773\\u17b7-\\u17bd\\u17c6\\u17c9-\\u17d3\\u17dd\\u180b-\\u180d\\u18a9\\u1920-\\u1922\\u1927\\u1928\\u1932\\u1939-\\u193b\\u1a17\\u1a18\\u1a56\\u1a58-\\u1a5e\\u1a60\\u1a62\\u1a65-\\u1a6c\\u1a73-\\u1a7c\\u1a7f\\u1b00-\\u1b03\\u1b34\\u1b36-\\u1b3a\\u1b3c\\u1b42\\u1b6b-\\u1b73\\u1b80\\u1b81\\u1ba2-\\u1ba5\\u1ba8\\u1ba9\\u1c2c-\\u1c33\\u1c36\\u1c37\\u1cd0-\\u1cd2\\u1cd4-\\u1ce0\\u1ce2-\\u1ce8\\u1ced\\u1dc0-\\u1de6\\u1dfd-\\u1dff\\u200c\\u200d\\u20d0-\\u20f0\\u2cef-\\u2cf1\\u2de0-\\u2dff\\u302a-\\u302f\\u3099\\u309a\\ua66f-\\ua672\\ua67c\\ua67d\\ua6f0\\ua6f1\\ua802\\ua806\\ua80b\\ua825\\ua826\\ua8c4\\ua8e0-\\ua8f1\\ua926-\\ua92d\\ua947-\\ua951\\ua980-\\ua982\\ua9b3\\ua9b6-\\ua9b9\\ua9bc\\uaa29-\\uaa2e\\uaa31\\uaa32\\uaa35\\uaa36\\uaa43\\uaa4c\\uaab0\\uaab2-\\uaab4\\uaab7\\uaab8\\uaabe\\uaabf\\uaac1\\uabe5\\uabe8\\uabed\\udc00-\\udfff\\ufb1e\\ufe00-\\ufe0f\\ufe20-\\ufe26\\uff9e\\uff9f]/;\n+\n+                    function isExtendingChar(ch) {\n+                        return ch.charCodeAt(0) >= 768 && extendingChars.test(ch);\n+                    }\n \n-                    function MotionComponent(props, externalRef) {\n-                        var layoutId = useLayoutId(props);\n-                        props = tslib.__assign(tslib.__assign({}, props), {\n-                            layoutId: layoutId\n-                        });\n-                        /**\n-                         * If we're rendering in a static environment, we only visually update the component\n-                         * as a result of a React-rerender rather than interactions or animations. This\n-                         * means we don't need to load additional memory structures like VisualElement,\n-                         * or any gesture/animation features.\n-                         */\n-                        var config = React.useContext(MotionConfigContext);\n-                        var features = null;\n-                        var context = useCreateMotionContext(props);\n-                        /**\n-                         * Create a unique projection ID for this component. If a new component is added\n-                         * during a layout animation we'll use this to query the DOM and hydrate its ref early, allowing\n-                         * us to measure it as soon as any layout effect flushes pending layout animations.\n-                         *\n-                         * Performance note: It'd be better not to have to search the DOM for these elements.\n-                         * For newly-entering components it could be enough to only correct treeScale, in which\n-                         * case we could mount in a scale-correction mode. This wouldn't be enough for\n-                         * shared element transitions however. Perhaps for those we could revert to a root node\n-                         * that gets forceRendered and layout animations are triggered on its layout effect.\n-                         */\n-                        var projectionId = config.isStatic ? undefined : useProjectionId();\n-                        /**\n-                         *\n-                         */\n-                        var visualState = useVisualState(props, config.isStatic);\n-                        if (!config.isStatic && isBrowser) {\n-                            /**\n-                             * Create a VisualElement for this component. A VisualElement provides a common\n-                             * interface to renderer-specific APIs (ie DOM/Three.js etc) as well as\n-                             * providing a way of rendering to these APIs outside of the React render loop\n-                             * for more performant animations and interactions\n-                             */\n-                            context.visualElement = useVisualElement(Component, visualState, tslib.__assign(tslib.__assign({}, config), props), createVisualElement);\n-                            useProjection(projectionId, props, context.visualElement, projectionNodeConstructor || featureDefinitions.projectionNodeConstructor);\n-                            /**\n-                             * Load Motion gesture and animation features. These are rendered as renderless\n-                             * components so each feature can optionally make use of React lifecycle methods.\n-                             */\n-                            features = useFeatures(props, context.visualElement, preloadedFeatures);\n+                    // Returns a number from the range [`0`; `str.length`] unless `pos` is outside that range.\n+                    function skipExtendingChars(str, pos, dir) {\n+                        while ((dir < 0 ? pos > 0 : pos < str.length) && isExtendingChar(str.charAt(pos))) {\n+                            pos += dir;\n                         }\n-                        /**\n-                         * The mount order and hierarchy is specific to ensure our element ref\n-                         * is hydrated by the time features fire their effects.\n-                         */\n-                        return React__namespace.createElement(VisualElementHandler, {\n-                            visualElement: context.visualElement,\n-                            props: tslib.__assign(tslib.__assign({}, config), props)\n-                        }, features, React__namespace.createElement(MotionContext.Provider, {\n-                            value: context\n-                        }, useRender(Component, props, projectionId, useMotionRef(visualState, context.visualElement, externalRef), visualState, config.isStatic, context.visualElement)));\n+                        return pos;\n                     }\n-                    return React.forwardRef(MotionComponent);\n-                }\n \n-                function useLayoutId(_a) {\n-                    var _b;\n-                    var layoutId = _a.layoutId;\n-                    var layoutGroupId = (_b = React.useContext(LayoutGroupContext)) === null || _b === void 0 ? void 0 : _b.id;\n-                    return layoutGroupId && layoutId !== undefined ? layoutGroupId + \"-\" + layoutId : layoutId;\n-                }\n+                    // Returns the value from the range [`from`; `to`] that satisfies\n+                    // `pred` and is closest to `from`. Assumes that at least `to`\n+                    // satisfies `pred`. Supports `from` being greater than `to`.\n+                    function findFirst(pred, from, to) {\n+                        // At any point we are certain `to` satisfies `pred`, don't know\n+                        // whether `from` does.\n+                        var dir = from > to ? -1 : 1;\n+                        for (;;) {\n+                            if (from == to) {\n+                                return from;\n+                            }\n+                            var midF = (from + to) / 2,\n+                                mid = dir < 0 ? Math.ceil(midF) : Math.floor(midF);\n+                            if (mid == from) {\n+                                return pred(mid) ? from : to;\n+                            }\n+                            if (pred(mid)) {\n+                                to = mid;\n+                            } else {\n+                                from = mid + dir;\n+                            }\n+                        }\n+                    }\n \n-                /**\n-                 * Convert any React component into a `motion` component. The provided component\n-                 * **must** use `React.forwardRef` to the underlying DOM component you want to animate.\n-                 *\n-                 * ```jsx\n-                 * const Component = React.forwardRef((props, ref) => {\n-                 *   return <div ref={ref} />\n-                 * })\n-                 *\n-                 * const MotionComponent = motion(Component)\n-                 * ```\n-                 *\n-                 * @public\n-                 */\n-                function createMotionProxy(createConfig) {\n-                    function custom(Component, customMotionComponentConfig) {\n-                        if (customMotionComponentConfig === void 0) {\n-                            customMotionComponentConfig = {};\n+                    // BIDI HELPERS\n+\n+                    function iterateBidiSections(order, from, to, f) {\n+                        if (!order) {\n+                            return f(from, to, \"ltr\", 0);\n+                        }\n+                        var found = false;\n+                        for (var i = 0; i < order.length; ++i) {\n+                            var part = order[i];\n+                            if (part.from < to && part.to > from || from == to && part.to == from) {\n+                                f(Math.max(part.from, from), Math.min(part.to, to), part.level == 1 ? \"rtl\" : \"ltr\", i);\n+                                found = true;\n+                            }\n+                        }\n+                        if (!found) {\n+                            f(from, to, \"ltr\");\n                         }\n-                        return createMotionComponent(createConfig(Component, customMotionComponentConfig));\n                     }\n-                    if (typeof Proxy === \"undefined\") {\n-                        return custom;\n+                    var bidiOther = null;\n+\n+                    function getBidiPartAt(order, ch, sticky) {\n+                        var found;\n+                        bidiOther = null;\n+                        for (var i = 0; i < order.length; ++i) {\n+                            var cur = order[i];\n+                            if (cur.from < ch && cur.to > ch) {\n+                                return i;\n+                            }\n+                            if (cur.to == ch) {\n+                                if (cur.from != cur.to && sticky == \"before\") {\n+                                    found = i;\n+                                } else {\n+                                    bidiOther = i;\n+                                }\n+                            }\n+                            if (cur.from == ch) {\n+                                if (cur.from != cur.to && sticky != \"before\") {\n+                                    found = i;\n+                                } else {\n+                                    bidiOther = i;\n+                                }\n+                            }\n+                        }\n+                        return found != null ? found : bidiOther;\n                     }\n-                    /**\n-                     * A cache of generated `motion` components, e.g `motion.div`, `motion.input` etc.\n-                     * Rather than generating them anew every render.\n-                     */\n-                    var componentCache = new Map();\n-                    return new Proxy(custom, {\n-                        /**\n-                         * Called when `motion` is referenced with a prop: `motion.div`, `motion.input` etc.\n-                         * The prop name is passed through as `key` and we can use that to generate a `motion`\n-                         * DOM component with that name.\n-                         */\n-                        get: function(_target, key) {\n-                            /**\n-                             * If this element doesn't exist in the component cache, create it and cache.\n-                             */\n-                            if (!componentCache.has(key)) {\n-                                componentCache.set(key, custom(key));\n+\n+                    // Bidirectional ordering algorithm\n+                    // See http://unicode.org/reports/tr9/tr9-13.html for the algorithm\n+                    // that this (partially) implements.\n+\n+                    // One-char codes used for character types:\n+                    // L (L):   Left-to-Right\n+                    // R (R):   Right-to-Left\n+                    // r (AL):  Right-to-Left Arabic\n+                    // 1 (EN):  European Number\n+                    // + (ES):  European Number Separator\n+                    // % (ET):  European Number Terminator\n+                    // n (AN):  Arabic Number\n+                    // , (CS):  Common Number Separator\n+                    // m (NSM): Non-Spacing Mark\n+                    // b (BN):  Boundary Neutral\n+                    // s (B):   Paragraph Separator\n+                    // t (S):   Segment Separator\n+                    // w (WS):  Whitespace\n+                    // N (ON):  Other Neutrals\n+\n+                    // Returns null if characters are ordered as they appear\n+                    // (left-to-right), or an array of sections ({from, to, level}\n+                    // objects) in the order in which they occur visually.\n+                    var bidiOrdering = function() {\n+                        // Character types for codepoints 0 to 0xff\n+                        var lowTypes = \"bbbbbbbbbtstwsbbbbbbbbbbbbbbssstwNN%%%NNNNNN,N,N1111111111NNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNbbbbbbsbbbbbbbbbbbbbbbbbbbbbbbbbb,N%%%%NNNNLNNNNN%%11NLNNN1LNNNNNLLLLLLLLLLLLLLLLLLLLLLLNLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLN\";\n+                        // Character types for codepoints 0x600 to 0x6f9\n+                        var arabicTypes = \"nnnnnnNNr%%r,rNNmmmmmmmmmmmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmmmmmmmmmmmmmmmnnnnnnnnnn%nnrrrmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmnNmmmmmmrrmmNmmmmrr1111111111\";\n+\n+                        function charType(code) {\n+                            if (code <= 0xf7) {\n+                                return lowTypes.charAt(code);\n+                            } else if (0x590 <= code && code <= 0x5f4) {\n+                                return \"R\";\n+                            } else if (0x600 <= code && code <= 0x6f9) {\n+                                return arabicTypes.charAt(code - 0x600);\n+                            } else if (0x6ee <= code && code <= 0x8ac) {\n+                                return \"r\";\n+                            } else if (0x2000 <= code && code <= 0x200b) {\n+                                return \"w\";\n+                            } else if (code == 0x200c) {\n+                                return \"b\";\n+                            } else {\n+                                return \"L\";\n                             }\n-                            return componentCache.get(key);\n                         }\n-                    });\n-                }\n+                        var bidiRE = /[\\u0590-\\u05f4\\u0600-\\u06ff\\u0700-\\u08ac]/;\n+                        var isNeutral = /[stwN]/,\n+                            isStrong = /[LRr]/,\n+                            countsAsLeft = /[Lb1n]/,\n+                            countsAsNum = /[1n]/;\n+\n+                        function BidiSpan(level, from, to) {\n+                            this.level = level;\n+                            this.from = from;\n+                            this.to = to;\n+                        }\n+                        return function(str, direction) {\n+                            var outerType = direction == \"ltr\" ? \"L\" : \"R\";\n+                            if (str.length == 0 || direction == \"ltr\" && !bidiRE.test(str)) {\n+                                return false;\n+                            }\n+                            var len = str.length,\n+                                types = [];\n+                            for (var i = 0; i < len; ++i) {\n+                                types.push(charType(str.charCodeAt(i)));\n+                            }\n \n-                /**\n-                 * We keep these listed seperately as we use the lowercase tag names as part\n-                 * of the runtime bundle to detect SVG components\n-                 */\n-                var lowercaseSVGElements = [\"animate\", \"circle\", \"defs\", \"desc\", \"ellipse\", \"g\", \"image\", \"line\", \"filter\", \"marker\", \"mask\", \"metadata\", \"path\", \"pattern\", \"polygon\", \"polyline\", \"rect\", \"stop\", \"svg\", \"switch\", \"symbol\", \"text\", \"tspan\", \"use\", \"view\"];\n+                            // W1. Examine each non-spacing mark (NSM) in the level run, and\n+                            // change the type of the NSM to the type of the previous\n+                            // character. If the NSM is at the start of the level run, it will\n+                            // get the type of sor.\n+                            for (var i$1 = 0, prev = outerType; i$1 < len; ++i$1) {\n+                                var type = types[i$1];\n+                                if (type == \"m\") {\n+                                    types[i$1] = prev;\n+                                } else {\n+                                    prev = type;\n+                                }\n+                            }\n \n-                function isSVGComponent(Component) {\n-                    if (\n-                        /**\n-                         * If it's not a string, it's a custom React component. Currently we only support\n-                         * HTML custom React components.\n-                         */\n-                        typeof Component !== \"string\" ||\n-                        /**\n-                         * If it contains a dash, the element is a custom HTML webcomponent.\n-                         */\n-                        Component.includes(\"-\")) {\n-                        return false;\n-                    } else if (\n-                        /**\n-                         * If it's in our list of lowercase SVG tags, it's an SVG component\n-                         */\n-                        lowercaseSVGElements.indexOf(Component) > -1 ||\n-                        /**\n-                         * If it contains a capital letter, it's an SVG component\n-                         */\n-                        /[A-Z]/.test(Component)) {\n-                        return true;\n-                    }\n-                    return false;\n-                }\n-                var scaleCorrectors = {};\n+                            // W2. Search backwards from each instance of a European number\n+                            // until the first strong type (R, L, AL, or sor) is found. If an\n+                            // AL is found, change the type of the European number to Arabic\n+                            // number.\n+                            // W3. Change all ALs to R.\n+                            for (var i$2 = 0, cur = outerType; i$2 < len; ++i$2) {\n+                                var type$1 = types[i$2];\n+                                if (type$1 == \"1\" && cur == \"r\") {\n+                                    types[i$2] = \"n\";\n+                                } else if (isStrong.test(type$1)) {\n+                                    cur = type$1;\n+                                    if (type$1 == \"r\") {\n+                                        types[i$2] = \"R\";\n+                                    }\n+                                }\n+                            }\n+\n+                            // W4. A single European separator between two European numbers\n+                            // changes to a European number. A single common separator between\n+                            // two numbers of the same type changes to that type.\n+                            for (var i$3 = 1, prev$1 = types[0]; i$3 < len - 1; ++i$3) {\n+                                var type$2 = types[i$3];\n+                                if (type$2 == \"+\" && prev$1 == \"1\" && types[i$3 + 1] == \"1\") {\n+                                    types[i$3] = \"1\";\n+                                } else if (type$2 == \",\" && prev$1 == types[i$3 + 1] && (prev$1 == \"1\" || prev$1 == \"n\")) {\n+                                    types[i$3] = prev$1;\n+                                }\n+                                prev$1 = type$2;\n+                            }\n+\n+                            // W5. A sequence of European terminators adjacent to European\n+                            // numbers changes to all European numbers.\n+                            // W6. Otherwise, separators and terminators change to Other\n+                            // Neutral.\n+                            for (var i$4 = 0; i$4 < len; ++i$4) {\n+                                var type$3 = types[i$4];\n+                                if (type$3 == \",\") {\n+                                    types[i$4] = \"N\";\n+                                } else if (type$3 == \"%\") {\n+                                    var end = void 0;\n+                                    for (end = i$4 + 1; end < len && types[end] == \"%\"; ++end) {}\n+                                    var replace = i$4 && types[i$4 - 1] == \"!\" || end < len && types[end] == \"1\" ? \"1\" : \"N\";\n+                                    for (var j = i$4; j < end; ++j) {\n+                                        types[j] = replace;\n+                                    }\n+                                    i$4 = end - 1;\n+                                }\n+                            }\n+\n+                            // W7. Search backwards from each instance of a European number\n+                            // until the first strong type (R, L, or sor) is found. If an L is\n+                            // found, then change the type of the European number to L.\n+                            for (var i$5 = 0, cur$1 = outerType; i$5 < len; ++i$5) {\n+                                var type$4 = types[i$5];\n+                                if (cur$1 == \"L\" && type$4 == \"1\") {\n+                                    types[i$5] = \"L\";\n+                                } else if (isStrong.test(type$4)) {\n+                                    cur$1 = type$4;\n+                                }\n+                            }\n+\n+                            // N1. A sequence of neutrals takes the direction of the\n+                            // surrounding strong text if the text on both sides has the same\n+                            // direction. European and Arabic numbers act as if they were R in\n+                            // terms of their influence on neutrals. Start-of-level-run (sor)\n+                            // and end-of-level-run (eor) are used at level run boundaries.\n+                            // N2. Any remaining neutrals take the embedding direction.\n+                            for (var i$6 = 0; i$6 < len; ++i$6) {\n+                                if (isNeutral.test(types[i$6])) {\n+                                    var end$1 = void 0;\n+                                    for (end$1 = i$6 + 1; end$1 < len && isNeutral.test(types[end$1]); ++end$1) {}\n+                                    var before = (i$6 ? types[i$6 - 1] : outerType) == \"L\";\n+                                    var after = (end$1 < len ? types[end$1] : outerType) == \"L\";\n+                                    var replace$1 = before == after ? before ? \"L\" : \"R\" : outerType;\n+                                    for (var j$1 = i$6; j$1 < end$1; ++j$1) {\n+                                        types[j$1] = replace$1;\n+                                    }\n+                                    i$6 = end$1 - 1;\n+                                }\n+                            }\n+\n+                            // Here we depart from the documented algorithm, in order to avoid\n+                            // building up an actual levels array. Since there are only three\n+                            // levels (0, 1, 2) in an implementation that doesn't take\n+                            // explicit embedding into account, we can build up the order on\n+                            // the fly, without following the level-based algorithm.\n+                            var order = [],\n+                                m;\n+                            for (var i$7 = 0; i$7 < len;) {\n+                                if (countsAsLeft.test(types[i$7])) {\n+                                    var start = i$7;\n+                                    for (++i$7; i$7 < len && countsAsLeft.test(types[i$7]); ++i$7) {}\n+                                    order.push(new BidiSpan(0, start, i$7));\n+                                } else {\n+                                    var pos = i$7,\n+                                        at = order.length,\n+                                        isRTL = direction == \"rtl\" ? 1 : 0;\n+                                    for (++i$7; i$7 < len && types[i$7] != \"L\"; ++i$7) {}\n+                                    for (var j$2 = pos; j$2 < i$7;) {\n+                                        if (countsAsNum.test(types[j$2])) {\n+                                            if (pos < j$2) {\n+                                                order.splice(at, 0, new BidiSpan(1, pos, j$2));\n+                                                at += isRTL;\n+                                            }\n+                                            var nstart = j$2;\n+                                            for (++j$2; j$2 < i$7 && countsAsNum.test(types[j$2]); ++j$2) {}\n+                                            order.splice(at, 0, new BidiSpan(2, nstart, j$2));\n+                                            at += isRTL;\n+                                            pos = j$2;\n+                                        } else {\n+                                            ++j$2;\n+                                        }\n+                                    }\n+                                    if (pos < i$7) {\n+                                        order.splice(at, 0, new BidiSpan(1, pos, i$7));\n+                                    }\n+                                }\n+                            }\n+                            if (direction == \"ltr\") {\n+                                if (order[0].level == 1 && (m = str.match(/^\\s+/))) {\n+                                    order[0].from = m[0].length;\n+                                    order.unshift(new BidiSpan(0, 0, m[0].length));\n+                                }\n+                                if (lst(order).level == 1 && (m = str.match(/\\s+$/))) {\n+                                    lst(order).to -= m[0].length;\n+                                    order.push(new BidiSpan(0, len - m[0].length, len));\n+                                }\n+                            }\n+                            return direction == \"rtl\" ? order.reverse() : order;\n+                        };\n+                    }();\n \n-                function addScaleCorrector(correctors) {\n-                    Object.assign(scaleCorrectors, correctors);\n-                }\n+                    // Get the bidi ordering for the given line (and cache it). Returns\n+                    // false for lines that are fully left-to-right, and an array of\n+                    // BidiSpan objects otherwise.\n+                    function getOrder(line, direction) {\n+                        var order = line.order;\n+                        if (order == null) {\n+                            order = line.order = bidiOrdering(line.text, direction);\n+                        }\n+                        return order;\n+                    }\n+\n+                    // EVENT HANDLING\n+\n+                    // Lightweight event framework. on/off also work on DOM nodes,\n+                    // registering native DOM handlers.\n+\n+                    var noHandlers = [];\n+                    var on = function(emitter, type, f) {\n+                        if (emitter.addEventListener) {\n+                            emitter.addEventListener(type, f, false);\n+                        } else if (emitter.attachEvent) {\n+                            emitter.attachEvent(\"on\" + type, f);\n+                        } else {\n+                            var map = emitter._handlers || (emitter._handlers = {});\n+                            map[type] = (map[type] || noHandlers).concat(f);\n+                        }\n+                    };\n \n-                /**\n-                 * A list of all transformable axes. We'll use this list to generated a version\n-                 * of each axes for each transform.\n-                 */\n-                var transformAxes = [\"\", \"X\", \"Y\", \"Z\"];\n-                /**\n-                 * An ordered array of each transformable value. By default, transform values\n-                 * will be sorted to this order.\n-                 */\n-                var order = [\"translate\", \"scale\", \"rotate\", \"skew\"];\n-                /**\n-                 * Generate a list of every possible transform key.\n-                 */\n-                var transformProps = [\"transformPerspective\", \"x\", \"y\", \"z\"];\n-                order.forEach(function(operationKey) {\n-                    return transformAxes.forEach(function(axesKey) {\n-                        return transformProps.push(operationKey + axesKey);\n-                    });\n-                });\n-                /**\n-                 * A function to use with Array.sort to sort transform keys by their default order.\n-                 */\n-                function sortTransformProps(a, b) {\n-                    return transformProps.indexOf(a) - transformProps.indexOf(b);\n-                }\n-                /**\n-                 * A quick lookup for transform props.\n-                 */\n-                var transformPropSet = new Set(transformProps);\n+                    function getHandlers(emitter, type) {\n+                        return emitter._handlers && emitter._handlers[type] || noHandlers;\n+                    }\n \n-                function isTransformProp(key) {\n-                    return transformPropSet.has(key);\n-                }\n-                /**\n-                 * A quick lookup for transform origin props\n-                 */\n-                var transformOriginProps = new Set([\"originX\", \"originY\", \"originZ\"]);\n+                    function off(emitter, type, f) {\n+                        if (emitter.removeEventListener) {\n+                            emitter.removeEventListener(type, f, false);\n+                        } else if (emitter.detachEvent) {\n+                            emitter.detachEvent(\"on\" + type, f);\n+                        } else {\n+                            var map = emitter._handlers,\n+                                arr = map && map[type];\n+                            if (arr) {\n+                                var index = indexOf(arr, f);\n+                                if (index > -1) {\n+                                    map[type] = arr.slice(0, index).concat(arr.slice(index + 1));\n+                                }\n+                            }\n+                        }\n+                    }\n \n-                function isTransformOriginProp(key) {\n-                    return transformOriginProps.has(key);\n-                }\n+                    function signal(emitter, type /*, values...*/ ) {\n+                        var handlers = getHandlers(emitter, type);\n+                        if (!handlers.length) {\n+                            return;\n+                        }\n+                        var args = Array.prototype.slice.call(arguments, 2);\n+                        for (var i = 0; i < handlers.length; ++i) {\n+                            handlers[i].apply(null, args);\n+                        }\n+                    }\n \n-                function isForcedMotionValue(key, _a) {\n-                    var layout = _a.layout,\n-                        layoutId = _a.layoutId;\n-                    return isTransformProp(key) || isTransformOriginProp(key) || (layout || layoutId !== undefined) && (!!scaleCorrectors[key] || key === \"opacity\");\n-                }\n-                var isMotionValue = function(value) {\n-                    return Boolean(value !== null && typeof value === \"object\" && value.getVelocity);\n-                };\n-                var translateAlias = {\n-                    x: \"translateX\",\n-                    y: \"translateY\",\n-                    z: \"translateZ\",\n-                    transformPerspective: \"perspective\"\n-                };\n-                /**\n-                 * Build a CSS transform style from individual x/y/scale etc properties.\n-                 *\n-                 * This outputs with a default order of transforms/scales/rotations, this can be customised by\n-                 * providing a transformTemplate function.\n-                 */\n-                function buildTransform(_a, _b, transformIsDefault, transformTemplate) {\n-                    var transform = _a.transform,\n-                        transformKeys = _a.transformKeys;\n-                    var _c = _b.enableHardwareAcceleration,\n-                        enableHardwareAcceleration = _c === void 0 ? true : _c,\n-                        _d = _b.allowTransformNone,\n-                        allowTransformNone = _d === void 0 ? true : _d;\n-                    // The transform string we're going to build into.\n-                    var transformString = \"\";\n-                    // Transform keys into their default order - this will determine the output order.\n-                    transformKeys.sort(sortTransformProps);\n-                    // Track whether the defined transform has a defined z so we don't add a\n-                    // second to enable hardware acceleration\n-                    var transformHasZ = false;\n-                    // Loop over each transform and build them into transformString\n-                    var numTransformKeys = transformKeys.length;\n-                    for (var i = 0; i < numTransformKeys; i++) {\n-                        var key = transformKeys[i];\n-                        transformString += \"\".concat(translateAlias[key] || key, \"(\").concat(transform[key], \") \");\n-                        if (key === \"z\") transformHasZ = true;\n+                    // The DOM events that CodeMirror handles can be overridden by\n+                    // registering a (non-DOM) handler on the editor for the event name,\n+                    // and preventDefault-ing the event in that handler.\n+                    function signalDOMEvent(cm, e, override) {\n+                        if (typeof e == \"string\") {\n+                            e = {\n+                                type: e,\n+                                preventDefault: function() {\n+                                    this.defaultPrevented = true;\n+                                }\n+                            };\n+                        }\n+                        signal(cm, override || e.type, cm, e);\n+                        return e_defaultPrevented(e) || e.codemirrorIgnore;\n                     }\n-                    if (!transformHasZ && enableHardwareAcceleration) {\n-                        transformString += \"translateZ(0)\";\n-                    } else {\n-                        transformString = transformString.trim();\n+\n+                    function signalCursorActivity(cm) {\n+                        var arr = cm._handlers && cm._handlers.cursorActivity;\n+                        if (!arr) {\n+                            return;\n+                        }\n+                        var set = cm.curOp.cursorActivityHandlers || (cm.curOp.cursorActivityHandlers = []);\n+                        for (var i = 0; i < arr.length; ++i) {\n+                            if (indexOf(set, arr[i]) == -1) {\n+                                set.push(arr[i]);\n+                            }\n+                        }\n                     }\n-                    // If we have a custom `transform` template, pass our transform values and\n-                    // generated transformString to that before returning\n-                    if (transformTemplate) {\n-                        transformString = transformTemplate(transform, transformIsDefault ? \"\" : transformString);\n-                    } else if (allowTransformNone && transformIsDefault) {\n-                        transformString = \"none\";\n+\n+                    function hasHandler(emitter, type) {\n+                        return getHandlers(emitter, type).length > 0;\n                     }\n-                    return transformString;\n-                }\n-                /**\n-                 * Build a transformOrigin style. Uses the same defaults as the browser for\n-                 * undefined origins.\n-                 */\n-                function buildTransformOrigin(_a) {\n-                    var _b = _a.originX,\n-                        originX = _b === void 0 ? \"50%\" : _b,\n-                        _c = _a.originY,\n-                        originY = _c === void 0 ? \"50%\" : _c,\n-                        _d = _a.originZ,\n-                        originZ = _d === void 0 ? 0 : _d;\n-                    return \"\".concat(originX, \" \").concat(originY, \" \").concat(originZ);\n-                }\n \n-                /**\n-                 * Returns true if the provided key is a CSS variable\n-                 */\n-                function isCSSVariable$1(key) {\n-                    return key.startsWith(\"--\");\n-                }\n+                    // Add on and off methods to a constructor's prototype, to make\n+                    // registering events on such objects more convenient.\n+                    function eventMixin(ctor) {\n+                        ctor.prototype.on = function(type, f) {\n+                            on(this, type, f);\n+                        };\n+                        ctor.prototype.off = function(type, f) {\n+                            off(this, type, f);\n+                        };\n+                    }\n \n-                /**\n-                 * Provided a value and a ValueType, returns the value as that value type.\n-                 */\n-                var getValueAsType = function(value, type) {\n-                    return type && typeof value === \"number\" ? type.transform(value) : value;\n-                };\n-                var int = tslib.__assign(tslib.__assign({}, styleValueTypes.number), {\n-                    transform: Math.round\n-                });\n-                var numberValueTypes = {\n-                    // Border props\n-                    borderWidth: styleValueTypes.px,\n-                    borderTopWidth: styleValueTypes.px,\n-                    borderRightWidth: styleValueTypes.px,\n-                    borderBottomWidth: styleValueTypes.px,\n-                    borderLeftWidth: styleValueTypes.px,\n-                    borderRadius: styleValueTypes.px,\n-                    radius: styleValueTypes.px,\n-                    borderTopLeftRadius: styleValueTypes.px,\n-                    borderTopRightRadius: styleValueTypes.px,\n-                    borderBottomRightRadius: styleValueTypes.px,\n-                    borderBottomLeftRadius: styleValueTypes.px,\n-                    // Positioning props\n-                    width: styleValueTypes.px,\n-                    maxWidth: styleValueTypes.px,\n-                    height: styleValueTypes.px,\n-                    maxHeight: styleValueTypes.px,\n-                    size: styleValueTypes.px,\n-                    top: styleValueTypes.px,\n-                    right: styleValueTypes.px,\n-                    bottom: styleValueTypes.px,\n-                    left: styleValueTypes.px,\n-                    // Spacing props\n-                    padding: styleValueTypes.px,\n-                    paddingTop: styleValueTypes.px,\n-                    paddingRight: styleValueTypes.px,\n-                    paddingBottom: styleValueTypes.px,\n-                    paddingLeft: styleValueTypes.px,\n-                    margin: styleValueTypes.px,\n-                    marginTop: styleValueTypes.px,\n-                    marginRight: styleValueTypes.px,\n-                    marginBottom: styleValueTypes.px,\n-                    marginLeft: styleValueTypes.px,\n-                    // Transform props\n-                    rotate: styleValueTypes.degrees,\n-                    rotateX: styleValueTypes.degrees,\n-                    rotateY: styleValueTypes.degrees,\n-                    rotateZ: styleValueTypes.degrees,\n-                    scale: styleValueTypes.scale,\n-                    scaleX: styleValueTypes.scale,\n-                    scaleY: styleValueTypes.scale,\n-                    scaleZ: styleValueTypes.scale,\n-                    skew: styleValueTypes.degrees,\n-                    skewX: styleValueTypes.degrees,\n-                    skewY: styleValueTypes.degrees,\n-                    distance: styleValueTypes.px,\n-                    translateX: styleValueTypes.px,\n-                    translateY: styleValueTypes.px,\n-                    translateZ: styleValueTypes.px,\n-                    x: styleValueTypes.px,\n-                    y: styleValueTypes.px,\n-                    z: styleValueTypes.px,\n-                    perspective: styleValueTypes.px,\n-                    transformPerspective: styleValueTypes.px,\n-                    opacity: styleValueTypes.alpha,\n-                    originX: styleValueTypes.progressPercentage,\n-                    originY: styleValueTypes.progressPercentage,\n-                    originZ: styleValueTypes.px,\n-                    // Misc\n-                    zIndex: int,\n-                    // SVG\n-                    fillOpacity: styleValueTypes.alpha,\n-                    strokeOpacity: styleValueTypes.alpha,\n-                    numOctaves: int\n-                };\n+                    // Due to the fact that we still support jurassic IE versions, some\n+                    // compatibility wrappers are needed.\n \n-                function buildHTMLStyles(state, latestValues, options, transformTemplate) {\n-                    var _a;\n-                    var style = state.style,\n-                        vars = state.vars,\n-                        transform = state.transform,\n-                        transformKeys = state.transformKeys,\n-                        transformOrigin = state.transformOrigin;\n-                    // Empty the transformKeys array. As we're throwing out refs to its items\n-                    // this might not be as cheap as suspected. Maybe using the array as a buffer\n-                    // with a manual incrementation would be better.\n-                    transformKeys.length = 0;\n-                    // Track whether we encounter any transform or transformOrigin values.\n-                    var hasTransform = false;\n-                    var hasTransformOrigin = false;\n-                    // Does the calculated transform essentially equal \"none\"?\n-                    var transformIsNone = true;\n-                    /**\n-                     * Loop over all our latest animated values and decide whether to handle them\n-                     * as a style or CSS variable.\n-                     *\n-                     * Transforms and transform origins are kept seperately for further processing.\n-                     */\n-                    for (var key in latestValues) {\n-                        var value = latestValues[key];\n-                        /**\n-                         * If this is a CSS variable we don't do any further processing.\n-                         */\n-                        if (isCSSVariable$1(key)) {\n-                            vars[key] = value;\n-                            continue;\n+                    function e_preventDefault(e) {\n+                        if (e.preventDefault) {\n+                            e.preventDefault();\n+                        } else {\n+                            e.returnValue = false;\n                         }\n-                        // Convert the value to its default value type, ie 0 -> \"0px\"\n-                        var valueType = numberValueTypes[key];\n-                        var valueAsType = getValueAsType(value, valueType);\n-                        if (isTransformProp(key)) {\n-                            // If this is a transform, flag to enable further transform processing\n-                            hasTransform = true;\n-                            transform[key] = valueAsType;\n-                            transformKeys.push(key);\n-                            // If we already know we have a non-default transform, early return\n-                            if (!transformIsNone) continue;\n-                            // Otherwise check to see if this is a default transform\n-                            if (value !== ((_a = valueType.default) !== null && _a !== void 0 ? _a : 0)) transformIsNone = false;\n-                        } else if (isTransformOriginProp(key)) {\n-                            transformOrigin[key] = valueAsType;\n-                            // If this is a transform origin, flag and enable further transform-origin processing\n-                            hasTransformOrigin = true;\n+                    }\n+\n+                    function e_stopPropagation(e) {\n+                        if (e.stopPropagation) {\n+                            e.stopPropagation();\n                         } else {\n-                            style[key] = valueAsType;\n+                            e.cancelBubble = true;\n                         }\n                     }\n-                    if (hasTransform) {\n-                        style.transform = buildTransform(state, options, transformIsNone, transformTemplate);\n-                    } else if (transformTemplate) {\n-                        style.transform = transformTemplate({}, \"\");\n-                    } else if (!latestValues.transform && style.transform) {\n-                        style.transform = \"none\";\n+\n+                    function e_defaultPrevented(e) {\n+                        return e.defaultPrevented != null ? e.defaultPrevented : e.returnValue == false;\n                     }\n-                    if (hasTransformOrigin) {\n-                        style.transformOrigin = buildTransformOrigin(transformOrigin);\n+\n+                    function e_stop(e) {\n+                        e_preventDefault(e);\n+                        e_stopPropagation(e);\n                     }\n-                }\n-                var createHtmlRenderState = function() {\n-                    return {\n-                        style: {},\n-                        transform: {},\n-                        transformKeys: [],\n-                        transformOrigin: {},\n-                        vars: {}\n-                    };\n-                };\n \n-                function copyRawValuesOnly(target, source, props) {\n-                    for (var key in source) {\n-                        if (!isMotionValue(source[key]) && !isForcedMotionValue(key, props)) {\n-                            target[key] = source[key];\n+                    function e_target(e) {\n+                        return e.target || e.srcElement;\n+                    }\n+\n+                    function e_button(e) {\n+                        var b = e.which;\n+                        if (b == null) {\n+                            if (e.button & 1) {\n+                                b = 1;\n+                            } else if (e.button & 2) {\n+                                b = 3;\n+                            } else if (e.button & 4) {\n+                                b = 2;\n+                            }\n+                        }\n+                        if (mac && e.ctrlKey && b == 1) {\n+                            b = 3;\n                         }\n+                        return b;\n                     }\n-                }\n \n-                function useInitialMotionValues(_a, visualState, isStatic) {\n-                    var transformTemplate = _a.transformTemplate;\n-                    return React.useMemo(function() {\n-                        var state = createHtmlRenderState();\n-                        buildHTMLStyles(state, visualState, {\n-                            enableHardwareAcceleration: !isStatic\n-                        }, transformTemplate);\n-                        var vars = state.vars,\n-                            style = state.style;\n-                        return tslib.__assign(tslib.__assign({}, vars), style);\n-                    }, [visualState]);\n-                }\n+                    // Detect drag-and-drop\n+                    var dragAndDrop = function() {\n+                        // There is *some* kind of drag-and-drop support in IE6-8, but I\n+                        // couldn't get it to work yet.\n+                        if (ie && ie_version < 9) {\n+                            return false;\n+                        }\n+                        var div = elt('div');\n+                        return \"draggable\" in div || \"dragDrop\" in div;\n+                    }();\n+                    var zwspSupported;\n \n-                function useStyle(props, visualState, isStatic) {\n-                    var styleProp = props.style || {};\n-                    var style = {};\n-                    /**\n-                     * Copy non-Motion Values straight into style\n-                     */\n-                    copyRawValuesOnly(style, styleProp, props);\n-                    Object.assign(style, useInitialMotionValues(props, visualState, isStatic));\n-                    if (props.transformValues) {\n-                        style = props.transformValues(style);\n+                    function zeroWidthElement(measure) {\n+                        if (zwspSupported == null) {\n+                            var test = elt(\"span\", \"\\u200b\");\n+                            removeChildrenAndAdd(measure, elt(\"span\", [test, document.createTextNode(\"x\")]));\n+                            if (measure.firstChild.offsetHeight != 0) {\n+                                zwspSupported = test.offsetWidth <= 1 && test.offsetHeight > 2 && !(ie && ie_version < 8);\n+                            }\n+                        }\n+                        var node = zwspSupported ? elt(\"span\", \"\\u200b\") : elt(\"span\", \"\\u00a0\", null, \"display: inline-block; width: 1px; margin-right: -1px\");\n+                        node.setAttribute(\"cm-text\", \"\");\n+                        return node;\n                     }\n-                    return style;\n-                }\n \n-                function useHTMLProps(props, visualState, isStatic) {\n-                    // The `any` isn't ideal but it is the type of createElement props argument\n-                    var htmlProps = {};\n-                    var style = useStyle(props, visualState, isStatic);\n-                    if (Boolean(props.drag) && props.dragListener !== false) {\n-                        // Disable the ghost element when a user drags\n-                        htmlProps.draggable = false;\n-                        // Disable text selection\n-                        style.userSelect = style.WebkitUserSelect = style.WebkitTouchCallout = \"none\";\n-                        // Disable scrolling on the draggable direction\n-                        style.touchAction = props.drag === true ? \"none\" : \"pan-\".concat(props.drag === \"x\" ? \"y\" : \"x\");\n-                    }\n-                    htmlProps.style = style;\n-                    return htmlProps;\n-                }\n+                    // Feature-detect IE's crummy client rect reporting for bidi text\n+                    var badBidiRects;\n \n-                /**\n-                 * A list of all valid MotionProps.\n-                 *\n-                 * @privateRemarks\n-                 * This doesn't throw if a `MotionProp` name is missing - it should.\n-                 */\n-                var validMotionProps = new Set([\"initial\", \"animate\", \"exit\", \"style\", \"variants\", \"transition\", \"transformTemplate\", \"transformValues\", \"custom\", \"inherit\", \"layout\", \"layoutId\", \"layoutDependency\", \"onLayoutAnimationStart\", \"onLayoutAnimationComplete\", \"onLayoutMeasure\", \"onBeforeLayoutMeasure\", \"onAnimationStart\", \"onAnimationComplete\", \"onUpdate\", \"onDragStart\", \"onDrag\", \"onDragEnd\", \"onMeasureDragConstraints\", \"onDirectionLock\", \"onDragTransitionEnd\", \"drag\", \"dragControls\", \"dragListener\", \"dragConstraints\", \"dragDirectionLock\", \"dragSnapToOrigin\", \"_dragX\", \"_dragY\", \"dragElastic\", \"dragMomentum\", \"dragPropagation\", \"dragTransition\", \"whileDrag\", \"onPan\", \"onPanStart\", \"onPanEnd\", \"onPanSessionStart\", \"onTap\", \"onTapStart\", \"onTapCancel\", \"onHoverStart\", \"onHoverEnd\", \"whileFocus\", \"whileTap\", \"whileHover\", \"whileInView\", \"onViewportEnter\", \"onViewportLeave\", \"viewport\", \"layoutScroll\"]);\n-                /**\n-                 * Check whether a prop name is a valid `MotionProp` key.\n-                 *\n-                 * @param key - Name of the property to check\n-                 * @returns `true` is key is a valid `MotionProp`.\n-                 *\n-                 * @public\n-                 */\n-                function isValidMotionProp(key) {\n-                    return validMotionProps.has(key);\n-                }\n-                var shouldForward = function(key) {\n-                    return !isValidMotionProp(key);\n-                };\n+                    function hasBadBidiRects(measure) {\n+                        if (badBidiRects != null) {\n+                            return badBidiRects;\n+                        }\n+                        var txt = removeChildrenAndAdd(measure, document.createTextNode(\"A\\u062eA\"));\n+                        var r0 = range(txt, 0, 1).getBoundingClientRect();\n+                        var r1 = range(txt, 1, 2).getBoundingClientRect();\n+                        removeChildren(measure);\n+                        if (!r0 || r0.left == r0.right) {\n+                            return false;\n+                        } // Safari returns null in some cases (#2780)\n+                        return badBidiRects = r1.right - r0.right < 3;\n+                    }\n \n-                function loadExternalIsValidProp(isValidProp) {\n-                    if (!isValidProp) return;\n-                    // Explicitly filter our events\n-                    shouldForward = function(key) {\n-                        return key.startsWith(\"on\") ? !isValidMotionProp(key) : isValidProp(key);\n+                    // See if \"\".split is the broken IE version, if so, provide an\n+                    // alternative way to split lines.\n+                    var splitLinesAuto = \"\\n\\nb\".split(/\\n/).length != 3 ? function(string) {\n+                        var pos = 0,\n+                            result = [],\n+                            l = string.length;\n+                        while (pos <= l) {\n+                            var nl = string.indexOf(\"\\n\", pos);\n+                            if (nl == -1) {\n+                                nl = string.length;\n+                            }\n+                            var line = string.slice(pos, string.charAt(nl - 1) == \"\\r\" ? nl - 1 : nl);\n+                            var rt = line.indexOf(\"\\r\");\n+                            if (rt != -1) {\n+                                result.push(line.slice(0, rt));\n+                                pos += rt + 1;\n+                            } else {\n+                                result.push(line);\n+                                pos = nl + 1;\n+                            }\n+                        }\n+                        return result;\n+                    } : function(string) {\n+                        return string.split(/\\r\\n?|\\n/);\n                     };\n-                }\n-                /**\n-                 * Emotion and Styled Components both allow users to pass through arbitrary props to their components\n-                 * to dynamically generate CSS. They both use the `@emotion/is-prop-valid` package to determine which\n-                 * of these should be passed to the underlying DOM node.\n-                 *\n-                 * However, when styling a Motion component `styled(motion.div)`, both packages pass through *all* props\n-                 * as it's seen as an arbitrary component rather than a DOM node. Motion only allows arbitrary props\n-                 * passed through the `custom` prop so it doesn't *need* the payload or computational overhead of\n-                 * `@emotion/is-prop-valid`, however to fix this problem we need to use it.\n-                 *\n-                 * By making it an optionalDependency we can offer this functionality only in the situations where it's\n-                 * actually required.\n-                 */\n-                try {\n-                    /**\n-                     * We attempt to import this package but require won't be defined in esm environments, in that case\n-                     * isPropValid will have to be provided via `MotionContext`. In a 6.0.0 this should probably be removed\n-                     * in favour of explicit injection.\n-                     */\n-                    loadExternalIsValidProp((__webpack_require__( /*! @emotion/is-prop-valid */ \"../../../node_modules/@emotion/is-prop-valid/dist/is-prop-valid.browser.esm.js\")[\"default\"]));\n-                } catch (_a) {\n-                    // We don't need to actually do anything here - the fallback is the existing `isPropValid`.\n-                }\n+                    var hasSelection = window.getSelection ? function(te) {\n+                        try {\n+                            return te.selectionStart != te.selectionEnd;\n+                        } catch (e) {\n+                            return false;\n+                        }\n+                    } : function(te) {\n+                        var range;\n+                        try {\n+                            range = te.ownerDocument.selection.createRange();\n+                        } catch (e) {}\n+                        if (!range || range.parentElement() != te) {\n+                            return false;\n+                        }\n+                        return range.compareEndPoints(\"StartToEnd\", range) != 0;\n+                    };\n+                    var hasCopyEvent = function() {\n+                        var e = elt(\"div\");\n+                        if (\"oncopy\" in e) {\n+                            return true;\n+                        }\n+                        e.setAttribute(\"oncopy\", \"return;\");\n+                        return typeof e.oncopy == \"function\";\n+                    }();\n+                    var badZoomedRects = null;\n \n-                function filterProps(props, isDom, forwardMotionProps) {\n-                    var filteredProps = {};\n-                    for (var key in props) {\n-                        if (shouldForward(key) || forwardMotionProps === true && isValidMotionProp(key) || !isDom && !isValidMotionProp(key) ||\n-                            // If trying to use native HTML drag events, forward drag listeners\n-                            props[\"draggable\"] && key.startsWith(\"onDrag\")) {\n-                            filteredProps[key] = props[key];\n+                    function hasBadZoomedRects(measure) {\n+                        if (badZoomedRects != null) {\n+                            return badZoomedRects;\n+                        }\n+                        var node = removeChildrenAndAdd(measure, elt(\"span\", \"x\"));\n+                        var normal = node.getBoundingClientRect();\n+                        var fromRange = range(node, 0, 1).getBoundingClientRect();\n+                        return badZoomedRects = Math.abs(normal.left - fromRange.left) > 1;\n+                    }\n+\n+                    // Known modes, by name and by MIME\n+                    var modes = {},\n+                        mimeModes = {};\n+\n+                    // Extra arguments are stored as the mode's dependencies, which is\n+                    // used by (legacy) mechanisms like loadmode.js to automatically\n+                    // load a mode. (Preferred mechanism is the require/define calls.)\n+                    function defineMode(name, mode) {\n+                        if (arguments.length > 2) {\n+                            mode.dependencies = Array.prototype.slice.call(arguments, 2);\n+                        }\n+                        modes[name] = mode;\n+                    }\n+\n+                    function defineMIME(mime, spec) {\n+                        mimeModes[mime] = spec;\n+                    }\n+\n+                    // Given a MIME type, a {name, ...options} config object, or a name\n+                    // string, return a mode config object.\n+                    function resolveMode(spec) {\n+                        if (typeof spec == \"string\" && mimeModes.hasOwnProperty(spec)) {\n+                            spec = mimeModes[spec];\n+                        } else if (spec && typeof spec.name == \"string\" && mimeModes.hasOwnProperty(spec.name)) {\n+                            var found = mimeModes[spec.name];\n+                            if (typeof found == \"string\") {\n+                                found = {\n+                                    name: found\n+                                };\n+                            }\n+                            spec = createObj(found, spec);\n+                            spec.name = found.name;\n+                        } else if (typeof spec == \"string\" && /^[\\w\\-]+\\/[\\w\\-]+\\+xml$/.test(spec)) {\n+                            return resolveMode(\"application/xml\");\n+                        } else if (typeof spec == \"string\" && /^[\\w\\-]+\\/[\\w\\-]+\\+json$/.test(spec)) {\n+                            return resolveMode(\"application/json\");\n+                        }\n+                        if (typeof spec == \"string\") {\n+                            return {\n+                                name: spec\n+                            };\n+                        } else {\n+                            return spec || {\n+                                name: \"null\"\n+                            };\n                         }\n                     }\n-                    return filteredProps;\n-                }\n \n-                function calcOrigin$1(origin, offset, size) {\n-                    return typeof origin === \"string\" ? origin : styleValueTypes.px.transform(offset + size * origin);\n-                }\n-                /**\n-                 * The SVG transform origin defaults are different to CSS and is less intuitive,\n-                 * so we use the measured dimensions of the SVG to reconcile these.\n-                 */\n-                function calcSVGTransformOrigin(dimensions, originX, originY) {\n-                    var pxOriginX = calcOrigin$1(originX, dimensions.x, dimensions.width);\n-                    var pxOriginY = calcOrigin$1(originY, dimensions.y, dimensions.height);\n-                    return \"\".concat(pxOriginX, \" \").concat(pxOriginY);\n-                }\n-                var dashKeys = {\n-                    offset: \"stroke-dashoffset\",\n-                    array: \"stroke-dasharray\"\n-                };\n-                var camelKeys = {\n-                    offset: \"strokeDashoffset\",\n-                    array: \"strokeDasharray\"\n-                };\n-                /**\n-                 * Build SVG path properties. Uses the path's measured length to convert\n-                 * our custom pathLength, pathSpacing and pathOffset into stroke-dashoffset\n-                 * and stroke-dasharray attributes.\n-                 *\n-                 * This function is mutative to reduce per-frame GC.\n-                 */\n-                function buildSVGPath(attrs, length, spacing, offset, useDashCase) {\n-                    if (spacing === void 0) {\n-                        spacing = 1;\n-                    }\n-                    if (offset === void 0) {\n-                        offset = 0;\n+                    // Given a mode spec (anything that resolveMode accepts), find and\n+                    // initialize an actual mode object.\n+                    function getMode(options, spec) {\n+                        spec = resolveMode(spec);\n+                        var mfactory = modes[spec.name];\n+                        if (!mfactory) {\n+                            return getMode(options, \"text/plain\");\n+                        }\n+                        var modeObj = mfactory(options, spec);\n+                        if (modeExtensions.hasOwnProperty(spec.name)) {\n+                            var exts = modeExtensions[spec.name];\n+                            for (var prop in exts) {\n+                                if (!exts.hasOwnProperty(prop)) {\n+                                    continue;\n+                                }\n+                                if (modeObj.hasOwnProperty(prop)) {\n+                                    modeObj[\"_\" + prop] = modeObj[prop];\n+                                }\n+                                modeObj[prop] = exts[prop];\n+                            }\n+                        }\n+                        modeObj.name = spec.name;\n+                        if (spec.helperType) {\n+                            modeObj.helperType = spec.helperType;\n+                        }\n+                        if (spec.modeProps) {\n+                            for (var prop$1 in spec.modeProps) {\n+                                modeObj[prop$1] = spec.modeProps[prop$1];\n+                            }\n+                        }\n+                        return modeObj;\n                     }\n-                    if (useDashCase === void 0) {\n-                        useDashCase = true;\n+\n+                    // This can be used to attach properties to mode objects from\n+                    // outside the actual mode definition.\n+                    var modeExtensions = {};\n+\n+                    function extendMode(mode, properties) {\n+                        var exts = modeExtensions.hasOwnProperty(mode) ? modeExtensions[mode] : modeExtensions[mode] = {};\n+                        copyObj(properties, exts);\n                     }\n-                    // Normalise path length by setting SVG attribute pathLength to 1\n-                    attrs.pathLength = 1;\n-                    // We use dash case when setting attributes directly to the DOM node and camel case\n-                    // when defining props on a React component.\n-                    var keys = useDashCase ? dashKeys : camelKeys;\n-                    // Build the dash offset\n-                    attrs[keys.offset] = styleValueTypes.px.transform(-offset);\n-                    // Build the dash array\n-                    var pathLength = styleValueTypes.px.transform(length);\n-                    var pathSpacing = styleValueTypes.px.transform(spacing);\n-                    attrs[keys.array] = \"\".concat(pathLength, \" \").concat(pathSpacing);\n-                }\n \n-                /**\n-                 * Build SVG visual attrbutes, like cx and style.transform\n-                 */\n-                function buildSVGAttrs(state, _a, options, transformTemplate) {\n-                    var attrX = _a.attrX,\n-                        attrY = _a.attrY,\n-                        originX = _a.originX,\n-                        originY = _a.originY,\n-                        pathLength = _a.pathLength,\n-                        _b = _a.pathSpacing,\n-                        pathSpacing = _b === void 0 ? 1 : _b,\n-                        _c = _a.pathOffset,\n-                        pathOffset = _c === void 0 ? 0 : _c,\n-                        // This is object creation, which we try to avoid per-frame.\n-                        latest = tslib.__rest(_a, [\"attrX\", \"attrY\", \"originX\", \"originY\", \"pathLength\", \"pathSpacing\", \"pathOffset\"]);\n-                    buildHTMLStyles(state, latest, options, transformTemplate);\n-                    state.attrs = state.style;\n-                    state.style = {};\n-                    var attrs = state.attrs,\n-                        style = state.style,\n-                        dimensions = state.dimensions;\n-                    /**\n-                     * However, we apply transforms as CSS transforms. So if we detect a transform we take it from attrs\n-                     * and copy it into style.\n-                     */\n-                    if (attrs.transform) {\n-                        if (dimensions) style.transform = attrs.transform;\n-                        delete attrs.transform;\n+                    function copyState(mode, state) {\n+                        if (state === true) {\n+                            return state;\n+                        }\n+                        if (mode.copyState) {\n+                            return mode.copyState(state);\n+                        }\n+                        var nstate = {};\n+                        for (var n in state) {\n+                            var val = state[n];\n+                            if (val instanceof Array) {\n+                                val = val.concat([]);\n+                            }\n+                            nstate[n] = val;\n+                        }\n+                        return nstate;\n+                    }\n+\n+                    // Given a mode and a state (for that mode), find the inner mode and\n+                    // state at the position that the state refers to.\n+                    function innerMode(mode, state) {\n+                        var info;\n+                        while (mode.innerMode) {\n+                            info = mode.innerMode(state);\n+                            if (!info || info.mode == mode) {\n+                                break;\n+                            }\n+                            state = info.state;\n+                            mode = info.mode;\n+                        }\n+                        return info || {\n+                            mode: mode,\n+                            state: state\n+                        };\n                     }\n-                    // Parse transformOrigin\n-                    if (dimensions && (originX !== undefined || originY !== undefined || style.transform)) {\n-                        style.transformOrigin = calcSVGTransformOrigin(dimensions, originX !== undefined ? originX : 0.5, originY !== undefined ? originY : 0.5);\n+\n+                    function startState(mode, a1, a2) {\n+                        return mode.startState ? mode.startState(a1, a2) : true;\n                     }\n-                    // Treat x/y not as shortcuts but as actual attributes\n-                    if (attrX !== undefined) attrs.x = attrX;\n-                    if (attrY !== undefined) attrs.y = attrY;\n-                    // Build SVG path if one has been defined\n-                    if (pathLength !== undefined) {\n-                        buildSVGPath(attrs, pathLength, pathSpacing, pathOffset, false);\n+\n+                    // STRING STREAM\n+\n+                    // Fed to the mode parsers, provides helper functions to make\n+                    // parsers more succinct.\n+\n+                    var StringStream = function(string, tabSize, lineOracle) {\n+                        this.pos = this.start = 0;\n+                        this.string = string;\n+                        this.tabSize = tabSize || 8;\n+                        this.lastColumnPos = this.lastColumnValue = 0;\n+                        this.lineStart = 0;\n+                        this.lineOracle = lineOracle;\n+                    };\n+                    StringStream.prototype.eol = function() {\n+                        return this.pos >= this.string.length;\n+                    };\n+                    StringStream.prototype.sol = function() {\n+                        return this.pos == this.lineStart;\n+                    };\n+                    StringStream.prototype.peek = function() {\n+                        return this.string.charAt(this.pos) || undefined;\n+                    };\n+                    StringStream.prototype.next = function() {\n+                        if (this.pos < this.string.length) {\n+                            return this.string.charAt(this.pos++);\n+                        }\n+                    };\n+                    StringStream.prototype.eat = function(match) {\n+                        var ch = this.string.charAt(this.pos);\n+                        var ok;\n+                        if (typeof match == \"string\") {\n+                            ok = ch == match;\n+                        } else {\n+                            ok = ch && (match.test ? match.test(ch) : match(ch));\n+                        }\n+                        if (ok) {\n+                            ++this.pos;\n+                            return ch;\n+                        }\n+                    };\n+                    StringStream.prototype.eatWhile = function(match) {\n+                        var start = this.pos;\n+                        while (this.eat(match)) {}\n+                        return this.pos > start;\n+                    };\n+                    StringStream.prototype.eatSpace = function() {\n+                        var start = this.pos;\n+                        while (/[\\s\\u00a0]/.test(this.string.charAt(this.pos))) {\n+                            ++this.pos;\n+                        }\n+                        return this.pos > start;\n+                    };\n+                    StringStream.prototype.skipToEnd = function() {\n+                        this.pos = this.string.length;\n+                    };\n+                    StringStream.prototype.skipTo = function(ch) {\n+                        var found = this.string.indexOf(ch, this.pos);\n+                        if (found > -1) {\n+                            this.pos = found;\n+                            return true;\n+                        }\n+                    };\n+                    StringStream.prototype.backUp = function(n) {\n+                        this.pos -= n;\n+                    };\n+                    StringStream.prototype.column = function() {\n+                        if (this.lastColumnPos < this.start) {\n+                            this.lastColumnValue = countColumn(this.string, this.start, this.tabSize, this.lastColumnPos, this.lastColumnValue);\n+                            this.lastColumnPos = this.start;\n+                        }\n+                        return this.lastColumnValue - (this.lineStart ? countColumn(this.string, this.lineStart, this.tabSize) : 0);\n+                    };\n+                    StringStream.prototype.indentation = function() {\n+                        return countColumn(this.string, null, this.tabSize) - (this.lineStart ? countColumn(this.string, this.lineStart, this.tabSize) : 0);\n+                    };\n+                    StringStream.prototype.match = function(pattern, consume, caseInsensitive) {\n+                        if (typeof pattern == \"string\") {\n+                            var cased = function(str) {\n+                                return caseInsensitive ? str.toLowerCase() : str;\n+                            };\n+                            var substr = this.string.substr(this.pos, pattern.length);\n+                            if (cased(substr) == cased(pattern)) {\n+                                if (consume !== false) {\n+                                    this.pos += pattern.length;\n+                                }\n+                                return true;\n+                            }\n+                        } else {\n+                            var match = this.string.slice(this.pos).match(pattern);\n+                            if (match && match.index > 0) {\n+                                return null;\n+                            }\n+                            if (match && consume !== false) {\n+                                this.pos += match[0].length;\n+                            }\n+                            return match;\n+                        }\n+                    };\n+                    StringStream.prototype.current = function() {\n+                        return this.string.slice(this.start, this.pos);\n+                    };\n+                    StringStream.prototype.hideFirstChars = function(n, inner) {\n+                        this.lineStart += n;\n+                        try {\n+                            return inner();\n+                        } finally {\n+                            this.lineStart -= n;\n+                        }\n+                    };\n+                    StringStream.prototype.lookAhead = function(n) {\n+                        var oracle = this.lineOracle;\n+                        return oracle && oracle.lookAhead(n);\n+                    };\n+                    StringStream.prototype.baseToken = function() {\n+                        var oracle = this.lineOracle;\n+                        return oracle && oracle.baseToken(this.pos);\n+                    };\n+\n+                    // Find the line object corresponding to the given line number.\n+                    function getLine(doc, n) {\n+                        n -= doc.first;\n+                        if (n < 0 || n >= doc.size) {\n+                            throw new Error(\"There is no line \" + (n + doc.first) + \" in the document.\");\n+                        }\n+                        var chunk = doc;\n+                        while (!chunk.lines) {\n+                            for (var i = 0;; ++i) {\n+                                var child = chunk.children[i],\n+                                    sz = child.chunkSize();\n+                                if (n < sz) {\n+                                    chunk = child;\n+                                    break;\n+                                }\n+                                n -= sz;\n+                            }\n+                        }\n+                        return chunk.lines[n];\n                     }\n-                }\n-                var createSvgRenderState = function() {\n-                    return tslib.__assign(tslib.__assign({}, createHtmlRenderState()), {\n-                        attrs: {}\n-                    });\n-                };\n \n-                function useSVGProps(props, visualState) {\n-                    var visualProps = React.useMemo(function() {\n-                        var state = createSvgRenderState();\n-                        buildSVGAttrs(state, visualState, {\n-                            enableHardwareAcceleration: false\n-                        }, props.transformTemplate);\n-                        return tslib.__assign(tslib.__assign({}, state.attrs), {\n-                            style: tslib.__assign({}, state.style)\n+                    // Get the part of a document between two positions, as an array of\n+                    // strings.\n+                    function getBetween(doc, start, end) {\n+                        var out = [],\n+                            n = start.line;\n+                        doc.iter(start.line, end.line + 1, function(line) {\n+                            var text = line.text;\n+                            if (n == end.line) {\n+                                text = text.slice(0, end.ch);\n+                            }\n+                            if (n == start.line) {\n+                                text = text.slice(start.ch);\n+                            }\n+                            out.push(text);\n+                            ++n;\n                         });\n-                    }, [visualState]);\n-                    if (props.style) {\n-                        var rawStyles = {};\n-                        copyRawValuesOnly(rawStyles, props.style, props);\n-                        visualProps.style = tslib.__assign(tslib.__assign({}, rawStyles), visualProps.style);\n+                        return out;\n+                    }\n+                    // Get the lines between from and to, as array of strings.\n+                    function getLines(doc, from, to) {\n+                        var out = [];\n+                        doc.iter(from, to, function(line) {\n+                            out.push(line.text);\n+                        }); // iter aborts when callback returns truthy value\n+                        return out;\n                     }\n-                    return visualProps;\n-                }\n \n-                function createUseRender(forwardMotionProps) {\n-                    if (forwardMotionProps === void 0) {\n-                        forwardMotionProps = false;\n+                    // Update the height of a line, propagating the height change\n+                    // upwards to parent nodes.\n+                    function updateLineHeight(line, height) {\n+                        var diff = height - line.height;\n+                        if (diff) {\n+                            for (var n = line; n; n = n.parent) {\n+                                n.height += diff;\n+                            }\n+                        }\n                     }\n-                    var useRender = function(Component, props, projectionId, ref, _a, isStatic) {\n-                        var latestValues = _a.latestValues;\n-                        var useVisualProps = isSVGComponent(Component) ? useSVGProps : useHTMLProps;\n-                        var visualProps = useVisualProps(props, latestValues, isStatic);\n-                        var filteredProps = filterProps(props, typeof Component === \"string\", forwardMotionProps);\n-                        var elementProps = tslib.__assign(tslib.__assign(tslib.__assign({}, filteredProps), visualProps), {\n-                            ref: ref\n-                        });\n-                        if (projectionId) {\n-                            elementProps[\"data-projection-id\"] = projectionId;\n+\n+                    // Given a line object, find its line number by walking up through\n+                    // its parent links.\n+                    function lineNo(line) {\n+                        if (line.parent == null) {\n+                            return null;\n                         }\n-                        return React.createElement(Component, elementProps);\n-                    };\n-                    return useRender;\n-                }\n-                var CAMEL_CASE_PATTERN = /([a-z])([A-Z])/g;\n-                var REPLACE_TEMPLATE = \"$1-$2\";\n-                /**\n-                 * Convert camelCase to dash-case properties.\n-                 */\n-                var camelToDash = function(str) {\n-                    return str.replace(CAMEL_CASE_PATTERN, REPLACE_TEMPLATE).toLowerCase();\n-                };\n+                        var cur = line.parent,\n+                            no = indexOf(cur.lines, line);\n+                        for (var chunk = cur.parent; chunk; cur = chunk, chunk = chunk.parent) {\n+                            for (var i = 0;; ++i) {\n+                                if (chunk.children[i] == cur) {\n+                                    break;\n+                                }\n+                                no += chunk.children[i].chunkSize();\n+                            }\n+                        }\n+                        return no + cur.first;\n+                    }\n \n-                function renderHTML(element, _a, styleProp, projection) {\n-                    var style = _a.style,\n-                        vars = _a.vars;\n-                    Object.assign(element.style, style, projection && projection.getProjectionStyles(styleProp));\n-                    // Loop over any CSS variables and assign those.\n-                    for (var key in vars) {\n-                        element.style.setProperty(key, vars[key]);\n+                    // Find the line at the given vertical position, using the height\n+                    // information in the document tree.\n+                    function lineAtHeight(chunk, h) {\n+                        var n = chunk.first;\n+                        outer: do {\n+                            for (var i$1 = 0; i$1 < chunk.children.length; ++i$1) {\n+                                var child = chunk.children[i$1],\n+                                    ch = child.height;\n+                                if (h < ch) {\n+                                    chunk = child;\n+                                    continue outer;\n+                                }\n+                                h -= ch;\n+                                n += child.chunkSize();\n+                            }\n+                            return n;\n+                        } while (!chunk.lines);\n+                        var i = 0;\n+                        for (; i < chunk.lines.length; ++i) {\n+                            var line = chunk.lines[i],\n+                                lh = line.height;\n+                            if (h < lh) {\n+                                break;\n+                            }\n+                            h -= lh;\n+                        }\n+                        return n + i;\n                     }\n-                }\n \n-                /**\n-                 * A set of attribute names that are always read/written as camel case.\n-                 */\n-                var camelCaseAttributes = new Set([\"baseFrequency\", \"diffuseConstant\", \"kernelMatrix\", \"kernelUnitLength\", \"keySplines\", \"keyTimes\", \"limitingConeAngle\", \"markerHeight\", \"markerWidth\", \"numOctaves\", \"targetX\", \"targetY\", \"surfaceScale\", \"specularConstant\", \"specularExponent\", \"stdDeviation\", \"tableValues\", \"viewBox\", \"gradientTransform\", \"pathLength\"]);\n+                    function isLine(doc, l) {\n+                        return l >= doc.first && l < doc.first + doc.size;\n+                    }\n \n-                function renderSVG(element, renderState, _styleProp, projection) {\n-                    renderHTML(element, renderState, undefined, projection);\n-                    for (var key in renderState.attrs) {\n-                        element.setAttribute(!camelCaseAttributes.has(key) ? camelToDash(key) : key, renderState.attrs[key]);\n+                    function lineNumberFor(options, i) {\n+                        return String(options.lineNumberFormatter(i + options.firstLineNumber));\n                     }\n-                }\n \n-                function scrapeMotionValuesFromProps$1(props) {\n-                    var style = props.style;\n-                    var newValues = {};\n-                    for (var key in style) {\n-                        if (isMotionValue(style[key]) || isForcedMotionValue(key, props)) {\n-                            newValues[key] = style[key];\n+                    // A Pos instance represents a position within the text.\n+                    function Pos(line, ch, sticky) {\n+                        if (sticky === void 0) sticky = null;\n+                        if (!(this instanceof Pos)) {\n+                            return new Pos(line, ch, sticky);\n                         }\n+                        this.line = line;\n+                        this.ch = ch;\n+                        this.sticky = sticky;\n                     }\n-                    return newValues;\n-                }\n \n-                function scrapeMotionValuesFromProps(props) {\n-                    var newValues = scrapeMotionValuesFromProps$1(props);\n-                    for (var key in props) {\n-                        if (isMotionValue(props[key])) {\n-                            var targetKey = key === \"x\" || key === \"y\" ? \"attr\" + key.toUpperCase() : key;\n-                            newValues[targetKey] = props[key];\n-                        }\n+                    // Compare two positions, return 0 if they are the same, a negative\n+                    // number when a is less, and a positive number otherwise.\n+                    function cmp(a, b) {\n+                        return a.line - b.line || a.ch - b.ch;\n                     }\n-                    return newValues;\n-                }\n \n-                function isAnimationControls(v) {\n-                    return typeof v === \"object\" && typeof v.start === \"function\";\n-                }\n-                var isKeyframesTarget = function(v) {\n-                    return Array.isArray(v);\n-                };\n-                var isCustomValue = function(v) {\n-                    return Boolean(v && typeof v === \"object\" && v.mix && v.toValue);\n-                };\n-                var resolveFinalValueInKeyframes = function(v) {\n-                    // TODO maybe throw if v.length - 1 is placeholder token?\n-                    return isKeyframesTarget(v) ? v[v.length - 1] || 0 : v;\n-                };\n+                    function equalCursorPos(a, b) {\n+                        return a.sticky == b.sticky && cmp(a, b) == 0;\n+                    }\n \n-                /**\n-                 * If the provided value is a MotionValue, this returns the actual value, otherwise just the value itself\n-                 *\n-                 * TODO: Remove and move to library\n-                 */\n-                function resolveMotionValue(value) {\n-                    var unwrappedValue = isMotionValue(value) ? value.get() : value;\n-                    return isCustomValue(unwrappedValue) ? unwrappedValue.toValue() : unwrappedValue;\n-                }\n+                    function copyPos(x) {\n+                        return Pos(x.line, x.ch);\n+                    }\n \n-                function makeState(_a, props, context, presenceContext) {\n-                    var scrapeMotionValuesFromProps = _a.scrapeMotionValuesFromProps,\n-                        createRenderState = _a.createRenderState,\n-                        onMount = _a.onMount;\n-                    var state = {\n-                        latestValues: makeLatestValues(props, context, presenceContext, scrapeMotionValuesFromProps),\n-                        renderState: createRenderState()\n+                    function maxPos(a, b) {\n+                        return cmp(a, b) < 0 ? b : a;\n+                    }\n+\n+                    function minPos(a, b) {\n+                        return cmp(a, b) < 0 ? a : b;\n+                    }\n+\n+                    // Most of the external API clips given positions to make sure they\n+                    // actually exist within the document.\n+                    function clipLine(doc, n) {\n+                        return Math.max(doc.first, Math.min(n, doc.first + doc.size - 1));\n+                    }\n+\n+                    function clipPos(doc, pos) {\n+                        if (pos.line < doc.first) {\n+                            return Pos(doc.first, 0);\n+                        }\n+                        var last = doc.first + doc.size - 1;\n+                        if (pos.line > last) {\n+                            return Pos(last, getLine(doc, last).text.length);\n+                        }\n+                        return clipToLen(pos, getLine(doc, pos.line).text.length);\n+                    }\n+\n+                    function clipToLen(pos, linelen) {\n+                        var ch = pos.ch;\n+                        if (ch == null || ch > linelen) {\n+                            return Pos(pos.line, linelen);\n+                        } else if (ch < 0) {\n+                            return Pos(pos.line, 0);\n+                        } else {\n+                            return pos;\n+                        }\n+                    }\n+\n+                    function clipPosArray(doc, array) {\n+                        var out = [];\n+                        for (var i = 0; i < array.length; i++) {\n+                            out[i] = clipPos(doc, array[i]);\n+                        }\n+                        return out;\n+                    }\n+                    var SavedContext = function(state, lookAhead) {\n+                        this.state = state;\n+                        this.lookAhead = lookAhead;\n                     };\n-                    if (onMount) {\n-                        state.mount = function(instance) {\n-                            return onMount(props, instance, state);\n+                    var Context = function(doc, state, line, lookAhead) {\n+                        this.state = state;\n+                        this.doc = doc;\n+                        this.line = line;\n+                        this.maxLookAhead = lookAhead || 0;\n+                        this.baseTokens = null;\n+                        this.baseTokenPos = 1;\n+                    };\n+                    Context.prototype.lookAhead = function(n) {\n+                        var line = this.doc.getLine(this.line + n);\n+                        if (line != null && n > this.maxLookAhead) {\n+                            this.maxLookAhead = n;\n+                        }\n+                        return line;\n+                    };\n+                    Context.prototype.baseToken = function(n) {\n+                        if (!this.baseTokens) {\n+                            return null;\n+                        }\n+                        while (this.baseTokens[this.baseTokenPos] <= n) {\n+                            this.baseTokenPos += 2;\n+                        }\n+                        var type = this.baseTokens[this.baseTokenPos + 1];\n+                        return {\n+                            type: type && type.replace(/( |^)overlay .*/, \"\"),\n+                            size: this.baseTokens[this.baseTokenPos] - n\n                         };\n-                    }\n-                    return state;\n-                }\n-                var makeUseVisualState = function(config) {\n-                    return function(props, isStatic) {\n-                        var context = React.useContext(MotionContext);\n-                        var presenceContext = React.useContext(PresenceContext);\n-                        return isStatic ? makeState(config, props, context, presenceContext) : useConstant(function() {\n-                            return makeState(config, props, context, presenceContext);\n-                        });\n                     };\n-                };\n+                    Context.prototype.nextLine = function() {\n+                        this.line++;\n+                        if (this.maxLookAhead > 0) {\n+                            this.maxLookAhead--;\n+                        }\n+                    };\n+                    Context.fromSaved = function(doc, saved, line) {\n+                        if (saved instanceof SavedContext) {\n+                            return new Context(doc, copyState(doc.mode, saved.state), line, saved.lookAhead);\n+                        } else {\n+                            return new Context(doc, copyState(doc.mode, saved), line);\n+                        }\n+                    };\n+                    Context.prototype.save = function(copy) {\n+                        var state = copy !== false ? copyState(this.doc.mode, this.state) : this.state;\n+                        return this.maxLookAhead > 0 ? new SavedContext(state, this.maxLookAhead) : state;\n+                    };\n+\n+                    // Compute a style array (an array starting with a mode generation\n+                    // -- for invalidation -- followed by pairs of end positions and\n+                    // style strings), which is used to highlight the tokens on the\n+                    // line.\n+                    function highlightLine(cm, line, context, forceToEnd) {\n+                        // A styles array always starts with a number identifying the\n+                        // mode/overlays that it is based on (for easy invalidation).\n+                        var st = [cm.state.modeGen],\n+                            lineClasses = {};\n+                        // Compute the base array of styles\n+                        runMode(cm, line.text, cm.doc.mode, context, function(end, style) {\n+                            return st.push(end, style);\n+                        }, lineClasses, forceToEnd);\n+                        var state = context.state;\n+\n+                        // Run overlays, adjust style array.\n+                        var loop = function(o) {\n+                            context.baseTokens = st;\n+                            var overlay = cm.state.overlays[o],\n+                                i = 1,\n+                                at = 0;\n+                            context.state = true;\n+                            runMode(cm, line.text, overlay.mode, context, function(end, style) {\n+                                var start = i;\n+                                // Ensure there's a token end at the current position, and that i points at it\n+                                while (at < end) {\n+                                    var i_end = st[i];\n+                                    if (i_end > end) {\n+                                        st.splice(i, 1, end, st[i + 1], i_end);\n+                                    }\n+                                    i += 2;\n+                                    at = Math.min(end, i_end);\n+                                }\n+                                if (!style) {\n+                                    return;\n+                                }\n+                                if (overlay.opaque) {\n+                                    st.splice(start, i - start, end, \"overlay \" + style);\n+                                    i = start + 2;\n+                                } else {\n+                                    for (; start < i; start += 2) {\n+                                        var cur = st[start + 1];\n+                                        st[start + 1] = (cur ? cur + \" \" : \"\") + \"overlay \" + style;\n+                                    }\n+                                }\n+                            }, lineClasses);\n+                            context.state = state;\n+                            context.baseTokens = null;\n+                            context.baseTokenPos = 1;\n+                        };\n+                        for (var o = 0; o < cm.state.overlays.length; ++o) loop(o);\n+                        return {\n+                            styles: st,\n+                            classes: lineClasses.bgClass || lineClasses.textClass ? lineClasses : null\n+                        };\n+                    }\n \n-                function makeLatestValues(props, context, presenceContext, scrapeMotionValues) {\n-                    var values = {};\n-                    var blockInitialAnimation = (presenceContext === null || presenceContext === void 0 ? void 0 : presenceContext.initial) === false;\n-                    var motionValues = scrapeMotionValues(props);\n-                    for (var key in motionValues) {\n-                        values[key] = resolveMotionValue(motionValues[key]);\n+                    function getLineStyles(cm, line, updateFrontier) {\n+                        if (!line.styles || line.styles[0] != cm.state.modeGen) {\n+                            var context = getContextBefore(cm, lineNo(line));\n+                            var resetState = line.text.length > cm.options.maxHighlightLength && copyState(cm.doc.mode, context.state);\n+                            var result = highlightLine(cm, line, context);\n+                            if (resetState) {\n+                                context.state = resetState;\n+                            }\n+                            line.stateAfter = context.save(!resetState);\n+                            line.styles = result.styles;\n+                            if (result.classes) {\n+                                line.styleClasses = result.classes;\n+                            } else if (line.styleClasses) {\n+                                line.styleClasses = null;\n+                            }\n+                            if (updateFrontier === cm.doc.highlightFrontier) {\n+                                cm.doc.modeFrontier = Math.max(cm.doc.modeFrontier, ++cm.doc.highlightFrontier);\n+                            }\n+                        }\n+                        return line.styles;\n+                    }\n+\n+                    function getContextBefore(cm, n, precise) {\n+                        var doc = cm.doc,\n+                            display = cm.display;\n+                        if (!doc.mode.startState) {\n+                            return new Context(doc, true, n);\n+                        }\n+                        var start = findStartLine(cm, n, precise);\n+                        var saved = start > doc.first && getLine(doc, start - 1).stateAfter;\n+                        var context = saved ? Context.fromSaved(doc, saved, start) : new Context(doc, startState(doc.mode), start);\n+                        doc.iter(start, n, function(line) {\n+                            processLine(cm, line.text, context);\n+                            var pos = context.line;\n+                            line.stateAfter = pos == n - 1 || pos % 5 == 0 || pos >= display.viewFrom && pos < display.viewTo ? context.save() : null;\n+                            context.nextLine();\n+                        });\n+                        if (precise) {\n+                            doc.modeFrontier = context.line;\n+                        }\n+                        return context;\n+                    }\n+\n+                    // Lightweight form of highlight -- proceed over this line and\n+                    // update state, but don't save a style array. Used for lines that\n+                    // aren't currently visible.\n+                    function processLine(cm, text, context, startAt) {\n+                        var mode = cm.doc.mode;\n+                        var stream = new StringStream(text, cm.options.tabSize, context);\n+                        stream.start = stream.pos = startAt || 0;\n+                        if (text == \"\") {\n+                            callBlankLine(mode, context.state);\n+                        }\n+                        while (!stream.eol()) {\n+                            readToken(mode, stream, context.state);\n+                            stream.start = stream.pos;\n+                        }\n                     }\n-                    var initial = props.initial,\n-                        animate = props.animate;\n-                    var isControllingVariants = checkIfControllingVariants(props);\n-                    var isVariantNode = checkIfVariantNode(props);\n-                    if (context && isVariantNode && !isControllingVariants && props.inherit !== false) {\n-                        initial !== null && initial !== void 0 ? initial : initial = context.initial;\n-                        animate !== null && animate !== void 0 ? animate : animate = context.animate;\n+\n+                    function callBlankLine(mode, state) {\n+                        if (mode.blankLine) {\n+                            return mode.blankLine(state);\n+                        }\n+                        if (!mode.innerMode) {\n+                            return;\n+                        }\n+                        var inner = innerMode(mode, state);\n+                        if (inner.mode.blankLine) {\n+                            return inner.mode.blankLine(inner.state);\n+                        }\n                     }\n-                    var initialAnimationIsBlocked = blockInitialAnimation || initial === false;\n-                    var variantToSet = initialAnimationIsBlocked ? animate : initial;\n-                    if (variantToSet && typeof variantToSet !== \"boolean\" && !isAnimationControls(variantToSet)) {\n-                        var list = Array.isArray(variantToSet) ? variantToSet : [variantToSet];\n-                        list.forEach(function(definition) {\n-                            var resolved = resolveVariantFromProps(props, definition);\n-                            if (!resolved) return;\n-                            var transitionEnd = resolved.transitionEnd;\n-                            resolved.transition;\n-                            var target = tslib.__rest(resolved, [\"transitionEnd\", \"transition\"]);\n-                            for (var key in target) {\n-                                var valueTarget = target[key];\n-                                if (Array.isArray(valueTarget)) {\n-                                    /**\n-                                     * Take final keyframe if the initial animation is blocked because\n-                                     * we want to initialise at the end of that blocked animation.\n-                                     */\n-                                    var index = initialAnimationIsBlocked ? valueTarget.length - 1 : 0;\n-                                    valueTarget = valueTarget[index];\n+\n+                    function readToken(mode, stream, state, inner) {\n+                        for (var i = 0; i < 10; i++) {\n+                            if (inner) {\n+                                inner[0] = innerMode(mode, state).mode;\n+                            }\n+                            var style = mode.token(stream, state);\n+                            if (stream.pos > stream.start) {\n+                                return style;\n+                            }\n+                        }\n+                        throw new Error(\"Mode \" + mode.name + \" failed to advance stream.\");\n+                    }\n+                    var Token = function(stream, type, state) {\n+                        this.start = stream.start;\n+                        this.end = stream.pos;\n+                        this.string = stream.current();\n+                        this.type = type || null;\n+                        this.state = state;\n+                    };\n+\n+                    // Utility for getTokenAt and getLineTokens\n+                    function takeToken(cm, pos, precise, asArray) {\n+                        var doc = cm.doc,\n+                            mode = doc.mode,\n+                            style;\n+                        pos = clipPos(doc, pos);\n+                        var line = getLine(doc, pos.line),\n+                            context = getContextBefore(cm, pos.line, precise);\n+                        var stream = new StringStream(line.text, cm.options.tabSize, context),\n+                            tokens;\n+                        if (asArray) {\n+                            tokens = [];\n+                        }\n+                        while ((asArray || stream.pos < pos.ch) && !stream.eol()) {\n+                            stream.start = stream.pos;\n+                            style = readToken(mode, stream, context.state);\n+                            if (asArray) {\n+                                tokens.push(new Token(stream, style, copyState(doc.mode, context.state)));\n+                            }\n+                        }\n+                        return asArray ? tokens : new Token(stream, style, context.state);\n+                    }\n+\n+                    function extractLineClasses(type, output) {\n+                        if (type) {\n+                            for (;;) {\n+                                var lineClass = type.match(/(?:^|\\s+)line-(background-)?(\\S+)/);\n+                                if (!lineClass) {\n+                                    break;\n                                 }\n-                                if (valueTarget !== null) {\n-                                    values[key] = valueTarget;\n+                                type = type.slice(0, lineClass.index) + type.slice(lineClass.index + lineClass[0].length);\n+                                var prop = lineClass[1] ? \"bgClass\" : \"textClass\";\n+                                if (output[prop] == null) {\n+                                    output[prop] = lineClass[2];\n+                                } else if (!new RegExp(\"(?:^|\\\\s)\" + lineClass[2] + \"(?:$|\\\\s)\").test(output[prop])) {\n+                                    output[prop] += \" \" + lineClass[2];\n                                 }\n                             }\n-                            for (var key in transitionEnd) values[key] = transitionEnd[key];\n-                        });\n+                        }\n+                        return type;\n                     }\n-                    return values;\n-                }\n-                var svgMotionConfig = {\n-                    useVisualState: makeUseVisualState({\n-                        scrapeMotionValuesFromProps: scrapeMotionValuesFromProps,\n-                        createRenderState: createSvgRenderState,\n-                        onMount: function(props, instance, _a) {\n-                            var renderState = _a.renderState,\n-                                latestValues = _a.latestValues;\n-                            try {\n-                                renderState.dimensions = typeof instance.getBBox === \"function\" ? instance.getBBox() : instance.getBoundingClientRect();\n-                            } catch (e) {\n-                                // Most likely trying to measure an unrendered element under Firefox\n-                                renderState.dimensions = {\n-                                    x: 0,\n-                                    y: 0,\n-                                    width: 0,\n-                                    height: 0\n-                                };\n+\n+                    // Run the given mode's parser over a line, calling f for each token.\n+                    function runMode(cm, text, mode, context, f, lineClasses, forceToEnd) {\n+                        var flattenSpans = mode.flattenSpans;\n+                        if (flattenSpans == null) {\n+                            flattenSpans = cm.options.flattenSpans;\n+                        }\n+                        var curStart = 0,\n+                            curStyle = null;\n+                        var stream = new StringStream(text, cm.options.tabSize, context),\n+                            style;\n+                        var inner = cm.options.addModeClass && [null];\n+                        if (text == \"\") {\n+                            extractLineClasses(callBlankLine(mode, context.state), lineClasses);\n+                        }\n+                        while (!stream.eol()) {\n+                            if (stream.pos > cm.options.maxHighlightLength) {\n+                                flattenSpans = false;\n+                                if (forceToEnd) {\n+                                    processLine(cm, text, context, stream.pos);\n+                                }\n+                                stream.pos = text.length;\n+                                style = null;\n+                            } else {\n+                                style = extractLineClasses(readToken(mode, stream, context.state, inner), lineClasses);\n                             }\n-                            buildSVGAttrs(renderState, latestValues, {\n-                                enableHardwareAcceleration: false\n-                            }, props.transformTemplate);\n-                            renderSVG(instance, renderState);\n+                            if (inner) {\n+                                var mName = inner[0].name;\n+                                if (mName) {\n+                                    style = \"m-\" + (style ? mName + \" \" + style : mName);\n+                                }\n+                            }\n+                            if (!flattenSpans || curStyle != style) {\n+                                while (curStart < stream.start) {\n+                                    curStart = Math.min(stream.start, curStart + 5000);\n+                                    f(curStart, curStyle);\n+                                }\n+                                curStyle = style;\n+                            }\n+                            stream.start = stream.pos;\n                         }\n-                    })\n-                };\n-                var htmlMotionConfig = {\n-                    useVisualState: makeUseVisualState({\n-                        scrapeMotionValuesFromProps: scrapeMotionValuesFromProps$1,\n-                        createRenderState: createHtmlRenderState\n-                    })\n-                };\n-\n-                function createDomMotionConfig(Component, _a, preloadedFeatures, createVisualElement, projectionNodeConstructor) {\n-                    var _b = _a.forwardMotionProps,\n-                        forwardMotionProps = _b === void 0 ? false : _b;\n-                    var baseConfig = isSVGComponent(Component) ? svgMotionConfig : htmlMotionConfig;\n-                    return tslib.__assign(tslib.__assign({}, baseConfig), {\n-                        preloadedFeatures: preloadedFeatures,\n-                        useRender: createUseRender(forwardMotionProps),\n-                        createVisualElement: createVisualElement,\n-                        projectionNodeConstructor: projectionNodeConstructor,\n-                        Component: Component\n-                    });\n-                }\n-                exports.AnimationType = void 0;\n-                (function(AnimationType) {\n-                    AnimationType[\"Animate\"] = \"animate\";\n-                    AnimationType[\"Hover\"] = \"whileHover\";\n-                    AnimationType[\"Tap\"] = \"whileTap\";\n-                    AnimationType[\"Drag\"] = \"whileDrag\";\n-                    AnimationType[\"Focus\"] = \"whileFocus\";\n-                    AnimationType[\"InView\"] = \"whileInView\";\n-                    AnimationType[\"Exit\"] = \"exit\";\n-                })(exports.AnimationType || (exports.AnimationType = {}));\n+                        while (curStart < stream.pos) {\n+                            // Webkit seems to refuse to render text nodes longer than 57444\n+                            // characters, and returns inaccurate measurements in nodes\n+                            // starting around 5000 chars.\n+                            var pos = Math.min(stream.pos, curStart + 5000);\n+                            f(pos, curStyle);\n+                            curStart = pos;\n+                        }\n+                    }\n \n-                function addDomEvent(target, eventName, handler, options) {\n-                    if (options === void 0) {\n-                        options = {\n-                            passive: true\n-                        };\n+                    // Finds the line to start with when starting a parse. Tries to\n+                    // find a line with a stateAfter, so that it can start with a\n+                    // valid state. If that fails, it returns the line with the\n+                    // smallest indentation, which tends to need the least context to\n+                    // parse correctly.\n+                    function findStartLine(cm, n, precise) {\n+                        var minindent,\n+                            minline,\n+                            doc = cm.doc;\n+                        var lim = precise ? -1 : n - (cm.doc.mode.innerMode ? 1000 : 100);\n+                        for (var search = n; search > lim; --search) {\n+                            if (search <= doc.first) {\n+                                return doc.first;\n+                            }\n+                            var line = getLine(doc, search - 1),\n+                                after = line.stateAfter;\n+                            if (after && (!precise || search + (after instanceof SavedContext ? after.lookAhead : 0) <= doc.modeFrontier)) {\n+                                return search;\n+                            }\n+                            var indented = countColumn(line.text, null, cm.options.tabSize);\n+                            if (minline == null || minindent > indented) {\n+                                minline = search - 1;\n+                                minindent = indented;\n+                            }\n+                        }\n+                        return minline;\n                     }\n-                    target.addEventListener(eventName, handler, options);\n-                    return function() {\n-                        return target.removeEventListener(eventName, handler);\n-                    };\n-                }\n-                /**\n-                 * Attaches an event listener directly to the provided DOM element.\n-                 *\n-                 * Bypassing React's event system can be desirable, for instance when attaching non-passive\n-                 * event handlers.\n-                 *\n-                 * ```jsx\n-                 * const ref = useRef(null)\n-                 *\n-                 * useDomEvent(ref, 'wheel', onWheel, { passive: false })\n-                 *\n-                 * return <div ref={ref} />\n-                 * ```\n-                 *\n-                 * @param ref - React.RefObject that's been provided to the element you want to bind the listener to.\n-                 * @param eventName - Name of the event you want listen for.\n-                 * @param handler - Function to fire when receiving the event.\n-                 * @param options - Options to pass to `Event.addEventListener`.\n-                 *\n-                 * @public\n-                 */\n-                function useDomEvent(ref, eventName, handler, options) {\n-                    React.useEffect(function() {\n-                        var element = ref.current;\n-                        if (handler && element) {\n-                            return addDomEvent(element, eventName, handler, options);\n+\n+                    function retreatFrontier(doc, n) {\n+                        doc.modeFrontier = Math.min(doc.modeFrontier, n);\n+                        if (doc.highlightFrontier < n - 10) {\n+                            return;\n                         }\n-                    }, [ref, eventName, handler, options]);\n-                }\n+                        var start = doc.first;\n+                        for (var line = n - 1; line > start; line--) {\n+                            var saved = getLine(doc, line).stateAfter;\n+                            // change is on 3\n+                            // state on line 1 looked ahead 2 -- so saw 3\n+                            // test 1 + 2 < 3 should cover this\n+                            if (saved && (!(saved instanceof SavedContext) || line + saved.lookAhead < n)) {\n+                                start = line + 1;\n+                                break;\n+                            }\n+                        }\n+                        doc.highlightFrontier = Math.min(doc.highlightFrontier, start);\n+                    }\n \n-                /**\n-                 *\n-                 * @param props\n-                 * @param ref\n-                 * @internal\n-                 */\n-                function useFocusGesture(_a) {\n-                    var whileFocus = _a.whileFocus,\n-                        visualElement = _a.visualElement;\n-                    var onFocus = function() {\n-                        var _a;\n-                        (_a = visualElement.animationState) === null || _a === void 0 ? void 0 : _a.setActive(exports.AnimationType.Focus, true);\n-                    };\n-                    var onBlur = function() {\n-                        var _a;\n-                        (_a = visualElement.animationState) === null || _a === void 0 ? void 0 : _a.setActive(exports.AnimationType.Focus, false);\n-                    };\n-                    useDomEvent(visualElement, \"focus\", whileFocus ? onFocus : undefined);\n-                    useDomEvent(visualElement, \"blur\", whileFocus ? onBlur : undefined);\n-                }\n+                    // Optimize some code when these features are not used.\n+                    var sawReadOnlySpans = false,\n+                        sawCollapsedSpans = false;\n \n-                function isMouseEvent(event) {\n-                    // PointerEvent inherits from MouseEvent so we can't use a straight instanceof check.\n-                    if (typeof PointerEvent !== \"undefined\" && event instanceof PointerEvent) {\n-                        return !!(event.pointerType === \"mouse\");\n+                    function seeReadOnlySpans() {\n+                        sawReadOnlySpans = true;\n                     }\n-                    return event instanceof MouseEvent;\n-                }\n \n-                function isTouchEvent(event) {\n-                    var hasTouches = !!event.touches;\n-                    return hasTouches;\n-                }\n+                    function seeCollapsedSpans() {\n+                        sawCollapsedSpans = true;\n+                    }\n \n-                /**\n-                 * Filters out events not attached to the primary pointer (currently left mouse button)\n-                 * @param eventHandler\n-                 */\n-                function filterPrimaryPointer(eventHandler) {\n-                    return function(event) {\n-                        var isMouseEvent = event instanceof MouseEvent;\n-                        var isPrimaryPointer = !isMouseEvent || isMouseEvent && event.button === 0;\n-                        if (isPrimaryPointer) {\n-                            eventHandler(event);\n-                        }\n-                    };\n-                }\n-                var defaultPagePoint = {\n-                    pageX: 0,\n-                    pageY: 0\n-                };\n+                    // TEXTMARKER SPANS\n \n-                function pointFromTouch(e, pointType) {\n-                    if (pointType === void 0) {\n-                        pointType = \"page\";\n+                    function MarkedSpan(marker, from, to) {\n+                        this.marker = marker;\n+                        this.from = from;\n+                        this.to = to;\n                     }\n-                    var primaryTouch = e.touches[0] || e.changedTouches[0];\n-                    var point = primaryTouch || defaultPagePoint;\n-                    return {\n-                        x: point[pointType + \"X\"],\n-                        y: point[pointType + \"Y\"]\n-                    };\n-                }\n \n-                function pointFromMouse(point, pointType) {\n-                    if (pointType === void 0) {\n-                        pointType = \"page\";\n+                    // Search an array of spans for a span matching the given marker.\n+                    function getMarkedSpanFor(spans, marker) {\n+                        if (spans) {\n+                            for (var i = 0; i < spans.length; ++i) {\n+                                var span = spans[i];\n+                                if (span.marker == marker) {\n+                                    return span;\n+                                }\n+                            }\n+                        }\n                     }\n-                    return {\n-                        x: point[pointType + \"X\"],\n-                        y: point[pointType + \"Y\"]\n-                    };\n-                }\n \n-                function extractEventInfo(event, pointType) {\n-                    if (pointType === void 0) {\n-                        pointType = \"page\";\n+                    // Remove a span from an array, returning undefined if no spans are\n+                    // left (we don't store arrays for lines without spans).\n+                    function removeMarkedSpan(spans, span) {\n+                        var r;\n+                        for (var i = 0; i < spans.length; ++i) {\n+                            if (spans[i] != span) {\n+                                (r || (r = [])).push(spans[i]);\n+                            }\n+                        }\n+                        return r;\n                     }\n-                    return {\n-                        point: isTouchEvent(event) ? pointFromTouch(event, pointType) : pointFromMouse(event, pointType)\n-                    };\n-                }\n-                var wrapHandler = function(handler, shouldFilterPrimaryPointer) {\n-                    if (shouldFilterPrimaryPointer === void 0) {\n-                        shouldFilterPrimaryPointer = false;\n+\n+                    // Add a span to a line.\n+                    function addMarkedSpan(line, span, op) {\n+                        var inThisOp = op && window.WeakSet && (op.markedSpans || (op.markedSpans = new WeakSet()));\n+                        if (inThisOp && line.markedSpans && inThisOp.has(line.markedSpans)) {\n+                            line.markedSpans.push(span);\n+                        } else {\n+                            line.markedSpans = line.markedSpans ? line.markedSpans.concat([span]) : [span];\n+                            if (inThisOp) {\n+                                inThisOp.add(line.markedSpans);\n+                            }\n+                        }\n+                        span.marker.attachLine(line);\n                     }\n-                    var listener = function(event) {\n-                        return handler(event, extractEventInfo(event));\n-                    };\n-                    return shouldFilterPrimaryPointer ? filterPrimaryPointer(listener) : listener;\n-                };\n \n-                // We check for event support via functions in case they've been mocked by a testing suite.\n-                var supportsPointerEvents = function() {\n-                    return isBrowser && window.onpointerdown === null;\n-                };\n-                var supportsTouchEvents = function() {\n-                    return isBrowser && window.ontouchstart === null;\n-                };\n-                var supportsMouseEvents = function() {\n-                    return isBrowser && window.onmousedown === null;\n-                };\n-                var mouseEventNames = {\n-                    pointerdown: \"mousedown\",\n-                    pointermove: \"mousemove\",\n-                    pointerup: \"mouseup\",\n-                    pointercancel: \"mousecancel\",\n-                    pointerover: \"mouseover\",\n-                    pointerout: \"mouseout\",\n-                    pointerenter: \"mouseenter\",\n-                    pointerleave: \"mouseleave\"\n-                };\n-                var touchEventNames = {\n-                    pointerdown: \"touchstart\",\n-                    pointermove: \"touchmove\",\n-                    pointerup: \"touchend\",\n-                    pointercancel: \"touchcancel\"\n-                };\n+                    // Used for the algorithm that adjusts markers for a change in the\n+                    // document. These functions cut an array of spans at a given\n+                    // character position, returning an array of remaining chunks (or\n+                    // undefined if nothing remains).\n+                    function markedSpansBefore(old, startCh, isInsert) {\n+                        var nw;\n+                        if (old) {\n+                            for (var i = 0; i < old.length; ++i) {\n+                                var span = old[i],\n+                                    marker = span.marker;\n+                                var startsBefore = span.from == null || (marker.inclusiveLeft ? span.from <= startCh : span.from < startCh);\n+                                if (startsBefore || span.from == startCh && marker.type == \"bookmark\" && (!isInsert || !span.marker.insertLeft)) {\n+                                    var endsAfter = span.to == null || (marker.inclusiveRight ? span.to >= startCh : span.to > startCh);\n+                                    (nw || (nw = [])).push(new MarkedSpan(marker, span.from, endsAfter ? null : span.to));\n+                                }\n+                            }\n+                        }\n+                        return nw;\n+                    }\n \n-                function getPointerEventName(name) {\n-                    if (supportsPointerEvents()) {\n-                        return name;\n-                    } else if (supportsTouchEvents()) {\n-                        return touchEventNames[name];\n-                    } else if (supportsMouseEvents()) {\n-                        return mouseEventNames[name];\n+                    function markedSpansAfter(old, endCh, isInsert) {\n+                        var nw;\n+                        if (old) {\n+                            for (var i = 0; i < old.length; ++i) {\n+                                var span = old[i],\n+                                    marker = span.marker;\n+                                var endsAfter = span.to == null || (marker.inclusiveRight ? span.to >= endCh : span.to > endCh);\n+                                if (endsAfter || span.from == endCh && marker.type == \"bookmark\" && (!isInsert || span.marker.insertLeft)) {\n+                                    var startsBefore = span.from == null || (marker.inclusiveLeft ? span.from <= endCh : span.from < endCh);\n+                                    (nw || (nw = [])).push(new MarkedSpan(marker, startsBefore ? null : span.from - endCh, span.to == null ? null : span.to - endCh));\n+                                }\n+                            }\n+                        }\n+                        return nw;\n                     }\n-                    return name;\n-                }\n \n-                function addPointerEvent(target, eventName, handler, options) {\n-                    return addDomEvent(target, getPointerEventName(eventName), wrapHandler(handler, eventName === \"pointerdown\"), options);\n-                }\n+                    // Given a change object, compute the new set of marker spans that\n+                    // cover the line in which the change took place. Removes spans\n+                    // entirely within the change, reconnects spans belonging to the\n+                    // same marker that appear on both sides of the change, and cuts off\n+                    // spans partially within the change. Returns an array of span\n+                    // arrays with one element for each line in (after) the change.\n+                    function stretchSpansOverChange(doc, change) {\n+                        if (change.full) {\n+                            return null;\n+                        }\n+                        var oldFirst = isLine(doc, change.from.line) && getLine(doc, change.from.line).markedSpans;\n+                        var oldLast = isLine(doc, change.to.line) && getLine(doc, change.to.line).markedSpans;\n+                        if (!oldFirst && !oldLast) {\n+                            return null;\n+                        }\n+                        var startCh = change.from.ch,\n+                            endCh = change.to.ch,\n+                            isInsert = cmp(change.from, change.to) == 0;\n+                        // Get the spans that 'stick out' on both sides\n+                        var first = markedSpansBefore(oldFirst, startCh, isInsert);\n+                        var last = markedSpansAfter(oldLast, endCh, isInsert);\n+\n+                        // Next, merge those two ends\n+                        var sameLine = change.text.length == 1,\n+                            offset = lst(change.text).length + (sameLine ? startCh : 0);\n+                        if (first) {\n+                            // Fix up .to properties of first\n+                            for (var i = 0; i < first.length; ++i) {\n+                                var span = first[i];\n+                                if (span.to == null) {\n+                                    var found = getMarkedSpanFor(last, span.marker);\n+                                    if (!found) {\n+                                        span.to = startCh;\n+                                    } else if (sameLine) {\n+                                        span.to = found.to == null ? null : found.to + offset;\n+                                    }\n+                                }\n+                            }\n+                        }\n+                        if (last) {\n+                            // Fix up .from in last (or move them into first in case of sameLine)\n+                            for (var i$1 = 0; i$1 < last.length; ++i$1) {\n+                                var span$1 = last[i$1];\n+                                if (span$1.to != null) {\n+                                    span$1.to += offset;\n+                                }\n+                                if (span$1.from == null) {\n+                                    var found$1 = getMarkedSpanFor(first, span$1.marker);\n+                                    if (!found$1) {\n+                                        span$1.from = offset;\n+                                        if (sameLine) {\n+                                            (first || (first = [])).push(span$1);\n+                                        }\n+                                    }\n+                                } else {\n+                                    span$1.from += offset;\n+                                    if (sameLine) {\n+                                        (first || (first = [])).push(span$1);\n+                                    }\n+                                }\n+                            }\n+                        }\n+                        // Make sure we didn't create any zero-length spans\n+                        if (first) {\n+                            first = clearEmptySpans(first);\n+                        }\n+                        if (last && last != first) {\n+                            last = clearEmptySpans(last);\n+                        }\n+                        var newMarkers = [first];\n+                        if (!sameLine) {\n+                            // Fill gap with whole-line-spans\n+                            var gap = change.text.length - 2,\n+                                gapMarkers;\n+                            if (gap > 0 && first) {\n+                                for (var i$2 = 0; i$2 < first.length; ++i$2) {\n+                                    if (first[i$2].to == null) {\n+                                        (gapMarkers || (gapMarkers = [])).push(new MarkedSpan(first[i$2].marker, null, null));\n+                                    }\n+                                }\n+                            }\n+                            for (var i$3 = 0; i$3 < gap; ++i$3) {\n+                                newMarkers.push(gapMarkers);\n+                            }\n+                            newMarkers.push(last);\n+                        }\n+                        return newMarkers;\n+                    }\n \n-                function usePointerEvent(ref, eventName, handler, options) {\n-                    return useDomEvent(ref, getPointerEventName(eventName), handler && wrapHandler(handler, eventName === \"pointerdown\"), options);\n-                }\n+                    // Remove spans that are empty and don't have a clearWhenEmpty\n+                    // option of false.\n+                    function clearEmptySpans(spans) {\n+                        for (var i = 0; i < spans.length; ++i) {\n+                            var span = spans[i];\n+                            if (span.from != null && span.from == span.to && span.marker.clearWhenEmpty !== false) {\n+                                spans.splice(i--, 1);\n+                            }\n+                        }\n+                        if (!spans.length) {\n+                            return null;\n+                        }\n+                        return spans;\n+                    }\n \n-                function createLock(name) {\n-                    var lock = null;\n-                    return function() {\n-                        var openLock = function() {\n-                            lock = null;\n-                        };\n-                        if (lock === null) {\n-                            lock = name;\n-                            return openLock;\n+                    // Used to 'clip' out readOnly ranges when making a change.\n+                    function removeReadOnlyRanges(doc, from, to) {\n+                        var markers = null;\n+                        doc.iter(from.line, to.line + 1, function(line) {\n+                            if (line.markedSpans) {\n+                                for (var i = 0; i < line.markedSpans.length; ++i) {\n+                                    var mark = line.markedSpans[i].marker;\n+                                    if (mark.readOnly && (!markers || indexOf(markers, mark) == -1)) {\n+                                        (markers || (markers = [])).push(mark);\n+                                    }\n+                                }\n+                            }\n+                        });\n+                        if (!markers) {\n+                            return null;\n                         }\n-                        return false;\n-                    };\n-                }\n-                var globalHorizontalLock = createLock(\"dragHorizontal\");\n-                var globalVerticalLock = createLock(\"dragVertical\");\n+                        var parts = [{\n+                            from: from,\n+                            to: to\n+                        }];\n+                        for (var i = 0; i < markers.length; ++i) {\n+                            var mk = markers[i],\n+                                m = mk.find(0);\n+                            for (var j = 0; j < parts.length; ++j) {\n+                                var p = parts[j];\n+                                if (cmp(p.to, m.from) < 0 || cmp(p.from, m.to) > 0) {\n+                                    continue;\n+                                }\n+                                var newParts = [j, 1],\n+                                    dfrom = cmp(p.from, m.from),\n+                                    dto = cmp(p.to, m.to);\n+                                if (dfrom < 0 || !mk.inclusiveLeft && !dfrom) {\n+                                    newParts.push({\n+                                        from: p.from,\n+                                        to: m.from\n+                                    });\n+                                }\n+                                if (dto > 0 || !mk.inclusiveRight && !dto) {\n+                                    newParts.push({\n+                                        from: m.to,\n+                                        to: p.to\n+                                    });\n+                                }\n+                                parts.splice.apply(parts, newParts);\n+                                j += newParts.length - 3;\n+                            }\n+                        }\n+                        return parts;\n+                    }\n \n-                function getGlobalLock(drag) {\n-                    var lock = false;\n-                    if (drag === \"y\") {\n-                        lock = globalVerticalLock();\n-                    } else if (drag === \"x\") {\n-                        lock = globalHorizontalLock();\n-                    } else {\n-                        var openHorizontal_1 = globalHorizontalLock();\n-                        var openVertical_1 = globalVerticalLock();\n-                        if (openHorizontal_1 && openVertical_1) {\n-                            lock = function() {\n-                                openHorizontal_1();\n-                                openVertical_1();\n-                            };\n-                        } else {\n-                            // Release the locks because we don't use them\n-                            if (openHorizontal_1) openHorizontal_1();\n-                            if (openVertical_1) openVertical_1();\n+                    // Connect or disconnect spans from a line.\n+                    function detachMarkedSpans(line) {\n+                        var spans = line.markedSpans;\n+                        if (!spans) {\n+                            return;\n                         }\n+                        for (var i = 0; i < spans.length; ++i) {\n+                            spans[i].marker.detachLine(line);\n+                        }\n+                        line.markedSpans = null;\n                     }\n-                    return lock;\n-                }\n \n-                function isDragActive() {\n-                    // Check the gesture lock - if we get it, it means no drag gesture is active\n-                    // and we can safely fire the tap gesture.\n-                    var openGestureLock = getGlobalLock(true);\n-                    if (!openGestureLock) return true;\n-                    openGestureLock();\n-                    return false;\n-                }\n+                    function attachMarkedSpans(line, spans) {\n+                        if (!spans) {\n+                            return;\n+                        }\n+                        for (var i = 0; i < spans.length; ++i) {\n+                            spans[i].marker.attachLine(line);\n+                        }\n+                        line.markedSpans = spans;\n+                    }\n \n-                function createHoverEvent(visualElement, isActive, callback) {\n-                    return function(event, info) {\n-                        var _a;\n-                        if (!isMouseEvent(event) || isDragActive()) return;\n-                        /**\n-                         * Ensure we trigger animations before firing event callback\n-                         */\n-                        (_a = visualElement.animationState) === null || _a === void 0 ? void 0 : _a.setActive(exports.AnimationType.Hover, isActive);\n-                        callback === null || callback === void 0 ? void 0 : callback(event, info);\n-                    };\n-                }\n+                    // Helpers used when computing which overlapping collapsed span\n+                    // counts as the larger one.\n+                    function extraLeft(marker) {\n+                        return marker.inclusiveLeft ? -1 : 0;\n+                    }\n \n-                function useHoverGesture(_a) {\n-                    var onHoverStart = _a.onHoverStart,\n-                        onHoverEnd = _a.onHoverEnd,\n-                        whileHover = _a.whileHover,\n-                        visualElement = _a.visualElement;\n-                    usePointerEvent(visualElement, \"pointerenter\", onHoverStart || whileHover ? createHoverEvent(visualElement, true, onHoverStart) : undefined, {\n-                        passive: !onHoverStart\n-                    });\n-                    usePointerEvent(visualElement, \"pointerleave\", onHoverEnd || whileHover ? createHoverEvent(visualElement, false, onHoverEnd) : undefined, {\n-                        passive: !onHoverEnd\n-                    });\n-                }\n+                    function extraRight(marker) {\n+                        return marker.inclusiveRight ? 1 : 0;\n+                    }\n \n-                /**\n-                 * Recursively traverse up the tree to check whether the provided child node\n-                 * is the parent or a descendant of it.\n-                 *\n-                 * @param parent - Element to find\n-                 * @param child - Element to test against parent\n-                 */\n-                var isNodeOrChild = function(parent, child) {\n-                    if (!child) {\n-                        return false;\n-                    } else if (parent === child) {\n-                        return true;\n-                    } else {\n-                        return isNodeOrChild(parent, child.parentElement);\n+                    // Returns a number indicating which of two overlapping collapsed\n+                    // spans is larger (and thus includes the other). Falls back to\n+                    // comparing ids when the spans cover exactly the same range.\n+                    function compareCollapsedMarkers(a, b) {\n+                        var lenDiff = a.lines.length - b.lines.length;\n+                        if (lenDiff != 0) {\n+                            return lenDiff;\n+                        }\n+                        var aPos = a.find(),\n+                            bPos = b.find();\n+                        var fromCmp = cmp(aPos.from, bPos.from) || extraLeft(a) - extraLeft(b);\n+                        if (fromCmp) {\n+                            return -fromCmp;\n+                        }\n+                        var toCmp = cmp(aPos.to, bPos.to) || extraRight(a) - extraRight(b);\n+                        if (toCmp) {\n+                            return toCmp;\n+                        }\n+                        return b.id - a.id;\n                     }\n-                };\n \n-                function useUnmountEffect(callback) {\n-                    return React.useEffect(function() {\n-                        return function() {\n-                            return callback();\n-                        };\n-                    }, []);\n-                }\n+                    // Find out whether a line ends or starts in a collapsed span. If\n+                    // so, return the marker for that span.\n+                    function collapsedSpanAtSide(line, start) {\n+                        var sps = sawCollapsedSpans && line.markedSpans,\n+                            found;\n+                        if (sps) {\n+                            for (var sp = void 0, i = 0; i < sps.length; ++i) {\n+                                sp = sps[i];\n+                                if (sp.marker.collapsed && (start ? sp.from : sp.to) == null && (!found || compareCollapsedMarkers(found, sp.marker) < 0)) {\n+                                    found = sp.marker;\n+                                }\n+                            }\n+                        }\n+                        return found;\n+                    }\n \n-                /**\n-                 * @param handlers -\n-                 * @internal\n-                 */\n-                function useTapGesture(_a) {\n-                    var onTap = _a.onTap,\n-                        onTapStart = _a.onTapStart,\n-                        onTapCancel = _a.onTapCancel,\n-                        whileTap = _a.whileTap,\n-                        visualElement = _a.visualElement;\n-                    var hasPressListeners = onTap || onTapStart || onTapCancel || whileTap;\n-                    var isPressing = React.useRef(false);\n-                    var cancelPointerEndListeners = React.useRef(null);\n-                    /**\n-                     * Only set listener to passive if there are no external listeners.\n-                     */\n-                    var eventOptions = {\n-                        passive: !(onTapStart || onTap || onTapCancel || onPointerDown)\n-                    };\n+                    function collapsedSpanAtStart(line) {\n+                        return collapsedSpanAtSide(line, true);\n+                    }\n \n-                    function removePointerEndListener() {\n-                        var _a;\n-                        (_a = cancelPointerEndListeners.current) === null || _a === void 0 ? void 0 : _a.call(cancelPointerEndListeners);\n-                        cancelPointerEndListeners.current = null;\n+                    function collapsedSpanAtEnd(line) {\n+                        return collapsedSpanAtSide(line, false);\n                     }\n \n-                    function checkPointerEnd() {\n-                        var _a;\n-                        removePointerEndListener();\n-                        isPressing.current = false;\n-                        (_a = visualElement.animationState) === null || _a === void 0 ? void 0 : _a.setActive(exports.AnimationType.Tap, false);\n-                        return !isDragActive();\n+                    function collapsedSpanAround(line, ch) {\n+                        var sps = sawCollapsedSpans && line.markedSpans,\n+                            found;\n+                        if (sps) {\n+                            for (var i = 0; i < sps.length; ++i) {\n+                                var sp = sps[i];\n+                                if (sp.marker.collapsed && (sp.from == null || sp.from < ch) && (sp.to == null || sp.to > ch) && (!found || compareCollapsedMarkers(found, sp.marker) < 0)) {\n+                                    found = sp.marker;\n+                                }\n+                            }\n+                        }\n+                        return found;\n                     }\n \n-                    function onPointerUp(event, info) {\n-                        if (!checkPointerEnd()) return;\n-                        /**\n-                         * We only count this as a tap gesture if the event.target is the same\n-                         * as, or a child of, this component's element\n-                         */\n-                        !isNodeOrChild(visualElement.getInstance(), event.target) ? onTapCancel === null || onTapCancel === void 0 ? void 0 : onTapCancel(event, info) : onTap === null || onTap === void 0 ? void 0 : onTap(event, info);\n+                    // Test whether there exists a collapsed span that partially\n+                    // overlaps (covers the start or end, but not both) of a new span.\n+                    // Such overlap is not allowed.\n+                    function conflictingCollapsedRange(doc, lineNo, from, to, marker) {\n+                        var line = getLine(doc, lineNo);\n+                        var sps = sawCollapsedSpans && line.markedSpans;\n+                        if (sps) {\n+                            for (var i = 0; i < sps.length; ++i) {\n+                                var sp = sps[i];\n+                                if (!sp.marker.collapsed) {\n+                                    continue;\n+                                }\n+                                var found = sp.marker.find(0);\n+                                var fromCmp = cmp(found.from, from) || extraLeft(sp.marker) - extraLeft(marker);\n+                                var toCmp = cmp(found.to, to) || extraRight(sp.marker) - extraRight(marker);\n+                                if (fromCmp >= 0 && toCmp <= 0 || fromCmp <= 0 && toCmp >= 0) {\n+                                    continue;\n+                                }\n+                                if (fromCmp <= 0 && (sp.marker.inclusiveRight && marker.inclusiveLeft ? cmp(found.to, from) >= 0 : cmp(found.to, from) > 0) || fromCmp >= 0 && (sp.marker.inclusiveRight && marker.inclusiveLeft ? cmp(found.from, to) <= 0 : cmp(found.from, to) < 0)) {\n+                                    return true;\n+                                }\n+                            }\n+                        }\n                     }\n \n-                    function onPointerCancel(event, info) {\n-                        if (!checkPointerEnd()) return;\n-                        onTapCancel === null || onTapCancel === void 0 ? void 0 : onTapCancel(event, info);\n+                    // A visual line is a line as drawn on the screen. Folding, for\n+                    // example, can cause multiple logical lines to appear on the same\n+                    // visual line. This finds the start of the visual line that the\n+                    // given line is part of (usually that is the line itself).\n+                    function visualLine(line) {\n+                        var merged;\n+                        while (merged = collapsedSpanAtStart(line)) {\n+                            line = merged.find(-1, true).line;\n+                        }\n+                        return line;\n+                    }\n+\n+                    function visualLineEnd(line) {\n+                        var merged;\n+                        while (merged = collapsedSpanAtEnd(line)) {\n+                            line = merged.find(1, true).line;\n+                        }\n+                        return line;\n+                    }\n+\n+                    // Returns an array of logical lines that continue the visual line\n+                    // started by the argument, or undefined if there are no such lines.\n+                    function visualLineContinued(line) {\n+                        var merged, lines;\n+                        while (merged = collapsedSpanAtEnd(line)) {\n+                            line = merged.find(1, true).line;\n+                            (lines || (lines = [])).push(line);\n+                        }\n+                        return lines;\n+                    }\n+\n+                    // Get the line number of the start of the visual line that the\n+                    // given line number is part of.\n+                    function visualLineNo(doc, lineN) {\n+                        var line = getLine(doc, lineN),\n+                            vis = visualLine(line);\n+                        if (line == vis) {\n+                            return lineN;\n+                        }\n+                        return lineNo(vis);\n+                    }\n+\n+                    // Get the line number of the start of the next visual line after\n+                    // the given line.\n+                    function visualLineEndNo(doc, lineN) {\n+                        if (lineN > doc.lastLine()) {\n+                            return lineN;\n+                        }\n+                        var line = getLine(doc, lineN),\n+                            merged;\n+                        if (!lineIsHidden(doc, line)) {\n+                            return lineN;\n+                        }\n+                        while (merged = collapsedSpanAtEnd(line)) {\n+                            line = merged.find(1, true).line;\n+                        }\n+                        return lineNo(line) + 1;\n+                    }\n+\n+                    // Compute whether a line is hidden. Lines count as hidden when they\n+                    // are part of a visual line that starts with another line, or when\n+                    // they are entirely covered by collapsed, non-widget span.\n+                    function lineIsHidden(doc, line) {\n+                        var sps = sawCollapsedSpans && line.markedSpans;\n+                        if (sps) {\n+                            for (var sp = void 0, i = 0; i < sps.length; ++i) {\n+                                sp = sps[i];\n+                                if (!sp.marker.collapsed) {\n+                                    continue;\n+                                }\n+                                if (sp.from == null) {\n+                                    return true;\n+                                }\n+                                if (sp.marker.widgetNode) {\n+                                    continue;\n+                                }\n+                                if (sp.from == 0 && sp.marker.inclusiveLeft && lineIsHiddenInner(doc, line, sp)) {\n+                                    return true;\n+                                }\n+                            }\n+                        }\n                     }\n \n-                    function onPointerDown(event, info) {\n-                        var _a;\n-                        removePointerEndListener();\n-                        if (isPressing.current) return;\n-                        isPressing.current = true;\n-                        cancelPointerEndListeners.current = popmotion.pipe(addPointerEvent(window, \"pointerup\", onPointerUp, eventOptions), addPointerEvent(window, \"pointercancel\", onPointerCancel, eventOptions));\n-                        /**\n-                         * Ensure we trigger animations before firing event callback\n-                         */\n-                        (_a = visualElement.animationState) === null || _a === void 0 ? void 0 : _a.setActive(exports.AnimationType.Tap, true);\n-                        onTapStart === null || onTapStart === void 0 ? void 0 : onTapStart(event, info);\n+                    function lineIsHiddenInner(doc, line, span) {\n+                        if (span.to == null) {\n+                            var end = span.marker.find(1, true);\n+                            return lineIsHiddenInner(doc, end.line, getMarkedSpanFor(end.line.markedSpans, span.marker));\n+                        }\n+                        if (span.marker.inclusiveRight && span.to == line.text.length) {\n+                            return true;\n+                        }\n+                        for (var sp = void 0, i = 0; i < line.markedSpans.length; ++i) {\n+                            sp = line.markedSpans[i];\n+                            if (sp.marker.collapsed && !sp.marker.widgetNode && sp.from == span.to && (sp.to == null || sp.to != span.from) && (sp.marker.inclusiveLeft || span.marker.inclusiveRight) && lineIsHiddenInner(doc, line, sp)) {\n+                                return true;\n+                            }\n+                        }\n                     }\n-                    usePointerEvent(visualElement, \"pointerdown\", hasPressListeners ? onPointerDown : undefined, eventOptions);\n-                    useUnmountEffect(removePointerEndListener);\n-                }\n-                var warned = new Set();\n \n-                function warnOnce(condition, message, element) {\n-                    if (condition || warned.has(message)) return;\n-                    console.warn(message);\n-                    if (element) console.warn(element);\n-                    warned.add(message);\n-                }\n+                    // Find the height above the given line.\n+                    function heightAtLine(lineObj) {\n+                        lineObj = visualLine(lineObj);\n+                        var h = 0,\n+                            chunk = lineObj.parent;\n+                        for (var i = 0; i < chunk.lines.length; ++i) {\n+                            var line = chunk.lines[i];\n+                            if (line == lineObj) {\n+                                break;\n+                            } else {\n+                                h += line.height;\n+                            }\n+                        }\n+                        for (var p = chunk.parent; p; chunk = p, p = chunk.parent) {\n+                            for (var i$1 = 0; i$1 < p.children.length; ++i$1) {\n+                                var cur = p.children[i$1];\n+                                if (cur == chunk) {\n+                                    break;\n+                                } else {\n+                                    h += cur.height;\n+                                }\n+                            }\n+                        }\n+                        return h;\n+                    }\n \n-                /**\n-                 * Map an IntersectionHandler callback to an element. We only ever make one handler for one\n-                 * element, so even though these handlers might all be triggered by different\n-                 * observers, we can keep them in the same map.\n-                 */\n-                var observerCallbacks = new WeakMap();\n-                /**\n-                 * Multiple observers can be created for multiple element/document roots. Each with\n-                 * different settings. So here we store dictionaries of observers to each root,\n-                 * using serialised settings (threshold/margin) as lookup keys.\n-                 */\n-                var observers = new WeakMap();\n-                var fireObserverCallback = function(entry) {\n-                    var _a;\n-                    (_a = observerCallbacks.get(entry.target)) === null || _a === void 0 ? void 0 : _a(entry);\n-                };\n-                var fireAllObserverCallbacks = function(entries) {\n-                    entries.forEach(fireObserverCallback);\n-                };\n+                    // Compute the character length of a line, taking into account\n+                    // collapsed ranges (see markText) that might hide parts, and join\n+                    // other lines onto it.\n+                    function lineLength(line) {\n+                        if (line.height == 0) {\n+                            return 0;\n+                        }\n+                        var len = line.text.length,\n+                            merged,\n+                            cur = line;\n+                        while (merged = collapsedSpanAtStart(cur)) {\n+                            var found = merged.find(0, true);\n+                            cur = found.from.line;\n+                            len += found.from.ch - found.to.ch;\n+                        }\n+                        cur = line;\n+                        while (merged = collapsedSpanAtEnd(cur)) {\n+                            var found$1 = merged.find(0, true);\n+                            len -= cur.text.length - found$1.from.ch;\n+                            cur = found$1.to.line;\n+                            len += cur.text.length - found$1.to.ch;\n+                        }\n+                        return len;\n+                    }\n+\n+                    // Find the longest line in the document.\n+                    function findMaxLine(cm) {\n+                        var d = cm.display,\n+                            doc = cm.doc;\n+                        d.maxLine = getLine(doc, doc.first);\n+                        d.maxLineLength = lineLength(d.maxLine);\n+                        d.maxLineChanged = true;\n+                        doc.iter(function(line) {\n+                            var len = lineLength(line);\n+                            if (len > d.maxLineLength) {\n+                                d.maxLineLength = len;\n+                                d.maxLine = line;\n+                            }\n+                        });\n+                    }\n+\n+                    // LINE DATA STRUCTURE\n+\n+                    // Line objects. These hold state related to a line, including\n+                    // highlighting info (the styles array).\n+                    var Line = function(text, markedSpans, estimateHeight) {\n+                        this.text = text;\n+                        attachMarkedSpans(this, markedSpans);\n+                        this.height = estimateHeight ? estimateHeight(this) : 1;\n+                    };\n+                    Line.prototype.lineNo = function() {\n+                        return lineNo(this);\n+                    };\n+                    eventMixin(Line);\n+\n+                    // Change the content (text, markers) of a line. Automatically\n+                    // invalidates cached information and tries to re-estimate the\n+                    // line's height.\n+                    function updateLine(line, text, markedSpans, estimateHeight) {\n+                        line.text = text;\n+                        if (line.stateAfter) {\n+                            line.stateAfter = null;\n+                        }\n+                        if (line.styles) {\n+                            line.styles = null;\n+                        }\n+                        if (line.order != null) {\n+                            line.order = null;\n+                        }\n+                        detachMarkedSpans(line);\n+                        attachMarkedSpans(line, markedSpans);\n+                        var estHeight = estimateHeight ? estimateHeight(line) : 1;\n+                        if (estHeight != line.height) {\n+                            updateLineHeight(line, estHeight);\n+                        }\n+                    }\n+\n+                    // Detach a line from the document tree and its markers.\n+                    function cleanUpLine(line) {\n+                        line.parent = null;\n+                        detachMarkedSpans(line);\n+                    }\n+\n+                    // Convert a style as returned by a mode (either null, or a string\n+                    // containing one or more styles) to a CSS style. This is cached,\n+                    // and also looks for line-wide styles.\n+                    var styleToClassCache = {},\n+                        styleToClassCacheWithMode = {};\n \n-                function initIntersectionObserver(_a) {\n-                    var root = _a.root,\n-                        options = tslib.__rest(_a, [\"root\"]);\n-                    var lookupRoot = root || document;\n-                    /**\n-                     * If we don't have an observer lookup map for this root, create one.\n-                     */\n-                    if (!observers.has(lookupRoot)) {\n-                        observers.set(lookupRoot, {});\n+                    function interpretTokenStyle(style, options) {\n+                        if (!style || /^\\s*$/.test(style)) {\n+                            return null;\n+                        }\n+                        var cache = options.addModeClass ? styleToClassCacheWithMode : styleToClassCache;\n+                        return cache[style] || (cache[style] = style.replace(/\\S+/g, \"cm-$&\"));\n                     }\n-                    var rootObservers = observers.get(lookupRoot);\n-                    var key = JSON.stringify(options);\n-                    /**\n-                     * If we don't have an observer for this combination of root and settings,\n-                     * create one.\n-                     */\n-                    if (!rootObservers[key]) {\n-                        rootObservers[key] = new IntersectionObserver(fireAllObserverCallbacks, tslib.__assign({\n-                            root: root\n-                        }, options));\n+\n+                    // Render the DOM representation of the text of a line. Also builds\n+                    // up a 'line map', which points at the DOM nodes that represent\n+                    // specific stretches of text, and is used by the measuring code.\n+                    // The returned object contains the DOM node, this map, and\n+                    // information about line-wide styles that were set by the mode.\n+                    function buildLineContent(cm, lineView) {\n+                        // The padding-right forces the element to have a 'border', which\n+                        // is needed on Webkit to be able to get line-level bounding\n+                        // rectangles for it (in measureChar).\n+                        var content = eltP(\"span\", null, null, webkit ? \"padding-right: .1px\" : null);\n+                        var builder = {\n+                            pre: eltP(\"pre\", [content], \"CodeMirror-line\"),\n+                            content: content,\n+                            col: 0,\n+                            pos: 0,\n+                            cm: cm,\n+                            trailingSpace: false,\n+                            splitSpaces: cm.getOption(\"lineWrapping\")\n+                        };\n+                        lineView.measure = {};\n+\n+                        // Iterate over the logical lines that make up this visual line.\n+                        for (var i = 0; i <= (lineView.rest ? lineView.rest.length : 0); i++) {\n+                            var line = i ? lineView.rest[i - 1] : lineView.line,\n+                                order = void 0;\n+                            builder.pos = 0;\n+                            builder.addToken = buildToken;\n+                            // Optionally wire in some hacks into the token-rendering\n+                            // algorithm, to deal with browser quirks.\n+                            if (hasBadBidiRects(cm.display.measure) && (order = getOrder(line, cm.doc.direction))) {\n+                                builder.addToken = buildTokenBadBidi(builder.addToken, order);\n+                            }\n+                            builder.map = [];\n+                            var allowFrontierUpdate = lineView != cm.display.externalMeasured && lineNo(line);\n+                            insertLineContent(line, builder, getLineStyles(cm, line, allowFrontierUpdate));\n+                            if (line.styleClasses) {\n+                                if (line.styleClasses.bgClass) {\n+                                    builder.bgClass = joinClasses(line.styleClasses.bgClass, builder.bgClass || \"\");\n+                                }\n+                                if (line.styleClasses.textClass) {\n+                                    builder.textClass = joinClasses(line.styleClasses.textClass, builder.textClass || \"\");\n+                                }\n+                            }\n+\n+                            // Ensure at least a single node is present, for measuring.\n+                            if (builder.map.length == 0) {\n+                                builder.map.push(0, 0, builder.content.appendChild(zeroWidthElement(cm.display.measure)));\n+                            }\n+\n+                            // Store the map and a cache object for the current logical line\n+                            if (i == 0) {\n+                                lineView.measure.map = builder.map;\n+                                lineView.measure.cache = {};\n+                            } else {\n+                                (lineView.measure.maps || (lineView.measure.maps = [])).push(builder.map);\n+                                (lineView.measure.caches || (lineView.measure.caches = [])).push({});\n+                            }\n+                        }\n+\n+                        // See issue #2901\n+                        if (webkit) {\n+                            var last = builder.content.lastChild;\n+                            if (/\\bcm-tab\\b/.test(last.className) || last.querySelector && last.querySelector(\".cm-tab\")) {\n+                                builder.content.className = \"cm-tab-wrap-hack\";\n+                            }\n+                        }\n+                        signal(cm, \"renderLine\", cm, lineView.line, builder.pre);\n+                        if (builder.pre.className) {\n+                            builder.textClass = joinClasses(builder.pre.className, builder.textClass || \"\");\n+                        }\n+                        return builder;\n                     }\n-                    return rootObservers[key];\n-                }\n \n-                function observeIntersection(element, options, callback) {\n-                    var rootInteresectionObserver = initIntersectionObserver(options);\n-                    observerCallbacks.set(element, callback);\n-                    rootInteresectionObserver.observe(element);\n-                    return function() {\n-                        observerCallbacks.delete(element);\n-                        rootInteresectionObserver.unobserve(element);\n-                    };\n-                }\n+                    function defaultSpecialCharPlaceholder(ch) {\n+                        var token = elt(\"span\", \"\\u2022\", \"cm-invalidchar\");\n+                        token.title = \"\\\\u\" + ch.charCodeAt(0).toString(16);\n+                        token.setAttribute(\"aria-label\", token.title);\n+                        return token;\n+                    }\n \n-                function useViewport(_a) {\n-                    var visualElement = _a.visualElement,\n-                        whileInView = _a.whileInView,\n-                        onViewportEnter = _a.onViewportEnter,\n-                        onViewportLeave = _a.onViewportLeave,\n-                        _b = _a.viewport,\n-                        viewport = _b === void 0 ? {} : _b;\n-                    var state = React.useRef({\n-                        hasEnteredView: false,\n-                        isInView: false\n-                    });\n-                    var shouldObserve = Boolean(whileInView || onViewportEnter || onViewportLeave);\n-                    if (viewport.once && state.current.hasEnteredView) shouldObserve = false;\n-                    var useObserver = typeof IntersectionObserver === \"undefined\" ? useMissingIntersectionObserver : useIntersectionObserver;\n-                    useObserver(shouldObserve, state.current, visualElement, viewport);\n-                }\n-                var thresholdNames = {\n-                    some: 0,\n-                    all: 1\n-                };\n+                    // Build up the DOM representation for a single token, and add it to\n+                    // the line map. Takes care to render special characters separately.\n+                    function buildToken(builder, text, style, startStyle, endStyle, css, attributes) {\n+                        if (!text) {\n+                            return;\n+                        }\n+                        var displayText = builder.splitSpaces ? splitSpaces(text, builder.trailingSpace) : text;\n+                        var special = builder.cm.state.specialChars,\n+                            mustWrap = false;\n+                        var content;\n+                        if (!special.test(text)) {\n+                            builder.col += text.length;\n+                            content = document.createTextNode(displayText);\n+                            builder.map.push(builder.pos, builder.pos + text.length, content);\n+                            if (ie && ie_version < 9) {\n+                                mustWrap = true;\n+                            }\n+                            builder.pos += text.length;\n+                        } else {\n+                            content = document.createDocumentFragment();\n+                            var pos = 0;\n+                            while (true) {\n+                                special.lastIndex = pos;\n+                                var m = special.exec(text);\n+                                var skipped = m ? m.index - pos : text.length - pos;\n+                                if (skipped) {\n+                                    var txt = document.createTextNode(displayText.slice(pos, pos + skipped));\n+                                    if (ie && ie_version < 9) {\n+                                        content.appendChild(elt(\"span\", [txt]));\n+                                    } else {\n+                                        content.appendChild(txt);\n+                                    }\n+                                    builder.map.push(builder.pos, builder.pos + skipped, txt);\n+                                    builder.col += skipped;\n+                                    builder.pos += skipped;\n+                                }\n+                                if (!m) {\n+                                    break;\n+                                }\n+                                pos += skipped + 1;\n+                                var txt$1 = void 0;\n+                                if (m[0] == \"\\t\") {\n+                                    var tabSize = builder.cm.options.tabSize,\n+                                        tabWidth = tabSize - builder.col % tabSize;\n+                                    txt$1 = content.appendChild(elt(\"span\", spaceStr(tabWidth), \"cm-tab\"));\n+                                    txt$1.setAttribute(\"role\", \"presentation\");\n+                                    txt$1.setAttribute(\"cm-text\", \"\\t\");\n+                                    builder.col += tabWidth;\n+                                } else if (m[0] == \"\\r\" || m[0] == \"\\n\") {\n+                                    txt$1 = content.appendChild(elt(\"span\", m[0] == \"\\r\" ? \"\\u240d\" : \"\\u2424\", \"cm-invalidchar\"));\n+                                    txt$1.setAttribute(\"cm-text\", m[0]);\n+                                    builder.col += 1;\n+                                } else {\n+                                    txt$1 = builder.cm.options.specialCharPlaceholder(m[0]);\n+                                    txt$1.setAttribute(\"cm-text\", m[0]);\n+                                    if (ie && ie_version < 9) {\n+                                        content.appendChild(elt(\"span\", [txt$1]));\n+                                    } else {\n+                                        content.appendChild(txt$1);\n+                                    }\n+                                    builder.col += 1;\n+                                }\n+                                builder.map.push(builder.pos, builder.pos + 1, txt$1);\n+                                builder.pos++;\n+                            }\n+                        }\n+                        builder.trailingSpace = displayText.charCodeAt(text.length - 1) == 32;\n+                        if (style || startStyle || endStyle || mustWrap || css || attributes) {\n+                            var fullStyle = style || \"\";\n+                            if (startStyle) {\n+                                fullStyle += startStyle;\n+                            }\n+                            if (endStyle) {\n+                                fullStyle += endStyle;\n+                            }\n+                            var token = elt(\"span\", [content], fullStyle, css);\n+                            if (attributes) {\n+                                for (var attr in attributes) {\n+                                    if (attributes.hasOwnProperty(attr) && attr != \"style\" && attr != \"class\") {\n+                                        token.setAttribute(attr, attributes[attr]);\n+                                    }\n+                                }\n+                            }\n+                            return builder.content.appendChild(token);\n+                        }\n+                        builder.content.appendChild(content);\n+                    }\n \n-                function useIntersectionObserver(shouldObserve, state, visualElement, _a) {\n-                    var root = _a.root,\n-                        rootMargin = _a.margin,\n-                        _b = _a.amount,\n-                        amount = _b === void 0 ? \"some\" : _b,\n-                        once = _a.once;\n-                    React.useEffect(function() {\n-                        if (!shouldObserve) return;\n-                        var options = {\n-                            root: root === null || root === void 0 ? void 0 : root.current,\n-                            rootMargin: rootMargin,\n-                            threshold: typeof amount === \"number\" ? amount : thresholdNames[amount]\n-                        };\n-                        var intersectionCallback = function(entry) {\n-                            var _a;\n-                            var isIntersecting = entry.isIntersecting;\n-                            /**\n-                             * If there's been no change in the viewport state, early return.\n-                             */\n-                            if (state.isInView === isIntersecting) return;\n-                            state.isInView = isIntersecting;\n-                            /**\n-                             * Handle hasEnteredView. If this is only meant to run once, and\n-                             * element isn't visible, early return. Otherwise set hasEnteredView to true.\n-                             */\n-                            if (once && !isIntersecting && state.hasEnteredView) {\n-                                return;\n-                            } else if (isIntersecting) {\n-                                state.hasEnteredView = true;\n+                    // Change some spaces to NBSP to prevent the browser from collapsing\n+                    // trailing spaces at the end of a line when rendering text (issue #1362).\n+                    function splitSpaces(text, trailingBefore) {\n+                        if (text.length > 1 && !/  /.test(text)) {\n+                            return text;\n+                        }\n+                        var spaceBefore = trailingBefore,\n+                            result = \"\";\n+                        for (var i = 0; i < text.length; i++) {\n+                            var ch = text.charAt(i);\n+                            if (ch == \" \" && spaceBefore && (i == text.length - 1 || text.charCodeAt(i + 1) == 32)) {\n+                                ch = \"\\u00a0\";\n+                            }\n+                            result += ch;\n+                            spaceBefore = ch == \" \";\n+                        }\n+                        return result;\n+                    }\n+\n+                    // Work around nonsense dimensions being reported for stretches of\n+                    // right-to-left text.\n+                    function buildTokenBadBidi(inner, order) {\n+                        return function(builder, text, style, startStyle, endStyle, css, attributes) {\n+                            style = style ? style + \" cm-force-border\" : \"cm-force-border\";\n+                            var start = builder.pos,\n+                                end = start + text.length;\n+                            for (;;) {\n+                                // Find the part that overlaps with the start of this text\n+                                var part = void 0;\n+                                for (var i = 0; i < order.length; i++) {\n+                                    part = order[i];\n+                                    if (part.to > start && part.from <= start) {\n+                                        break;\n+                                    }\n+                                }\n+                                if (part.to >= end) {\n+                                    return inner(builder, text, style, startStyle, endStyle, css, attributes);\n+                                }\n+                                inner(builder, text.slice(0, part.to - start), style, startStyle, null, css, attributes);\n+                                startStyle = null;\n+                                text = text.slice(part.to - start);\n+                                start = part.to;\n                             }\n-                            (_a = visualElement.animationState) === null || _a === void 0 ? void 0 : _a.setActive(exports.AnimationType.InView, isIntersecting);\n-                            /**\n-                             * Use the latest committed props rather than the ones in scope\n-                             * when this observer is created\n-                             */\n-                            var props = visualElement.getProps();\n-                            var callback = isIntersecting ? props.onViewportEnter : props.onViewportLeave;\n-                            callback === null || callback === void 0 ? void 0 : callback(entry);\n                         };\n-                        return observeIntersection(visualElement.getInstance(), options, intersectionCallback);\n-                    }, [shouldObserve, root, rootMargin, amount]);\n-                }\n-                /**\n-                 * If IntersectionObserver is missing, we activate inView and fire onViewportEnter\n-                 * on mount. This way, the page will be in the state the author expects users\n-                 * to see it in for everyone.\n-                 */\n-                function useMissingIntersectionObserver(shouldObserve, state, visualElement, _a) {\n-                    var _b = _a.fallback,\n-                        fallback = _b === void 0 ? true : _b;\n-                    React.useEffect(function() {\n-                        if (!shouldObserve || !fallback) return;\n-                        if (env !== \"production\") {\n-                            warnOnce(false, \"IntersectionObserver not available on this device. whileInView animations will trigger on mount.\");\n+                    }\n+\n+                    function buildCollapsedSpan(builder, size, marker, ignoreWidget) {\n+                        var widget = !ignoreWidget && marker.widgetNode;\n+                        if (widget) {\n+                            builder.map.push(builder.pos, builder.pos + size, widget);\n                         }\n-                        /**\n-                         * Fire this in an rAF because, at this point, the animation state\n-                         * won't have flushed for the first time and there's certain logic in\n-                         * there that behaves differently on the initial animation.\n-                         *\n-                         * This hook should be quite rarely called so setting this in an rAF\n-                         * is preferred to changing the behaviour of the animation state.\n-                         */\n-                        requestAnimationFrame(function() {\n-                            var _a;\n-                            state.hasEnteredView = true;\n-                            var onViewportEnter = visualElement.getProps().onViewportEnter;\n-                            onViewportEnter === null || onViewportEnter === void 0 ? void 0 : onViewportEnter(null);\n-                            (_a = visualElement.animationState) === null || _a === void 0 ? void 0 : _a.setActive(exports.AnimationType.InView, true);\n-                        });\n-                    }, [shouldObserve]);\n-                }\n-                var makeRenderlessComponent = function(hook) {\n-                    return function(props) {\n-                        hook(props);\n-                        return null;\n-                    };\n-                };\n-                var gestureAnimations = {\n-                    inView: makeRenderlessComponent(useViewport),\n-                    tap: makeRenderlessComponent(useTapGesture),\n-                    focus: makeRenderlessComponent(useFocusGesture),\n-                    hover: makeRenderlessComponent(useHoverGesture)\n-                };\n-                var counter = 0;\n-                var incrementId = function() {\n-                    return counter++;\n-                };\n-                var useId = function() {\n-                    return useConstant(incrementId);\n-                };\n-                /**\n-                 * Ideally we'd use the following code to support React 18 optionally.\n-                 * But this fairly fails in Webpack (otherwise treeshaking wouldn't work at all).\n-                 * Need to come up with a different way of figuring this out.\n-                 */\n-                // export const useId = (React as any).useId\n-                //     ? (React as any).useId\n-                //     : () => useConstant(incrementId)\n+                        if (!ignoreWidget && builder.cm.display.input.needsContentAttribute) {\n+                            if (!widget) {\n+                                widget = builder.content.appendChild(document.createElement(\"span\"));\n+                            }\n+                            widget.setAttribute(\"cm-marker\", marker.id);\n+                        }\n+                        if (widget) {\n+                            builder.cm.display.input.setUneditable(widget);\n+                            builder.content.appendChild(widget);\n+                        }\n+                        builder.pos += size;\n+                        builder.trailingSpace = false;\n+                    }\n \n-                /**\n-                 * When a component is the child of `AnimatePresence`, it can use `usePresence`\n-                 * to access information about whether it's still present in the React tree.\n-                 *\n-                 * ```jsx\n-                 * import { usePresence } from \"framer-motion\"\n-                 *\n-                 * export const Component = () => {\n-                 *   const [isPresent, safeToRemove] = usePresence()\n-                 *\n-                 *   useEffect(() => {\n-                 *     !isPresent && setTimeout(safeToRemove, 1000)\n-                 *   }, [isPresent])\n-                 *\n-                 *   return <div />\n-                 * }\n-                 * ```\n-                 *\n-                 * If `isPresent` is `false`, it means that a component has been removed the tree, but\n-                 * `AnimatePresence` won't really remove it until `safeToRemove` has been called.\n-                 *\n-                 * @public\n-                 */\n-                function usePresence() {\n-                    var context = React.useContext(PresenceContext);\n-                    if (context === null) return [true, null];\n-                    var isPresent = context.isPresent,\n-                        onExitComplete = context.onExitComplete,\n-                        register = context.register;\n-                    // It's safe to call the following hooks conditionally (after an early return) because the context will always\n-                    // either be null or non-null for the lifespan of the component.\n-                    // Replace with useId when released in React\n-                    var id = useId();\n-                    React.useEffect(function() {\n-                        return register(id);\n-                    }, []);\n-                    var safeToRemove = function() {\n-                        return onExitComplete === null || onExitComplete === void 0 ? void 0 : onExitComplete(id);\n-                    };\n-                    return !isPresent && onExitComplete ? [false, safeToRemove] : [true];\n-                }\n-                /**\n-                 * Similar to `usePresence`, except `useIsPresent` simply returns whether or not the component is present.\n-                 * There is no `safeToRemove` function.\n-                 *\n-                 * ```jsx\n-                 * import { useIsPresent } from \"framer-motion\"\n-                 *\n-                 * export const Component = () => {\n-                 *   const isPresent = useIsPresent()\n-                 *\n-                 *   useEffect(() => {\n-                 *     !isPresent && console.log(\"I've been removed!\")\n-                 *   }, [isPresent])\n-                 *\n-                 *   return <div />\n-                 * }\n-                 * ```\n-                 *\n-                 * @public\n-                 */\n-                function useIsPresent() {\n-                    return isPresent(React.useContext(PresenceContext));\n-                }\n+                    // Outputs a number of spans to make up a line, taking highlighting\n+                    // and marked text into account.\n+                    function insertLineContent(line, builder, styles) {\n+                        var spans = line.markedSpans,\n+                            allText = line.text,\n+                            at = 0;\n+                        if (!spans) {\n+                            for (var i$1 = 1; i$1 < styles.length; i$1 += 2) {\n+                                builder.addToken(builder, allText.slice(at, at = styles[i$1]), interpretTokenStyle(styles[i$1 + 1], builder.cm.options));\n+                            }\n+                            return;\n+                        }\n+                        var len = allText.length,\n+                            pos = 0,\n+                            i = 1,\n+                            text = \"\",\n+                            style,\n+                            css;\n+                        var nextChange = 0,\n+                            spanStyle,\n+                            spanEndStyle,\n+                            spanStartStyle,\n+                            collapsed,\n+                            attributes;\n+                        for (;;) {\n+                            if (nextChange == pos) {\n+                                // Update current marker set\n+                                spanStyle = spanEndStyle = spanStartStyle = css = \"\";\n+                                attributes = null;\n+                                collapsed = null;\n+                                nextChange = Infinity;\n+                                var foundBookmarks = [],\n+                                    endStyles = void 0;\n+                                for (var j = 0; j < spans.length; ++j) {\n+                                    var sp = spans[j],\n+                                        m = sp.marker;\n+                                    if (m.type == \"bookmark\" && sp.from == pos && m.widgetNode) {\n+                                        foundBookmarks.push(m);\n+                                    } else if (sp.from <= pos && (sp.to == null || sp.to > pos || m.collapsed && sp.to == pos && sp.from == pos)) {\n+                                        if (sp.to != null && sp.to != pos && nextChange > sp.to) {\n+                                            nextChange = sp.to;\n+                                            spanEndStyle = \"\";\n+                                        }\n+                                        if (m.className) {\n+                                            spanStyle += \" \" + m.className;\n+                                        }\n+                                        if (m.css) {\n+                                            css = (css ? css + \";\" : \"\") + m.css;\n+                                        }\n+                                        if (m.startStyle && sp.from == pos) {\n+                                            spanStartStyle += \" \" + m.startStyle;\n+                                        }\n+                                        if (m.endStyle && sp.to == nextChange) {\n+                                            (endStyles || (endStyles = [])).push(m.endStyle, sp.to);\n+                                        }\n+                                        // support for the old title property\n+                                        // https://github.com/codemirror/CodeMirror/pull/5673\n+                                        if (m.title) {\n+                                            (attributes || (attributes = {})).title = m.title;\n+                                        }\n+                                        if (m.attributes) {\n+                                            for (var attr in m.attributes) {\n+                                                (attributes || (attributes = {}))[attr] = m.attributes[attr];\n+                                            }\n+                                        }\n+                                        if (m.collapsed && (!collapsed || compareCollapsedMarkers(collapsed.marker, m) < 0)) {\n+                                            collapsed = sp;\n+                                        }\n+                                    } else if (sp.from > pos && nextChange > sp.from) {\n+                                        nextChange = sp.from;\n+                                    }\n+                                }\n+                                if (endStyles) {\n+                                    for (var j$1 = 0; j$1 < endStyles.length; j$1 += 2) {\n+                                        if (endStyles[j$1 + 1] == nextChange) {\n+                                            spanEndStyle += \" \" + endStyles[j$1];\n+                                        }\n+                                    }\n+                                }\n+                                if (!collapsed || collapsed.from == pos) {\n+                                    for (var j$2 = 0; j$2 < foundBookmarks.length; ++j$2) {\n+                                        buildCollapsedSpan(builder, 0, foundBookmarks[j$2]);\n+                                    }\n+                                }\n+                                if (collapsed && (collapsed.from || 0) == pos) {\n+                                    buildCollapsedSpan(builder, (collapsed.to == null ? len + 1 : collapsed.to) - pos, collapsed.marker, collapsed.from == null);\n+                                    if (collapsed.to == null) {\n+                                        return;\n+                                    }\n+                                    if (collapsed.to == pos) {\n+                                        collapsed = false;\n+                                    }\n+                                }\n+                            }\n+                            if (pos >= len) {\n+                                break;\n+                            }\n+                            var upto = Math.min(len, nextChange);\n+                            while (true) {\n+                                if (text) {\n+                                    var end = pos + text.length;\n+                                    if (!collapsed) {\n+                                        var tokenText = end > upto ? text.slice(0, upto - pos) : text;\n+                                        builder.addToken(builder, tokenText, style ? style + spanStyle : spanStyle, spanStartStyle, pos + tokenText.length == nextChange ? spanEndStyle : \"\", css, attributes);\n+                                    }\n+                                    if (end >= upto) {\n+                                        text = text.slice(upto - pos);\n+                                        pos = upto;\n+                                        break;\n+                                    }\n+                                    pos = end;\n+                                    spanStartStyle = \"\";\n+                                }\n+                                text = allText.slice(at, at = styles[i++]);\n+                                style = interpretTokenStyle(styles[i++], builder.cm.options);\n+                            }\n+                        }\n+                    }\n \n-                function isPresent(context) {\n-                    return context === null ? true : context.isPresent;\n-                }\n+                    // These objects are used to represent the visible (currently drawn)\n+                    // part of the document. A LineView may correspond to multiple\n+                    // logical lines, if those are connected by collapsed ranges.\n+                    function LineView(doc, line, lineN) {\n+                        // The starting line\n+                        this.line = line;\n+                        // Continuing lines, if any\n+                        this.rest = visualLineContinued(line);\n+                        // Number of logical lines in this visual line\n+                        this.size = this.rest ? lineNo(lst(this.rest)) - lineN + 1 : 1;\n+                        this.node = this.text = null;\n+                        this.hidden = lineIsHidden(doc, line);\n+                    }\n+\n+                    // Create a range of LineView objects for the given lines.\n+                    function buildViewArray(cm, from, to) {\n+                        var array = [],\n+                            nextPos;\n+                        for (var pos = from; pos < to; pos = nextPos) {\n+                            var view = new LineView(cm.doc, getLine(cm.doc, pos), pos);\n+                            nextPos = pos + view.size;\n+                            array.push(view);\n+                        }\n+                        return array;\n+                    }\n+                    var operationGroup = null;\n+\n+                    function pushOperation(op) {\n+                        if (operationGroup) {\n+                            operationGroup.ops.push(op);\n+                        } else {\n+                            op.ownsGroup = operationGroup = {\n+                                ops: [op],\n+                                delayedCallbacks: []\n+                            };\n+                        }\n+                    }\n \n-                function shallowCompare(next, prev) {\n-                    if (!Array.isArray(prev)) return false;\n-                    var prevLength = prev.length;\n-                    if (prevLength !== next.length) return false;\n-                    for (var i = 0; i < prevLength; i++) {\n-                        if (prev[i] !== next[i]) return false;\n+                    function fireCallbacksForOps(group) {\n+                        // Calls delayed callbacks and cursorActivity handlers until no\n+                        // new ones appear\n+                        var callbacks = group.delayedCallbacks,\n+                            i = 0;\n+                        do {\n+                            for (; i < callbacks.length; i++) {\n+                                callbacks[i].call(null);\n+                            }\n+                            for (var j = 0; j < group.ops.length; j++) {\n+                                var op = group.ops[j];\n+                                if (op.cursorActivityHandlers) {\n+                                    while (op.cursorActivityCalled < op.cursorActivityHandlers.length) {\n+                                        op.cursorActivityHandlers[op.cursorActivityCalled++].call(null, op.cm);\n+                                    }\n+                                }\n+                            }\n+                        } while (i < callbacks.length);\n                     }\n-                    return true;\n-                }\n \n-                /**\n-                 * Converts seconds to milliseconds\n-                 *\n-                 * @param seconds - Time in seconds.\n-                 * @return milliseconds - Converted time in milliseconds.\n-                 */\n-                var secondsToMilliseconds = function(seconds) {\n-                    return seconds * 1000;\n-                };\n-                var easingLookup = {\n-                    linear: popmotion.linear,\n-                    easeIn: popmotion.easeIn,\n-                    easeInOut: popmotion.easeInOut,\n-                    easeOut: popmotion.easeOut,\n-                    circIn: popmotion.circIn,\n-                    circInOut: popmotion.circInOut,\n-                    circOut: popmotion.circOut,\n-                    backIn: popmotion.backIn,\n-                    backInOut: popmotion.backInOut,\n-                    backOut: popmotion.backOut,\n-                    anticipate: popmotion.anticipate,\n-                    bounceIn: popmotion.bounceIn,\n-                    bounceInOut: popmotion.bounceInOut,\n-                    bounceOut: popmotion.bounceOut\n-                };\n-                var easingDefinitionToFunction = function(definition) {\n-                    if (Array.isArray(definition)) {\n-                        // If cubic bezier definition, create bezier curve\n-                        heyListen.invariant(definition.length === 4, \"Cubic bezier arrays must contain four numerical values.\");\n-                        var _a = tslib.__read(definition, 4),\n-                            x1 = _a[0],\n-                            y1 = _a[1],\n-                            x2 = _a[2],\n-                            y2 = _a[3];\n-                        return popmotion.cubicBezier(x1, y1, x2, y2);\n-                    } else if (typeof definition === \"string\") {\n-                        // Else lookup from table\n-                        heyListen.invariant(easingLookup[definition] !== undefined, \"Invalid easing type '\".concat(definition, \"'\"));\n-                        return easingLookup[definition];\n+                    function finishOperation(op, endCb) {\n+                        var group = op.ownsGroup;\n+                        if (!group) {\n+                            return;\n+                        }\n+                        try {\n+                            fireCallbacksForOps(group);\n+                        } finally {\n+                            operationGroup = null;\n+                            endCb(group);\n+                        }\n                     }\n-                    return definition;\n-                };\n-                var isEasingArray = function(ease) {\n-                    return Array.isArray(ease) && typeof ease[0] !== \"number\";\n-                };\n+                    var orphanDelayedCallbacks = null;\n \n-                /**\n-                 * Check if a value is animatable. Examples:\n-                 *\n-                 * \u2705: 100, \"100px\", \"#fff\"\n-                 * \u274c: \"block\", \"url(2.jpg)\"\n-                 * @param value\n-                 *\n-                 * @internal\n-                 */\n-                var isAnimatable = function(key, value) {\n-                    // If the list of keys tat might be non-animatable grows, replace with Set\n-                    if (key === \"zIndex\") return false;\n-                    // If it's a number or a keyframes array, we can animate it. We might at some point\n-                    // need to do a deep isAnimatable check of keyframes, or let Popmotion handle this,\n-                    // but for now lets leave it like this for performance reasons\n-                    if (typeof value === \"number\" || Array.isArray(value)) return true;\n-                    if (typeof value === \"string\" &&\n-                        // It's animatable if we have a string\n-                        styleValueTypes.complex.test(value) &&\n-                        // And it contains numbers and/or colors\n-                        !value.startsWith(\"url(\") // Unless it starts with \"url(\"\n-                    ) {\n-                        return true;\n+                    // Often, we want to signal events at a point where we are in the\n+                    // middle of some work, but don't want the handler to start calling\n+                    // other methods on the editor, which might be in an inconsistent\n+                    // state or simply not expect any other events to happen.\n+                    // signalLater looks whether there are any handlers, and schedules\n+                    // them to be executed when the last operation ends, or, if no\n+                    // operation is active, when a timeout fires.\n+                    function signalLater(emitter, type /*, values...*/ ) {\n+                        var arr = getHandlers(emitter, type);\n+                        if (!arr.length) {\n+                            return;\n+                        }\n+                        var args = Array.prototype.slice.call(arguments, 2),\n+                            list;\n+                        if (operationGroup) {\n+                            list = operationGroup.delayedCallbacks;\n+                        } else if (orphanDelayedCallbacks) {\n+                            list = orphanDelayedCallbacks;\n+                        } else {\n+                            list = orphanDelayedCallbacks = [];\n+                            setTimeout(fireOrphanDelayed, 0);\n+                        }\n+                        var loop = function(i) {\n+                            list.push(function() {\n+                                return arr[i].apply(null, args);\n+                            });\n+                        };\n+                        for (var i = 0; i < arr.length; ++i) loop(i);\n                     }\n-                    return false;\n-                };\n-                var underDampedSpring = function() {\n-                    return {\n-                        type: \"spring\",\n-                        stiffness: 500,\n-                        damping: 25,\n-                        restSpeed: 10\n-                    };\n-                };\n-                var criticallyDampedSpring = function(to) {\n-                    return {\n-                        type: \"spring\",\n-                        stiffness: 550,\n-                        damping: to === 0 ? 2 * Math.sqrt(550) : 30,\n-                        restSpeed: 10\n-                    };\n-                };\n-                var linearTween = function() {\n-                    return {\n-                        type: \"keyframes\",\n-                        ease: \"linear\",\n-                        duration: 0.3\n-                    };\n-                };\n-                var keyframes = function(values) {\n-                    return {\n-                        type: \"keyframes\",\n-                        duration: 0.8,\n-                        values: values\n-                    };\n-                };\n-                var defaultTransitions = {\n-                    x: underDampedSpring,\n-                    y: underDampedSpring,\n-                    z: underDampedSpring,\n-                    rotate: underDampedSpring,\n-                    rotateX: underDampedSpring,\n-                    rotateY: underDampedSpring,\n-                    rotateZ: underDampedSpring,\n-                    scaleX: criticallyDampedSpring,\n-                    scaleY: criticallyDampedSpring,\n-                    scale: criticallyDampedSpring,\n-                    opacity: linearTween,\n-                    backgroundColor: linearTween,\n-                    color: linearTween,\n-                    default: criticallyDampedSpring\n-                };\n-                var getDefaultTransition = function(valueKey, to) {\n-                    var transitionFactory;\n-                    if (isKeyframesTarget(to)) {\n-                        transitionFactory = keyframes;\n-                    } else {\n-                        transitionFactory = defaultTransitions[valueKey] || defaultTransitions.default;\n+\n+                    function fireOrphanDelayed() {\n+                        var delayed = orphanDelayedCallbacks;\n+                        orphanDelayedCallbacks = null;\n+                        for (var i = 0; i < delayed.length; ++i) {\n+                            delayed[i]();\n+                        }\n                     }\n-                    return tslib.__assign({\n-                        to: to\n-                    }, transitionFactory(to));\n-                };\n \n-                /**\n-                 * A map of default value types for common values\n-                 */\n-                var defaultValueTypes = tslib.__assign(tslib.__assign({}, numberValueTypes), {\n-                    // Color props\n-                    color: styleValueTypes.color,\n-                    backgroundColor: styleValueTypes.color,\n-                    outlineColor: styleValueTypes.color,\n-                    fill: styleValueTypes.color,\n-                    stroke: styleValueTypes.color,\n-                    // Border props\n-                    borderColor: styleValueTypes.color,\n-                    borderTopColor: styleValueTypes.color,\n-                    borderRightColor: styleValueTypes.color,\n-                    borderBottomColor: styleValueTypes.color,\n-                    borderLeftColor: styleValueTypes.color,\n-                    filter: styleValueTypes.filter,\n-                    WebkitFilter: styleValueTypes.filter\n-                });\n-                /**\n-                 * Gets the default ValueType for the provided value key\n-                 */\n-                var getDefaultValueType = function(key) {\n-                    return defaultValueTypes[key];\n-                };\n+                    // When an aspect of a line changes, a string is added to\n+                    // lineView.changes. This updates the relevant part of the line's\n+                    // DOM structure.\n+                    function updateLineForChanges(cm, lineView, lineN, dims) {\n+                        for (var j = 0; j < lineView.changes.length; j++) {\n+                            var type = lineView.changes[j];\n+                            if (type == \"text\") {\n+                                updateLineText(cm, lineView);\n+                            } else if (type == \"gutter\") {\n+                                updateLineGutter(cm, lineView, lineN, dims);\n+                            } else if (type == \"class\") {\n+                                updateLineClasses(cm, lineView);\n+                            } else if (type == \"widget\") {\n+                                updateLineWidgets(cm, lineView, dims);\n+                            }\n+                        }\n+                        lineView.changes = null;\n+                    }\n \n-                function getAnimatableNone(key, value) {\n-                    var _a;\n-                    var defaultValueType = getDefaultValueType(key);\n-                    if (defaultValueType !== styleValueTypes.filter) defaultValueType = styleValueTypes.complex;\n-                    // If value is not recognised as animatable, ie \"none\", create an animatable version origin based on the target\n-                    return (_a = defaultValueType.getAnimatableNone) === null || _a === void 0 ? void 0 : _a.call(defaultValueType, value);\n-                }\n-                var instantAnimationState = {\n-                    current: false\n-                };\n+                    // Lines with gutter elements, widgets or a background class need to\n+                    // be wrapped, and have the extra elements added to the wrapper div\n+                    function ensureLineWrapped(lineView) {\n+                        if (lineView.node == lineView.text) {\n+                            lineView.node = elt(\"div\", null, null, \"position: relative\");\n+                            if (lineView.text.parentNode) {\n+                                lineView.text.parentNode.replaceChild(lineView.node, lineView.text);\n+                            }\n+                            lineView.node.appendChild(lineView.text);\n+                            if (ie && ie_version < 8) {\n+                                lineView.node.style.zIndex = 2;\n+                            }\n+                        }\n+                        return lineView.node;\n+                    }\n \n-                /**\n-                 * Decide whether a transition is defined on a given Transition.\n-                 * This filters out orchestration options and returns true\n-                 * if any options are left.\n-                 */\n-                function isTransitionDefined(_a) {\n-                    _a.when;\n-                    _a.delay;\n-                    _a.delayChildren;\n-                    _a.staggerChildren;\n-                    _a.staggerDirection;\n-                    _a.repeat;\n-                    _a.repeatType;\n-                    _a.repeatDelay;\n-                    _a.from;\n-                    var transition = tslib.__rest(_a, [\"when\", \"delay\", \"delayChildren\", \"staggerChildren\", \"staggerDirection\", \"repeat\", \"repeatType\", \"repeatDelay\", \"from\"]);\n-                    return !!Object.keys(transition).length;\n-                }\n-                var legacyRepeatWarning = false;\n-                /**\n-                 * Convert Framer Motion's Transition type into Popmotion-compatible options.\n-                 */\n-                function convertTransitionToAnimationOptions(_a) {\n-                    var ease = _a.ease,\n-                        times = _a.times,\n-                        yoyo = _a.yoyo,\n-                        flip = _a.flip,\n-                        loop = _a.loop,\n-                        transition = tslib.__rest(_a, [\"ease\", \"times\", \"yoyo\", \"flip\", \"loop\"]);\n-                    var options = tslib.__assign({}, transition);\n-                    if (times) options[\"offset\"] = times;\n-                    /**\n-                     * Convert any existing durations from seconds to milliseconds\n-                     */\n-                    if (transition.duration) options[\"duration\"] = secondsToMilliseconds(transition.duration);\n-                    if (transition.repeatDelay) options.repeatDelay = secondsToMilliseconds(transition.repeatDelay);\n-                    /**\n-                     * Map easing names to Popmotion's easing functions\n-                     */\n-                    if (ease) {\n-                        options[\"ease\"] = isEasingArray(ease) ? ease.map(easingDefinitionToFunction) : easingDefinitionToFunction(ease);\n+                    function updateLineBackground(cm, lineView) {\n+                        var cls = lineView.bgClass ? lineView.bgClass + \" \" + (lineView.line.bgClass || \"\") : lineView.line.bgClass;\n+                        if (cls) {\n+                            cls += \" CodeMirror-linebackground\";\n+                        }\n+                        if (lineView.background) {\n+                            if (cls) {\n+                                lineView.background.className = cls;\n+                            } else {\n+                                lineView.background.parentNode.removeChild(lineView.background);\n+                                lineView.background = null;\n+                            }\n+                        } else if (cls) {\n+                            var wrap = ensureLineWrapped(lineView);\n+                            lineView.background = wrap.insertBefore(elt(\"div\", null, cls), wrap.firstChild);\n+                            cm.display.input.setUneditable(lineView.background);\n+                        }\n                     }\n-                    /**\n-                     * Support legacy transition API\n-                     */\n-                    if (transition.type === \"tween\") options.type = \"keyframes\";\n-                    /**\n-                     * TODO: These options are officially removed from the API.\n-                     */\n-                    if (yoyo || loop || flip) {\n-                        heyListen.warning(!legacyRepeatWarning, \"yoyo, loop and flip have been removed from the API. Replace with repeat and repeatType options.\");\n-                        legacyRepeatWarning = true;\n-                        if (yoyo) {\n-                            options.repeatType = \"reverse\";\n-                        } else if (loop) {\n-                            options.repeatType = \"loop\";\n-                        } else if (flip) {\n-                            options.repeatType = \"mirror\";\n+\n+                    // Wrapper around buildLineContent which will reuse the structure\n+                    // in display.externalMeasured when possible.\n+                    function getLineContent(cm, lineView) {\n+                        var ext = cm.display.externalMeasured;\n+                        if (ext && ext.line == lineView.line) {\n+                            cm.display.externalMeasured = null;\n+                            lineView.measure = ext.measure;\n+                            return ext.built;\n                         }\n-                        options.repeat = loop || yoyo || flip || transition.repeat;\n+                        return buildLineContent(cm, lineView);\n                     }\n-                    /**\n-                     * TODO: Popmotion 9 has the ability to automatically detect whether to use\n-                     * a keyframes or spring animation, but does so by detecting velocity and other spring options.\n-                     * It'd be good to introduce a similar thing here.\n-                     */\n-                    if (transition.type !== \"spring\") options.type = \"keyframes\";\n-                    return options;\n-                }\n-                /**\n-                 * Get the delay for a value by checking Transition with decreasing specificity.\n-                 */\n-                function getDelayFromTransition(transition, key) {\n-                    var _a, _b;\n-                    var valueTransition = getValueTransition(transition, key) || {};\n-                    return (_b = (_a = valueTransition.delay) !== null && _a !== void 0 ? _a : transition.delay) !== null && _b !== void 0 ? _b : 0;\n-                }\n \n-                function hydrateKeyframes(options) {\n-                    if (Array.isArray(options.to) && options.to[0] === null) {\n-                        options.to = tslib.__spreadArray([], tslib.__read(options.to), false);\n-                        options.to[0] = options.from;\n+                    // Redraw the line's text. Interacts with the background and text\n+                    // classes because the mode may output tokens that influence these\n+                    // classes.\n+                    function updateLineText(cm, lineView) {\n+                        var cls = lineView.text.className;\n+                        var built = getLineContent(cm, lineView);\n+                        if (lineView.text == lineView.node) {\n+                            lineView.node = built.pre;\n+                        }\n+                        lineView.text.parentNode.replaceChild(built.pre, lineView.text);\n+                        lineView.text = built.pre;\n+                        if (built.bgClass != lineView.bgClass || built.textClass != lineView.textClass) {\n+                            lineView.bgClass = built.bgClass;\n+                            lineView.textClass = built.textClass;\n+                            updateLineClasses(cm, lineView);\n+                        } else if (cls) {\n+                            lineView.text.className = cls;\n+                        }\n                     }\n-                    return options;\n-                }\n \n-                function getPopmotionAnimationOptions(transition, options, key) {\n-                    var _a;\n-                    if (Array.isArray(options.to)) {\n-                        (_a = transition.duration) !== null && _a !== void 0 ? _a : transition.duration = 0.8;\n+                    function updateLineClasses(cm, lineView) {\n+                        updateLineBackground(cm, lineView);\n+                        if (lineView.line.wrapClass) {\n+                            ensureLineWrapped(lineView).className = lineView.line.wrapClass;\n+                        } else if (lineView.node != lineView.text) {\n+                            lineView.node.className = \"\";\n+                        }\n+                        var textClass = lineView.textClass ? lineView.textClass + \" \" + (lineView.line.textClass || \"\") : lineView.line.textClass;\n+                        lineView.text.className = textClass || \"\";\n                     }\n-                    hydrateKeyframes(options);\n-                    /**\n-                     * Get a default transition if none is determined to be defined.\n-                     */\n-                    if (!isTransitionDefined(transition)) {\n-                        transition = tslib.__assign(tslib.__assign({}, transition), getDefaultTransition(key, options.to));\n+\n+                    function updateLineGutter(cm, lineView, lineN, dims) {\n+                        if (lineView.gutter) {\n+                            lineView.node.removeChild(lineView.gutter);\n+                            lineView.gutter = null;\n+                        }\n+                        if (lineView.gutterBackground) {\n+                            lineView.node.removeChild(lineView.gutterBackground);\n+                            lineView.gutterBackground = null;\n+                        }\n+                        if (lineView.line.gutterClass) {\n+                            var wrap = ensureLineWrapped(lineView);\n+                            lineView.gutterBackground = elt(\"div\", null, \"CodeMirror-gutter-background \" + lineView.line.gutterClass, \"left: \" + (cm.options.fixedGutter ? dims.fixedPos : -dims.gutterTotalWidth) + \"px; width: \" + dims.gutterTotalWidth + \"px\");\n+                            cm.display.input.setUneditable(lineView.gutterBackground);\n+                            wrap.insertBefore(lineView.gutterBackground, lineView.text);\n+                        }\n+                        var markers = lineView.line.gutterMarkers;\n+                        if (cm.options.lineNumbers || markers) {\n+                            var wrap$1 = ensureLineWrapped(lineView);\n+                            var gutterWrap = lineView.gutter = elt(\"div\", null, \"CodeMirror-gutter-wrapper\", \"left: \" + (cm.options.fixedGutter ? dims.fixedPos : -dims.gutterTotalWidth) + \"px\");\n+                            gutterWrap.setAttribute(\"aria-hidden\", \"true\");\n+                            cm.display.input.setUneditable(gutterWrap);\n+                            wrap$1.insertBefore(gutterWrap, lineView.text);\n+                            if (lineView.line.gutterClass) {\n+                                gutterWrap.className += \" \" + lineView.line.gutterClass;\n+                            }\n+                            if (cm.options.lineNumbers && (!markers || !markers[\"CodeMirror-linenumbers\"])) {\n+                                lineView.lineNumber = gutterWrap.appendChild(elt(\"div\", lineNumberFor(cm.options, lineN), \"CodeMirror-linenumber CodeMirror-gutter-elt\", \"left: \" + dims.gutterLeft[\"CodeMirror-linenumbers\"] + \"px; width: \" + cm.display.lineNumInnerWidth + \"px\"));\n+                            }\n+                            if (markers) {\n+                                for (var k = 0; k < cm.display.gutterSpecs.length; ++k) {\n+                                    var id = cm.display.gutterSpecs[k].className,\n+                                        found = markers.hasOwnProperty(id) && markers[id];\n+                                    if (found) {\n+                                        gutterWrap.appendChild(elt(\"div\", [found], \"CodeMirror-gutter-elt\", \"left: \" + dims.gutterLeft[id] + \"px; width: \" + dims.gutterWidth[id] + \"px\"));\n+                                    }\n+                                }\n+                            }\n+                        }\n                     }\n-                    return tslib.__assign(tslib.__assign({}, options), convertTransitionToAnimationOptions(transition));\n-                }\n-                /**\n-                 *\n-                 */\n-                function getAnimation(key, value, target, transition, onComplete) {\n-                    var _a;\n-                    var valueTransition = getValueTransition(transition, key);\n-                    var origin = (_a = valueTransition.from) !== null && _a !== void 0 ? _a : value.get();\n-                    var isTargetAnimatable = isAnimatable(key, target);\n-                    if (origin === \"none\" && isTargetAnimatable && typeof target === \"string\") {\n-                        /**\n-                         * If we're trying to animate from \"none\", try and get an animatable version\n-                         * of the target. This could be improved to work both ways.\n-                         */\n-                        origin = getAnimatableNone(key, target);\n-                    } else if (isZero(origin) && typeof target === \"string\") {\n-                        origin = getZeroUnit(target);\n-                    } else if (!Array.isArray(target) && isZero(target) && typeof origin === \"string\") {\n-                        target = getZeroUnit(origin);\n+\n+                    function updateLineWidgets(cm, lineView, dims) {\n+                        if (lineView.alignable) {\n+                            lineView.alignable = null;\n+                        }\n+                        var isWidget = classTest(\"CodeMirror-linewidget\");\n+                        for (var node = lineView.node.firstChild, next = void 0; node; node = next) {\n+                            next = node.nextSibling;\n+                            if (isWidget.test(node.className)) {\n+                                lineView.node.removeChild(node);\n+                            }\n+                        }\n+                        insertLineWidgets(cm, lineView, dims);\n                     }\n-                    var isOriginAnimatable = isAnimatable(key, origin);\n-                    heyListen.warning(isOriginAnimatable === isTargetAnimatable, \"You are trying to animate \".concat(key, \" from \\\"\").concat(origin, \"\\\" to \\\"\").concat(target, \"\\\". \").concat(origin, \" is not an animatable value - to enable this animation set \").concat(origin, \" to a value animatable to \").concat(target, \" via the `style` property.\"));\n \n-                    function start() {\n-                        var options = {\n-                            from: origin,\n-                            to: target,\n-                            velocity: value.getVelocity(),\n-                            onComplete: onComplete,\n-                            onUpdate: function(v) {\n-                                return value.set(v);\n+                    // Build a line's DOM representation from scratch\n+                    function buildLineElement(cm, lineView, lineN, dims) {\n+                        var built = getLineContent(cm, lineView);\n+                        lineView.text = lineView.node = built.pre;\n+                        if (built.bgClass) {\n+                            lineView.bgClass = built.bgClass;\n+                        }\n+                        if (built.textClass) {\n+                            lineView.textClass = built.textClass;\n+                        }\n+                        updateLineClasses(cm, lineView);\n+                        updateLineGutter(cm, lineView, lineN, dims);\n+                        insertLineWidgets(cm, lineView, dims);\n+                        return lineView.node;\n+                    }\n+\n+                    // A lineView may contain multiple logical lines (when merged by\n+                    // collapsed spans). The widgets for all of them need to be drawn.\n+                    function insertLineWidgets(cm, lineView, dims) {\n+                        insertLineWidgetsFor(cm, lineView.line, lineView, dims, true);\n+                        if (lineView.rest) {\n+                            for (var i = 0; i < lineView.rest.length; i++) {\n+                                insertLineWidgetsFor(cm, lineView.rest[i], lineView, dims, false);\n                             }\n-                        };\n-                        return valueTransition.type === \"inertia\" || valueTransition.type === \"decay\" ? popmotion.inertia(tslib.__assign(tslib.__assign({}, options), valueTransition)) : popmotion.animate(tslib.__assign(tslib.__assign({}, getPopmotionAnimationOptions(valueTransition, options, key)), {\n-                            onUpdate: function(v) {\n-                                var _a;\n-                                options.onUpdate(v);\n-                                (_a = valueTransition.onUpdate) === null || _a === void 0 ? void 0 : _a.call(valueTransition, v);\n-                            },\n-                            onComplete: function() {\n-                                var _a;\n-                                options.onComplete();\n-                                (_a = valueTransition.onComplete) === null || _a === void 0 ? void 0 : _a.call(valueTransition);\n+                        }\n+                    }\n+\n+                    function insertLineWidgetsFor(cm, line, lineView, dims, allowAbove) {\n+                        if (!line.widgets) {\n+                            return;\n+                        }\n+                        var wrap = ensureLineWrapped(lineView);\n+                        for (var i = 0, ws = line.widgets; i < ws.length; ++i) {\n+                            var widget = ws[i],\n+                                node = elt(\"div\", [widget.node], \"CodeMirror-linewidget\" + (widget.className ? \" \" + widget.className : \"\"));\n+                            if (!widget.handleMouseEvents) {\n+                                node.setAttribute(\"cm-ignore-events\", \"true\");\n+                            }\n+                            positionLineWidget(widget, node, lineView, dims);\n+                            cm.display.input.setUneditable(node);\n+                            if (allowAbove && widget.above) {\n+                                wrap.insertBefore(node, lineView.gutter || lineView.text);\n+                            } else {\n+                                wrap.appendChild(node);\n                             }\n-                        }));\n+                            signalLater(widget, \"redraw\");\n+                        }\n                     }\n \n-                    function set() {\n-                        var _a, _b;\n-                        var finalTarget = resolveFinalValueInKeyframes(target);\n-                        value.set(finalTarget);\n-                        onComplete();\n-                        (_a = valueTransition === null || valueTransition === void 0 ? void 0 : valueTransition.onUpdate) === null || _a === void 0 ? void 0 : _a.call(valueTransition, finalTarget);\n-                        (_b = valueTransition === null || valueTransition === void 0 ? void 0 : valueTransition.onComplete) === null || _b === void 0 ? void 0 : _b.call(valueTransition);\n-                        return {\n-                            stop: function() {}\n-                        };\n+                    function positionLineWidget(widget, node, lineView, dims) {\n+                        if (widget.noHScroll) {\n+                            (lineView.alignable || (lineView.alignable = [])).push(node);\n+                            var width = dims.wrapperWidth;\n+                            node.style.left = dims.fixedPos + \"px\";\n+                            if (!widget.coverGutter) {\n+                                width -= dims.gutterTotalWidth;\n+                                node.style.paddingLeft = dims.gutterTotalWidth + \"px\";\n+                            }\n+                            node.style.width = width + \"px\";\n+                        }\n+                        if (widget.coverGutter) {\n+                            node.style.zIndex = 5;\n+                            node.style.position = \"relative\";\n+                            if (!widget.noHScroll) {\n+                                node.style.marginLeft = -dims.gutterTotalWidth + \"px\";\n+                            }\n+                        }\n                     }\n-                    return !isOriginAnimatable || !isTargetAnimatable || valueTransition.type === false ? set : start;\n-                }\n \n-                function isZero(value) {\n-                    return value === 0 || typeof value === \"string\" && parseFloat(value) === 0 && value.indexOf(\" \") === -1;\n-                }\n+                    function widgetHeight(widget) {\n+                        if (widget.height != null) {\n+                            return widget.height;\n+                        }\n+                        var cm = widget.doc.cm;\n+                        if (!cm) {\n+                            return 0;\n+                        }\n+                        if (!contains(document.body, widget.node)) {\n+                            var parentStyle = \"position: relative;\";\n+                            if (widget.coverGutter) {\n+                                parentStyle += \"margin-left: -\" + cm.display.gutters.offsetWidth + \"px;\";\n+                            }\n+                            if (widget.noHScroll) {\n+                                parentStyle += \"width: \" + cm.display.wrapper.clientWidth + \"px;\";\n+                            }\n+                            removeChildrenAndAdd(cm.display.measure, elt(\"div\", [widget.node], null, parentStyle));\n+                        }\n+                        return widget.height = widget.node.parentNode.offsetHeight;\n+                    }\n \n-                function getZeroUnit(potentialUnitType) {\n-                    return typeof potentialUnitType === \"number\" ? 0 : getAnimatableNone(\"\", potentialUnitType);\n-                }\n+                    // Return true when the given mouse event happened in a widget\n+                    function eventInWidget(display, e) {\n+                        for (var n = e_target(e); n != display.wrapper; n = n.parentNode) {\n+                            if (!n || n.nodeType == 1 && n.getAttribute(\"cm-ignore-events\") == \"true\" || n.parentNode == display.sizer && n != display.mover) {\n+                                return true;\n+                            }\n+                        }\n+                    }\n \n-                function getValueTransition(transition, key) {\n-                    return transition[key] || transition[\"default\"] || transition;\n-                }\n-                /**\n-                 * Start animation on a MotionValue. This function is an interface between\n-                 * Framer Motion and Popmotion\n-                 */\n-                function startAnimation(key, value, target, transition) {\n-                    if (transition === void 0) {\n-                        transition = {};\n+                    // POSITION MEASUREMENT\n+\n+                    function paddingTop(display) {\n+                        return display.lineSpace.offsetTop;\n                     }\n-                    if (instantAnimationState.current) {\n-                        transition = {\n-                            type: false\n-                        };\n+\n+                    function paddingVert(display) {\n+                        return display.mover.offsetHeight - display.lineSpace.offsetHeight;\n                     }\n-                    return value.start(function(onComplete) {\n-                        var delayTimer;\n-                        var controls;\n-                        var animation = getAnimation(key, value, target, transition, onComplete);\n-                        var delay = getDelayFromTransition(transition, key);\n-                        var start = function() {\n-                            return controls = animation();\n-                        };\n-                        if (delay) {\n-                            delayTimer = window.setTimeout(start, secondsToMilliseconds(delay));\n-                        } else {\n-                            start();\n+\n+                    function paddingH(display) {\n+                        if (display.cachedPaddingH) {\n+                            return display.cachedPaddingH;\n                         }\n-                        return function() {\n-                            clearTimeout(delayTimer);\n-                            controls === null || controls === void 0 ? void 0 : controls.stop();\n+                        var e = removeChildrenAndAdd(display.measure, elt(\"pre\", \"x\", \"CodeMirror-line-like\"));\n+                        var style = window.getComputedStyle ? window.getComputedStyle(e) : e.currentStyle;\n+                        var data = {\n+                            left: parseInt(style.paddingLeft),\n+                            right: parseInt(style.paddingRight)\n                         };\n-                    });\n-                }\n+                        if (!isNaN(data.left) && !isNaN(data.right)) {\n+                            display.cachedPaddingH = data;\n+                        }\n+                        return data;\n+                    }\n \n-                /**\n-                 * Check if value is a numerical string, ie a string that is purely a number eg \"100\" or \"-100.1\"\n-                 */\n-                var isNumericalString = function(v) {\n-                    return /^\\-?\\d*\\.?\\d+$/.test(v);\n-                };\n+                    function scrollGap(cm) {\n+                        return scrollerGap - cm.display.nativeBarWidth;\n+                    }\n \n-                /**\n-                 * Check if the value is a zero value string like \"0px\" or \"0%\"\n-                 */\n-                var isZeroValueString = function(v) {\n-                    return /^0[^.\\s]+$/.test(v);\n-                };\n+                    function displayWidth(cm) {\n+                        return cm.display.scroller.clientWidth - scrollGap(cm) - cm.display.barWidth;\n+                    }\n \n-                function addUniqueItem(arr, item) {\n-                    arr.indexOf(item) === -1 && arr.push(item);\n-                }\n+                    function displayHeight(cm) {\n+                        return cm.display.scroller.clientHeight - scrollGap(cm) - cm.display.barHeight;\n+                    }\n \n-                function removeItem(arr, item) {\n-                    var index = arr.indexOf(item);\n-                    index > -1 && arr.splice(index, 1);\n-                }\n-                // Adapted from array-move\n-                function moveItem(_a, fromIndex, toIndex) {\n-                    var _b = tslib.__read(_a),\n-                        arr = _b.slice(0);\n-                    var startIndex = fromIndex < 0 ? arr.length + fromIndex : fromIndex;\n-                    if (startIndex >= 0 && startIndex < arr.length) {\n-                        var endIndex = toIndex < 0 ? arr.length + toIndex : toIndex;\n-                        var _c = tslib.__read(arr.splice(fromIndex, 1), 1),\n-                            item = _c[0];\n-                        arr.splice(endIndex, 0, item);\n+                    // Ensure the lineView.wrapping.heights array is populated. This is\n+                    // an array of bottom offsets for the lines that make up a drawn\n+                    // line. When lineWrapping is on, there might be more than one\n+                    // height.\n+                    function ensureLineHeights(cm, lineView, rect) {\n+                        var wrapping = cm.options.lineWrapping;\n+                        var curWidth = wrapping && displayWidth(cm);\n+                        if (!lineView.measure.heights || wrapping && lineView.measure.width != curWidth) {\n+                            var heights = lineView.measure.heights = [];\n+                            if (wrapping) {\n+                                lineView.measure.width = curWidth;\n+                                var rects = lineView.text.firstChild.getClientRects();\n+                                for (var i = 0; i < rects.length - 1; i++) {\n+                                    var cur = rects[i],\n+                                        next = rects[i + 1];\n+                                    if (Math.abs(cur.bottom - next.bottom) > 2) {\n+                                        heights.push((cur.bottom + next.top) / 2 - rect.top);\n+                                    }\n+                                }\n+                            }\n+                            heights.push(rect.bottom - rect.top);\n+                        }\n                     }\n-                    return arr;\n-                }\n-                var SubscriptionManager = /** @class */ function() {\n-                    function SubscriptionManager() {\n-                        this.subscriptions = [];\n+\n+                    // Find a line map (mapping character offsets to text nodes) and a\n+                    // measurement cache for the given line number. (A line view might\n+                    // contain multiple lines when collapsed ranges are present.)\n+                    function mapFromLineView(lineView, line, lineN) {\n+                        if (lineView.line == line) {\n+                            return {\n+                                map: lineView.measure.map,\n+                                cache: lineView.measure.cache\n+                            };\n+                        }\n+                        if (lineView.rest) {\n+                            for (var i = 0; i < lineView.rest.length; i++) {\n+                                if (lineView.rest[i] == line) {\n+                                    return {\n+                                        map: lineView.measure.maps[i],\n+                                        cache: lineView.measure.caches[i]\n+                                    };\n+                                }\n+                            }\n+                            for (var i$1 = 0; i$1 < lineView.rest.length; i$1++) {\n+                                if (lineNo(lineView.rest[i$1]) > lineN) {\n+                                    return {\n+                                        map: lineView.measure.maps[i$1],\n+                                        cache: lineView.measure.caches[i$1],\n+                                        before: true\n+                                    };\n+                                }\n+                            }\n+                        }\n                     }\n-                    SubscriptionManager.prototype.add = function(handler) {\n-                        var _this = this;\n-                        addUniqueItem(this.subscriptions, handler);\n-                        return function() {\n-                            return removeItem(_this.subscriptions, handler);\n+\n+                    // Render a line into the hidden node display.externalMeasured. Used\n+                    // when measurement is needed for a line that's not in the viewport.\n+                    function updateExternalMeasurement(cm, line) {\n+                        line = visualLine(line);\n+                        var lineN = lineNo(line);\n+                        var view = cm.display.externalMeasured = new LineView(cm.doc, line, lineN);\n+                        view.lineN = lineN;\n+                        var built = view.built = buildLineContent(cm, view);\n+                        view.text = built.pre;\n+                        removeChildrenAndAdd(cm.display.lineMeasure, built.pre);\n+                        return view;\n+                    }\n+\n+                    // Get a {top, bottom, left, right} box (in line-local coordinates)\n+                    // for a given character.\n+                    function measureChar(cm, line, ch, bias) {\n+                        return measureCharPrepared(cm, prepareMeasureForLine(cm, line), ch, bias);\n+                    }\n+\n+                    // Find a line view that corresponds to the given line number.\n+                    function findViewForLine(cm, lineN) {\n+                        if (lineN >= cm.display.viewFrom && lineN < cm.display.viewTo) {\n+                            return cm.display.view[findViewIndex(cm, lineN)];\n+                        }\n+                        var ext = cm.display.externalMeasured;\n+                        if (ext && lineN >= ext.lineN && lineN < ext.lineN + ext.size) {\n+                            return ext;\n+                        }\n+                    }\n+\n+                    // Measurement can be split in two steps, the set-up work that\n+                    // applies to the whole line, and the measurement of the actual\n+                    // character. Functions like coordsChar, that need to do a lot of\n+                    // measurements in a row, can thus ensure that the set-up work is\n+                    // only done once.\n+                    function prepareMeasureForLine(cm, line) {\n+                        var lineN = lineNo(line);\n+                        var view = findViewForLine(cm, lineN);\n+                        if (view && !view.text) {\n+                            view = null;\n+                        } else if (view && view.changes) {\n+                            updateLineForChanges(cm, view, lineN, getDimensions(cm));\n+                            cm.curOp.forceUpdate = true;\n+                        }\n+                        if (!view) {\n+                            view = updateExternalMeasurement(cm, line);\n+                        }\n+                        var info = mapFromLineView(view, line, lineN);\n+                        return {\n+                            line: line,\n+                            view: view,\n+                            rect: null,\n+                            map: info.map,\n+                            cache: info.cache,\n+                            before: info.before,\n+                            hasHeights: false\n                         };\n-                    };\n-                    SubscriptionManager.prototype.notify = function(a, b, c) {\n-                        var numSubscriptions = this.subscriptions.length;\n-                        if (!numSubscriptions) return;\n-                        if (numSubscriptions === 1) {\n-                            /**\n-                             * If there's only a single handler we can just call it without invoking a loop.\n-                             */\n-                            this.subscriptions[0](a, b, c);\n+                    }\n+\n+                    // Given a prepared measurement object, measures the position of an\n+                    // actual character (or fetches it from the cache).\n+                    function measureCharPrepared(cm, prepared, ch, bias, varHeight) {\n+                        if (prepared.before) {\n+                            ch = -1;\n+                        }\n+                        var key = ch + (bias || \"\"),\n+                            found;\n+                        if (prepared.cache.hasOwnProperty(key)) {\n+                            found = prepared.cache[key];\n                         } else {\n-                            for (var i = 0; i < numSubscriptions; i++) {\n-                                /**\n-                                 * Check whether the handler exists before firing as it's possible\n-                                 * the subscriptions were modified during this loop running.\n-                                 */\n-                                var handler = this.subscriptions[i];\n-                                handler && handler(a, b, c);\n+                            if (!prepared.rect) {\n+                                prepared.rect = prepared.view.text.getBoundingClientRect();\n+                            }\n+                            if (!prepared.hasHeights) {\n+                                ensureLineHeights(cm, prepared.view, prepared.rect);\n+                                prepared.hasHeights = true;\n+                            }\n+                            found = measureCharInner(cm, prepared, ch, bias);\n+                            if (!found.bogus) {\n+                                prepared.cache[key] = found;\n                             }\n                         }\n+                        return {\n+                            left: found.left,\n+                            right: found.right,\n+                            top: varHeight ? found.rtop : found.top,\n+                            bottom: varHeight ? found.rbottom : found.bottom\n+                        };\n+                    }\n+                    var nullRect = {\n+                        left: 0,\n+                        right: 0,\n+                        top: 0,\n+                        bottom: 0\n                     };\n-                    SubscriptionManager.prototype.getSize = function() {\n-                        return this.subscriptions.length;\n-                    };\n-                    SubscriptionManager.prototype.clear = function() {\n-                        this.subscriptions.length = 0;\n-                    };\n-                    return SubscriptionManager;\n-                }();\n-                var isFloat = function(value) {\n-                    return !isNaN(parseFloat(value));\n-                };\n-                /**\n-                 * `MotionValue` is used to track the state and velocity of motion values.\n-                 *\n-                 * @public\n-                 */\n-                var MotionValue = /** @class */ function() {\n-                    /**\n-                     * @param init - The initiating value\n-                     * @param config - Optional configuration options\n-                     *\n-                     * -  `transformer`: A function to transform incoming values with.\n-                     *\n-                     * @internal\n-                     */\n-                    function MotionValue(init) {\n-                        var _this = this;\n-                        /**\n-                         * This will be replaced by the build step with the latest version number.\n-                         * When MotionValues are provided to motion components, warn if versions are mixed.\n-                         */\n-                        this.version = \"6.5.1\";\n-                        /**\n-                         * Duration, in milliseconds, since last updating frame.\n-                         *\n-                         * @internal\n-                         */\n-                        this.timeDelta = 0;\n-                        /**\n-                         * Timestamp of the last time this `MotionValue` was updated.\n-                         *\n-                         * @internal\n-                         */\n-                        this.lastUpdated = 0;\n-                        /**\n-                         * Functions to notify when the `MotionValue` updates.\n-                         *\n-                         * @internal\n-                         */\n-                        this.updateSubscribers = new SubscriptionManager();\n-                        /**\n-                         * Functions to notify when the velocity updates.\n-                         *\n-                         * @internal\n-                         */\n-                        this.velocityUpdateSubscribers = new SubscriptionManager();\n-                        /**\n-                         * Functions to notify when the `MotionValue` updates and `render` is set to `true`.\n-                         *\n-                         * @internal\n-                         */\n-                        this.renderSubscribers = new SubscriptionManager();\n-                        /**\n-                         * Tracks whether this value can output a velocity. Currently this is only true\n-                         * if the value is numerical, but we might be able to widen the scope here and support\n-                         * other value types.\n-                         *\n-                         * @internal\n-                         */\n-                        this.canTrackVelocity = false;\n-                        this.updateAndNotify = function(v, render) {\n-                            if (render === void 0) {\n-                                render = true;\n+\n+                    function nodeAndOffsetInLineMap(map, ch, bias) {\n+                        var node, start, end, collapse, mStart, mEnd;\n+                        // First, search the line map for the text node corresponding to,\n+                        // or closest to, the target character.\n+                        for (var i = 0; i < map.length; i += 3) {\n+                            mStart = map[i];\n+                            mEnd = map[i + 1];\n+                            if (ch < mStart) {\n+                                start = 0;\n+                                end = 1;\n+                                collapse = \"left\";\n+                            } else if (ch < mEnd) {\n+                                start = ch - mStart;\n+                                end = start + 1;\n+                            } else if (i == map.length - 3 || ch == mEnd && map[i + 3] > ch) {\n+                                end = mEnd - mStart;\n+                                start = end - 1;\n+                                if (ch >= mEnd) {\n+                                    collapse = \"right\";\n+                                }\n+                            }\n+                            if (start != null) {\n+                                node = map[i + 2];\n+                                if (mStart == mEnd && bias == (node.insertLeft ? \"left\" : \"right\")) {\n+                                    collapse = bias;\n+                                }\n+                                if (bias == \"left\" && start == 0) {\n+                                    while (i && map[i - 2] == map[i - 3] && map[i - 1].insertLeft) {\n+                                        node = map[(i -= 3) + 2];\n+                                        collapse = \"left\";\n+                                    }\n+                                }\n+                                if (bias == \"right\" && start == mEnd - mStart) {\n+                                    while (i < map.length - 3 && map[i + 3] == map[i + 4] && !map[i + 5].insertLeft) {\n+                                        node = map[(i += 3) + 2];\n+                                        collapse = \"right\";\n+                                    }\n+                                }\n+                                break;\n                             }\n-                            _this.prev = _this.current;\n-                            _this.current = v;\n-                            // Update timestamp\n-                            var _a = sync.getFrameData(),\n-                                delta = _a.delta,\n-                                timestamp = _a.timestamp;\n-                            if (_this.lastUpdated !== timestamp) {\n-                                _this.timeDelta = delta;\n-                                _this.lastUpdated = timestamp;\n-                                sync__default[\"default\"].postRender(_this.scheduleVelocityCheck);\n+                        }\n+                        return {\n+                            node: node,\n+                            start: start,\n+                            end: end,\n+                            collapse: collapse,\n+                            coverStart: mStart,\n+                            coverEnd: mEnd\n+                        };\n+                    }\n+\n+                    function getUsefulRect(rects, bias) {\n+                        var rect = nullRect;\n+                        if (bias == \"left\") {\n+                            for (var i = 0; i < rects.length; i++) {\n+                                if ((rect = rects[i]).left != rect.right) {\n+                                    break;\n+                                }\n                             }\n-                            // Update update subscribers\n-                            if (_this.prev !== _this.current) {\n-                                _this.updateSubscribers.notify(_this.current);\n+                        } else {\n+                            for (var i$1 = rects.length - 1; i$1 >= 0; i$1--) {\n+                                if ((rect = rects[i$1]).left != rect.right) {\n+                                    break;\n+                                }\n                             }\n-                            // Update velocity subscribers\n-                            if (_this.velocityUpdateSubscribers.getSize()) {\n-                                _this.velocityUpdateSubscribers.notify(_this.getVelocity());\n+                        }\n+                        return rect;\n+                    }\n+\n+                    function measureCharInner(cm, prepared, ch, bias) {\n+                        var place = nodeAndOffsetInLineMap(prepared.map, ch, bias);\n+                        var node = place.node,\n+                            start = place.start,\n+                            end = place.end,\n+                            collapse = place.collapse;\n+                        var rect;\n+                        if (node.nodeType == 3) {\n+                            // If it is a text node, use a range to retrieve the coordinates.\n+                            for (var i$1 = 0; i$1 < 4; i$1++) {\n+                                // Retry a maximum of 4 times when nonsense rectangles are returned\n+                                while (start && isExtendingChar(prepared.line.text.charAt(place.coverStart + start))) {\n+                                    --start;\n+                                }\n+                                while (place.coverStart + end < place.coverEnd && isExtendingChar(prepared.line.text.charAt(place.coverStart + end))) {\n+                                    ++end;\n+                                }\n+                                if (ie && ie_version < 9 && start == 0 && end == place.coverEnd - place.coverStart) {\n+                                    rect = node.parentNode.getBoundingClientRect();\n+                                } else {\n+                                    rect = getUsefulRect(range(node, start, end).getClientRects(), bias);\n+                                }\n+                                if (rect.left || rect.right || start == 0) {\n+                                    break;\n+                                }\n+                                end = start;\n+                                start = start - 1;\n+                                collapse = \"right\";\n                             }\n-                            // Update render subscribers\n-                            if (render) {\n-                                _this.renderSubscribers.notify(_this.current);\n+                            if (ie && ie_version < 11) {\n+                                rect = maybeUpdateRectForZooming(cm.display.measure, rect);\n                             }\n-                        };\n-                        /**\n-                         * Schedule a velocity check for the next frame.\n-                         *\n-                         * This is an instanced and bound function to prevent generating a new\n-                         * function once per frame.\n-                         *\n-                         * @internal\n-                         */\n-                        this.scheduleVelocityCheck = function() {\n-                            return sync__default[\"default\"].postRender(_this.velocityCheck);\n-                        };\n-                        /**\n-                         * Updates `prev` with `current` if the value hasn't been updated this frame.\n-                         * This ensures velocity calculations return `0`.\n-                         *\n-                         * This is an instanced and bound function to prevent generating a new\n-                         * function once per frame.\n-                         *\n-                         * @internal\n-                         */\n-                        this.velocityCheck = function(_a) {\n-                            var timestamp = _a.timestamp;\n-                            if (timestamp !== _this.lastUpdated) {\n-                                _this.prev = _this.current;\n-                                _this.velocityUpdateSubscribers.notify(_this.getVelocity());\n+                        } else {\n+                            // If it is a widget, simply get the box for the whole widget.\n+                            if (start > 0) {\n+                                collapse = bias = \"right\";\n+                            }\n+                            var rects;\n+                            if (cm.options.lineWrapping && (rects = node.getClientRects()).length > 1) {\n+                                rect = rects[bias == \"right\" ? rects.length - 1 : 0];\n+                            } else {\n+                                rect = node.getBoundingClientRect();\n                             }\n-                        };\n-                        this.hasAnimated = false;\n-                        this.prev = this.current = init;\n-                        this.canTrackVelocity = isFloat(this.current);\n-                    }\n-                    /**\n-                     * Adds a function that will be notified when the `MotionValue` is updated.\n-                     *\n-                     * It returns a function that, when called, will cancel the subscription.\n-                     *\n-                     * When calling `onChange` inside a React component, it should be wrapped with the\n-                     * `useEffect` hook. As it returns an unsubscribe function, this should be returned\n-                     * from the `useEffect` function to ensure you don't add duplicate subscribers..\n-                     *\n-                     * ```jsx\n-                     * export const MyComponent = () => {\n-                     *   const x = useMotionValue(0)\n-                     *   const y = useMotionValue(0)\n-                     *   const opacity = useMotionValue(1)\n-                     *\n-                     *   useEffect(() => {\n-                     *     function updateOpacity() {\n-                     *       const maxXY = Math.max(x.get(), y.get())\n-                     *       const newOpacity = transform(maxXY, [0, 100], [1, 0])\n-                     *       opacity.set(newOpacity)\n-                     *     }\n-                     *\n-                     *     const unsubscribeX = x.onChange(updateOpacity)\n-                     *     const unsubscribeY = y.onChange(updateOpacity)\n-                     *\n-                     *     return () => {\n-                     *       unsubscribeX()\n-                     *       unsubscribeY()\n-                     *     }\n-                     *   }, [])\n-                     *\n-                     *   return <motion.div style={{ x }} />\n-                     * }\n-                     * ```\n-                     *\n-                     * @privateRemarks\n-                     *\n-                     * We could look into a `useOnChange` hook if the above lifecycle management proves confusing.\n-                     *\n-                     * ```jsx\n-                     * useOnChange(x, () => {})\n-                     * ```\n-                     *\n-                     * @param subscriber - A function that receives the latest value.\n-                     * @returns A function that, when called, will cancel this subscription.\n-                     *\n-                     * @public\n-                     */\n-                    MotionValue.prototype.onChange = function(subscription) {\n-                        return this.updateSubscribers.add(subscription);\n-                    };\n-                    MotionValue.prototype.clearListeners = function() {\n-                        this.updateSubscribers.clear();\n-                    };\n-                    /**\n-                     * Adds a function that will be notified when the `MotionValue` requests a render.\n-                     *\n-                     * @param subscriber - A function that's provided the latest value.\n-                     * @returns A function that, when called, will cancel this subscription.\n-                     *\n-                     * @internal\n-                     */\n-                    MotionValue.prototype.onRenderRequest = function(subscription) {\n-                        // Render immediately\n-                        subscription(this.get());\n-                        return this.renderSubscribers.add(subscription);\n-                    };\n-                    /**\n-                     * Attaches a passive effect to the `MotionValue`.\n-                     *\n-                     * @internal\n-                     */\n-                    MotionValue.prototype.attach = function(passiveEffect) {\n-                        this.passiveEffect = passiveEffect;\n-                    };\n-                    /**\n-                     * Sets the state of the `MotionValue`.\n-                     *\n-                     * @remarks\n-                     *\n-                     * ```jsx\n-                     * const x = useMotionValue(0)\n-                     * x.set(10)\n-                     * ```\n-                     *\n-                     * @param latest - Latest value to set.\n-                     * @param render - Whether to notify render subscribers. Defaults to `true`\n-                     *\n-                     * @public\n-                     */\n-                    MotionValue.prototype.set = function(v, render) {\n-                        if (render === void 0) {\n-                            render = true;\n                         }\n-                        if (!render || !this.passiveEffect) {\n-                            this.updateAndNotify(v, render);\n-                        } else {\n-                            this.passiveEffect(v, this.updateAndNotify);\n+                        if (ie && ie_version < 9 && !start && (!rect || !rect.left && !rect.right)) {\n+                            var rSpan = node.parentNode.getClientRects()[0];\n+                            if (rSpan) {\n+                                rect = {\n+                                    left: rSpan.left,\n+                                    right: rSpan.left + charWidth(cm.display),\n+                                    top: rSpan.top,\n+                                    bottom: rSpan.bottom\n+                                };\n+                            } else {\n+                                rect = nullRect;\n+                            }\n                         }\n-                    };\n-                    /**\n-                     * Returns the latest state of `MotionValue`\n-                     *\n-                     * @returns - The latest state of `MotionValue`\n-                     *\n-                     * @public\n-                     */\n-                    MotionValue.prototype.get = function() {\n-                        return this.current;\n-                    };\n-                    /**\n-                     * @public\n-                     */\n-                    MotionValue.prototype.getPrevious = function() {\n-                        return this.prev;\n-                    };\n-                    /**\n-                     * Returns the latest velocity of `MotionValue`\n-                     *\n-                     * @returns - The latest velocity of `MotionValue`. Returns `0` if the state is non-numerical.\n-                     *\n-                     * @public\n-                     */\n-                    MotionValue.prototype.getVelocity = function() {\n-                        // This could be isFloat(this.prev) && isFloat(this.current), but that would be wasteful\n-                        return this.canTrackVelocity ?\n-                            // These casts could be avoided if parseFloat would be typed better\n-                            popmotion.velocityPerSecond(parseFloat(this.current) - parseFloat(this.prev), this.timeDelta) : 0;\n-                    };\n-                    /**\n-                     * Registers a new animation to control this `MotionValue`. Only one\n-                     * animation can drive a `MotionValue` at one time.\n-                     *\n-                     * ```jsx\n-                     * value.start()\n-                     * ```\n-                     *\n-                     * @param animation - A function that starts the provided animation\n-                     *\n-                     * @internal\n-                     */\n-                    MotionValue.prototype.start = function(animation) {\n-                        var _this = this;\n-                        this.stop();\n-                        return new Promise(function(resolve) {\n-                            _this.hasAnimated = true;\n-                            _this.stopAnimation = animation(resolve);\n-                        }).then(function() {\n-                            return _this.clearAnimation();\n-                        });\n-                    };\n-                    /**\n-                     * Stop the currently active animation.\n-                     *\n-                     * @public\n-                     */\n-                    MotionValue.prototype.stop = function() {\n-                        if (this.stopAnimation) this.stopAnimation();\n-                        this.clearAnimation();\n-                    };\n-                    /**\n-                     * Returns `true` if this value is currently animating.\n-                     *\n-                     * @public\n-                     */\n-                    MotionValue.prototype.isAnimating = function() {\n-                        return !!this.stopAnimation;\n-                    };\n-                    MotionValue.prototype.clearAnimation = function() {\n-                        this.stopAnimation = null;\n-                    };\n-                    /**\n-                     * Destroy and clean up subscribers to this `MotionValue`.\n-                     *\n-                     * The `MotionValue` hooks like `useMotionValue` and `useTransform` automatically\n-                     * handle the lifecycle of the returned `MotionValue`, so this method is only necessary if you've manually\n-                     * created a `MotionValue` via the `motionValue` function.\n-                     *\n-                     * @public\n-                     */\n-                    MotionValue.prototype.destroy = function() {\n-                        this.updateSubscribers.clear();\n-                        this.renderSubscribers.clear();\n-                        this.stop();\n-                    };\n-                    return MotionValue;\n-                }();\n+                        var rtop = rect.top - prepared.rect.top,\n+                            rbot = rect.bottom - prepared.rect.top;\n+                        var mid = (rtop + rbot) / 2;\n+                        var heights = prepared.view.measure.heights;\n+                        var i = 0;\n+                        for (; i < heights.length - 1; i++) {\n+                            if (mid < heights[i]) {\n+                                break;\n+                            }\n+                        }\n+                        var top = i ? heights[i - 1] : 0,\n+                            bot = heights[i];\n+                        var result = {\n+                            left: (collapse == \"right\" ? rect.right : rect.left) - prepared.rect.left,\n+                            right: (collapse == \"left\" ? rect.left : rect.right) - prepared.rect.left,\n+                            top: top,\n+                            bottom: bot\n+                        };\n+                        if (!rect.left && !rect.right) {\n+                            result.bogus = true;\n+                        }\n+                        if (!cm.options.singleCursorHeightPerLine) {\n+                            result.rtop = rtop;\n+                            result.rbottom = rbot;\n+                        }\n+                        return result;\n+                    }\n \n-                function motionValue(init) {\n-                    return new MotionValue(init);\n-                }\n+                    // Work around problem with bounding client rects on ranges being\n+                    // returned incorrectly when zoomed on IE10 and below.\n+                    function maybeUpdateRectForZooming(measure, rect) {\n+                        if (!window.screen || screen.logicalXDPI == null || screen.logicalXDPI == screen.deviceXDPI || !hasBadZoomedRects(measure)) {\n+                            return rect;\n+                        }\n+                        var scaleX = screen.logicalXDPI / screen.deviceXDPI;\n+                        var scaleY = screen.logicalYDPI / screen.deviceYDPI;\n+                        return {\n+                            left: rect.left * scaleX,\n+                            right: rect.right * scaleX,\n+                            top: rect.top * scaleY,\n+                            bottom: rect.bottom * scaleY\n+                        };\n+                    }\n \n-                /**\n-                 * Tests a provided value against a ValueType\n-                 */\n-                var testValueType = function(v) {\n-                    return function(type) {\n-                        return type.test(v);\n-                    };\n-                };\n+                    function clearLineMeasurementCacheFor(lineView) {\n+                        if (lineView.measure) {\n+                            lineView.measure.cache = {};\n+                            lineView.measure.heights = null;\n+                            if (lineView.rest) {\n+                                for (var i = 0; i < lineView.rest.length; i++) {\n+                                    lineView.measure.caches[i] = {};\n+                                }\n+                            }\n+                        }\n+                    }\n \n-                /**\n-                 * ValueType for \"auto\"\n-                 */\n-                var auto = {\n-                    test: function(v) {\n-                        return v === \"auto\";\n-                    },\n-                    parse: function(v) {\n-                        return v;\n+                    function clearLineMeasurementCache(cm) {\n+                        cm.display.externalMeasure = null;\n+                        removeChildren(cm.display.lineMeasure);\n+                        for (var i = 0; i < cm.display.view.length; i++) {\n+                            clearLineMeasurementCacheFor(cm.display.view[i]);\n+                        }\n                     }\n-                };\n \n-                /**\n-                 * A list of value types commonly used for dimensions\n-                 */\n-                var dimensionValueTypes = [styleValueTypes.number, styleValueTypes.px, styleValueTypes.percent, styleValueTypes.degrees, styleValueTypes.vw, styleValueTypes.vh, auto];\n-                /**\n-                 * Tests a dimensional value against the list of dimension ValueTypes\n-                 */\n-                var findDimensionValueType = function(v) {\n-                    return dimensionValueTypes.find(testValueType(v));\n-                };\n+                    function clearCaches(cm) {\n+                        clearLineMeasurementCache(cm);\n+                        cm.display.cachedCharWidth = cm.display.cachedTextHeight = cm.display.cachedPaddingH = null;\n+                        if (!cm.options.lineWrapping) {\n+                            cm.display.maxLineChanged = true;\n+                        }\n+                        cm.display.lineNumChars = null;\n+                    }\n \n-                /**\n-                 * A list of all ValueTypes\n-                 */\n-                var valueTypes = tslib.__spreadArray(tslib.__spreadArray([], tslib.__read(dimensionValueTypes), false), [styleValueTypes.color, styleValueTypes.complex], false);\n-                /**\n-                 * Tests a value against the list of ValueTypes\n-                 */\n-                var findValueType = function(v) {\n-                    return valueTypes.find(testValueType(v));\n-                };\n+                    function pageScrollX() {\n+                        // Work around https://bugs.chromium.org/p/chromium/issues/detail?id=489206\n+                        // which causes page_Offset and bounding client rects to use\n+                        // different reference viewports and invalidate our calculations.\n+                        if (chrome && android) {\n+                            return -(document.body.getBoundingClientRect().left - parseInt(getComputedStyle(document.body).marginLeft));\n+                        }\n+                        return window.pageXOffset || (document.documentElement || document.body).scrollLeft;\n+                    }\n \n-                /**\n-                 * Set VisualElement's MotionValue, creating a new MotionValue for it if\n-                 * it doesn't exist.\n-                 */\n-                function setMotionValue(visualElement, key, value) {\n-                    if (visualElement.hasValue(key)) {\n-                        visualElement.getValue(key).set(value);\n-                    } else {\n-                        visualElement.addValue(key, motionValue(value));\n+                    function pageScrollY() {\n+                        if (chrome && android) {\n+                            return -(document.body.getBoundingClientRect().top - parseInt(getComputedStyle(document.body).marginTop));\n+                        }\n+                        return window.pageYOffset || (document.documentElement || document.body).scrollTop;\n                     }\n-                }\n \n-                function setTarget(visualElement, definition) {\n-                    var resolved = resolveVariant(visualElement, definition);\n-                    var _a = resolved ? visualElement.makeTargetAnimatable(resolved, false) : {},\n-                        _b = _a.transitionEnd,\n-                        transitionEnd = _b === void 0 ? {} : _b;\n-                    _a.transition;\n-                    var target = tslib.__rest(_a, [\"transitionEnd\", \"transition\"]);\n-                    target = tslib.__assign(tslib.__assign({}, target), transitionEnd);\n-                    for (var key in target) {\n-                        var value = resolveFinalValueInKeyframes(target[key]);\n-                        setMotionValue(visualElement, key, value);\n+                    function widgetTopHeight(lineObj) {\n+                        var ref = visualLine(lineObj);\n+                        var widgets = ref.widgets;\n+                        var height = 0;\n+                        if (widgets) {\n+                            for (var i = 0; i < widgets.length; ++i) {\n+                                if (widgets[i].above) {\n+                                    height += widgetHeight(widgets[i]);\n+                                }\n+                            }\n+                        }\n+                        return height;\n                     }\n-                }\n \n-                function setVariants(visualElement, variantLabels) {\n-                    var reversedLabels = tslib.__spreadArray([], tslib.__read(variantLabels), false).reverse();\n-                    reversedLabels.forEach(function(key) {\n-                        var _a;\n-                        var variant = visualElement.getVariant(key);\n-                        variant && setTarget(visualElement, variant);\n-                        (_a = visualElement.variantChildren) === null || _a === void 0 ? void 0 : _a.forEach(function(child) {\n-                            setVariants(child, variantLabels);\n-                        });\n-                    });\n-                }\n+                    // Converts a {top, bottom, left, right} box from line-local\n+                    // coordinates into another coordinate system. Context may be one of\n+                    // \"line\", \"div\" (display.lineDiv), \"local\"./null (editor), \"window\",\n+                    // or \"page\".\n+                    function intoCoordSystem(cm, lineObj, rect, context, includeWidgets) {\n+                        if (!includeWidgets) {\n+                            var height = widgetTopHeight(lineObj);\n+                            rect.top += height;\n+                            rect.bottom += height;\n+                        }\n+                        if (context == \"line\") {\n+                            return rect;\n+                        }\n+                        if (!context) {\n+                            context = \"local\";\n+                        }\n+                        var yOff = heightAtLine(lineObj);\n+                        if (context == \"local\") {\n+                            yOff += paddingTop(cm.display);\n+                        } else {\n+                            yOff -= cm.display.viewOffset;\n+                        }\n+                        if (context == \"page\" || context == \"window\") {\n+                            var lOff = cm.display.lineSpace.getBoundingClientRect();\n+                            yOff += lOff.top + (context == \"window\" ? 0 : pageScrollY());\n+                            var xOff = lOff.left + (context == \"window\" ? 0 : pageScrollX());\n+                            rect.left += xOff;\n+                            rect.right += xOff;\n+                        }\n+                        rect.top += yOff;\n+                        rect.bottom += yOff;\n+                        return rect;\n+                    }\n \n-                function setValues(visualElement, definition) {\n-                    if (Array.isArray(definition)) {\n-                        return setVariants(visualElement, definition);\n-                    } else if (typeof definition === \"string\") {\n-                        return setVariants(visualElement, [definition]);\n-                    } else {\n-                        setTarget(visualElement, definition);\n+                    // Coverts a box from \"div\" coords to another coordinate system.\n+                    // Context may be \"window\", \"page\", \"div\", or \"local\"./null.\n+                    function fromCoordSystem(cm, coords, context) {\n+                        if (context == \"div\") {\n+                            return coords;\n+                        }\n+                        var left = coords.left,\n+                            top = coords.top;\n+                        // First move into \"page\" coordinate system\n+                        if (context == \"page\") {\n+                            left -= pageScrollX();\n+                            top -= pageScrollY();\n+                        } else if (context == \"local\" || !context) {\n+                            var localBox = cm.display.sizer.getBoundingClientRect();\n+                            left += localBox.left;\n+                            top += localBox.top;\n+                        }\n+                        var lineSpaceBox = cm.display.lineSpace.getBoundingClientRect();\n+                        return {\n+                            left: left - lineSpaceBox.left,\n+                            top: top - lineSpaceBox.top\n+                        };\n                     }\n-                }\n \n-                function checkTargetForNewValues(visualElement, target, origin) {\n-                    var _a, _b, _c;\n-                    var _d;\n-                    var newValueKeys = Object.keys(target).filter(function(key) {\n-                        return !visualElement.hasValue(key);\n-                    });\n-                    var numNewValues = newValueKeys.length;\n-                    if (!numNewValues) return;\n-                    for (var i = 0; i < numNewValues; i++) {\n-                        var key = newValueKeys[i];\n-                        var targetValue = target[key];\n-                        var value = null;\n-                        /**\n-                         * If the target is a series of keyframes, we can use the first value\n-                         * in the array. If this first value is null, we'll still need to read from the DOM.\n-                         */\n-                        if (Array.isArray(targetValue)) {\n-                            value = targetValue[0];\n+                    function charCoords(cm, pos, context, lineObj, bias) {\n+                        if (!lineObj) {\n+                            lineObj = getLine(cm.doc, pos.line);\n+                        }\n+                        return intoCoordSystem(cm, lineObj, measureChar(cm, lineObj, pos.ch, bias), context);\n+                    }\n+\n+                    // Returns a box for a given cursor position, which may have an\n+                    // 'other' property containing the position of the secondary cursor\n+                    // on a bidi boundary.\n+                    // A cursor Pos(line, char, \"before\") is on the same visual line as `char - 1`\n+                    // and after `char - 1` in writing order of `char - 1`\n+                    // A cursor Pos(line, char, \"after\") is on the same visual line as `char`\n+                    // and before `char` in writing order of `char`\n+                    // Examples (upper-case letters are RTL, lower-case are LTR):\n+                    //     Pos(0, 1, ...)\n+                    //     before   after\n+                    // ab     a|b     a|b\n+                    // aB     a|B     aB|\n+                    // Ab     |Ab     A|b\n+                    // AB     B|A     B|A\n+                    // Every position after the last character on a line is considered to stick\n+                    // to the last character on the line.\n+                    function cursorCoords(cm, pos, context, lineObj, preparedMeasure, varHeight) {\n+                        lineObj = lineObj || getLine(cm.doc, pos.line);\n+                        if (!preparedMeasure) {\n+                            preparedMeasure = prepareMeasureForLine(cm, lineObj);\n+                        }\n+\n+                        function get(ch, right) {\n+                            var m = measureCharPrepared(cm, preparedMeasure, ch, right ? \"right\" : \"left\", varHeight);\n+                            if (right) {\n+                                m.left = m.right;\n+                            } else {\n+                                m.right = m.left;\n+                            }\n+                            return intoCoordSystem(cm, lineObj, m, context);\n                         }\n-                        /**\n-                         * If the target isn't keyframes, or the first keyframe was null, we need to\n-                         * first check if an origin value was explicitly defined in the transition as \"from\",\n-                         * if not read the value from the DOM. As an absolute fallback, take the defined target value.\n-                         */\n-                        if (value === null) {\n-                            value = (_b = (_a = origin[key]) !== null && _a !== void 0 ? _a : visualElement.readValue(key)) !== null && _b !== void 0 ? _b : target[key];\n+                        var order = getOrder(lineObj, cm.doc.direction),\n+                            ch = pos.ch,\n+                            sticky = pos.sticky;\n+                        if (ch >= lineObj.text.length) {\n+                            ch = lineObj.text.length;\n+                            sticky = \"before\";\n+                        } else if (ch <= 0) {\n+                            ch = 0;\n+                            sticky = \"after\";\n+                        }\n+                        if (!order) {\n+                            return get(sticky == \"before\" ? ch - 1 : ch, sticky == \"before\");\n+                        }\n+\n+                        function getBidi(ch, partPos, invert) {\n+                            var part = order[partPos],\n+                                right = part.level == 1;\n+                            return get(invert ? ch - 1 : ch, right != invert);\n+                        }\n+                        var partPos = getBidiPartAt(order, ch, sticky);\n+                        var other = bidiOther;\n+                        var val = getBidi(ch, partPos, sticky == \"before\");\n+                        if (other != null) {\n+                            val.other = getBidi(ch, other, sticky != \"before\");\n+                        }\n+                        return val;\n+                    }\n+\n+                    // Used to cheaply estimate the coordinates for a position. Used for\n+                    // intermediate scroll updates.\n+                    function estimateCoords(cm, pos) {\n+                        var left = 0;\n+                        pos = clipPos(cm.doc, pos);\n+                        if (!cm.options.lineWrapping) {\n+                            left = charWidth(cm.display) * pos.ch;\n                         }\n-                        /**\n-                         * If value is still undefined or null, ignore it. Preferably this would throw,\n-                         * but this was causing issues in Framer.\n-                         */\n-                        if (value === undefined || value === null) continue;\n-                        if (typeof value === \"string\" && (isNumericalString(value) || isZeroValueString(value))) {\n-                            // If this is a number read as a string, ie \"0\" or \"200\", convert it to a number\n-                            value = parseFloat(value);\n-                        } else if (!findValueType(value) && styleValueTypes.complex.test(targetValue)) {\n-                            value = getAnimatableNone(key, targetValue);\n+                        var lineObj = getLine(cm.doc, pos.line);\n+                        var top = heightAtLine(lineObj) + paddingTop(cm.display);\n+                        return {\n+                            left: left,\n+                            right: left,\n+                            top: top,\n+                            bottom: top + lineObj.height\n+                        };\n+                    }\n+\n+                    // Positions returned by coordsChar contain some extra information.\n+                    // xRel is the relative x position of the input coordinates compared\n+                    // to the found position (so xRel > 0 means the coordinates are to\n+                    // the right of the character position, for example). When outside\n+                    // is true, that means the coordinates lie outside the line's\n+                    // vertical range.\n+                    function PosWithInfo(line, ch, sticky, outside, xRel) {\n+                        var pos = Pos(line, ch, sticky);\n+                        pos.xRel = xRel;\n+                        if (outside) {\n+                            pos.outside = outside;\n                         }\n-                        visualElement.addValue(key, motionValue(value));\n-                        (_c = (_d = origin)[key]) !== null && _c !== void 0 ? _c : _d[key] = value;\n-                        visualElement.setBaseTarget(key, value);\n+                        return pos;\n                     }\n-                }\n \n-                function getOriginFromTransition(key, transition) {\n-                    if (!transition) return;\n-                    var valueTransition = transition[key] || transition[\"default\"] || transition;\n-                    return valueTransition.from;\n-                }\n+                    // Compute the character position closest to the given coordinates.\n+                    // Input must be lineSpace-local (\"div\" coordinate system).\n+                    function coordsChar(cm, x, y) {\n+                        var doc = cm.doc;\n+                        y += cm.display.viewOffset;\n+                        if (y < 0) {\n+                            return PosWithInfo(doc.first, 0, null, -1, -1);\n+                        }\n+                        var lineN = lineAtHeight(doc, y),\n+                            last = doc.first + doc.size - 1;\n+                        if (lineN > last) {\n+                            return PosWithInfo(doc.first + doc.size - 1, getLine(doc, last).text.length, null, 1, 1);\n+                        }\n+                        if (x < 0) {\n+                            x = 0;\n+                        }\n+                        var lineObj = getLine(doc, lineN);\n+                        for (;;) {\n+                            var found = coordsCharInner(cm, lineObj, lineN, x, y);\n+                            var collapsed = collapsedSpanAround(lineObj, found.ch + (found.xRel > 0 || found.outside > 0 ? 1 : 0));\n+                            if (!collapsed) {\n+                                return found;\n+                            }\n+                            var rangeEnd = collapsed.find(1);\n+                            if (rangeEnd.line == lineN) {\n+                                return rangeEnd;\n+                            }\n+                            lineObj = getLine(doc, lineN = rangeEnd.line);\n+                        }\n+                    }\n \n-                function getOrigin(target, transition, visualElement) {\n-                    var _a, _b;\n-                    var origin = {};\n-                    for (var key in target) {\n-                        origin[key] = (_a = getOriginFromTransition(key, transition)) !== null && _a !== void 0 ? _a : (_b = visualElement.getValue(key)) === null || _b === void 0 ? void 0 : _b.get();\n+                    function wrappedLineExtent(cm, lineObj, preparedMeasure, y) {\n+                        y -= widgetTopHeight(lineObj);\n+                        var end = lineObj.text.length;\n+                        var begin = findFirst(function(ch) {\n+                            return measureCharPrepared(cm, preparedMeasure, ch - 1).bottom <= y;\n+                        }, end, 0);\n+                        end = findFirst(function(ch) {\n+                            return measureCharPrepared(cm, preparedMeasure, ch).top > y;\n+                        }, begin, end);\n+                        return {\n+                            begin: begin,\n+                            end: end\n+                        };\n                     }\n-                    return origin;\n-                }\n \n-                function animateVisualElement(visualElement, definition, options) {\n-                    if (options === void 0) {\n-                        options = {};\n+                    function wrappedLineExtentChar(cm, lineObj, preparedMeasure, target) {\n+                        if (!preparedMeasure) {\n+                            preparedMeasure = prepareMeasureForLine(cm, lineObj);\n+                        }\n+                        var targetTop = intoCoordSystem(cm, lineObj, measureCharPrepared(cm, preparedMeasure, target), \"line\").top;\n+                        return wrappedLineExtent(cm, lineObj, preparedMeasure, targetTop);\n+                    }\n+\n+                    // Returns true if the given side of a box is after the given\n+                    // coordinates, in top-to-bottom, left-to-right order.\n+                    function boxIsAfter(box, x, y, left) {\n+                        return box.bottom <= y ? false : box.top > y ? true : (left ? box.left : box.right) > x;\n+                    }\n+\n+                    function coordsCharInner(cm, lineObj, lineNo, x, y) {\n+                        // Move y into line-local coordinate space\n+                        y -= heightAtLine(lineObj);\n+                        var preparedMeasure = prepareMeasureForLine(cm, lineObj);\n+                        // When directly calling `measureCharPrepared`, we have to adjust\n+                        // for the widgets at this line.\n+                        var widgetHeight = widgetTopHeight(lineObj);\n+                        var begin = 0,\n+                            end = lineObj.text.length,\n+                            ltr = true;\n+                        var order = getOrder(lineObj, cm.doc.direction);\n+                        // If the line isn't plain left-to-right text, first figure out\n+                        // which bidi section the coordinates fall into.\n+                        if (order) {\n+                            var part = (cm.options.lineWrapping ? coordsBidiPartWrapped : coordsBidiPart)(cm, lineObj, lineNo, preparedMeasure, order, x, y);\n+                            ltr = part.level != 1;\n+                            // The awkward -1 offsets are needed because findFirst (called\n+                            // on these below) will treat its first bound as inclusive,\n+                            // second as exclusive, but we want to actually address the\n+                            // characters in the part's range\n+                            begin = ltr ? part.from : part.to - 1;\n+                            end = ltr ? part.to : part.from - 1;\n+                        }\n+\n+                        // A binary search to find the first character whose bounding box\n+                        // starts after the coordinates. If we run across any whose box wrap\n+                        // the coordinates, store that.\n+                        var chAround = null,\n+                            boxAround = null;\n+                        var ch = findFirst(function(ch) {\n+                            var box = measureCharPrepared(cm, preparedMeasure, ch);\n+                            box.top += widgetHeight;\n+                            box.bottom += widgetHeight;\n+                            if (!boxIsAfter(box, x, y, false)) {\n+                                return false;\n+                            }\n+                            if (box.top <= y && box.left <= x) {\n+                                chAround = ch;\n+                                boxAround = box;\n+                            }\n+                            return true;\n+                        }, begin, end);\n+                        var baseX,\n+                            sticky,\n+                            outside = false;\n+                        // If a box around the coordinates was found, use that\n+                        if (boxAround) {\n+                            // Distinguish coordinates nearer to the left or right side of the box\n+                            var atLeft = x - boxAround.left < boxAround.right - x,\n+                                atStart = atLeft == ltr;\n+                            ch = chAround + (atStart ? 0 : 1);\n+                            sticky = atStart ? \"after\" : \"before\";\n+                            baseX = atLeft ? boxAround.left : boxAround.right;\n+                        } else {\n+                            // (Adjust for extended bound, if necessary.)\n+                            if (!ltr && (ch == end || ch == begin)) {\n+                                ch++;\n+                            }\n+                            // To determine which side to associate with, get the box to the\n+                            // left of the character and compare it's vertical position to the\n+                            // coordinates\n+                            sticky = ch == 0 ? \"after\" : ch == lineObj.text.length ? \"before\" : measureCharPrepared(cm, preparedMeasure, ch - (ltr ? 1 : 0)).bottom + widgetHeight <= y == ltr ? \"after\" : \"before\";\n+                            // Now get accurate coordinates for this place, in order to get a\n+                            // base X position\n+                            var coords = cursorCoords(cm, Pos(lineNo, ch, sticky), \"line\", lineObj, preparedMeasure);\n+                            baseX = coords.left;\n+                            outside = y < coords.top ? -1 : y >= coords.bottom ? 1 : 0;\n+                        }\n+                        ch = skipExtendingChars(lineObj.text, ch, 1);\n+                        return PosWithInfo(lineNo, ch, sticky, outside, x - baseX);\n+                    }\n+\n+                    function coordsBidiPart(cm, lineObj, lineNo, preparedMeasure, order, x, y) {\n+                        // Bidi parts are sorted left-to-right, and in a non-line-wrapping\n+                        // situation, we can take this ordering to correspond to the visual\n+                        // ordering. This finds the first part whose end is after the given\n+                        // coordinates.\n+                        var index = findFirst(function(i) {\n+                            var part = order[i],\n+                                ltr = part.level != 1;\n+                            return boxIsAfter(cursorCoords(cm, Pos(lineNo, ltr ? part.to : part.from, ltr ? \"before\" : \"after\"), \"line\", lineObj, preparedMeasure), x, y, true);\n+                        }, 0, order.length - 1);\n+                        var part = order[index];\n+                        // If this isn't the first part, the part's start is also after\n+                        // the coordinates, and the coordinates aren't on the same line as\n+                        // that start, move one part back.\n+                        if (index > 0) {\n+                            var ltr = part.level != 1;\n+                            var start = cursorCoords(cm, Pos(lineNo, ltr ? part.from : part.to, ltr ? \"after\" : \"before\"), \"line\", lineObj, preparedMeasure);\n+                            if (boxIsAfter(start, x, y, true) && start.top > y) {\n+                                part = order[index - 1];\n+                            }\n+                        }\n+                        return part;\n+                    }\n+\n+                    function coordsBidiPartWrapped(cm, lineObj, _lineNo, preparedMeasure, order, x, y) {\n+                        // In a wrapped line, rtl text on wrapping boundaries can do things\n+                        // that don't correspond to the ordering in our `order` array at\n+                        // all, so a binary search doesn't work, and we want to return a\n+                        // part that only spans one line so that the binary search in\n+                        // coordsCharInner is safe. As such, we first find the extent of the\n+                        // wrapped line, and then do a flat search in which we discard any\n+                        // spans that aren't on the line.\n+                        var ref = wrappedLineExtent(cm, lineObj, preparedMeasure, y);\n+                        var begin = ref.begin;\n+                        var end = ref.end;\n+                        if (/\\s/.test(lineObj.text.charAt(end - 1))) {\n+                            end--;\n+                        }\n+                        var part = null,\n+                            closestDist = null;\n+                        for (var i = 0; i < order.length; i++) {\n+                            var p = order[i];\n+                            if (p.from >= end || p.to <= begin) {\n+                                continue;\n+                            }\n+                            var ltr = p.level != 1;\n+                            var endX = measureCharPrepared(cm, preparedMeasure, ltr ? Math.min(end, p.to) - 1 : Math.max(begin, p.from)).right;\n+                            // Weigh against spans ending before this, so that they are only\n+                            // picked if nothing ends after\n+                            var dist = endX < x ? x - endX + 1e9 : endX - x;\n+                            if (!part || closestDist > dist) {\n+                                part = p;\n+                                closestDist = dist;\n+                            }\n+                        }\n+                        if (!part) {\n+                            part = order[order.length - 1];\n+                        }\n+                        // Clip the part to the wrapped line.\n+                        if (part.from < begin) {\n+                            part = {\n+                                from: begin,\n+                                to: part.to,\n+                                level: part.level\n+                            };\n+                        }\n+                        if (part.to > end) {\n+                            part = {\n+                                from: part.from,\n+                                to: end,\n+                                level: part.level\n+                            };\n+                        }\n+                        return part;\n                     }\n-                    visualElement.notifyAnimationStart(definition);\n-                    var animation;\n-                    if (Array.isArray(definition)) {\n-                        var animations = definition.map(function(variant) {\n-                            return animateVariant(visualElement, variant, options);\n-                        });\n-                        animation = Promise.all(animations);\n-                    } else if (typeof definition === \"string\") {\n-                        animation = animateVariant(visualElement, definition, options);\n-                    } else {\n-                        var resolvedDefinition = typeof definition === \"function\" ? resolveVariant(visualElement, definition, options.custom) : definition;\n-                        animation = animateTarget(visualElement, resolvedDefinition, options);\n+                    var measureText;\n+                    // Compute the default text height.\n+                    function textHeight(display) {\n+                        if (display.cachedTextHeight != null) {\n+                            return display.cachedTextHeight;\n+                        }\n+                        if (measureText == null) {\n+                            measureText = elt(\"pre\", null, \"CodeMirror-line-like\");\n+                            // Measure a bunch of lines, for browsers that compute\n+                            // fractional heights.\n+                            for (var i = 0; i < 49; ++i) {\n+                                measureText.appendChild(document.createTextNode(\"x\"));\n+                                measureText.appendChild(elt(\"br\"));\n+                            }\n+                            measureText.appendChild(document.createTextNode(\"x\"));\n+                        }\n+                        removeChildrenAndAdd(display.measure, measureText);\n+                        var height = measureText.offsetHeight / 50;\n+                        if (height > 3) {\n+                            display.cachedTextHeight = height;\n+                        }\n+                        removeChildren(display.measure);\n+                        return height || 1;\n+                    }\n+\n+                    // Compute the default character width.\n+                    function charWidth(display) {\n+                        if (display.cachedCharWidth != null) {\n+                            return display.cachedCharWidth;\n+                        }\n+                        var anchor = elt(\"span\", \"xxxxxxxxxx\");\n+                        var pre = elt(\"pre\", [anchor], \"CodeMirror-line-like\");\n+                        removeChildrenAndAdd(display.measure, pre);\n+                        var rect = anchor.getBoundingClientRect(),\n+                            width = (rect.right - rect.left) / 10;\n+                        if (width > 2) {\n+                            display.cachedCharWidth = width;\n+                        }\n+                        return width || 10;\n+                    }\n+\n+                    // Do a bulk-read of the DOM positions and sizes needed to draw the\n+                    // view, so that we don't interleave reading and writing to the DOM.\n+                    function getDimensions(cm) {\n+                        var d = cm.display,\n+                            left = {},\n+                            width = {};\n+                        var gutterLeft = d.gutters.clientLeft;\n+                        for (var n = d.gutters.firstChild, i = 0; n; n = n.nextSibling, ++i) {\n+                            var id = cm.display.gutterSpecs[i].className;\n+                            left[id] = n.offsetLeft + n.clientLeft + gutterLeft;\n+                            width[id] = n.clientWidth;\n+                        }\n+                        return {\n+                            fixedPos: compensateForHScroll(d),\n+                            gutterTotalWidth: d.gutters.offsetWidth,\n+                            gutterLeft: left,\n+                            gutterWidth: width,\n+                            wrapperWidth: d.wrapper.clientWidth\n+                        };\n                     }\n-                    return animation.then(function() {\n-                        return visualElement.notifyAnimationComplete(definition);\n-                    });\n-                }\n \n-                function animateVariant(visualElement, variant, options) {\n-                    var _a;\n-                    if (options === void 0) {\n-                        options = {};\n+                    // Computes display.scroller.scrollLeft + display.gutters.offsetWidth,\n+                    // but using getBoundingClientRect to get a sub-pixel-accurate\n+                    // result.\n+                    function compensateForHScroll(display) {\n+                        return display.scroller.getBoundingClientRect().left - display.sizer.getBoundingClientRect().left;\n+                    }\n+\n+                    // Returns a function that estimates the height of a line, to use as\n+                    // first approximation until the line becomes visible (and is thus\n+                    // properly measurable).\n+                    function estimateHeight(cm) {\n+                        var th = textHeight(cm.display),\n+                            wrapping = cm.options.lineWrapping;\n+                        var perLine = wrapping && Math.max(5, cm.display.scroller.clientWidth / charWidth(cm.display) - 3);\n+                        return function(line) {\n+                            if (lineIsHidden(cm.doc, line)) {\n+                                return 0;\n+                            }\n+                            var widgetsHeight = 0;\n+                            if (line.widgets) {\n+                                for (var i = 0; i < line.widgets.length; i++) {\n+                                    if (line.widgets[i].height) {\n+                                        widgetsHeight += line.widgets[i].height;\n+                                    }\n+                                }\n+                            }\n+                            if (wrapping) {\n+                                return widgetsHeight + (Math.ceil(line.text.length / perLine) || 1) * th;\n+                            } else {\n+                                return widgetsHeight + th;\n+                            }\n+                        };\n                     }\n-                    var resolved = resolveVariant(visualElement, variant, options.custom);\n-                    var _b = (resolved || {}).transition,\n-                        transition = _b === void 0 ? visualElement.getDefaultTransition() || {} : _b;\n-                    if (options.transitionOverride) {\n-                        transition = options.transitionOverride;\n+\n+                    function estimateLineHeights(cm) {\n+                        var doc = cm.doc,\n+                            est = estimateHeight(cm);\n+                        doc.iter(function(line) {\n+                            var estHeight = est(line);\n+                            if (estHeight != line.height) {\n+                                updateLineHeight(line, estHeight);\n+                            }\n+                        });\n                     }\n-                    /**\n-                     * If we have a variant, create a callback that runs it as an animation.\n-                     * Otherwise, we resolve a Promise immediately for a composable no-op.\n-                     */\n-                    var getAnimation = resolved ? function() {\n-                        return animateTarget(visualElement, resolved, options);\n-                    } : function() {\n-                        return Promise.resolve();\n-                    };\n-                    /**\n-                     * If we have children, create a callback that runs all their animations.\n-                     * Otherwise, we resolve a Promise immediately for a composable no-op.\n-                     */\n-                    var getChildAnimations = ((_a = visualElement.variantChildren) === null || _a === void 0 ? void 0 : _a.size) ? function(forwardDelay) {\n-                        if (forwardDelay === void 0) {\n-                            forwardDelay = 0;\n+\n+                    // Given a mouse event, find the corresponding position. If liberal\n+                    // is false, it checks whether a gutter or scrollbar was clicked,\n+                    // and returns null if it was. forRect is used by rectangular\n+                    // selections, and tries to estimate a character position even for\n+                    // coordinates beyond the right of the text.\n+                    function posFromMouse(cm, e, liberal, forRect) {\n+                        var display = cm.display;\n+                        if (!liberal && e_target(e).getAttribute(\"cm-not-content\") == \"true\") {\n+                            return null;\n                         }\n-                        var _a = transition.delayChildren,\n-                            delayChildren = _a === void 0 ? 0 : _a,\n-                            staggerChildren = transition.staggerChildren,\n-                            staggerDirection = transition.staggerDirection;\n-                        return animateChildren(visualElement, variant, delayChildren + forwardDelay, staggerChildren, staggerDirection, options);\n-                    } : function() {\n-                        return Promise.resolve();\n-                    };\n-                    /**\n-                     * If the transition explicitly defines a \"when\" option, we need to resolve either\n-                     * this animation or all children animations before playing the other.\n-                     */\n-                    var when = transition.when;\n-                    if (when) {\n-                        var _c = tslib.__read(when === \"beforeChildren\" ? [getAnimation, getChildAnimations] : [getChildAnimations, getAnimation], 2),\n-                            first = _c[0],\n-                            last = _c[1];\n-                        return first().then(last);\n-                    } else {\n-                        return Promise.all([getAnimation(), getChildAnimations(options.delay)]);\n+                        var x,\n+                            y,\n+                            space = display.lineSpace.getBoundingClientRect();\n+                        // Fails unpredictably on IE[67] when mouse is dragged around quickly.\n+                        try {\n+                            x = e.clientX - space.left;\n+                            y = e.clientY - space.top;\n+                        } catch (e$1) {\n+                            return null;\n+                        }\n+                        var coords = coordsChar(cm, x, y),\n+                            line;\n+                        if (forRect && coords.xRel > 0 && (line = getLine(cm.doc, coords.line).text).length == coords.ch) {\n+                            var colDiff = countColumn(line, line.length, cm.options.tabSize) - line.length;\n+                            coords = Pos(coords.line, Math.max(0, Math.round((x - paddingH(cm.display).left) / charWidth(cm.display)) - colDiff));\n+                        }\n+                        return coords;\n                     }\n-                }\n-                /**\n-                 * @internal\n-                 */\n-                function animateTarget(visualElement, definition, _a) {\n-                    var _b;\n-                    var _c = _a === void 0 ? {} : _a,\n-                        _d = _c.delay,\n-                        delay = _d === void 0 ? 0 : _d,\n-                        transitionOverride = _c.transitionOverride,\n-                        type = _c.type;\n-                    var _e = visualElement.makeTargetAnimatable(definition),\n-                        _f = _e.transition,\n-                        transition = _f === void 0 ? visualElement.getDefaultTransition() : _f,\n-                        transitionEnd = _e.transitionEnd,\n-                        target = tslib.__rest(_e, [\"transition\", \"transitionEnd\"]);\n-                    if (transitionOverride) transition = transitionOverride;\n-                    var animations = [];\n-                    var animationTypeState = type && ((_b = visualElement.animationState) === null || _b === void 0 ? void 0 : _b.getState()[type]);\n-                    for (var key in target) {\n-                        var value = visualElement.getValue(key);\n-                        var valueTarget = target[key];\n-                        if (!value || valueTarget === undefined || animationTypeState && shouldBlockAnimation(animationTypeState, key)) {\n-                            continue;\n+\n+                    // Find the view element corresponding to a given line. Return null\n+                    // when the line isn't visible.\n+                    function findViewIndex(cm, n) {\n+                        if (n >= cm.display.viewTo) {\n+                            return null;\n                         }\n-                        var valueTransition = tslib.__assign({\n-                            delay: delay\n-                        }, transition);\n-                        /**\n-                         * Make animation instant if this is a transform prop and we should reduce motion.\n-                         */\n-                        if (visualElement.shouldReduceMotion && isTransformProp(key)) {\n-                            valueTransition = tslib.__assign(tslib.__assign({}, valueTransition), {\n-                                type: false,\n-                                delay: 0\n-                            });\n+                        n -= cm.display.viewFrom;\n+                        if (n < 0) {\n+                            return null;\n+                        }\n+                        var view = cm.display.view;\n+                        for (var i = 0; i < view.length; i++) {\n+                            n -= view[i].size;\n+                            if (n < 0) {\n+                                return i;\n+                            }\n                         }\n-                        var animation = startAnimation(key, value, valueTarget, valueTransition);\n-                        animations.push(animation);\n                     }\n-                    return Promise.all(animations).then(function() {\n-                        transitionEnd && setTarget(visualElement, transitionEnd);\n-                    });\n-                }\n \n-                function animateChildren(visualElement, variant, delayChildren, staggerChildren, staggerDirection, options) {\n-                    if (delayChildren === void 0) {\n-                        delayChildren = 0;\n-                    }\n-                    if (staggerChildren === void 0) {\n-                        staggerChildren = 0;\n-                    }\n-                    if (staggerDirection === void 0) {\n-                        staggerDirection = 1;\n-                    }\n-                    var animations = [];\n-                    var maxStaggerDuration = (visualElement.variantChildren.size - 1) * staggerChildren;\n-                    var generateStaggerDuration = staggerDirection === 1 ? function(i) {\n-                        if (i === void 0) {\n-                            i = 0;\n+                    // Updates the display.view data structure for a given change to the\n+                    // document. From and to are in pre-change coordinates. Lendiff is\n+                    // the amount of lines added or subtracted by the change. This is\n+                    // used for changes that span multiple lines, or change the way\n+                    // lines are divided into visual lines. regLineChange (below)\n+                    // registers single-line changes.\n+                    function regChange(cm, from, to, lendiff) {\n+                        if (from == null) {\n+                            from = cm.doc.first;\n+                        }\n+                        if (to == null) {\n+                            to = cm.doc.first + cm.doc.size;\n+                        }\n+                        if (!lendiff) {\n+                            lendiff = 0;\n+                        }\n+                        var display = cm.display;\n+                        if (lendiff && to < display.viewTo && (display.updateLineNumbers == null || display.updateLineNumbers > from)) {\n+                            display.updateLineNumbers = from;\n+                        }\n+                        cm.curOp.viewChanged = true;\n+                        if (from >= display.viewTo) {\n+                            // Change after\n+                            if (sawCollapsedSpans && visualLineNo(cm.doc, from) < display.viewTo) {\n+                                resetView(cm);\n+                            }\n+                        } else if (to <= display.viewFrom) {\n+                            // Change before\n+                            if (sawCollapsedSpans && visualLineEndNo(cm.doc, to + lendiff) > display.viewFrom) {\n+                                resetView(cm);\n+                            } else {\n+                                display.viewFrom += lendiff;\n+                                display.viewTo += lendiff;\n+                            }\n+                        } else if (from <= display.viewFrom && to >= display.viewTo) {\n+                            // Full overlap\n+                            resetView(cm);\n+                        } else if (from <= display.viewFrom) {\n+                            // Top overlap\n+                            var cut = viewCuttingPoint(cm, to, to + lendiff, 1);\n+                            if (cut) {\n+                                display.view = display.view.slice(cut.index);\n+                                display.viewFrom = cut.lineN;\n+                                display.viewTo += lendiff;\n+                            } else {\n+                                resetView(cm);\n+                            }\n+                        } else if (to >= display.viewTo) {\n+                            // Bottom overlap\n+                            var cut$1 = viewCuttingPoint(cm, from, from, -1);\n+                            if (cut$1) {\n+                                display.view = display.view.slice(0, cut$1.index);\n+                                display.viewTo = cut$1.lineN;\n+                            } else {\n+                                resetView(cm);\n+                            }\n+                        } else {\n+                            // Gap in the middle\n+                            var cutTop = viewCuttingPoint(cm, from, from, -1);\n+                            var cutBot = viewCuttingPoint(cm, to, to + lendiff, 1);\n+                            if (cutTop && cutBot) {\n+                                display.view = display.view.slice(0, cutTop.index).concat(buildViewArray(cm, cutTop.lineN, cutBot.lineN)).concat(display.view.slice(cutBot.index));\n+                                display.viewTo += lendiff;\n+                            } else {\n+                                resetView(cm);\n+                            }\n                         }\n-                        return i * staggerChildren;\n-                    } : function(i) {\n-                        if (i === void 0) {\n-                            i = 0;\n+                        var ext = display.externalMeasured;\n+                        if (ext) {\n+                            if (to < ext.lineN) {\n+                                ext.lineN += lendiff;\n+                            } else if (from < ext.lineN + ext.size) {\n+                                display.externalMeasured = null;\n+                            }\n                         }\n-                        return maxStaggerDuration - i * staggerChildren;\n-                    };\n-                    Array.from(visualElement.variantChildren).sort(sortByTreeOrder).forEach(function(child, i) {\n-                        animations.push(animateVariant(child, variant, tslib.__assign(tslib.__assign({}, options), {\n-                            delay: delayChildren + generateStaggerDuration(i)\n-                        })).then(function() {\n-                            return child.notifyAnimationComplete(variant);\n-                        }));\n-                    });\n-                    return Promise.all(animations);\n-                }\n+                    }\n \n-                function stopAnimation(visualElement) {\n-                    visualElement.forEachValue(function(value) {\n-                        return value.stop();\n-                    });\n-                }\n+                    // Register a change to a single line. Type must be one of \"text\",\n+                    // \"gutter\", \"class\", \"widget\"\n+                    function regLineChange(cm, line, type) {\n+                        cm.curOp.viewChanged = true;\n+                        var display = cm.display,\n+                            ext = cm.display.externalMeasured;\n+                        if (ext && line >= ext.lineN && line < ext.lineN + ext.size) {\n+                            display.externalMeasured = null;\n+                        }\n+                        if (line < display.viewFrom || line >= display.viewTo) {\n+                            return;\n+                        }\n+                        var lineView = display.view[findViewIndex(cm, line)];\n+                        if (lineView.node == null) {\n+                            return;\n+                        }\n+                        var arr = lineView.changes || (lineView.changes = []);\n+                        if (indexOf(arr, type) == -1) {\n+                            arr.push(type);\n+                        }\n+                    }\n \n-                function sortByTreeOrder(a, b) {\n-                    return a.sortNodePosition(b);\n-                }\n-                /**\n-                 * Decide whether we should block this animation. Previously, we achieved this\n-                 * just by checking whether the key was listed in protectedKeys, but this\n-                 * posed problems if an animation was triggered by afterChildren and protectedKeys\n-                 * had been set to true in the meantime.\n-                 */\n-                function shouldBlockAnimation(_a, key) {\n-                    var protectedKeys = _a.protectedKeys,\n-                        needsAnimating = _a.needsAnimating;\n-                    var shouldBlock = protectedKeys.hasOwnProperty(key) && needsAnimating[key] !== true;\n-                    needsAnimating[key] = false;\n-                    return shouldBlock;\n-                }\n-                var variantPriorityOrder = [exports.AnimationType.Animate, exports.AnimationType.InView, exports.AnimationType.Focus, exports.AnimationType.Hover, exports.AnimationType.Tap, exports.AnimationType.Drag, exports.AnimationType.Exit];\n-                var reversePriorityOrder = tslib.__spreadArray([], tslib.__read(variantPriorityOrder), false).reverse();\n-                var numAnimationTypes = variantPriorityOrder.length;\n+                    // Clear the view.\n+                    function resetView(cm) {\n+                        cm.display.viewFrom = cm.display.viewTo = cm.doc.first;\n+                        cm.display.view = [];\n+                        cm.display.viewOffset = 0;\n+                    }\n \n-                function animateList(visualElement) {\n-                    return function(animations) {\n-                        return Promise.all(animations.map(function(_a) {\n-                            var animation = _a.animation,\n-                                options = _a.options;\n-                            return animateVisualElement(visualElement, animation, options);\n-                        }));\n-                    };\n-                }\n+                    function viewCuttingPoint(cm, oldN, newN, dir) {\n+                        var index = findViewIndex(cm, oldN),\n+                            diff,\n+                            view = cm.display.view;\n+                        if (!sawCollapsedSpans || newN == cm.doc.first + cm.doc.size) {\n+                            return {\n+                                index: index,\n+                                lineN: newN\n+                            };\n+                        }\n+                        var n = cm.display.viewFrom;\n+                        for (var i = 0; i < index; i++) {\n+                            n += view[i].size;\n+                        }\n+                        if (n != oldN) {\n+                            if (dir > 0) {\n+                                if (index == view.length - 1) {\n+                                    return null;\n+                                }\n+                                diff = n + view[index].size - oldN;\n+                                index++;\n+                            } else {\n+                                diff = n - oldN;\n+                            }\n+                            oldN += diff;\n+                            newN += diff;\n+                        }\n+                        while (visualLineNo(cm.doc, newN) != newN) {\n+                            if (index == (dir < 0 ? 0 : view.length - 1)) {\n+                                return null;\n+                            }\n+                            newN += dir * view[index - (dir < 0 ? 1 : 0)].size;\n+                            index += dir;\n+                        }\n+                        return {\n+                            index: index,\n+                            lineN: newN\n+                        };\n+                    }\n \n-                function createAnimationState(visualElement) {\n-                    var animate = animateList(visualElement);\n-                    var state = createState();\n-                    var allAnimatedKeys = {};\n-                    var isInitialRender = true;\n-                    /**\n-                     * This function will be used to reduce the animation definitions for\n-                     * each active animation type into an object of resolved values for it.\n-                     */\n-                    var buildResolvedTypeValues = function(acc, definition) {\n-                        var resolved = resolveVariant(visualElement, definition);\n-                        if (resolved) {\n-                            resolved.transition;\n-                            var transitionEnd = resolved.transitionEnd,\n-                                target = tslib.__rest(resolved, [\"transition\", \"transitionEnd\"]);\n-                            acc = tslib.__assign(tslib.__assign(tslib.__assign({}, acc), target), transitionEnd);\n+                    // Force the view to cover a given range, adding empty view element\n+                    // or clipping off existing ones as needed.\n+                    function adjustView(cm, from, to) {\n+                        var display = cm.display,\n+                            view = display.view;\n+                        if (view.length == 0 || from >= display.viewTo || to <= display.viewFrom) {\n+                            display.view = buildViewArray(cm, from, to);\n+                            display.viewFrom = from;\n+                        } else {\n+                            if (display.viewFrom > from) {\n+                                display.view = buildViewArray(cm, from, display.viewFrom).concat(display.view);\n+                            } else if (display.viewFrom < from) {\n+                                display.view = display.view.slice(findViewIndex(cm, from));\n+                            }\n+                            display.viewFrom = from;\n+                            if (display.viewTo < to) {\n+                                display.view = display.view.concat(buildViewArray(cm, display.viewTo, to));\n+                            } else if (display.viewTo > to) {\n+                                display.view = display.view.slice(0, findViewIndex(cm, to));\n+                            }\n                         }\n-                        return acc;\n-                    };\n+                        display.viewTo = to;\n+                    }\n \n-                    function isAnimated(key) {\n-                        return allAnimatedKeys[key] !== undefined;\n+                    // Count the number of lines in the view whose DOM representation is\n+                    // out of date (or nonexistent).\n+                    function countDirtyView(cm) {\n+                        var view = cm.display.view,\n+                            dirty = 0;\n+                        for (var i = 0; i < view.length; i++) {\n+                            var lineView = view[i];\n+                            if (!lineView.hidden && (!lineView.node || lineView.changes)) {\n+                                ++dirty;\n+                            }\n+                        }\n+                        return dirty;\n                     }\n-                    /**\n-                     * This just allows us to inject mocked animation functions\n-                     * @internal\n-                     */\n-                    function setAnimateFunction(makeAnimator) {\n-                        animate = makeAnimator(visualElement);\n+\n+                    function updateSelection(cm) {\n+                        cm.display.input.showSelection(cm.display.input.prepareSelection());\n                     }\n-                    /**\n-                     * When we receive new props, we need to:\n-                     * 1. Create a list of protected keys for each type. This is a directory of\n-                     *    value keys that are currently being \"handled\" by types of a higher priority\n-                     *    so that whenever an animation is played of a given type, these values are\n-                     *    protected from being animated.\n-                     * 2. Determine if an animation type needs animating.\n-                     * 3. Determine if any values have been removed from a type and figure out\n-                     *    what to animate those to.\n-                     */\n-                    function animateChanges(options, changedActiveType) {\n-                        var _a;\n-                        var props = visualElement.getProps();\n-                        var context = visualElement.getVariantContext(true) || {};\n-                        /**\n-                         * A list of animations that we'll build into as we iterate through the animation\n-                         * types. This will get executed at the end of the function.\n-                         */\n-                        var animations = [];\n-                        /**\n-                         * Keep track of which values have been removed. Then, as we hit lower priority\n-                         * animation types, we can check if they contain removed values and animate to that.\n-                         */\n-                        var removedKeys = new Set();\n-                        /**\n-                         * A dictionary of all encountered keys. This is an object to let us build into and\n-                         * copy it without iteration. Each time we hit an animation type we set its protected\n-                         * keys - the keys its not allowed to animate - to the latest version of this object.\n-                         */\n-                        var encounteredKeys = {};\n-                        /**\n-                         * If a variant has been removed at a given index, and this component is controlling\n-                         * variant animations, we want to ensure lower-priority variants are forced to animate.\n-                         */\n-                        var removedVariantIndex = Infinity;\n-                        var _loop_1 = function(i) {\n-                            var type = reversePriorityOrder[i];\n-                            var typeState = state[type];\n-                            var prop = (_a = props[type]) !== null && _a !== void 0 ? _a : context[type];\n-                            var propIsVariant = isVariantLabel(prop);\n-                            /**\n-                             * If this type has *just* changed isActive status, set activeDelta\n-                             * to that status. Otherwise set to null.\n-                             */\n-                            var activeDelta = type === changedActiveType ? typeState.isActive : null;\n-                            if (activeDelta === false) removedVariantIndex = i;\n-                            /**\n-                             * If this prop is an inherited variant, rather than been set directly on the\n-                             * component itself, we want to make sure we allow the parent to trigger animations.\n-                             *\n-                             * TODO: Can probably change this to a !isControllingVariants check\n-                             */\n-                            var isInherited = prop === context[type] && prop !== props[type] && propIsVariant;\n-                            /**\n-                             *\n-                             */\n-                            if (isInherited && isInitialRender && visualElement.manuallyAnimateOnMount) {\n-                                isInherited = false;\n+\n+                    function prepareSelection(cm, primary) {\n+                        if (primary === void 0) primary = true;\n+                        var doc = cm.doc,\n+                            result = {};\n+                        var curFragment = result.cursors = document.createDocumentFragment();\n+                        var selFragment = result.selection = document.createDocumentFragment();\n+                        var customCursor = cm.options.$customCursor;\n+                        if (customCursor) {\n+                            primary = true;\n+                        }\n+                        for (var i = 0; i < doc.sel.ranges.length; i++) {\n+                            if (!primary && i == doc.sel.primIndex) {\n+                                continue;\n                             }\n-                            /**\n-                             * Set all encountered keys so far as the protected keys for this type. This will\n-                             * be any key that has been animated or otherwise handled by active, higher-priortiy types.\n-                             */\n-                            typeState.protectedKeys = tslib.__assign({}, encounteredKeys);\n-                            // Check if we can skip analysing this prop early\n-                            if (\n-                                // If it isn't active and hasn't *just* been set as inactive\n-                                !typeState.isActive && activeDelta === null ||\n-                                // If we didn't and don't have any defined prop for this animation type\n-                                !prop && !typeState.prevProp ||\n-                                // Or if the prop doesn't define an animation\n-                                isAnimationControls(prop) || typeof prop === \"boolean\") {\n-                                return \"continue\";\n+                            var range = doc.sel.ranges[i];\n+                            if (range.from().line >= cm.display.viewTo || range.to().line < cm.display.viewFrom) {\n+                                continue;\n                             }\n-                            /**\n-                             * As we go look through the values defined on this type, if we detect\n-                             * a changed value or a value that was removed in a higher priority, we set\n-                             * this to true and add this prop to the animation list.\n-                             */\n-                            var variantDidChange = checkVariantsDidChange(typeState.prevProp, prop);\n-                            var shouldAnimateType = variantDidChange ||\n-                                // If we're making this variant active, we want to always make it active\n-                                type === changedActiveType && typeState.isActive && !isInherited && propIsVariant ||\n-                                // If we removed a higher-priority variant (i is in reverse order)\n-                                i > removedVariantIndex && propIsVariant;\n-                            /**\n-                             * As animations can be set as variant lists, variants or target objects, we\n-                             * coerce everything to an array if it isn't one already\n-                             */\n-                            var definitionList = Array.isArray(prop) ? prop : [prop];\n-                            /**\n-                             * Build an object of all the resolved values. We'll use this in the subsequent\n-                             * animateChanges calls to determine whether a value has changed.\n-                             */\n-                            var resolvedValues = definitionList.reduce(buildResolvedTypeValues, {});\n-                            if (activeDelta === false) resolvedValues = {};\n-                            /**\n-                             * Now we need to loop through all the keys in the prev prop and this prop,\n-                             * and decide:\n-                             * 1. If the value has changed, and needs animating\n-                             * 2. If it has been removed, and needs adding to the removedKeys set\n-                             * 3. If it has been removed in a higher priority type and needs animating\n-                             * 4. If it hasn't been removed in a higher priority but hasn't changed, and\n-                             *    needs adding to the type's protectedKeys list.\n-                             */\n-                            var _b = typeState.prevResolvedValues,\n-                                prevResolvedValues = _b === void 0 ? {} : _b;\n-                            var allKeys = tslib.__assign(tslib.__assign({}, prevResolvedValues), resolvedValues);\n-                            var markToAnimate = function(key) {\n-                                shouldAnimateType = true;\n-                                removedKeys.delete(key);\n-                                typeState.needsAnimating[key] = true;\n-                            };\n-                            for (var key in allKeys) {\n-                                var next = resolvedValues[key];\n-                                var prev = prevResolvedValues[key];\n-                                // If we've already handled this we can just skip ahead\n-                                if (encounteredKeys.hasOwnProperty(key)) continue;\n-                                /**\n-                                 * If the value has changed, we probably want to animate it.\n-                                 */\n-                                if (next !== prev) {\n-                                    /**\n-                                     * If both values are keyframes, we need to shallow compare them to\n-                                     * detect whether any value has changed. If it has, we animate it.\n-                                     */\n-                                    if (isKeyframesTarget(next) && isKeyframesTarget(prev)) {\n-                                        if (!shallowCompare(next, prev) || variantDidChange) {\n-                                            markToAnimate(key);\n-                                        } else {\n-                                            /**\n-                                             * If it hasn't changed, we want to ensure it doesn't animate by\n-                                             * adding it to the list of protected keys.\n-                                             */\n-                                            typeState.protectedKeys[key] = true;\n-                                        }\n-                                    } else if (next !== undefined) {\n-                                        // If next is defined and doesn't equal prev, it needs animating\n-                                        markToAnimate(key);\n-                                    } else {\n-                                        // If it's undefined, it's been removed.\n-                                        removedKeys.add(key);\n-                                    }\n-                                } else if (next !== undefined && removedKeys.has(key)) {\n-                                    /**\n-                                     * If next hasn't changed and it isn't undefined, we want to check if it's\n-                                     * been removed by a higher priority\n-                                     */\n-                                    markToAnimate(key);\n-                                } else {\n-                                    /**\n-                                     * If it hasn't changed, we add it to the list of protected values\n-                                     * to ensure it doesn't get animated.\n-                                     */\n-                                    typeState.protectedKeys[key] = true;\n+                            var collapsed = range.empty();\n+                            if (customCursor) {\n+                                var head = customCursor(cm, range);\n+                                if (head) {\n+                                    drawSelectionCursor(cm, head, curFragment);\n                                 }\n+                            } else if (collapsed || cm.options.showCursorWhenSelecting) {\n+                                drawSelectionCursor(cm, range.head, curFragment);\n                             }\n-                            /**\n-                             * Update the typeState so next time animateChanges is called we can compare the\n-                             * latest prop and resolvedValues to these.\n-                             */\n-                            typeState.prevProp = prop;\n-                            typeState.prevResolvedValues = resolvedValues;\n-                            /**\n-                             *\n-                             */\n-                            if (typeState.isActive) {\n-                                encounteredKeys = tslib.__assign(tslib.__assign({}, encounteredKeys), resolvedValues);\n-                            }\n-                            if (isInitialRender && visualElement.blockInitialAnimation) {\n-                                shouldAnimateType = false;\n-                            }\n-                            /**\n-                             * If this is an inherited prop we want to hard-block animations\n-                             * TODO: Test as this should probably still handle animations triggered\n-                             * by removed values?\n-                             */\n-                            if (shouldAnimateType && !isInherited) {\n-                                animations.push.apply(animations, tslib.__spreadArray([], tslib.__read(definitionList.map(function(animation) {\n-                                    return {\n-                                        animation: animation,\n-                                        options: tslib.__assign({\n-                                            type: type\n-                                        }, options)\n-                                    };\n-                                })), false));\n+                            if (!collapsed) {\n+                                drawSelectionRange(cm, range, selFragment);\n                             }\n-                        };\n-                        /**\n-                         * Iterate through all animation types in reverse priority order. For each, we want to\n-                         * detect which values it's handling and whether or not they've changed (and therefore\n-                         * need to be animated). If any values have been removed, we want to detect those in\n-                         * lower priority props and flag for animation.\n-                         */\n-                        for (var i = 0; i < numAnimationTypes; i++) {\n-                            _loop_1(i);\n                         }\n-                        allAnimatedKeys = tslib.__assign({}, encounteredKeys);\n-                        /**\n-                         * If there are some removed value that haven't been dealt with,\n-                         * we need to create a new animation that falls back either to the value\n-                         * defined in the style prop, or the last read value.\n-                         */\n-                        if (removedKeys.size) {\n-                            var fallbackAnimation_1 = {};\n-                            removedKeys.forEach(function(key) {\n-                                var fallbackTarget = visualElement.getBaseTarget(key);\n-                                if (fallbackTarget !== undefined) {\n-                                    fallbackAnimation_1[key] = fallbackTarget;\n+                        return result;\n+                    }\n+\n+                    // Draws a cursor for the given range\n+                    function drawSelectionCursor(cm, head, output) {\n+                        var pos = cursorCoords(cm, head, \"div\", null, null, !cm.options.singleCursorHeightPerLine);\n+                        var cursor = output.appendChild(elt(\"div\", \"\\u00a0\", \"CodeMirror-cursor\"));\n+                        cursor.style.left = pos.left + \"px\";\n+                        cursor.style.top = pos.top + \"px\";\n+                        cursor.style.height = Math.max(0, pos.bottom - pos.top) * cm.options.cursorHeight + \"px\";\n+                        if (/\\bcm-fat-cursor\\b/.test(cm.getWrapperElement().className)) {\n+                            var charPos = charCoords(cm, head, \"div\", null, null);\n+                            var width = charPos.right - charPos.left;\n+                            cursor.style.width = (width > 0 ? width : cm.defaultCharWidth()) + \"px\";\n+                        }\n+                        if (pos.other) {\n+                            // Secondary cursor, shown when on a 'jump' in bi-directional text\n+                            var otherCursor = output.appendChild(elt(\"div\", \"\\u00a0\", \"CodeMirror-cursor CodeMirror-secondarycursor\"));\n+                            otherCursor.style.display = \"\";\n+                            otherCursor.style.left = pos.other.left + \"px\";\n+                            otherCursor.style.top = pos.other.top + \"px\";\n+                            otherCursor.style.height = (pos.other.bottom - pos.other.top) * .85 + \"px\";\n+                        }\n+                    }\n+\n+                    function cmpCoords(a, b) {\n+                        return a.top - b.top || a.left - b.left;\n+                    }\n+\n+                    // Draws the given range as a highlighted selection\n+                    function drawSelectionRange(cm, range, output) {\n+                        var display = cm.display,\n+                            doc = cm.doc;\n+                        var fragment = document.createDocumentFragment();\n+                        var padding = paddingH(cm.display),\n+                            leftSide = padding.left;\n+                        var rightSide = Math.max(display.sizerWidth, displayWidth(cm) - display.sizer.offsetLeft) - padding.right;\n+                        var docLTR = doc.direction == \"ltr\";\n+\n+                        function add(left, top, width, bottom) {\n+                            if (top < 0) {\n+                                top = 0;\n+                            }\n+                            top = Math.round(top);\n+                            bottom = Math.round(bottom);\n+                            fragment.appendChild(elt(\"div\", null, \"CodeMirror-selected\", \"position: absolute; left: \" + left + \"px;\\n                             top: \" + top + \"px; width: \" + (width == null ? rightSide - left : width) + \"px;\\n                             height: \" + (bottom - top) + \"px\"));\n+                        }\n+\n+                        function drawForLine(line, fromArg, toArg) {\n+                            var lineObj = getLine(doc, line);\n+                            var lineLen = lineObj.text.length;\n+                            var start, end;\n+\n+                            function coords(ch, bias) {\n+                                return charCoords(cm, Pos(line, ch), \"div\", lineObj, bias);\n+                            }\n+\n+                            function wrapX(pos, dir, side) {\n+                                var extent = wrappedLineExtentChar(cm, lineObj, null, pos);\n+                                var prop = dir == \"ltr\" == (side == \"after\") ? \"left\" : \"right\";\n+                                var ch = side == \"after\" ? extent.begin : extent.end - (/\\s/.test(lineObj.text.charAt(extent.end - 1)) ? 2 : 1);\n+                                return coords(ch, prop)[prop];\n+                            }\n+                            var order = getOrder(lineObj, doc.direction);\n+                            iterateBidiSections(order, fromArg || 0, toArg == null ? lineLen : toArg, function(from, to, dir, i) {\n+                                var ltr = dir == \"ltr\";\n+                                var fromPos = coords(from, ltr ? \"left\" : \"right\");\n+                                var toPos = coords(to - 1, ltr ? \"right\" : \"left\");\n+                                var openStart = fromArg == null && from == 0,\n+                                    openEnd = toArg == null && to == lineLen;\n+                                var first = i == 0,\n+                                    last = !order || i == order.length - 1;\n+                                if (toPos.top - fromPos.top <= 3) {\n+                                    // Single line\n+                                    var openLeft = (docLTR ? openStart : openEnd) && first;\n+                                    var openRight = (docLTR ? openEnd : openStart) && last;\n+                                    var left = openLeft ? leftSide : (ltr ? fromPos : toPos).left;\n+                                    var right = openRight ? rightSide : (ltr ? toPos : fromPos).right;\n+                                    add(left, fromPos.top, right - left, fromPos.bottom);\n+                                } else {\n+                                    // Multiple lines\n+                                    var topLeft, topRight, botLeft, botRight;\n+                                    if (ltr) {\n+                                        topLeft = docLTR && openStart && first ? leftSide : fromPos.left;\n+                                        topRight = docLTR ? rightSide : wrapX(from, dir, \"before\");\n+                                        botLeft = docLTR ? leftSide : wrapX(to, dir, \"after\");\n+                                        botRight = docLTR && openEnd && last ? rightSide : toPos.right;\n+                                    } else {\n+                                        topLeft = !docLTR ? leftSide : wrapX(from, dir, \"before\");\n+                                        topRight = !docLTR && openStart && first ? rightSide : fromPos.right;\n+                                        botLeft = !docLTR && openEnd && last ? leftSide : toPos.left;\n+                                        botRight = !docLTR ? rightSide : wrapX(to, dir, \"after\");\n+                                    }\n+                                    add(topLeft, fromPos.top, topRight - topLeft, fromPos.bottom);\n+                                    if (fromPos.bottom < toPos.top) {\n+                                        add(leftSide, fromPos.bottom, null, toPos.top);\n+                                    }\n+                                    add(botLeft, toPos.top, botRight - botLeft, toPos.bottom);\n+                                }\n+                                if (!start || cmpCoords(fromPos, start) < 0) {\n+                                    start = fromPos;\n+                                }\n+                                if (cmpCoords(toPos, start) < 0) {\n+                                    start = toPos;\n+                                }\n+                                if (!end || cmpCoords(fromPos, end) < 0) {\n+                                    end = fromPos;\n+                                }\n+                                if (cmpCoords(toPos, end) < 0) {\n+                                    end = toPos;\n                                 }\n                             });\n-                            animations.push({\n-                                animation: fallbackAnimation_1\n-                            });\n+                            return {\n+                                start: start,\n+                                end: end\n+                            };\n                         }\n-                        var shouldAnimate = Boolean(animations.length);\n-                        if (isInitialRender && props.initial === false && !visualElement.manuallyAnimateOnMount) {\n-                            shouldAnimate = false;\n+                        var sFrom = range.from(),\n+                            sTo = range.to();\n+                        if (sFrom.line == sTo.line) {\n+                            drawForLine(sFrom.line, sFrom.ch, sTo.ch);\n+                        } else {\n+                            var fromLine = getLine(doc, sFrom.line),\n+                                toLine = getLine(doc, sTo.line);\n+                            var singleVLine = visualLine(fromLine) == visualLine(toLine);\n+                            var leftEnd = drawForLine(sFrom.line, sFrom.ch, singleVLine ? fromLine.text.length + 1 : null).end;\n+                            var rightStart = drawForLine(sTo.line, singleVLine ? 0 : null, sTo.ch).start;\n+                            if (singleVLine) {\n+                                if (leftEnd.top < rightStart.top - 2) {\n+                                    add(leftEnd.right, leftEnd.top, null, leftEnd.bottom);\n+                                    add(leftSide, rightStart.top, rightStart.left, rightStart.bottom);\n+                                } else {\n+                                    add(leftEnd.right, leftEnd.top, rightStart.left - leftEnd.right, leftEnd.bottom);\n+                                }\n+                            }\n+                            if (leftEnd.bottom < rightStart.top) {\n+                                add(leftSide, leftEnd.bottom, null, rightStart.top);\n+                            }\n                         }\n-                        isInitialRender = false;\n-                        return shouldAnimate ? animate(animations) : Promise.resolve();\n+                        output.appendChild(fragment);\n                     }\n-                    /**\n-                     * Change whether a certain animation type is active.\n-                     */\n-                    function setActive(type, isActive, options) {\n-                        var _a;\n-                        // If the active state hasn't changed, we can safely do nothing here\n-                        if (state[type].isActive === isActive) return Promise.resolve();\n-                        // Propagate active change to children\n-                        (_a = visualElement.variantChildren) === null || _a === void 0 ? void 0 : _a.forEach(function(child) {\n-                            var _a;\n-                            return (_a = child.animationState) === null || _a === void 0 ? void 0 : _a.setActive(type, isActive);\n-                        });\n-                        state[type].isActive = isActive;\n-                        var animations = animateChanges(options, type);\n-                        for (var key in state) {\n-                            state[key].protectedKeys = {};\n+\n+                    // Cursor-blinking\n+                    function restartBlink(cm) {\n+                        if (!cm.state.focused) {\n+                            return;\n+                        }\n+                        var display = cm.display;\n+                        clearInterval(display.blinker);\n+                        var on = true;\n+                        display.cursorDiv.style.visibility = \"\";\n+                        if (cm.options.cursorBlinkRate > 0) {\n+                            display.blinker = setInterval(function() {\n+                                if (!cm.hasFocus()) {\n+                                    onBlur(cm);\n+                                }\n+                                display.cursorDiv.style.visibility = (on = !on) ? \"\" : \"hidden\";\n+                            }, cm.options.cursorBlinkRate);\n+                        } else if (cm.options.cursorBlinkRate < 0) {\n+                            display.cursorDiv.style.visibility = \"hidden\";\n                         }\n-                        return animations;\n                     }\n-                    return {\n-                        isAnimated: isAnimated,\n-                        animateChanges: animateChanges,\n-                        setActive: setActive,\n-                        setAnimateFunction: setAnimateFunction,\n-                        getState: function() {\n-                            return state;\n+\n+                    function ensureFocus(cm) {\n+                        if (!cm.hasFocus()) {\n+                            cm.display.input.focus();\n+                            if (!cm.state.focused) {\n+                                onFocus(cm);\n+                            }\n                         }\n-                    };\n-                }\n+                    }\n \n-                function checkVariantsDidChange(prev, next) {\n-                    if (typeof next === \"string\") {\n-                        return next !== prev;\n-                    } else if (isVariantLabels(next)) {\n-                        return !shallowCompare(next, prev);\n+                    function delayBlurEvent(cm) {\n+                        cm.state.delayingBlurEvent = true;\n+                        setTimeout(function() {\n+                            if (cm.state.delayingBlurEvent) {\n+                                cm.state.delayingBlurEvent = false;\n+                                if (cm.state.focused) {\n+                                    onBlur(cm);\n+                                }\n+                            }\n+                        }, 100);\n                     }\n-                    return false;\n-                }\n \n-                function createTypeState(isActive) {\n-                    if (isActive === void 0) {\n-                        isActive = false;\n+                    function onFocus(cm, e) {\n+                        if (cm.state.delayingBlurEvent && !cm.state.draggingText) {\n+                            cm.state.delayingBlurEvent = false;\n+                        }\n+                        if (cm.options.readOnly == \"nocursor\") {\n+                            return;\n+                        }\n+                        if (!cm.state.focused) {\n+                            signal(cm, \"focus\", cm, e);\n+                            cm.state.focused = true;\n+                            addClass(cm.display.wrapper, \"CodeMirror-focused\");\n+                            // This test prevents this from firing when a context\n+                            // menu is closed (since the input reset would kill the\n+                            // select-all detection hack)\n+                            if (!cm.curOp && cm.display.selForContextMenu != cm.doc.sel) {\n+                                cm.display.input.reset();\n+                                if (webkit) {\n+                                    setTimeout(function() {\n+                                        return cm.display.input.reset(true);\n+                                    }, 20);\n+                                } // Issue #1730\n+                            }\n+                            cm.display.input.receivedFocus();\n+                        }\n+                        restartBlink(cm);\n                     }\n-                    return {\n-                        isActive: isActive,\n-                        protectedKeys: {},\n-                        needsAnimating: {},\n-                        prevResolvedValues: {}\n-                    };\n-                }\n \n-                function createState() {\n-                    var _a;\n-                    return _a = {}, _a[exports.AnimationType.Animate] = createTypeState(true), _a[exports.AnimationType.InView] = createTypeState(), _a[exports.AnimationType.Hover] = createTypeState(), _a[exports.AnimationType.Tap] = createTypeState(), _a[exports.AnimationType.Drag] = createTypeState(), _a[exports.AnimationType.Focus] = createTypeState(), _a[exports.AnimationType.Exit] = createTypeState(), _a;\n-                }\n-                var animations = {\n-                    animation: makeRenderlessComponent(function(_a) {\n-                        var visualElement = _a.visualElement,\n-                            animate = _a.animate;\n-                        /**\n-                         * We dynamically generate the AnimationState manager as it contains a reference\n-                         * to the underlying animation library. We only want to load that if we load this,\n-                         * so people can optionally code split it out using the `m` component.\n-                         */\n-                        visualElement.animationState || (visualElement.animationState = createAnimationState(visualElement));\n-                        /**\n-                         * Subscribe any provided AnimationControls to the component's VisualElement\n-                         */\n-                        if (isAnimationControls(animate)) {\n-                            React.useEffect(function() {\n-                                return animate.subscribe(visualElement);\n-                            }, [animate]);\n+                    function onBlur(cm, e) {\n+                        if (cm.state.delayingBlurEvent) {\n+                            return;\n                         }\n-                    }),\n-                    exit: makeRenderlessComponent(function(props) {\n-                        var custom = props.custom,\n-                            visualElement = props.visualElement;\n-                        var _a = tslib.__read(usePresence(), 2),\n-                            isPresent = _a[0],\n-                            safeToRemove = _a[1];\n-                        var presenceContext = React.useContext(PresenceContext);\n-                        React.useEffect(function() {\n-                            var _a, _b;\n-                            visualElement.isPresent = isPresent;\n-                            var animation = (_a = visualElement.animationState) === null || _a === void 0 ? void 0 : _a.setActive(exports.AnimationType.Exit, !isPresent, {\n-                                custom: (_b = presenceContext === null || presenceContext === void 0 ? void 0 : presenceContext.custom) !== null && _b !== void 0 ? _b : custom\n-                            });\n-                            !isPresent && (animation === null || animation === void 0 ? void 0 : animation.then(safeToRemove));\n-                        }, [isPresent]);\n-                    })\n-                };\n+                        if (cm.state.focused) {\n+                            signal(cm, \"blur\", cm, e);\n+                            cm.state.focused = false;\n+                            rmClass(cm.display.wrapper, \"CodeMirror-focused\");\n+                        }\n+                        clearInterval(cm.display.blinker);\n+                        setTimeout(function() {\n+                            if (!cm.state.focused) {\n+                                cm.display.shift = false;\n+                            }\n+                        }, 150);\n+                    }\n \n-                /**\n-                 * @internal\n-                 */\n-                var PanSession = /** @class */ function() {\n-                    function PanSession(event, handlers, _a) {\n-                        var _this = this;\n-                        var _b = _a === void 0 ? {} : _a,\n-                            transformPagePoint = _b.transformPagePoint;\n-                        /**\n-                         * @internal\n-                         */\n-                        this.startEvent = null;\n-                        /**\n-                         * @internal\n-                         */\n-                        this.lastMoveEvent = null;\n-                        /**\n-                         * @internal\n-                         */\n-                        this.lastMoveEventInfo = null;\n-                        /**\n-                         * @internal\n-                         */\n-                        this.handlers = {};\n-                        this.updatePoint = function() {\n-                            if (!(_this.lastMoveEvent && _this.lastMoveEventInfo)) return;\n-                            var info = getPanInfo(_this.lastMoveEventInfo, _this.history);\n-                            var isPanStarted = _this.startEvent !== null;\n-                            // Only start panning if the offset is larger than 3 pixels. If we make it\n-                            // any larger than this we'll want to reset the pointer history\n-                            // on the first update to avoid visual snapping to the cursoe.\n-                            var isDistancePastThreshold = popmotion.distance(info.offset, {\n-                                x: 0,\n-                                y: 0\n-                            }) >= 3;\n-                            if (!isPanStarted && !isDistancePastThreshold) return;\n-                            var point = info.point;\n-                            var timestamp = sync.getFrameData().timestamp;\n-                            _this.history.push(tslib.__assign(tslib.__assign({}, point), {\n-                                timestamp: timestamp\n-                            }));\n-                            var _a = _this.handlers,\n-                                onStart = _a.onStart,\n-                                onMove = _a.onMove;\n-                            if (!isPanStarted) {\n-                                onStart && onStart(_this.lastMoveEvent, info);\n-                                _this.startEvent = _this.lastMoveEvent;\n+                    // Read the actual heights of the rendered lines, and update their\n+                    // stored heights to match.\n+                    function updateHeightsInViewport(cm) {\n+                        var display = cm.display;\n+                        var prevBottom = display.lineDiv.offsetTop;\n+                        var viewTop = Math.max(0, display.scroller.getBoundingClientRect().top);\n+                        var oldHeight = display.lineDiv.getBoundingClientRect().top;\n+                        var mustScroll = 0;\n+                        for (var i = 0; i < display.view.length; i++) {\n+                            var cur = display.view[i],\n+                                wrapping = cm.options.lineWrapping;\n+                            var height = void 0,\n+                                width = 0;\n+                            if (cur.hidden) {\n+                                continue;\n                             }\n-                            onMove && onMove(_this.lastMoveEvent, info);\n-                        };\n-                        this.handlePointerMove = function(event, info) {\n-                            _this.lastMoveEvent = event;\n-                            _this.lastMoveEventInfo = transformPoint(info, _this.transformPagePoint);\n-                            // Because Safari doesn't trigger mouseup events when it's above a `<select>`\n-                            if (isMouseEvent(event) && event.buttons === 0) {\n-                                _this.handlePointerUp(event, info);\n-                                return;\n+                            oldHeight += cur.line.height;\n+                            if (ie && ie_version < 8) {\n+                                var bot = cur.node.offsetTop + cur.node.offsetHeight;\n+                                height = bot - prevBottom;\n+                                prevBottom = bot;\n+                            } else {\n+                                var box = cur.node.getBoundingClientRect();\n+                                height = box.bottom - box.top;\n+                                // Check that lines don't extend past the right of the current\n+                                // editor width\n+                                if (!wrapping && cur.text.firstChild) {\n+                                    width = cur.text.firstChild.getBoundingClientRect().right - box.left - 1;\n+                                }\n+                            }\n+                            var diff = cur.line.height - height;\n+                            if (diff > .005 || diff < -.005) {\n+                                if (oldHeight < viewTop) {\n+                                    mustScroll -= diff;\n+                                }\n+                                updateLineHeight(cur.line, height);\n+                                updateWidgetHeight(cur.line);\n+                                if (cur.rest) {\n+                                    for (var j = 0; j < cur.rest.length; j++) {\n+                                        updateWidgetHeight(cur.rest[j]);\n+                                    }\n+                                }\n+                            }\n+                            if (width > cm.display.sizerWidth) {\n+                                var chWidth = Math.ceil(width / charWidth(cm.display));\n+                                if (chWidth > cm.display.maxLineLength) {\n+                                    cm.display.maxLineLength = chWidth;\n+                                    cm.display.maxLine = cur.line;\n+                                    cm.display.maxLineChanged = true;\n+                                }\n+                            }\n+                        }\n+                        if (Math.abs(mustScroll) > 2) {\n+                            display.scroller.scrollTop += mustScroll;\n+                        }\n+                    }\n+\n+                    // Read and store the height of line widgets associated with the\n+                    // given line.\n+                    function updateWidgetHeight(line) {\n+                        if (line.widgets) {\n+                            for (var i = 0; i < line.widgets.length; ++i) {\n+                                var w = line.widgets[i],\n+                                    parent = w.node.parentNode;\n+                                if (parent) {\n+                                    w.height = parent.offsetHeight;\n+                                }\n                             }\n-                            // Throttle mouse move event to once per frame\n-                            sync__default[\"default\"].update(_this.updatePoint, true);\n-                        };\n-                        this.handlePointerUp = function(event, info) {\n-                            _this.end();\n-                            var _a = _this.handlers,\n-                                onEnd = _a.onEnd,\n-                                onSessionEnd = _a.onSessionEnd;\n-                            var panInfo = getPanInfo(transformPoint(info, _this.transformPagePoint), _this.history);\n-                            if (_this.startEvent && onEnd) {\n-                                onEnd(event, panInfo);\n+                        }\n+                    }\n+\n+                    // Compute the lines that are visible in a given viewport (defaults\n+                    // the the current scroll position). viewport may contain top,\n+                    // height, and ensure (see op.scrollToPos) properties.\n+                    function visibleLines(display, doc, viewport) {\n+                        var top = viewport && viewport.top != null ? Math.max(0, viewport.top) : display.scroller.scrollTop;\n+                        top = Math.floor(top - paddingTop(display));\n+                        var bottom = viewport && viewport.bottom != null ? viewport.bottom : top + display.wrapper.clientHeight;\n+                        var from = lineAtHeight(doc, top),\n+                            to = lineAtHeight(doc, bottom);\n+                        // Ensure is a {from: {line, ch}, to: {line, ch}} object, and\n+                        // forces those lines into the viewport (if possible).\n+                        if (viewport && viewport.ensure) {\n+                            var ensureFrom = viewport.ensure.from.line,\n+                                ensureTo = viewport.ensure.to.line;\n+                            if (ensureFrom < from) {\n+                                from = ensureFrom;\n+                                to = lineAtHeight(doc, heightAtLine(getLine(doc, ensureFrom)) + display.wrapper.clientHeight);\n+                            } else if (Math.min(ensureTo, doc.lastLine()) >= to) {\n+                                from = lineAtHeight(doc, heightAtLine(getLine(doc, ensureTo)) - display.wrapper.clientHeight);\n+                                to = ensureTo;\n                             }\n-                            onSessionEnd && onSessionEnd(event, panInfo);\n+                        }\n+                        return {\n+                            from: from,\n+                            to: Math.max(to, from + 1)\n                         };\n-                        // If we have more than one touch, don't start detecting this gesture\n-                        if (isTouchEvent(event) && event.touches.length > 1) return;\n-                        this.handlers = handlers;\n-                        this.transformPagePoint = transformPagePoint;\n-                        var info = extractEventInfo(event);\n-                        var initialInfo = transformPoint(info, this.transformPagePoint);\n-                        var point = initialInfo.point;\n-                        var timestamp = sync.getFrameData().timestamp;\n-                        this.history = [tslib.__assign(tslib.__assign({}, point), {\n-                            timestamp: timestamp\n-                        })];\n-                        var onSessionStart = handlers.onSessionStart;\n-                        onSessionStart && onSessionStart(event, getPanInfo(initialInfo, this.history));\n-                        this.removeListeners = popmotion.pipe(addPointerEvent(window, \"pointermove\", this.handlePointerMove), addPointerEvent(window, \"pointerup\", this.handlePointerUp), addPointerEvent(window, \"pointercancel\", this.handlePointerUp));\n                     }\n-                    PanSession.prototype.updateHandlers = function(handlers) {\n-                        this.handlers = handlers;\n-                    };\n-                    PanSession.prototype.end = function() {\n-                        this.removeListeners && this.removeListeners();\n-                        sync.cancelSync.update(this.updatePoint);\n-                    };\n-                    return PanSession;\n-                }();\n \n-                function transformPoint(info, transformPagePoint) {\n-                    return transformPagePoint ? {\n-                        point: transformPagePoint(info.point)\n-                    } : info;\n-                }\n+                    // SCROLLING THINGS INTO VIEW\n \n-                function subtractPoint(a, b) {\n-                    return {\n-                        x: a.x - b.x,\n-                        y: a.y - b.y\n-                    };\n-                }\n+                    // If an editor sits on the top or bottom of the window, partially\n+                    // scrolled out of view, this ensures that the cursor is visible.\n+                    function maybeScrollWindow(cm, rect) {\n+                        if (signalDOMEvent(cm, \"scrollCursorIntoView\")) {\n+                            return;\n+                        }\n+                        var display = cm.display,\n+                            box = display.sizer.getBoundingClientRect(),\n+                            doScroll = null;\n+                        if (rect.top + box.top < 0) {\n+                            doScroll = true;\n+                        } else if (rect.bottom + box.top > (window.innerHeight || document.documentElement.clientHeight)) {\n+                            doScroll = false;\n+                        }\n+                        if (doScroll != null && !phantom) {\n+                            var scrollNode = elt(\"div\", \"\\u200b\", null, \"position: absolute;\\n                         top: \" + (rect.top - display.viewOffset - paddingTop(cm.display)) + \"px;\\n                         height: \" + (rect.bottom - rect.top + scrollGap(cm) + display.barHeight) + \"px;\\n                         left: \" + rect.left + \"px; width: \" + Math.max(2, rect.right - rect.left) + \"px;\");\n+                            cm.display.lineSpace.appendChild(scrollNode);\n+                            scrollNode.scrollIntoView(doScroll);\n+                            cm.display.lineSpace.removeChild(scrollNode);\n+                        }\n+                    }\n \n-                function getPanInfo(_a, history) {\n-                    var point = _a.point;\n-                    return {\n-                        point: point,\n-                        delta: subtractPoint(point, lastDevicePoint(history)),\n-                        offset: subtractPoint(point, startDevicePoint(history)),\n-                        velocity: getVelocity(history, 0.1)\n-                    };\n-                }\n+                    // Scroll a given position into view (immediately), verifying that\n+                    // it actually became visible (as line heights are accurately\n+                    // measured, the position of something may 'drift' during drawing).\n+                    function scrollPosIntoView(cm, pos, end, margin) {\n+                        if (margin == null) {\n+                            margin = 0;\n+                        }\n+                        var rect;\n+                        if (!cm.options.lineWrapping && pos == end) {\n+                            // Set pos and end to the cursor positions around the character pos sticks to\n+                            // If pos.sticky == \"before\", that is around pos.ch - 1, otherwise around pos.ch\n+                            // If pos == Pos(_, 0, \"before\"), pos and end are unchanged\n+                            end = pos.sticky == \"before\" ? Pos(pos.line, pos.ch + 1, \"before\") : pos;\n+                            pos = pos.ch ? Pos(pos.line, pos.sticky == \"before\" ? pos.ch - 1 : pos.ch, \"after\") : pos;\n+                        }\n+                        for (var limit = 0; limit < 5; limit++) {\n+                            var changed = false;\n+                            var coords = cursorCoords(cm, pos);\n+                            var endCoords = !end || end == pos ? coords : cursorCoords(cm, end);\n+                            rect = {\n+                                left: Math.min(coords.left, endCoords.left),\n+                                top: Math.min(coords.top, endCoords.top) - margin,\n+                                right: Math.max(coords.left, endCoords.left),\n+                                bottom: Math.max(coords.bottom, endCoords.bottom) + margin\n+                            };\n+                            var scrollPos = calculateScrollPos(cm, rect);\n+                            var startTop = cm.doc.scrollTop,\n+                                startLeft = cm.doc.scrollLeft;\n+                            if (scrollPos.scrollTop != null) {\n+                                updateScrollTop(cm, scrollPos.scrollTop);\n+                                if (Math.abs(cm.doc.scrollTop - startTop) > 1) {\n+                                    changed = true;\n+                                }\n+                            }\n+                            if (scrollPos.scrollLeft != null) {\n+                                setScrollLeft(cm, scrollPos.scrollLeft);\n+                                if (Math.abs(cm.doc.scrollLeft - startLeft) > 1) {\n+                                    changed = true;\n+                                }\n+                            }\n+                            if (!changed) {\n+                                break;\n+                            }\n+                        }\n+                        return rect;\n+                    }\n \n-                function startDevicePoint(history) {\n-                    return history[0];\n-                }\n+                    // Scroll a given set of coordinates into view (immediately).\n+                    function scrollIntoView(cm, rect) {\n+                        var scrollPos = calculateScrollPos(cm, rect);\n+                        if (scrollPos.scrollTop != null) {\n+                            updateScrollTop(cm, scrollPos.scrollTop);\n+                        }\n+                        if (scrollPos.scrollLeft != null) {\n+                            setScrollLeft(cm, scrollPos.scrollLeft);\n+                        }\n+                    }\n \n-                function lastDevicePoint(history) {\n-                    return history[history.length - 1];\n-                }\n+                    // Calculate a new scroll position needed to scroll the given\n+                    // rectangle into view. Returns an object with scrollTop and\n+                    // scrollLeft properties. When these are undefined, the\n+                    // vertical/horizontal position does not need to be adjusted.\n+                    function calculateScrollPos(cm, rect) {\n+                        var display = cm.display,\n+                            snapMargin = textHeight(cm.display);\n+                        if (rect.top < 0) {\n+                            rect.top = 0;\n+                        }\n+                        var screentop = cm.curOp && cm.curOp.scrollTop != null ? cm.curOp.scrollTop : display.scroller.scrollTop;\n+                        var screen = displayHeight(cm),\n+                            result = {};\n+                        if (rect.bottom - rect.top > screen) {\n+                            rect.bottom = rect.top + screen;\n+                        }\n+                        var docBottom = cm.doc.height + paddingVert(display);\n+                        var atTop = rect.top < snapMargin,\n+                            atBottom = rect.bottom > docBottom - snapMargin;\n+                        if (rect.top < screentop) {\n+                            result.scrollTop = atTop ? 0 : rect.top;\n+                        } else if (rect.bottom > screentop + screen) {\n+                            var newTop = Math.min(rect.top, (atBottom ? docBottom : rect.bottom) - screen);\n+                            if (newTop != screentop) {\n+                                result.scrollTop = newTop;\n+                            }\n+                        }\n+                        var gutterSpace = cm.options.fixedGutter ? 0 : display.gutters.offsetWidth;\n+                        var screenleft = cm.curOp && cm.curOp.scrollLeft != null ? cm.curOp.scrollLeft : display.scroller.scrollLeft - gutterSpace;\n+                        var screenw = displayWidth(cm) - display.gutters.offsetWidth;\n+                        var tooWide = rect.right - rect.left > screenw;\n+                        if (tooWide) {\n+                            rect.right = rect.left + screenw;\n+                        }\n+                        if (rect.left < 10) {\n+                            result.scrollLeft = 0;\n+                        } else if (rect.left < screenleft) {\n+                            result.scrollLeft = Math.max(0, rect.left + gutterSpace - (tooWide ? 0 : 10));\n+                        } else if (rect.right > screenw + screenleft - 3) {\n+                            result.scrollLeft = rect.right + (tooWide ? 0 : 10) - screenw;\n+                        }\n+                        return result;\n+                    }\n \n-                function getVelocity(history, timeDelta) {\n-                    if (history.length < 2) {\n-                        return {\n-                            x: 0,\n-                            y: 0\n+                    // Store a relative adjustment to the scroll position in the current\n+                    // operation (to be applied when the operation finishes).\n+                    function addToScrollTop(cm, top) {\n+                        if (top == null) {\n+                            return;\n+                        }\n+                        resolveScrollToPos(cm);\n+                        cm.curOp.scrollTop = (cm.curOp.scrollTop == null ? cm.doc.scrollTop : cm.curOp.scrollTop) + top;\n+                    }\n+\n+                    // Make sure that at the end of the operation the current cursor is\n+                    // shown.\n+                    function ensureCursorVisible(cm) {\n+                        resolveScrollToPos(cm);\n+                        var cur = cm.getCursor();\n+                        cm.curOp.scrollToPos = {\n+                            from: cur,\n+                            to: cur,\n+                            margin: cm.options.cursorScrollMargin\n                         };\n                     }\n-                    var i = history.length - 1;\n-                    var timestampedPoint = null;\n-                    var lastPoint = lastDevicePoint(history);\n-                    while (i >= 0) {\n-                        timestampedPoint = history[i];\n-                        if (lastPoint.timestamp - timestampedPoint.timestamp > secondsToMilliseconds(timeDelta)) {\n-                            break;\n+\n+                    function scrollToCoords(cm, x, y) {\n+                        if (x != null || y != null) {\n+                            resolveScrollToPos(cm);\n+                        }\n+                        if (x != null) {\n+                            cm.curOp.scrollLeft = x;\n+                        }\n+                        if (y != null) {\n+                            cm.curOp.scrollTop = y;\n                         }\n-                        i--;\n                     }\n-                    if (!timestampedPoint) {\n+\n+                    function scrollToRange(cm, range) {\n+                        resolveScrollToPos(cm);\n+                        cm.curOp.scrollToPos = range;\n+                    }\n+\n+                    // When an operation has its scrollToPos property set, and another\n+                    // scroll action is applied before the end of the operation, this\n+                    // 'simulates' scrolling that position into view in a cheap way, so\n+                    // that the effect of intermediate scroll commands is not ignored.\n+                    function resolveScrollToPos(cm) {\n+                        var range = cm.curOp.scrollToPos;\n+                        if (range) {\n+                            cm.curOp.scrollToPos = null;\n+                            var from = estimateCoords(cm, range.from),\n+                                to = estimateCoords(cm, range.to);\n+                            scrollToCoordsRange(cm, from, to, range.margin);\n+                        }\n+                    }\n+\n+                    function scrollToCoordsRange(cm, from, to, margin) {\n+                        var sPos = calculateScrollPos(cm, {\n+                            left: Math.min(from.left, to.left),\n+                            top: Math.min(from.top, to.top) - margin,\n+                            right: Math.max(from.right, to.right),\n+                            bottom: Math.max(from.bottom, to.bottom) + margin\n+                        });\n+                        scrollToCoords(cm, sPos.scrollLeft, sPos.scrollTop);\n+                    }\n+\n+                    // Sync the scrollable area and scrollbars, ensure the viewport\n+                    // covers the visible area.\n+                    function updateScrollTop(cm, val) {\n+                        if (Math.abs(cm.doc.scrollTop - val) < 2) {\n+                            return;\n+                        }\n+                        if (!gecko) {\n+                            updateDisplaySimple(cm, {\n+                                top: val\n+                            });\n+                        }\n+                        setScrollTop(cm, val, true);\n+                        if (gecko) {\n+                            updateDisplaySimple(cm);\n+                        }\n+                        startWorker(cm, 100);\n+                    }\n+\n+                    function setScrollTop(cm, val, forceScroll) {\n+                        val = Math.max(0, Math.min(cm.display.scroller.scrollHeight - cm.display.scroller.clientHeight, val));\n+                        if (cm.display.scroller.scrollTop == val && !forceScroll) {\n+                            return;\n+                        }\n+                        cm.doc.scrollTop = val;\n+                        cm.display.scrollbars.setScrollTop(val);\n+                        if (cm.display.scroller.scrollTop != val) {\n+                            cm.display.scroller.scrollTop = val;\n+                        }\n+                    }\n+\n+                    // Sync scroller and scrollbar, ensure the gutter elements are\n+                    // aligned.\n+                    function setScrollLeft(cm, val, isScroller, forceScroll) {\n+                        val = Math.max(0, Math.min(val, cm.display.scroller.scrollWidth - cm.display.scroller.clientWidth));\n+                        if ((isScroller ? val == cm.doc.scrollLeft : Math.abs(cm.doc.scrollLeft - val) < 2) && !forceScroll) {\n+                            return;\n+                        }\n+                        cm.doc.scrollLeft = val;\n+                        alignHorizontally(cm);\n+                        if (cm.display.scroller.scrollLeft != val) {\n+                            cm.display.scroller.scrollLeft = val;\n+                        }\n+                        cm.display.scrollbars.setScrollLeft(val);\n+                    }\n+\n+                    // SCROLLBARS\n+\n+                    // Prepare DOM reads needed to update the scrollbars. Done in one\n+                    // shot to minimize update/measure roundtrips.\n+                    function measureForScrollbars(cm) {\n+                        var d = cm.display,\n+                            gutterW = d.gutters.offsetWidth;\n+                        var docH = Math.round(cm.doc.height + paddingVert(cm.display));\n                         return {\n-                            x: 0,\n-                            y: 0\n+                            clientHeight: d.scroller.clientHeight,\n+                            viewHeight: d.wrapper.clientHeight,\n+                            scrollWidth: d.scroller.scrollWidth,\n+                            clientWidth: d.scroller.clientWidth,\n+                            viewWidth: d.wrapper.clientWidth,\n+                            barLeft: cm.options.fixedGutter ? gutterW : 0,\n+                            docHeight: docH,\n+                            scrollHeight: docH + scrollGap(cm) + d.barHeight,\n+                            nativeBarWidth: d.nativeBarWidth,\n+                            gutterWidth: gutterW\n+                        };\n+                    }\n+                    var NativeScrollbars = function(place, scroll, cm) {\n+                        this.cm = cm;\n+                        var vert = this.vert = elt(\"div\", [elt(\"div\", null, null, \"min-width: 1px\")], \"CodeMirror-vscrollbar\");\n+                        var horiz = this.horiz = elt(\"div\", [elt(\"div\", null, null, \"height: 100%; min-height: 1px\")], \"CodeMirror-hscrollbar\");\n+                        vert.tabIndex = horiz.tabIndex = -1;\n+                        place(vert);\n+                        place(horiz);\n+                        on(vert, \"scroll\", function() {\n+                            if (vert.clientHeight) {\n+                                scroll(vert.scrollTop, \"vertical\");\n+                            }\n+                        });\n+                        on(horiz, \"scroll\", function() {\n+                            if (horiz.clientWidth) {\n+                                scroll(horiz.scrollLeft, \"horizontal\");\n+                            }\n+                        });\n+                        this.checkedZeroWidth = false;\n+                        // Need to set a minimum width to see the scrollbar on IE7 (but must not set it on IE8).\n+                        if (ie && ie_version < 8) {\n+                            this.horiz.style.minHeight = this.vert.style.minWidth = \"18px\";\n+                        }\n+                    };\n+                    NativeScrollbars.prototype.update = function(measure) {\n+                        var needsH = measure.scrollWidth > measure.clientWidth + 1;\n+                        var needsV = measure.scrollHeight > measure.clientHeight + 1;\n+                        var sWidth = measure.nativeBarWidth;\n+                        if (needsV) {\n+                            this.vert.style.display = \"block\";\n+                            this.vert.style.bottom = needsH ? sWidth + \"px\" : \"0\";\n+                            var totalHeight = measure.viewHeight - (needsH ? sWidth : 0);\n+                            // A bug in IE8 can cause this value to be negative, so guard it.\n+                            this.vert.firstChild.style.height = Math.max(0, measure.scrollHeight - measure.clientHeight + totalHeight) + \"px\";\n+                        } else {\n+                            this.vert.scrollTop = 0;\n+                            this.vert.style.display = \"\";\n+                            this.vert.firstChild.style.height = \"0\";\n+                        }\n+                        if (needsH) {\n+                            this.horiz.style.display = \"block\";\n+                            this.horiz.style.right = needsV ? sWidth + \"px\" : \"0\";\n+                            this.horiz.style.left = measure.barLeft + \"px\";\n+                            var totalWidth = measure.viewWidth - measure.barLeft - (needsV ? sWidth : 0);\n+                            this.horiz.firstChild.style.width = Math.max(0, measure.scrollWidth - measure.clientWidth + totalWidth) + \"px\";\n+                        } else {\n+                            this.horiz.style.display = \"\";\n+                            this.horiz.firstChild.style.width = \"0\";\n+                        }\n+                        if (!this.checkedZeroWidth && measure.clientHeight > 0) {\n+                            if (sWidth == 0) {\n+                                this.zeroWidthHack();\n+                            }\n+                            this.checkedZeroWidth = true;\n+                        }\n+                        return {\n+                            right: needsV ? sWidth : 0,\n+                            bottom: needsH ? sWidth : 0\n                         };\n-                    }\n-                    var time = (lastPoint.timestamp - timestampedPoint.timestamp) / 1000;\n-                    if (time === 0) {\n+                    };\n+                    NativeScrollbars.prototype.setScrollLeft = function(pos) {\n+                        if (this.horiz.scrollLeft != pos) {\n+                            this.horiz.scrollLeft = pos;\n+                        }\n+                        if (this.disableHoriz) {\n+                            this.enableZeroWidthBar(this.horiz, this.disableHoriz, \"horiz\");\n+                        }\n+                    };\n+                    NativeScrollbars.prototype.setScrollTop = function(pos) {\n+                        if (this.vert.scrollTop != pos) {\n+                            this.vert.scrollTop = pos;\n+                        }\n+                        if (this.disableVert) {\n+                            this.enableZeroWidthBar(this.vert, this.disableVert, \"vert\");\n+                        }\n+                    };\n+                    NativeScrollbars.prototype.zeroWidthHack = function() {\n+                        var w = mac && !mac_geMountainLion ? \"12px\" : \"18px\";\n+                        this.horiz.style.height = this.vert.style.width = w;\n+                        this.horiz.style.pointerEvents = this.vert.style.pointerEvents = \"none\";\n+                        this.disableHoriz = new Delayed();\n+                        this.disableVert = new Delayed();\n+                    };\n+                    NativeScrollbars.prototype.enableZeroWidthBar = function(bar, delay, type) {\n+                        bar.style.pointerEvents = \"auto\";\n+\n+                        function maybeDisable() {\n+                            // To find out whether the scrollbar is still visible, we\n+                            // check whether the element under the pixel in the bottom\n+                            // right corner of the scrollbar box is the scrollbar box\n+                            // itself (when the bar is still visible) or its filler child\n+                            // (when the bar is hidden). If it is still visible, we keep\n+                            // it enabled, if it's hidden, we disable pointer events.\n+                            var box = bar.getBoundingClientRect();\n+                            var elt = type == \"vert\" ? document.elementFromPoint(box.right - 1, (box.top + box.bottom) / 2) : document.elementFromPoint((box.right + box.left) / 2, box.bottom - 1);\n+                            if (elt != bar) {\n+                                bar.style.pointerEvents = \"none\";\n+                            } else {\n+                                delay.set(1000, maybeDisable);\n+                            }\n+                        }\n+                        delay.set(1000, maybeDisable);\n+                    };\n+                    NativeScrollbars.prototype.clear = function() {\n+                        var parent = this.horiz.parentNode;\n+                        parent.removeChild(this.horiz);\n+                        parent.removeChild(this.vert);\n+                    };\n+                    var NullScrollbars = function() {};\n+                    NullScrollbars.prototype.update = function() {\n                         return {\n-                            x: 0,\n-                            y: 0\n+                            bottom: 0,\n+                            right: 0\n                         };\n-                    }\n-                    var currentVelocity = {\n-                        x: (lastPoint.x - timestampedPoint.x) / time,\n-                        y: (lastPoint.y - timestampedPoint.y) / time\n                     };\n-                    if (currentVelocity.x === Infinity) {\n-                        currentVelocity.x = 0;\n+                    NullScrollbars.prototype.setScrollLeft = function() {};\n+                    NullScrollbars.prototype.setScrollTop = function() {};\n+                    NullScrollbars.prototype.clear = function() {};\n+\n+                    function updateScrollbars(cm, measure) {\n+                        if (!measure) {\n+                            measure = measureForScrollbars(cm);\n+                        }\n+                        var startWidth = cm.display.barWidth,\n+                            startHeight = cm.display.barHeight;\n+                        updateScrollbarsInner(cm, measure);\n+                        for (var i = 0; i < 4 && startWidth != cm.display.barWidth || startHeight != cm.display.barHeight; i++) {\n+                            if (startWidth != cm.display.barWidth && cm.options.lineWrapping) {\n+                                updateHeightsInViewport(cm);\n+                            }\n+                            updateScrollbarsInner(cm, measureForScrollbars(cm));\n+                            startWidth = cm.display.barWidth;\n+                            startHeight = cm.display.barHeight;\n+                        }\n                     }\n-                    if (currentVelocity.y === Infinity) {\n-                        currentVelocity.y = 0;\n+\n+                    // Re-synchronize the fake scrollbars with the actual size of the\n+                    // content.\n+                    function updateScrollbarsInner(cm, measure) {\n+                        var d = cm.display;\n+                        var sizes = d.scrollbars.update(measure);\n+                        d.sizer.style.paddingRight = (d.barWidth = sizes.right) + \"px\";\n+                        d.sizer.style.paddingBottom = (d.barHeight = sizes.bottom) + \"px\";\n+                        d.heightForcer.style.borderBottom = sizes.bottom + \"px solid transparent\";\n+                        if (sizes.right && sizes.bottom) {\n+                            d.scrollbarFiller.style.display = \"block\";\n+                            d.scrollbarFiller.style.height = sizes.bottom + \"px\";\n+                            d.scrollbarFiller.style.width = sizes.right + \"px\";\n+                        } else {\n+                            d.scrollbarFiller.style.display = \"\";\n+                        }\n+                        if (sizes.bottom && cm.options.coverGutterNextToScrollbar && cm.options.fixedGutter) {\n+                            d.gutterFiller.style.display = \"block\";\n+                            d.gutterFiller.style.height = sizes.bottom + \"px\";\n+                            d.gutterFiller.style.width = measure.gutterWidth + \"px\";\n+                        } else {\n+                            d.gutterFiller.style.display = \"\";\n+                        }\n                     }\n-                    return currentVelocity;\n-                }\n+                    var scrollbarModel = {\n+                        \"native\": NativeScrollbars,\n+                        \"null\": NullScrollbars\n+                    };\n \n-                function calcLength(axis) {\n-                    return axis.max - axis.min;\n-                }\n+                    function initScrollbars(cm) {\n+                        if (cm.display.scrollbars) {\n+                            cm.display.scrollbars.clear();\n+                            if (cm.display.scrollbars.addClass) {\n+                                rmClass(cm.display.wrapper, cm.display.scrollbars.addClass);\n+                            }\n+                        }\n+                        cm.display.scrollbars = new scrollbarModel[cm.options.scrollbarStyle](function(node) {\n+                            cm.display.wrapper.insertBefore(node, cm.display.scrollbarFiller);\n+                            // Prevent clicks in the scrollbars from killing focus\n+                            on(node, \"mousedown\", function() {\n+                                if (cm.state.focused) {\n+                                    setTimeout(function() {\n+                                        return cm.display.input.focus();\n+                                    }, 0);\n+                                }\n+                            });\n+                            node.setAttribute(\"cm-not-content\", \"true\");\n+                        }, function(pos, axis) {\n+                            if (axis == \"horizontal\") {\n+                                setScrollLeft(cm, pos);\n+                            } else {\n+                                updateScrollTop(cm, pos);\n+                            }\n+                        }, cm);\n+                        if (cm.display.scrollbars.addClass) {\n+                            addClass(cm.display.wrapper, cm.display.scrollbars.addClass);\n+                        }\n+                    }\n+\n+                    // Operations are used to wrap a series of changes to the editor\n+                    // state in such a way that each change won't have to update the\n+                    // cursor and display (which would be awkward, slow, and\n+                    // error-prone). Instead, display updates are batched and then all\n+                    // combined and executed at once.\n+\n+                    var nextOpId = 0;\n+                    // Start a new operation.\n+                    function startOperation(cm) {\n+                        cm.curOp = {\n+                            cm: cm,\n+                            viewChanged: false,\n+                            // Flag that indicates that lines might need to be redrawn\n+                            startHeight: cm.doc.height,\n+                            // Used to detect need to update scrollbar\n+                            forceUpdate: false,\n+                            // Used to force a redraw\n+                            updateInput: 0,\n+                            // Whether to reset the input textarea\n+                            typing: false,\n+                            // Whether this reset should be careful to leave existing text (for compositing)\n+                            changeObjs: null,\n+                            // Accumulated changes, for firing change events\n+                            cursorActivityHandlers: null,\n+                            // Set of handlers to fire cursorActivity on\n+                            cursorActivityCalled: 0,\n+                            // Tracks which cursorActivity handlers have been called already\n+                            selectionChanged: false,\n+                            // Whether the selection needs to be redrawn\n+                            updateMaxLine: false,\n+                            // Set when the widest line needs to be determined anew\n+                            scrollLeft: null,\n+                            scrollTop: null,\n+                            // Intermediate scroll position, not pushed to DOM yet\n+                            scrollToPos: null,\n+                            // Used to scroll to a specific position\n+                            focus: false,\n+                            id: ++nextOpId,\n+                            // Unique ID\n+                            markArrays: null // Used by addMarkedSpan\n+                        };\n+                        pushOperation(cm.curOp);\n+                    }\n+\n+                    // Finish an operation, updating the display and signalling delayed events\n+                    function endOperation(cm) {\n+                        var op = cm.curOp;\n+                        if (op) {\n+                            finishOperation(op, function(group) {\n+                                for (var i = 0; i < group.ops.length; i++) {\n+                                    group.ops[i].cm.curOp = null;\n+                                }\n+                                endOperations(group);\n+                            });\n+                        }\n+                    }\n+\n+                    // The DOM updates done when an operation finishes are batched so\n+                    // that the minimum number of relayouts are required.\n+                    function endOperations(group) {\n+                        var ops = group.ops;\n+                        for (var i = 0; i < ops.length; i++)\n+                        // Read DOM\n+                        {\n+                            endOperation_R1(ops[i]);\n+                        }\n+                        for (var i$1 = 0; i$1 < ops.length; i$1++)\n+                        // Write DOM (maybe)\n+                        {\n+                            endOperation_W1(ops[i$1]);\n+                        }\n+                        for (var i$2 = 0; i$2 < ops.length; i$2++)\n+                        // Read DOM\n+                        {\n+                            endOperation_R2(ops[i$2]);\n+                        }\n+                        for (var i$3 = 0; i$3 < ops.length; i$3++)\n+                        // Write DOM (maybe)\n+                        {\n+                            endOperation_W2(ops[i$3]);\n+                        }\n+                        for (var i$4 = 0; i$4 < ops.length; i$4++)\n+                        // Read DOM\n+                        {\n+                            endOperation_finish(ops[i$4]);\n+                        }\n+                    }\n \n-                function isNear(value, target, maxDistance) {\n-                    if (target === void 0) {\n-                        target = 0;\n+                    function endOperation_R1(op) {\n+                        var cm = op.cm,\n+                            display = cm.display;\n+                        maybeClipScrollbars(cm);\n+                        if (op.updateMaxLine) {\n+                            findMaxLine(cm);\n+                        }\n+                        op.mustUpdate = op.viewChanged || op.forceUpdate || op.scrollTop != null || op.scrollToPos && (op.scrollToPos.from.line < display.viewFrom || op.scrollToPos.to.line >= display.viewTo) || display.maxLineChanged && cm.options.lineWrapping;\n+                        op.update = op.mustUpdate && new DisplayUpdate(cm, op.mustUpdate && {\n+                            top: op.scrollTop,\n+                            ensure: op.scrollToPos\n+                        }, op.forceUpdate);\n                     }\n-                    if (maxDistance === void 0) {\n-                        maxDistance = 0.01;\n+\n+                    function endOperation_W1(op) {\n+                        op.updatedDisplay = op.mustUpdate && updateDisplayIfNeeded(op.cm, op.update);\n                     }\n-                    return popmotion.distance(value, target) < maxDistance;\n-                }\n \n-                function calcAxisDelta(delta, source, target, origin) {\n-                    if (origin === void 0) {\n-                        origin = 0.5;\n+                    function endOperation_R2(op) {\n+                        var cm = op.cm,\n+                            display = cm.display;\n+                        if (op.updatedDisplay) {\n+                            updateHeightsInViewport(cm);\n+                        }\n+                        op.barMeasure = measureForScrollbars(cm);\n+\n+                        // If the max line changed since it was last measured, measure it,\n+                        // and ensure the document's width matches it.\n+                        // updateDisplay_W2 will use these properties to do the actual resizing\n+                        if (display.maxLineChanged && !cm.options.lineWrapping) {\n+                            op.adjustWidthTo = measureChar(cm, display.maxLine, display.maxLine.text.length).left + 3;\n+                            cm.display.sizerWidth = op.adjustWidthTo;\n+                            op.barMeasure.scrollWidth = Math.max(display.scroller.clientWidth, display.sizer.offsetLeft + op.adjustWidthTo + scrollGap(cm) + cm.display.barWidth);\n+                            op.maxScrollLeft = Math.max(0, display.sizer.offsetLeft + op.adjustWidthTo - displayWidth(cm));\n+                        }\n+                        if (op.updatedDisplay || op.selectionChanged) {\n+                            op.preparedSelection = display.input.prepareSelection();\n+                        }\n                     }\n-                    delta.origin = origin;\n-                    delta.originPoint = popmotion.mix(source.min, source.max, delta.origin);\n-                    delta.scale = calcLength(target) / calcLength(source);\n-                    if (isNear(delta.scale, 1, 0.0001) || isNaN(delta.scale)) delta.scale = 1;\n-                    delta.translate = popmotion.mix(target.min, target.max, delta.origin) - delta.originPoint;\n-                    if (isNear(delta.translate) || isNaN(delta.translate)) delta.translate = 0;\n-                }\n \n-                function calcBoxDelta(delta, source, target, origin) {\n-                    calcAxisDelta(delta.x, source.x, target.x, origin === null || origin === void 0 ? void 0 : origin.originX);\n-                    calcAxisDelta(delta.y, source.y, target.y, origin === null || origin === void 0 ? void 0 : origin.originY);\n-                }\n+                    function endOperation_W2(op) {\n+                        var cm = op.cm;\n+                        if (op.adjustWidthTo != null) {\n+                            cm.display.sizer.style.minWidth = op.adjustWidthTo + \"px\";\n+                            if (op.maxScrollLeft < cm.doc.scrollLeft) {\n+                                setScrollLeft(cm, Math.min(cm.display.scroller.scrollLeft, op.maxScrollLeft), true);\n+                            }\n+                            cm.display.maxLineChanged = false;\n+                        }\n+                        var takeFocus = op.focus && op.focus == activeElt();\n+                        if (op.preparedSelection) {\n+                            cm.display.input.showSelection(op.preparedSelection, takeFocus);\n+                        }\n+                        if (op.updatedDisplay || op.startHeight != cm.doc.height) {\n+                            updateScrollbars(cm, op.barMeasure);\n+                        }\n+                        if (op.updatedDisplay) {\n+                            setDocumentHeight(cm, op.barMeasure);\n+                        }\n+                        if (op.selectionChanged) {\n+                            restartBlink(cm);\n+                        }\n+                        if (cm.state.focused && op.updateInput) {\n+                            cm.display.input.reset(op.typing);\n+                        }\n+                        if (takeFocus) {\n+                            ensureFocus(op.cm);\n+                        }\n+                    }\n \n-                function calcRelativeAxis(target, relative, parent) {\n-                    target.min = parent.min + relative.min;\n-                    target.max = target.min + calcLength(relative);\n-                }\n+                    function endOperation_finish(op) {\n+                        var cm = op.cm,\n+                            display = cm.display,\n+                            doc = cm.doc;\n+                        if (op.updatedDisplay) {\n+                            postUpdateDisplay(cm, op.update);\n+                        }\n \n-                function calcRelativeBox(target, relative, parent) {\n-                    calcRelativeAxis(target.x, relative.x, parent.x);\n-                    calcRelativeAxis(target.y, relative.y, parent.y);\n-                }\n+                        // Abort mouse wheel delta measurement, when scrolling explicitly\n+                        if (display.wheelStartX != null && (op.scrollTop != null || op.scrollLeft != null || op.scrollToPos)) {\n+                            display.wheelStartX = display.wheelStartY = null;\n+                        }\n \n-                function calcRelativeAxisPosition(target, layout, parent) {\n-                    target.min = layout.min - parent.min;\n-                    target.max = target.min + calcLength(layout);\n-                }\n+                        // Propagate the scroll position to the actual DOM scroller\n+                        if (op.scrollTop != null) {\n+                            setScrollTop(cm, op.scrollTop, op.forceScroll);\n+                        }\n+                        if (op.scrollLeft != null) {\n+                            setScrollLeft(cm, op.scrollLeft, true, true);\n+                        }\n+                        // If we need to scroll a specific position into view, do so.\n+                        if (op.scrollToPos) {\n+                            var rect = scrollPosIntoView(cm, clipPos(doc, op.scrollToPos.from), clipPos(doc, op.scrollToPos.to), op.scrollToPos.margin);\n+                            maybeScrollWindow(cm, rect);\n+                        }\n \n-                function calcRelativePosition(target, layout, parent) {\n-                    calcRelativeAxisPosition(target.x, layout.x, parent.x);\n-                    calcRelativeAxisPosition(target.y, layout.y, parent.y);\n-                }\n+                        // Fire events for markers that are hidden/unidden by editing or\n+                        // undoing\n+                        var hidden = op.maybeHiddenMarkers,\n+                            unhidden = op.maybeUnhiddenMarkers;\n+                        if (hidden) {\n+                            for (var i = 0; i < hidden.length; ++i) {\n+                                if (!hidden[i].lines.length) {\n+                                    signal(hidden[i], \"hide\");\n+                                }\n+                            }\n+                        }\n+                        if (unhidden) {\n+                            for (var i$1 = 0; i$1 < unhidden.length; ++i$1) {\n+                                if (unhidden[i$1].lines.length) {\n+                                    signal(unhidden[i$1], \"unhide\");\n+                                }\n+                            }\n+                        }\n+                        if (display.wrapper.offsetHeight) {\n+                            doc.scrollTop = cm.display.scroller.scrollTop;\n+                        }\n \n-                /**\n-                 * Apply constraints to a point. These constraints are both physical along an\n-                 * axis, and an elastic factor that determines how much to constrain the point\n-                 * by if it does lie outside the defined parameters.\n-                 */\n-                function applyConstraints(point, _a, elastic) {\n-                    var min = _a.min,\n-                        max = _a.max;\n-                    if (min !== undefined && point < min) {\n-                        // If we have a min point defined, and this is outside of that, constrain\n-                        point = elastic ? popmotion.mix(min, point, elastic.min) : Math.max(point, min);\n-                    } else if (max !== undefined && point > max) {\n-                        // If we have a max point defined, and this is outside of that, constrain\n-                        point = elastic ? popmotion.mix(max, point, elastic.max) : Math.min(point, max);\n+                        // Fire change events, and delayed event handlers\n+                        if (op.changeObjs) {\n+                            signal(cm, \"changes\", cm, op.changeObjs);\n+                        }\n+                        if (op.update) {\n+                            op.update.finish();\n+                        }\n                     }\n-                    return point;\n-                }\n-                /**\n-                 * Calculate constraints in terms of the viewport when defined relatively to the\n-                 * measured axis. This is measured from the nearest edge, so a max constraint of 200\n-                 * on an axis with a max value of 300 would return a constraint of 500 - axis length\n-                 */\n-                function calcRelativeAxisConstraints(axis, min, max) {\n-                    return {\n-                        min: min !== undefined ? axis.min + min : undefined,\n-                        max: max !== undefined ? axis.max + max - (axis.max - axis.min) : undefined\n-                    };\n-                }\n-                /**\n-                 * Calculate constraints in terms of the viewport when\n-                 * defined relatively to the measured bounding box.\n-                 */\n-                function calcRelativeConstraints(layoutBox, _a) {\n-                    var top = _a.top,\n-                        left = _a.left,\n-                        bottom = _a.bottom,\n-                        right = _a.right;\n-                    return {\n-                        x: calcRelativeAxisConstraints(layoutBox.x, left, right),\n-                        y: calcRelativeAxisConstraints(layoutBox.y, top, bottom)\n-                    };\n-                }\n-                /**\n-                 * Calculate viewport constraints when defined as another viewport-relative axis\n-                 */\n-                function calcViewportAxisConstraints(layoutAxis, constraintsAxis) {\n-                    var _a;\n-                    var min = constraintsAxis.min - layoutAxis.min;\n-                    var max = constraintsAxis.max - layoutAxis.max;\n-                    // If the constraints axis is actually smaller than the layout axis then we can\n-                    // flip the constraints\n-                    if (constraintsAxis.max - constraintsAxis.min < layoutAxis.max - layoutAxis.min) {\n-                        _a = tslib.__read([max, min], 2), min = _a[0], max = _a[1];\n+\n+                    // Run the given function in an operation\n+                    function runInOp(cm, f) {\n+                        if (cm.curOp) {\n+                            return f();\n+                        }\n+                        startOperation(cm);\n+                        try {\n+                            return f();\n+                        } finally {\n+                            endOperation(cm);\n+                        }\n                     }\n-                    return {\n-                        min: min,\n-                        max: max\n-                    };\n-                }\n-                /**\n-                 * Calculate viewport constraints when defined as another viewport-relative box\n-                 */\n-                function calcViewportConstraints(layoutBox, constraintsBox) {\n-                    return {\n-                        x: calcViewportAxisConstraints(layoutBox.x, constraintsBox.x),\n-                        y: calcViewportAxisConstraints(layoutBox.y, constraintsBox.y)\n-                    };\n-                }\n-                /**\n-                 * Calculate a transform origin relative to the source axis, between 0-1, that results\n-                 * in an asthetically pleasing scale/transform needed to project from source to target.\n-                 */\n-                function calcOrigin(source, target) {\n-                    var origin = 0.5;\n-                    var sourceLength = calcLength(source);\n-                    var targetLength = calcLength(target);\n-                    if (targetLength > sourceLength) {\n-                        origin = popmotion.progress(target.min, target.max - sourceLength, source.min);\n-                    } else if (sourceLength > targetLength) {\n-                        origin = popmotion.progress(source.min, source.max - targetLength, target.min);\n+                    // Wraps a function in an operation. Returns the wrapped function.\n+                    function operation(cm, f) {\n+                        return function() {\n+                            if (cm.curOp) {\n+                                return f.apply(cm, arguments);\n+                            }\n+                            startOperation(cm);\n+                            try {\n+                                return f.apply(cm, arguments);\n+                            } finally {\n+                                endOperation(cm);\n+                            }\n+                        };\n                     }\n-                    return popmotion.clamp(0, 1, origin);\n-                }\n-                /**\n-                 * Rebase the calculated viewport constraints relative to the layout.min point.\n-                 */\n-                function rebaseAxisConstraints(layout, constraints) {\n-                    var relativeConstraints = {};\n-                    if (constraints.min !== undefined) {\n-                        relativeConstraints.min = constraints.min - layout.min;\n+                    // Used to add methods to editor and doc instances, wrapping them in\n+                    // operations.\n+                    function methodOp(f) {\n+                        return function() {\n+                            if (this.curOp) {\n+                                return f.apply(this, arguments);\n+                            }\n+                            startOperation(this);\n+                            try {\n+                                return f.apply(this, arguments);\n+                            } finally {\n+                                endOperation(this);\n+                            }\n+                        };\n                     }\n-                    if (constraints.max !== undefined) {\n-                        relativeConstraints.max = constraints.max - layout.min;\n+\n+                    function docMethodOp(f) {\n+                        return function() {\n+                            var cm = this.cm;\n+                            if (!cm || cm.curOp) {\n+                                return f.apply(this, arguments);\n+                            }\n+                            startOperation(cm);\n+                            try {\n+                                return f.apply(this, arguments);\n+                            } finally {\n+                                endOperation(cm);\n+                            }\n+                        };\n                     }\n-                    return relativeConstraints;\n-                }\n-                var defaultElastic = 0.35;\n-                /**\n-                 * Accepts a dragElastic prop and returns resolved elastic values for each axis.\n-                 */\n-                function resolveDragElastic(dragElastic) {\n-                    if (dragElastic === void 0) {\n-                        dragElastic = defaultElastic;\n+\n+                    // HIGHLIGHT WORKER\n+\n+                    function startWorker(cm, time) {\n+                        if (cm.doc.highlightFrontier < cm.display.viewTo) {\n+                            cm.state.highlight.set(time, bind(highlightWorker, cm));\n+                        }\n                     }\n-                    if (dragElastic === false) {\n-                        dragElastic = 0;\n-                    } else if (dragElastic === true) {\n-                        dragElastic = defaultElastic;\n+\n+                    function highlightWorker(cm) {\n+                        var doc = cm.doc;\n+                        if (doc.highlightFrontier >= cm.display.viewTo) {\n+                            return;\n+                        }\n+                        var end = +new Date() + cm.options.workTime;\n+                        var context = getContextBefore(cm, doc.highlightFrontier);\n+                        var changedLines = [];\n+                        doc.iter(context.line, Math.min(doc.first + doc.size, cm.display.viewTo + 500), function(line) {\n+                            if (context.line >= cm.display.viewFrom) {\n+                                // Visible\n+                                var oldStyles = line.styles;\n+                                var resetState = line.text.length > cm.options.maxHighlightLength ? copyState(doc.mode, context.state) : null;\n+                                var highlighted = highlightLine(cm, line, context, true);\n+                                if (resetState) {\n+                                    context.state = resetState;\n+                                }\n+                                line.styles = highlighted.styles;\n+                                var oldCls = line.styleClasses,\n+                                    newCls = highlighted.classes;\n+                                if (newCls) {\n+                                    line.styleClasses = newCls;\n+                                } else if (oldCls) {\n+                                    line.styleClasses = null;\n+                                }\n+                                var ischange = !oldStyles || oldStyles.length != line.styles.length || oldCls != newCls && (!oldCls || !newCls || oldCls.bgClass != newCls.bgClass || oldCls.textClass != newCls.textClass);\n+                                for (var i = 0; !ischange && i < oldStyles.length; ++i) {\n+                                    ischange = oldStyles[i] != line.styles[i];\n+                                }\n+                                if (ischange) {\n+                                    changedLines.push(context.line);\n+                                }\n+                                line.stateAfter = context.save();\n+                                context.nextLine();\n+                            } else {\n+                                if (line.text.length <= cm.options.maxHighlightLength) {\n+                                    processLine(cm, line.text, context);\n+                                }\n+                                line.stateAfter = context.line % 5 == 0 ? context.save() : null;\n+                                context.nextLine();\n+                            }\n+                            if (+new Date() > end) {\n+                                startWorker(cm, cm.options.workDelay);\n+                                return true;\n+                            }\n+                        });\n+                        doc.highlightFrontier = context.line;\n+                        doc.modeFrontier = Math.max(doc.modeFrontier, context.line);\n+                        if (changedLines.length) {\n+                            runInOp(cm, function() {\n+                                for (var i = 0; i < changedLines.length; i++) {\n+                                    regLineChange(cm, changedLines[i], \"text\");\n+                                }\n+                            });\n+                        }\n                     }\n-                    return {\n-                        x: resolveAxisElastic(dragElastic, \"left\", \"right\"),\n-                        y: resolveAxisElastic(dragElastic, \"top\", \"bottom\")\n-                    };\n-                }\n \n-                function resolveAxisElastic(dragElastic, minLabel, maxLabel) {\n-                    return {\n-                        min: resolvePointElastic(dragElastic, minLabel),\n-                        max: resolvePointElastic(dragElastic, maxLabel)\n-                    };\n-                }\n+                    // DISPLAY DRAWING\n \n-                function resolvePointElastic(dragElastic, label) {\n-                    var _a;\n-                    return typeof dragElastic === \"number\" ? dragElastic : (_a = dragElastic[label]) !== null && _a !== void 0 ? _a : 0;\n-                }\n-                var createAxisDelta = function() {\n-                    return {\n-                        translate: 0,\n-                        scale: 1,\n-                        origin: 0,\n-                        originPoint: 0\n-                    };\n-                };\n-                var createDelta = function() {\n-                    return {\n-                        x: createAxisDelta(),\n-                        y: createAxisDelta()\n+                    var DisplayUpdate = function(cm, viewport, force) {\n+                        var display = cm.display;\n+                        this.viewport = viewport;\n+                        // Store some values that we'll need later (but don't want to force a relayout for)\n+                        this.visible = visibleLines(display, cm.doc, viewport);\n+                        this.editorIsHidden = !display.wrapper.offsetWidth;\n+                        this.wrapperHeight = display.wrapper.clientHeight;\n+                        this.wrapperWidth = display.wrapper.clientWidth;\n+                        this.oldDisplayWidth = displayWidth(cm);\n+                        this.force = force;\n+                        this.dims = getDimensions(cm);\n+                        this.events = [];\n                     };\n-                };\n-                var createAxis = function() {\n-                    return {\n-                        min: 0,\n-                        max: 0\n+                    DisplayUpdate.prototype.signal = function(emitter, type) {\n+                        if (hasHandler(emitter, type)) {\n+                            this.events.push(arguments);\n+                        }\n                     };\n-                };\n-                var createBox = function() {\n-                    return {\n-                        x: createAxis(),\n-                        y: createAxis()\n+                    DisplayUpdate.prototype.finish = function() {\n+                        for (var i = 0; i < this.events.length; i++) {\n+                            signal.apply(null, this.events[i]);\n+                        }\n                     };\n-                };\n \n-                function eachAxis(callback) {\n-                    return [callback(\"x\"), callback(\"y\")];\n-                }\n+                    function maybeClipScrollbars(cm) {\n+                        var display = cm.display;\n+                        if (!display.scrollbarsClipped && display.scroller.offsetWidth) {\n+                            display.nativeBarWidth = display.scroller.offsetWidth - display.scroller.clientWidth;\n+                            display.heightForcer.style.height = scrollGap(cm) + \"px\";\n+                            display.sizer.style.marginBottom = -display.nativeBarWidth + \"px\";\n+                            display.sizer.style.borderRightWidth = scrollGap(cm) + \"px\";\n+                            display.scrollbarsClipped = true;\n+                        }\n+                    }\n \n-                /**\n-                 * Bounding boxes tend to be defined as top, left, right, bottom. For various operations\n-                 * it's easier to consider each axis individually. This function returns a bounding box\n-                 * as a map of single-axis min/max values.\n-                 */\n-                function convertBoundingBoxToBox(_a) {\n-                    var top = _a.top,\n-                        left = _a.left,\n-                        right = _a.right,\n-                        bottom = _a.bottom;\n-                    return {\n-                        x: {\n-                            min: left,\n-                            max: right\n-                        },\n-                        y: {\n-                            min: top,\n-                            max: bottom\n+                    function selectionSnapshot(cm) {\n+                        if (cm.hasFocus()) {\n+                            return null;\n                         }\n-                    };\n-                }\n+                        var active = activeElt();\n+                        if (!active || !contains(cm.display.lineDiv, active)) {\n+                            return null;\n+                        }\n+                        var result = {\n+                            activeElt: active\n+                        };\n+                        if (window.getSelection) {\n+                            var sel = window.getSelection();\n+                            if (sel.anchorNode && sel.extend && contains(cm.display.lineDiv, sel.anchorNode)) {\n+                                result.anchorNode = sel.anchorNode;\n+                                result.anchorOffset = sel.anchorOffset;\n+                                result.focusNode = sel.focusNode;\n+                                result.focusOffset = sel.focusOffset;\n+                            }\n+                        }\n+                        return result;\n+                    }\n \n-                function convertBoxToBoundingBox(_a) {\n-                    var x = _a.x,\n-                        y = _a.y;\n-                    return {\n-                        top: y.min,\n-                        right: x.max,\n-                        bottom: y.max,\n-                        left: x.min\n-                    };\n-                }\n-                /**\n-                 * Applies a TransformPoint function to a bounding box. TransformPoint is usually a function\n-                 * provided by Framer to allow measured points to be corrected for device scaling. This is used\n-                 * when measuring DOM elements and DOM event points.\n-                 */\n-                function transformBoxPoints(point, transformPoint) {\n-                    if (!transformPoint) return point;\n-                    var topLeft = transformPoint({\n-                        x: point.left,\n-                        y: point.top\n-                    });\n-                    var bottomRight = transformPoint({\n-                        x: point.right,\n-                        y: point.bottom\n-                    });\n-                    return {\n-                        top: topLeft.y,\n-                        left: topLeft.x,\n-                        bottom: bottomRight.y,\n-                        right: bottomRight.x\n-                    };\n-                }\n+                    function restoreSelection(snapshot) {\n+                        if (!snapshot || !snapshot.activeElt || snapshot.activeElt == activeElt()) {\n+                            return;\n+                        }\n+                        snapshot.activeElt.focus();\n+                        if (!/^(INPUT|TEXTAREA)$/.test(snapshot.activeElt.nodeName) && snapshot.anchorNode && contains(document.body, snapshot.anchorNode) && contains(document.body, snapshot.focusNode)) {\n+                            var sel = window.getSelection(),\n+                                range = document.createRange();\n+                            range.setEnd(snapshot.anchorNode, snapshot.anchorOffset);\n+                            range.collapse(false);\n+                            sel.removeAllRanges();\n+                            sel.addRange(range);\n+                            sel.extend(snapshot.focusNode, snapshot.focusOffset);\n+                        }\n+                    }\n \n-                function isIdentityScale(scale) {\n-                    return scale === undefined || scale === 1;\n-                }\n+                    // Does the actual updating of the line display. Bails out\n+                    // (returning false) when there is nothing to be done and forced is\n+                    // false.\n+                    function updateDisplayIfNeeded(cm, update) {\n+                        var display = cm.display,\n+                            doc = cm.doc;\n+                        if (update.editorIsHidden) {\n+                            resetView(cm);\n+                            return false;\n+                        }\n \n-                function hasScale(_a) {\n-                    var scale = _a.scale,\n-                        scaleX = _a.scaleX,\n-                        scaleY = _a.scaleY;\n-                    return !isIdentityScale(scale) || !isIdentityScale(scaleX) || !isIdentityScale(scaleY);\n-                }\n+                        // Bail out if the visible area is already rendered and nothing changed.\n+                        if (!update.force && update.visible.from >= display.viewFrom && update.visible.to <= display.viewTo && (display.updateLineNumbers == null || display.updateLineNumbers >= display.viewTo) && display.renderedView == display.view && countDirtyView(cm) == 0) {\n+                            return false;\n+                        }\n+                        if (maybeUpdateLineNumberWidth(cm)) {\n+                            resetView(cm);\n+                            update.dims = getDimensions(cm);\n+                        }\n+\n+                        // Compute a suitable new viewport (from & to)\n+                        var end = doc.first + doc.size;\n+                        var from = Math.max(update.visible.from - cm.options.viewportMargin, doc.first);\n+                        var to = Math.min(end, update.visible.to + cm.options.viewportMargin);\n+                        if (display.viewFrom < from && from - display.viewFrom < 20) {\n+                            from = Math.max(doc.first, display.viewFrom);\n+                        }\n+                        if (display.viewTo > to && display.viewTo - to < 20) {\n+                            to = Math.min(end, display.viewTo);\n+                        }\n+                        if (sawCollapsedSpans) {\n+                            from = visualLineNo(cm.doc, from);\n+                            to = visualLineEndNo(cm.doc, to);\n+                        }\n+                        var different = from != display.viewFrom || to != display.viewTo || display.lastWrapHeight != update.wrapperHeight || display.lastWrapWidth != update.wrapperWidth;\n+                        adjustView(cm, from, to);\n+                        display.viewOffset = heightAtLine(getLine(cm.doc, display.viewFrom));\n+                        // Position the mover div to align with the current scroll position\n+                        cm.display.mover.style.top = display.viewOffset + \"px\";\n+                        var toUpdate = countDirtyView(cm);\n+                        if (!different && toUpdate == 0 && !update.force && display.renderedView == display.view && (display.updateLineNumbers == null || display.updateLineNumbers >= display.viewTo)) {\n+                            return false;\n+                        }\n \n-                function hasTransform(values) {\n-                    return hasScale(values) || hasTranslate(values.x) || hasTranslate(values.y) || values.z || values.rotate || values.rotateX || values.rotateY;\n-                }\n+                        // For big changes, we hide the enclosing element during the\n+                        // update, since that speeds up the operations on most browsers.\n+                        var selSnapshot = selectionSnapshot(cm);\n+                        if (toUpdate > 4) {\n+                            display.lineDiv.style.display = \"none\";\n+                        }\n+                        patchDisplay(cm, display.updateLineNumbers, update.dims);\n+                        if (toUpdate > 4) {\n+                            display.lineDiv.style.display = \"\";\n+                        }\n+                        display.renderedView = display.view;\n+                        // There might have been a widget with a focused element that got\n+                        // hidden or updated, if so re-focus it.\n+                        restoreSelection(selSnapshot);\n+\n+                        // Prevent selection and cursors from interfering with the scroll\n+                        // width and height.\n+                        removeChildren(display.cursorDiv);\n+                        removeChildren(display.selectionDiv);\n+                        display.gutters.style.height = display.sizer.style.minHeight = 0;\n+                        if (different) {\n+                            display.lastWrapHeight = update.wrapperHeight;\n+                            display.lastWrapWidth = update.wrapperWidth;\n+                            startWorker(cm, 400);\n+                        }\n+                        display.updateLineNumbers = null;\n+                        return true;\n+                    }\n \n-                function hasTranslate(value) {\n-                    return value && value !== \"0%\";\n-                }\n+                    function postUpdateDisplay(cm, update) {\n+                        var viewport = update.viewport;\n+                        for (var first = true;; first = false) {\n+                            if (!first || !cm.options.lineWrapping || update.oldDisplayWidth == displayWidth(cm)) {\n+                                // Clip forced viewport to actual scrollable area.\n+                                if (viewport && viewport.top != null) {\n+                                    viewport = {\n+                                        top: Math.min(cm.doc.height + paddingVert(cm.display) - displayHeight(cm), viewport.top)\n+                                    };\n+                                }\n+                                // Updated line heights might result in the drawn area not\n+                                // actually covering the viewport. Keep looping until it does.\n+                                update.visible = visibleLines(cm.display, cm.doc, viewport);\n+                                if (update.visible.from >= cm.display.viewFrom && update.visible.to <= cm.display.viewTo) {\n+                                    break;\n+                                }\n+                            } else if (first) {\n+                                update.visible = visibleLines(cm.display, cm.doc, viewport);\n+                            }\n+                            if (!updateDisplayIfNeeded(cm, update)) {\n+                                break;\n+                            }\n+                            updateHeightsInViewport(cm);\n+                            var barMeasure = measureForScrollbars(cm);\n+                            updateSelection(cm);\n+                            updateScrollbars(cm, barMeasure);\n+                            setDocumentHeight(cm, barMeasure);\n+                            update.force = false;\n+                        }\n+                        update.signal(cm, \"update\", cm);\n+                        if (cm.display.viewFrom != cm.display.reportedViewFrom || cm.display.viewTo != cm.display.reportedViewTo) {\n+                            update.signal(cm, \"viewportChange\", cm, cm.display.viewFrom, cm.display.viewTo);\n+                            cm.display.reportedViewFrom = cm.display.viewFrom;\n+                            cm.display.reportedViewTo = cm.display.viewTo;\n+                        }\n+                    }\n \n-                /**\n-                 * Scales a point based on a factor and an originPoint\n-                 */\n-                function scalePoint(point, scale, originPoint) {\n-                    var distanceFromOrigin = point - originPoint;\n-                    var scaled = scale * distanceFromOrigin;\n-                    return originPoint + scaled;\n-                }\n-                /**\n-                 * Applies a translate/scale delta to a point\n-                 */\n-                function applyPointDelta(point, translate, scale, originPoint, boxScale) {\n-                    if (boxScale !== undefined) {\n-                        point = scalePoint(point, boxScale, originPoint);\n+                    function updateDisplaySimple(cm, viewport) {\n+                        var update = new DisplayUpdate(cm, viewport);\n+                        if (updateDisplayIfNeeded(cm, update)) {\n+                            updateHeightsInViewport(cm);\n+                            postUpdateDisplay(cm, update);\n+                            var barMeasure = measureForScrollbars(cm);\n+                            updateSelection(cm);\n+                            updateScrollbars(cm, barMeasure);\n+                            setDocumentHeight(cm, barMeasure);\n+                            update.finish();\n+                        }\n                     }\n-                    return scalePoint(point, scale, originPoint) + translate;\n-                }\n-                /**\n-                 * Applies a translate/scale delta to an axis\n-                 */\n-                function applyAxisDelta(axis, translate, scale, originPoint, boxScale) {\n-                    if (translate === void 0) {\n-                        translate = 0;\n+\n+                    // Sync the actual display DOM structure with display.view, removing\n+                    // nodes for lines that are no longer in view, and creating the ones\n+                    // that are not there yet, and updating the ones that are out of\n+                    // date.\n+                    function patchDisplay(cm, updateNumbersFrom, dims) {\n+                        var display = cm.display,\n+                            lineNumbers = cm.options.lineNumbers;\n+                        var container = display.lineDiv,\n+                            cur = container.firstChild;\n+\n+                        function rm(node) {\n+                            var next = node.nextSibling;\n+                            // Works around a throw-scroll bug in OS X Webkit\n+                            if (webkit && mac && cm.display.currentWheelTarget == node) {\n+                                node.style.display = \"none\";\n+                            } else {\n+                                node.parentNode.removeChild(node);\n+                            }\n+                            return next;\n+                        }\n+                        var view = display.view,\n+                            lineN = display.viewFrom;\n+                        // Loop over the elements in the view, syncing cur (the DOM nodes\n+                        // in display.lineDiv) with the view as we go.\n+                        for (var i = 0; i < view.length; i++) {\n+                            var lineView = view[i];\n+                            if (lineView.hidden);\n+                            else if (!lineView.node || lineView.node.parentNode != container) {\n+                                // Not drawn yet\n+                                var node = buildLineElement(cm, lineView, lineN, dims);\n+                                container.insertBefore(node, cur);\n+                            } else {\n+                                // Already drawn\n+                                while (cur != lineView.node) {\n+                                    cur = rm(cur);\n+                                }\n+                                var updateNumber = lineNumbers && updateNumbersFrom != null && updateNumbersFrom <= lineN && lineView.lineNumber;\n+                                if (lineView.changes) {\n+                                    if (indexOf(lineView.changes, \"gutter\") > -1) {\n+                                        updateNumber = false;\n+                                    }\n+                                    updateLineForChanges(cm, lineView, lineN, dims);\n+                                }\n+                                if (updateNumber) {\n+                                    removeChildren(lineView.lineNumber);\n+                                    lineView.lineNumber.appendChild(document.createTextNode(lineNumberFor(cm.options, lineN)));\n+                                }\n+                                cur = lineView.node.nextSibling;\n+                            }\n+                            lineN += lineView.size;\n+                        }\n+                        while (cur) {\n+                            cur = rm(cur);\n+                        }\n                     }\n-                    if (scale === void 0) {\n-                        scale = 1;\n+\n+                    function updateGutterSpace(display) {\n+                        var width = display.gutters.offsetWidth;\n+                        display.sizer.style.marginLeft = width + \"px\";\n+                        // Send an event to consumers responding to changes in gutter width.\n+                        signalLater(display, \"gutterChanged\", display);\n                     }\n-                    axis.min = applyPointDelta(axis.min, translate, scale, originPoint, boxScale);\n-                    axis.max = applyPointDelta(axis.max, translate, scale, originPoint, boxScale);\n-                }\n-                /**\n-                 * Applies a translate/scale delta to a box\n-                 */\n-                function applyBoxDelta(box, _a) {\n-                    var x = _a.x,\n-                        y = _a.y;\n-                    applyAxisDelta(box.x, x.translate, x.scale, x.originPoint);\n-                    applyAxisDelta(box.y, y.translate, y.scale, y.originPoint);\n-                }\n-                /**\n-                 * Apply a tree of deltas to a box. We do this to calculate the effect of all the transforms\n-                 * in a tree upon our box before then calculating how to project it into our desired viewport-relative box\n-                 *\n-                 * This is the final nested loop within updateLayoutDelta for future refactoring\n-                 */\n-                function applyTreeDeltas(box, treeScale, treePath, isSharedTransition) {\n-                    var _a, _b;\n-                    if (isSharedTransition === void 0) {\n-                        isSharedTransition = false;\n+\n+                    function setDocumentHeight(cm, measure) {\n+                        cm.display.sizer.style.minHeight = measure.docHeight + \"px\";\n+                        cm.display.heightForcer.style.top = measure.docHeight + \"px\";\n+                        cm.display.gutters.style.height = measure.docHeight + cm.display.barHeight + scrollGap(cm) + \"px\";\n                     }\n-                    var treeLength = treePath.length;\n-                    if (!treeLength) return;\n-                    // Reset the treeScale\n-                    treeScale.x = treeScale.y = 1;\n-                    var node;\n-                    var delta;\n-                    for (var i = 0; i < treeLength; i++) {\n-                        node = treePath[i];\n-                        delta = node.projectionDelta;\n-                        if (((_b = (_a = node.instance) === null || _a === void 0 ? void 0 : _a.style) === null || _b === void 0 ? void 0 : _b.display) === \"contents\") continue;\n-                        if (isSharedTransition && node.options.layoutScroll && node.scroll && node !== node.root) {\n-                            transformBox(box, {\n-                                x: -node.scroll.x,\n-                                y: -node.scroll.y\n-                            });\n+\n+                    // Re-align line numbers and gutter marks to compensate for\n+                    // horizontal scrolling.\n+                    function alignHorizontally(cm) {\n+                        var display = cm.display,\n+                            view = display.view;\n+                        if (!display.alignWidgets && (!display.gutters.firstChild || !cm.options.fixedGutter)) {\n+                            return;\n                         }\n-                        if (delta) {\n-                            // Incoporate each ancestor's scale into a culmulative treeScale for this component\n-                            treeScale.x *= delta.x.scale;\n-                            treeScale.y *= delta.y.scale;\n-                            // Apply each ancestor's calculated delta into this component's recorded layout box\n-                            applyBoxDelta(box, delta);\n+                        var comp = compensateForHScroll(display) - display.scroller.scrollLeft + cm.doc.scrollLeft;\n+                        var gutterW = display.gutters.offsetWidth,\n+                            left = comp + \"px\";\n+                        for (var i = 0; i < view.length; i++) {\n+                            if (!view[i].hidden) {\n+                                if (cm.options.fixedGutter) {\n+                                    if (view[i].gutter) {\n+                                        view[i].gutter.style.left = left;\n+                                    }\n+                                    if (view[i].gutterBackground) {\n+                                        view[i].gutterBackground.style.left = left;\n+                                    }\n+                                }\n+                                var align = view[i].alignable;\n+                                if (align) {\n+                                    for (var j = 0; j < align.length; j++) {\n+                                        align[j].style.left = left;\n+                                    }\n+                                }\n+                            }\n                         }\n-                        if (isSharedTransition && hasTransform(node.latestValues)) {\n-                            transformBox(box, node.latestValues);\n+                        if (cm.options.fixedGutter) {\n+                            display.gutters.style.left = comp + gutterW + \"px\";\n                         }\n                     }\n-                }\n-\n-                function translateAxis(axis, distance) {\n-                    axis.min = axis.min + distance;\n-                    axis.max = axis.max + distance;\n-                }\n-                /**\n-                 * Apply a transform to an axis from the latest resolved motion values.\n-                 * This function basically acts as a bridge between a flat motion value map\n-                 * and applyAxisDelta\n-                 */\n-                function transformAxis(axis, transforms, _a) {\n-                    var _b = tslib.__read(_a, 3),\n-                        key = _b[0],\n-                        scaleKey = _b[1],\n-                        originKey = _b[2];\n-                    var axisOrigin = transforms[originKey] !== undefined ? transforms[originKey] : 0.5;\n-                    var originPoint = popmotion.mix(axis.min, axis.max, axisOrigin);\n-                    // Apply the axis delta to the final axis\n-                    applyAxisDelta(axis, transforms[key], transforms[scaleKey], originPoint, transforms.scale);\n-                }\n-                /**\n-                 * The names of the motion values we want to apply as translation, scale and origin.\n-                 */\n-                var xKeys$1 = [\"x\", \"scaleX\", \"originX\"];\n-                var yKeys$1 = [\"y\", \"scaleY\", \"originY\"];\n-                /**\n-                 * Apply a transform to a box from the latest resolved motion values.\n-                 */\n-                function transformBox(box, transform) {\n-                    transformAxis(box.x, transform, xKeys$1);\n-                    transformAxis(box.y, transform, yKeys$1);\n-                }\n \n-                function measureViewportBox(instance, transformPoint) {\n-                    return convertBoundingBoxToBox(transformBoxPoints(instance.getBoundingClientRect(), transformPoint));\n-                }\n+                    // Used to ensure that the line number gutter is still the right\n+                    // size for the current document size. Returns true when an update\n+                    // is needed.\n+                    function maybeUpdateLineNumberWidth(cm) {\n+                        if (!cm.options.lineNumbers) {\n+                            return false;\n+                        }\n+                        var doc = cm.doc,\n+                            last = lineNumberFor(cm.options, doc.first + doc.size - 1),\n+                            display = cm.display;\n+                        if (last.length != display.lineNumChars) {\n+                            var test = display.measure.appendChild(elt(\"div\", [elt(\"div\", last)], \"CodeMirror-linenumber CodeMirror-gutter-elt\"));\n+                            var innerW = test.firstChild.offsetWidth,\n+                                padding = test.offsetWidth - innerW;\n+                            display.lineGutter.style.width = \"\";\n+                            display.lineNumInnerWidth = Math.max(innerW, display.lineGutter.offsetWidth - padding) + 1;\n+                            display.lineNumWidth = display.lineNumInnerWidth + padding;\n+                            display.lineNumChars = display.lineNumInnerWidth ? last.length : -1;\n+                            display.lineGutter.style.width = display.lineNumWidth + \"px\";\n+                            updateGutterSpace(cm.display);\n+                            return true;\n+                        }\n+                        return false;\n+                    }\n \n-                function measurePageBox(element, rootProjectionNode, transformPagePoint) {\n-                    var viewportBox = measureViewportBox(element, transformPagePoint);\n-                    var scroll = rootProjectionNode.scroll;\n-                    if (scroll) {\n-                        translateAxis(viewportBox.x, scroll.x);\n-                        translateAxis(viewportBox.y, scroll.y);\n+                    function getGutters(gutters, lineNumbers) {\n+                        var result = [],\n+                            sawLineNumbers = false;\n+                        for (var i = 0; i < gutters.length; i++) {\n+                            var name = gutters[i],\n+                                style = null;\n+                            if (typeof name != \"string\") {\n+                                style = name.style;\n+                                name = name.className;\n+                            }\n+                            if (name == \"CodeMirror-linenumbers\") {\n+                                if (!lineNumbers) {\n+                                    continue;\n+                                } else {\n+                                    sawLineNumbers = true;\n+                                }\n+                            }\n+                            result.push({\n+                                className: name,\n+                                style: style\n+                            });\n+                        }\n+                        if (lineNumbers && !sawLineNumbers) {\n+                            result.push({\n+                                className: \"CodeMirror-linenumbers\",\n+                                style: null\n+                            });\n+                        }\n+                        return result;\n                     }\n-                    return viewportBox;\n-                }\n-                var elementDragControls = new WeakMap();\n-                /**\n-                 *\n-                 */\n-                // let latestPointerEvent: AnyPointerEvent\n-                var VisualElementDragControls = /** @class */ function() {\n-                    function VisualElementDragControls(visualElement) {\n-                        // This is a reference to the global drag gesture lock, ensuring only one component\n-                        // can \"capture\" the drag of one or both axes.\n-                        // TODO: Look into moving this into pansession?\n-                        this.openGlobalLock = null;\n-                        this.isDragging = false;\n-                        this.currentDirection = null;\n-                        this.originPoint = {\n-                            x: 0,\n-                            y: 0\n+\n+                    // Rebuild the gutter elements, ensure the margin to the left of the\n+                    // code matches their width.\n+                    function renderGutters(display) {\n+                        var gutters = display.gutters,\n+                            specs = display.gutterSpecs;\n+                        removeChildren(gutters);\n+                        display.lineGutter = null;\n+                        for (var i = 0; i < specs.length; ++i) {\n+                            var ref = specs[i];\n+                            var className = ref.className;\n+                            var style = ref.style;\n+                            var gElt = gutters.appendChild(elt(\"div\", null, \"CodeMirror-gutter \" + className));\n+                            if (style) {\n+                                gElt.style.cssText = style;\n+                            }\n+                            if (className == \"CodeMirror-linenumbers\") {\n+                                display.lineGutter = gElt;\n+                                gElt.style.width = (display.lineNumWidth || 1) + \"px\";\n+                            }\n+                        }\n+                        gutters.style.display = specs.length ? \"\" : \"none\";\n+                        updateGutterSpace(display);\n+                    }\n+\n+                    function updateGutters(cm) {\n+                        renderGutters(cm.display);\n+                        regChange(cm);\n+                        alignHorizontally(cm);\n+                    }\n+\n+                    // The display handles the DOM integration, both for input reading\n+                    // and content drawing. It holds references to DOM nodes and\n+                    // display-related state.\n+\n+                    function Display(place, doc, input, options) {\n+                        var d = this;\n+                        this.input = input;\n+\n+                        // Covers bottom-right square when both scrollbars are present.\n+                        d.scrollbarFiller = elt(\"div\", null, \"CodeMirror-scrollbar-filler\");\n+                        d.scrollbarFiller.setAttribute(\"cm-not-content\", \"true\");\n+                        // Covers bottom of gutter when coverGutterNextToScrollbar is on\n+                        // and h scrollbar is present.\n+                        d.gutterFiller = elt(\"div\", null, \"CodeMirror-gutter-filler\");\n+                        d.gutterFiller.setAttribute(\"cm-not-content\", \"true\");\n+                        // Will contain the actual code, positioned to cover the viewport.\n+                        d.lineDiv = eltP(\"div\", null, \"CodeMirror-code\");\n+                        // Elements are added to these to represent selection and cursors.\n+                        d.selectionDiv = elt(\"div\", null, null, \"position: relative; z-index: 1\");\n+                        d.cursorDiv = elt(\"div\", null, \"CodeMirror-cursors\");\n+                        // A visibility: hidden element used to find the size of things.\n+                        d.measure = elt(\"div\", null, \"CodeMirror-measure\");\n+                        // When lines outside of the viewport are measured, they are drawn in this.\n+                        d.lineMeasure = elt(\"div\", null, \"CodeMirror-measure\");\n+                        // Wraps everything that needs to exist inside the vertically-padded coordinate system\n+                        d.lineSpace = eltP(\"div\", [d.measure, d.lineMeasure, d.selectionDiv, d.cursorDiv, d.lineDiv], null, \"position: relative; outline: none\");\n+                        var lines = eltP(\"div\", [d.lineSpace], \"CodeMirror-lines\");\n+                        // Moved around its parent to cover visible view.\n+                        d.mover = elt(\"div\", [lines], null, \"position: relative\");\n+                        // Set to the height of the document, allowing scrolling.\n+                        d.sizer = elt(\"div\", [d.mover], \"CodeMirror-sizer\");\n+                        d.sizerWidth = null;\n+                        // Behavior of elts with overflow: auto and padding is\n+                        // inconsistent across browsers. This is used to ensure the\n+                        // scrollable area is big enough.\n+                        d.heightForcer = elt(\"div\", null, null, \"position: absolute; height: \" + scrollerGap + \"px; width: 1px;\");\n+                        // Will contain the gutters, if any.\n+                        d.gutters = elt(\"div\", null, \"CodeMirror-gutters\");\n+                        d.lineGutter = null;\n+                        // Actual scrollable element.\n+                        d.scroller = elt(\"div\", [d.sizer, d.heightForcer, d.gutters], \"CodeMirror-scroll\");\n+                        d.scroller.setAttribute(\"tabIndex\", \"-1\");\n+                        // The element in which the editor lives.\n+                        d.wrapper = elt(\"div\", [d.scrollbarFiller, d.gutterFiller, d.scroller], \"CodeMirror\");\n+\n+                        // This attribute is respected by automatic translation systems such as Google Translate,\n+                        // and may also be respected by tools used by human translators.\n+                        d.wrapper.setAttribute('translate', 'no');\n+\n+                        // Work around IE7 z-index bug (not perfect, hence IE7 not really being supported)\n+                        if (ie && ie_version < 8) {\n+                            d.gutters.style.zIndex = -1;\n+                            d.scroller.style.paddingRight = 0;\n+                        }\n+                        if (!webkit && !(gecko && mobile)) {\n+                            d.scroller.draggable = true;\n+                        }\n+                        if (place) {\n+                            if (place.appendChild) {\n+                                place.appendChild(d.wrapper);\n+                            } else {\n+                                place(d.wrapper);\n+                            }\n+                        }\n+\n+                        // Current rendered range (may be bigger than the view window).\n+                        d.viewFrom = d.viewTo = doc.first;\n+                        d.reportedViewFrom = d.reportedViewTo = doc.first;\n+                        // Information about the rendered lines.\n+                        d.view = [];\n+                        d.renderedView = null;\n+                        // Holds info about a single rendered line when it was rendered\n+                        // for measurement, while not in view.\n+                        d.externalMeasured = null;\n+                        // Empty space (in pixels) above the view\n+                        d.viewOffset = 0;\n+                        d.lastWrapHeight = d.lastWrapWidth = 0;\n+                        d.updateLineNumbers = null;\n+                        d.nativeBarWidth = d.barHeight = d.barWidth = 0;\n+                        d.scrollbarsClipped = false;\n+\n+                        // Used to only resize the line number gutter when necessary (when\n+                        // the amount of lines crosses a boundary that makes its width change)\n+                        d.lineNumWidth = d.lineNumInnerWidth = d.lineNumChars = null;\n+                        // Set to true when a non-horizontal-scrolling line widget is\n+                        // added. As an optimization, line widget aligning is skipped when\n+                        // this is false.\n+                        d.alignWidgets = false;\n+                        d.cachedCharWidth = d.cachedTextHeight = d.cachedPaddingH = null;\n+\n+                        // Tracks the maximum line length so that the horizontal scrollbar\n+                        // can be kept static when scrolling.\n+                        d.maxLine = null;\n+                        d.maxLineLength = 0;\n+                        d.maxLineChanged = false;\n+\n+                        // Used for measuring wheel scrolling granularity\n+                        d.wheelDX = d.wheelDY = d.wheelStartX = d.wheelStartY = null;\n+\n+                        // True when shift is held down.\n+                        d.shift = false;\n+\n+                        // Used to track whether anything happened since the context menu\n+                        // was opened.\n+                        d.selForContextMenu = null;\n+                        d.activeTouch = null;\n+                        d.gutterSpecs = getGutters(options.gutters, options.lineNumbers);\n+                        renderGutters(d);\n+                        input.init(d);\n+                    }\n+\n+                    // Since the delta values reported on mouse wheel events are\n+                    // unstandardized between browsers and even browser versions, and\n+                    // generally horribly unpredictable, this code starts by measuring\n+                    // the scroll effect that the first few mouse wheel events have,\n+                    // and, from that, detects the way it can convert deltas to pixel\n+                    // offsets afterwards.\n+                    //\n+                    // The reason we want to know the amount a wheel event will scroll\n+                    // is that it gives us a chance to update the display before the\n+                    // actual scrolling happens, reducing flickering.\n+\n+                    var wheelSamples = 0,\n+                        wheelPixelsPerUnit = null;\n+                    // Fill in a browser-detected starting value on browsers where we\n+                    // know one. These don't have to be accurate -- the result of them\n+                    // being wrong would just be a slight flicker on the first wheel\n+                    // scroll (if it is large enough).\n+                    if (ie) {\n+                        wheelPixelsPerUnit = -.53;\n+                    } else if (gecko) {\n+                        wheelPixelsPerUnit = 15;\n+                    } else if (chrome) {\n+                        wheelPixelsPerUnit = -.7;\n+                    } else if (safari) {\n+                        wheelPixelsPerUnit = -1 / 3;\n+                    }\n+\n+                    function wheelEventDelta(e) {\n+                        var dx = e.wheelDeltaX,\n+                            dy = e.wheelDeltaY;\n+                        if (dx == null && e.detail && e.axis == e.HORIZONTAL_AXIS) {\n+                            dx = e.detail;\n+                        }\n+                        if (dy == null && e.detail && e.axis == e.VERTICAL_AXIS) {\n+                            dy = e.detail;\n+                        } else if (dy == null) {\n+                            dy = e.wheelDelta;\n+                        }\n+                        return {\n+                            x: dx,\n+                            y: dy\n                         };\n-                        /**\n-                         * The permitted boundaries of travel, in pixels.\n-                         */\n-                        this.constraints = false;\n-                        this.hasMutatedConstraints = false;\n-                        /**\n-                         * The per-axis resolved elastic values.\n-                         */\n-                        this.elastic = createBox();\n-                        this.visualElement = visualElement;\n                     }\n-                    VisualElementDragControls.prototype.start = function(originEvent, _a) {\n-                        var _this = this;\n-                        var _b = _a === void 0 ? {} : _a,\n-                            _c = _b.snapToCursor,\n-                            snapToCursor = _c === void 0 ? false : _c;\n-                        /**\n-                         * Don't start dragging if this component is exiting\n-                         */\n-                        if (this.visualElement.isPresent === false) return;\n-                        var onSessionStart = function(event) {\n-                            // Stop any animations on both axis values immediately. This allows the user to throw and catch\n-                            // the component.\n-                            _this.stopAnimation();\n-                            if (snapToCursor) {\n-                                _this.snapToCursor(extractEventInfo(event, \"page\").point);\n+\n+                    function wheelEventPixels(e) {\n+                        var delta = wheelEventDelta(e);\n+                        delta.x *= wheelPixelsPerUnit;\n+                        delta.y *= wheelPixelsPerUnit;\n+                        return delta;\n+                    }\n+\n+                    function onScrollWheel(cm, e) {\n+                        var delta = wheelEventDelta(e),\n+                            dx = delta.x,\n+                            dy = delta.y;\n+                        var pixelsPerUnit = wheelPixelsPerUnit;\n+                        if (e.deltaMode === 0) {\n+                            dx = e.deltaX;\n+                            dy = e.deltaY;\n+                            pixelsPerUnit = 1;\n+                        }\n+                        var display = cm.display,\n+                            scroll = display.scroller;\n+                        // Quit if there's nothing to scroll here\n+                        var canScrollX = scroll.scrollWidth > scroll.clientWidth;\n+                        var canScrollY = scroll.scrollHeight > scroll.clientHeight;\n+                        if (!(dx && canScrollX || dy && canScrollY)) {\n+                            return;\n+                        }\n+\n+                        // Webkit browsers on OS X abort momentum scrolls when the target\n+                        // of the scroll event is removed from the scrollable element.\n+                        // This hack (see related code in patchDisplay) makes sure the\n+                        // element is kept around.\n+                        if (dy && mac && webkit) {\n+                            outer: for (var cur = e.target, view = display.view; cur != scroll; cur = cur.parentNode) {\n+                                for (var i = 0; i < view.length; i++) {\n+                                    if (view[i].node == cur) {\n+                                        cm.display.currentWheelTarget = cur;\n+                                        break outer;\n+                                    }\n+                                }\n                             }\n-                        };\n-                        var onStart = function(event, info) {\n-                            var _a;\n-                            // Attempt to grab the global drag gesture lock - maybe make this part of PanSession\n-                            var _b = _this.getProps(),\n-                                drag = _b.drag,\n-                                dragPropagation = _b.dragPropagation,\n-                                onDragStart = _b.onDragStart;\n-                            if (drag && !dragPropagation) {\n-                                if (_this.openGlobalLock) _this.openGlobalLock();\n-                                _this.openGlobalLock = getGlobalLock(drag);\n-                                // If we don 't have the lock, don't start dragging\n-                                if (!_this.openGlobalLock) return;\n+                        }\n+\n+                        // On some browsers, horizontal scrolling will cause redraws to\n+                        // happen before the gutter has been realigned, causing it to\n+                        // wriggle around in a most unseemly way. When we have an\n+                        // estimated pixels/delta value, we just handle horizontal\n+                        // scrolling entirely here. It'll be slightly off from native, but\n+                        // better than glitching out.\n+                        if (dx && !gecko && !presto && pixelsPerUnit != null) {\n+                            if (dy && canScrollY) {\n+                                updateScrollTop(cm, Math.max(0, scroll.scrollTop + dy * pixelsPerUnit));\n+                            }\n+                            setScrollLeft(cm, Math.max(0, scroll.scrollLeft + dx * pixelsPerUnit));\n+                            // Only prevent default scrolling if vertical scrolling is\n+                            // actually possible. Otherwise, it causes vertical scroll\n+                            // jitter on OSX trackpads when deltaX is small and deltaY\n+                            // is large (issue #3579)\n+                            if (!dy || dy && canScrollY) {\n+                                e_preventDefault(e);\n                             }\n-                            _this.isDragging = true;\n-                            _this.currentDirection = null;\n-                            _this.resolveConstraints();\n-                            if (_this.visualElement.projection) {\n-                                _this.visualElement.projection.isAnimationBlocked = true;\n-                                _this.visualElement.projection.target = undefined;\n+                            display.wheelStartX = null; // Abort measurement, if in progress\n+                            return;\n+                        }\n+\n+                        // 'Project' the visible viewport to cover the area that is being\n+                        // scrolled into view (if we know enough to estimate it).\n+                        if (dy && pixelsPerUnit != null) {\n+                            var pixels = dy * pixelsPerUnit;\n+                            var top = cm.doc.scrollTop,\n+                                bot = top + display.wrapper.clientHeight;\n+                            if (pixels < 0) {\n+                                top = Math.max(0, top + pixels - 50);\n+                            } else {\n+                                bot = Math.min(cm.doc.height, bot + pixels + 50);\n                             }\n-                            /**\n-                             * Record gesture origin\n-                             */\n-                            eachAxis(function(axis) {\n-                                var _a, _b;\n-                                var current = _this.getAxisMotionValue(axis).get() || 0;\n-                                /**\n-                                 * If the MotionValue is a percentage value convert to px\n-                                 */\n-                                if (styleValueTypes.percent.test(current)) {\n-                                    var measuredAxis = (_b = (_a = _this.visualElement.projection) === null || _a === void 0 ? void 0 : _a.layout) === null || _b === void 0 ? void 0 : _b.actual[axis];\n-                                    if (measuredAxis) {\n-                                        var length_1 = calcLength(measuredAxis);\n-                                        current = length_1 * (parseFloat(current) / 100);\n-                                    }\n-                                }\n-                                _this.originPoint[axis] = current;\n+                            updateDisplaySimple(cm, {\n+                                top: top,\n+                                bottom: bot\n                             });\n-                            // Fire onDragStart event\n-                            onDragStart === null || onDragStart === void 0 ? void 0 : onDragStart(event, info);\n-                            (_a = _this.visualElement.animationState) === null || _a === void 0 ? void 0 : _a.setActive(exports.AnimationType.Drag, true);\n-                        };\n-                        var onMove = function(event, info) {\n-                            // latestPointerEvent = event\n-                            var _a = _this.getProps(),\n-                                dragPropagation = _a.dragPropagation,\n-                                dragDirectionLock = _a.dragDirectionLock,\n-                                onDirectionLock = _a.onDirectionLock,\n-                                onDrag = _a.onDrag;\n-                            // If we didn't successfully receive the gesture lock, early return.\n-                            if (!dragPropagation && !_this.openGlobalLock) return;\n-                            var offset = info.offset;\n-                            // Attempt to detect drag direction if directionLock is true\n-                            if (dragDirectionLock && _this.currentDirection === null) {\n-                                _this.currentDirection = getCurrentDirection(offset);\n-                                // If we've successfully set a direction, notify listener\n-                                if (_this.currentDirection !== null) {\n-                                    onDirectionLock === null || onDirectionLock === void 0 ? void 0 : onDirectionLock(_this.currentDirection);\n-                                }\n-                                return;\n+                        }\n+                        if (wheelSamples < 20 && e.deltaMode !== 0) {\n+                            if (display.wheelStartX == null) {\n+                                display.wheelStartX = scroll.scrollLeft;\n+                                display.wheelStartY = scroll.scrollTop;\n+                                display.wheelDX = dx;\n+                                display.wheelDY = dy;\n+                                setTimeout(function() {\n+                                    if (display.wheelStartX == null) {\n+                                        return;\n+                                    }\n+                                    var movedX = scroll.scrollLeft - display.wheelStartX;\n+                                    var movedY = scroll.scrollTop - display.wheelStartY;\n+                                    var sample = movedY && display.wheelDY && movedY / display.wheelDY || movedX && display.wheelDX && movedX / display.wheelDX;\n+                                    display.wheelStartX = display.wheelStartY = null;\n+                                    if (!sample) {\n+                                        return;\n+                                    }\n+                                    wheelPixelsPerUnit = (wheelPixelsPerUnit * wheelSamples + sample) / (wheelSamples + 1);\n+                                    ++wheelSamples;\n+                                }, 200);\n+                            } else {\n+                                display.wheelDX += dx;\n+                                display.wheelDY += dy;\n                             }\n-                            // Update each point with the latest position\n-                            _this.updateAxis(\"x\", info.point, offset);\n-                            _this.updateAxis(\"y\", info.point, offset);\n-                            /**\n-                             * Ideally we would leave the renderer to fire naturally at the end of\n-                             * this frame but if the element is about to change layout as the result\n-                             * of a re-render we want to ensure the browser can read the latest\n-                             * bounding box to ensure the pointer and element don't fall out of sync.\n-                             */\n-                            _this.visualElement.syncRender();\n-                            /**\n-                             * This must fire after the syncRender call as it might trigger a state\n-                             * change which itself might trigger a layout update.\n-                             */\n-                            onDrag === null || onDrag === void 0 ? void 0 : onDrag(event, info);\n-                        };\n-                        var onSessionEnd = function(event, info) {\n-                            return _this.stop(event, info);\n-                        };\n-                        this.panSession = new PanSession(originEvent, {\n-                            onSessionStart: onSessionStart,\n-                            onStart: onStart,\n-                            onMove: onMove,\n-                            onSessionEnd: onSessionEnd\n-                        }, {\n-                            transformPagePoint: this.visualElement.getTransformPagePoint()\n-                        });\n+                        }\n+                    }\n+\n+                    // Selection objects are immutable. A new one is created every time\n+                    // the selection changes. A selection is one or more non-overlapping\n+                    // (and non-touching) ranges, sorted, and an integer that indicates\n+                    // which one is the primary selection (the one that's scrolled into\n+                    // view, that getCursor returns, etc).\n+                    var Selection = function(ranges, primIndex) {\n+                        this.ranges = ranges;\n+                        this.primIndex = primIndex;\n                     };\n-                    VisualElementDragControls.prototype.stop = function(event, info) {\n-                        var isDragging = this.isDragging;\n-                        this.cancel();\n-                        if (!isDragging) return;\n-                        var velocity = info.velocity;\n-                        this.startAnimation(velocity);\n-                        var onDragEnd = this.getProps().onDragEnd;\n-                        onDragEnd === null || onDragEnd === void 0 ? void 0 : onDragEnd(event, info);\n+                    Selection.prototype.primary = function() {\n+                        return this.ranges[this.primIndex];\n                     };\n-                    VisualElementDragControls.prototype.cancel = function() {\n-                        var _a, _b;\n-                        this.isDragging = false;\n-                        if (this.visualElement.projection) {\n-                            this.visualElement.projection.isAnimationBlocked = false;\n-                        }\n-                        (_a = this.panSession) === null || _a === void 0 ? void 0 : _a.end();\n-                        this.panSession = undefined;\n-                        var dragPropagation = this.getProps().dragPropagation;\n-                        if (!dragPropagation && this.openGlobalLock) {\n-                            this.openGlobalLock();\n-                            this.openGlobalLock = null;\n+                    Selection.prototype.equals = function(other) {\n+                        if (other == this) {\n+                            return true;\n                         }\n-                        (_b = this.visualElement.animationState) === null || _b === void 0 ? void 0 : _b.setActive(exports.AnimationType.Drag, false);\n-                    };\n-                    VisualElementDragControls.prototype.updateAxis = function(axis, _point, offset) {\n-                        var drag = this.getProps().drag;\n-                        // If we're not dragging this axis, do an early return.\n-                        if (!offset || !shouldDrag(axis, drag, this.currentDirection)) return;\n-                        var axisValue = this.getAxisMotionValue(axis);\n-                        var next = this.originPoint[axis] + offset[axis];\n-                        // Apply constraints\n-                        if (this.constraints && this.constraints[axis]) {\n-                            next = applyConstraints(next, this.constraints[axis], this.elastic[axis]);\n+                        if (other.primIndex != this.primIndex || other.ranges.length != this.ranges.length) {\n+                            return false;\n                         }\n-                        axisValue.set(next);\n-                    };\n-                    VisualElementDragControls.prototype.resolveConstraints = function() {\n-                        var _this = this;\n-                        var _a = this.getProps(),\n-                            dragConstraints = _a.dragConstraints,\n-                            dragElastic = _a.dragElastic;\n-                        var layout = (this.visualElement.projection || {}).layout;\n-                        var prevConstraints = this.constraints;\n-                        if (dragConstraints && isRefObject(dragConstraints)) {\n-                            if (!this.constraints) {\n-                                this.constraints = this.resolveRefConstraints();\n-                            }\n-                        } else {\n-                            if (dragConstraints && layout) {\n-                                this.constraints = calcRelativeConstraints(layout.actual, dragConstraints);\n-                            } else {\n-                                this.constraints = false;\n+                        for (var i = 0; i < this.ranges.length; i++) {\n+                            var here = this.ranges[i],\n+                                there = other.ranges[i];\n+                            if (!equalCursorPos(here.anchor, there.anchor) || !equalCursorPos(here.head, there.head)) {\n+                                return false;\n                             }\n                         }\n-                        this.elastic = resolveDragElastic(dragElastic);\n-                        /**\n-                         * If we're outputting to external MotionValues, we want to rebase the measured constraints\n-                         * from viewport-relative to component-relative.\n-                         */\n-                        if (prevConstraints !== this.constraints && layout && this.constraints && !this.hasMutatedConstraints) {\n-                            eachAxis(function(axis) {\n-                                if (_this.getAxisMotionValue(axis)) {\n-                                    _this.constraints[axis] = rebaseAxisConstraints(layout.actual[axis], _this.constraints[axis]);\n-                                }\n-                            });\n-                        }\n+                        return true;\n                     };\n-                    VisualElementDragControls.prototype.resolveRefConstraints = function() {\n-                        var _a = this.getProps(),\n-                            constraints = _a.dragConstraints,\n-                            onMeasureDragConstraints = _a.onMeasureDragConstraints;\n-                        if (!constraints || !isRefObject(constraints)) return false;\n-                        var constraintsElement = constraints.current;\n-                        heyListen.invariant(constraintsElement !== null, \"If `dragConstraints` is set as a React ref, that ref must be passed to another component's `ref` prop.\");\n-                        var projection = this.visualElement.projection;\n-                        // TODO\n-                        if (!projection || !projection.layout) return false;\n-                        var constraintsBox = measurePageBox(constraintsElement, projection.root, this.visualElement.getTransformPagePoint());\n-                        var measuredConstraints = calcViewportConstraints(projection.layout.actual, constraintsBox);\n-                        /**\n-                         * If there's an onMeasureDragConstraints listener we call it and\n-                         * if different constraints are returned, set constraints to that\n-                         */\n-                        if (onMeasureDragConstraints) {\n-                            var userConstraints = onMeasureDragConstraints(convertBoxToBoundingBox(measuredConstraints));\n-                            this.hasMutatedConstraints = !!userConstraints;\n-                            if (userConstraints) {\n-                                measuredConstraints = convertBoundingBoxToBox(userConstraints);\n+                    Selection.prototype.deepCopy = function() {\n+                        var out = [];\n+                        for (var i = 0; i < this.ranges.length; i++) {\n+                            out[i] = new Range(copyPos(this.ranges[i].anchor), copyPos(this.ranges[i].head));\n+                        }\n+                        return new Selection(out, this.primIndex);\n+                    };\n+                    Selection.prototype.somethingSelected = function() {\n+                        for (var i = 0; i < this.ranges.length; i++) {\n+                            if (!this.ranges[i].empty()) {\n+                                return true;\n                             }\n                         }\n-                        return measuredConstraints;\n+                        return false;\n                     };\n-                    VisualElementDragControls.prototype.startAnimation = function(velocity) {\n-                        var _this = this;\n-                        var _a = this.getProps(),\n-                            drag = _a.drag,\n-                            dragMomentum = _a.dragMomentum,\n-                            dragElastic = _a.dragElastic,\n-                            dragTransition = _a.dragTransition,\n-                            dragSnapToOrigin = _a.dragSnapToOrigin,\n-                            onDragTransitionEnd = _a.onDragTransitionEnd;\n-                        var constraints = this.constraints || {};\n-                        var momentumAnimations = eachAxis(function(axis) {\n-                            var _a;\n-                            if (!shouldDrag(axis, drag, _this.currentDirection)) {\n-                                return;\n+                    Selection.prototype.contains = function(pos, end) {\n+                        if (!end) {\n+                            end = pos;\n+                        }\n+                        for (var i = 0; i < this.ranges.length; i++) {\n+                            var range = this.ranges[i];\n+                            if (cmp(end, range.from()) >= 0 && cmp(pos, range.to()) <= 0) {\n+                                return i;\n                             }\n-                            var transition = (_a = constraints === null || constraints === void 0 ? void 0 : constraints[axis]) !== null && _a !== void 0 ? _a : {};\n-                            if (dragSnapToOrigin) transition = {\n-                                min: 0,\n-                                max: 0\n-                            };\n-                            /**\n-                             * Overdamp the boundary spring if `dragElastic` is disabled. There's still a frame\n-                             * of spring animations so we should look into adding a disable spring option to `inertia`.\n-                             * We could do something here where we affect the `bounceStiffness` and `bounceDamping`\n-                             * using the value of `dragElastic`.\n-                             */\n-                            var bounceStiffness = dragElastic ? 200 : 1000000;\n-                            var bounceDamping = dragElastic ? 40 : 10000000;\n-                            var inertia = tslib.__assign(tslib.__assign({\n-                                type: \"inertia\",\n-                                velocity: dragMomentum ? velocity[axis] : 0,\n-                                bounceStiffness: bounceStiffness,\n-                                bounceDamping: bounceDamping,\n-                                timeConstant: 750,\n-                                restDelta: 1,\n-                                restSpeed: 10\n-                            }, dragTransition), transition);\n-                            // If we're not animating on an externally-provided `MotionValue` we can use the\n-                            // component's animation controls which will handle interactions with whileHover (etc),\n-                            // otherwise we just have to animate the `MotionValue` itself.\n-                            return _this.startAxisValueAnimation(axis, inertia);\n-                        });\n-                        // Run all animations and then resolve the new drag constraints.\n-                        return Promise.all(momentumAnimations).then(onDragTransitionEnd);\n-                    };\n-                    VisualElementDragControls.prototype.startAxisValueAnimation = function(axis, transition) {\n-                        var axisValue = this.getAxisMotionValue(axis);\n-                        return startAnimation(axis, axisValue, 0, transition);\n+                        }\n+                        return -1;\n                     };\n-                    VisualElementDragControls.prototype.stopAnimation = function() {\n-                        var _this = this;\n-                        eachAxis(function(axis) {\n-                            return _this.getAxisMotionValue(axis).stop();\n-                        });\n+                    var Range = function(anchor, head) {\n+                        this.anchor = anchor;\n+                        this.head = head;\n                     };\n-                    /**\n-                     * Drag works differently depending on which props are provided.\n-                     *\n-                     * - If _dragX and _dragY are provided, we output the gesture delta directly to those motion values.\n-                     * - Otherwise, we apply the delta to the x/y motion values.\n-                     */\n-                    VisualElementDragControls.prototype.getAxisMotionValue = function(axis) {\n-                        var _a, _b;\n-                        var dragKey = \"_drag\" + axis.toUpperCase();\n-                        var externalMotionValue = this.visualElement.getProps()[dragKey];\n-                        return externalMotionValue ? externalMotionValue : this.visualElement.getValue(axis, (_b = (_a = this.visualElement.getProps().initial) === null || _a === void 0 ? void 0 : _a[axis]) !== null && _b !== void 0 ? _b : 0);\n+                    Range.prototype.from = function() {\n+                        return minPos(this.anchor, this.head);\n                     };\n-                    VisualElementDragControls.prototype.snapToCursor = function(point) {\n-                        var _this = this;\n-                        eachAxis(function(axis) {\n-                            var drag = _this.getProps().drag;\n-                            // If we're not dragging this axis, do an early return.\n-                            if (!shouldDrag(axis, drag, _this.currentDirection)) return;\n-                            var projection = _this.visualElement.projection;\n-                            var axisValue = _this.getAxisMotionValue(axis);\n-                            if (projection && projection.layout) {\n-                                var _a = projection.layout.actual[axis],\n-                                    min = _a.min,\n-                                    max = _a.max;\n-                                axisValue.set(point[axis] - popmotion.mix(min, max, 0.5));\n-                            }\n-                        });\n+                    Range.prototype.to = function() {\n+                        return maxPos(this.anchor, this.head);\n                     };\n-                    /**\n-                     * When the viewport resizes we want to check if the measured constraints\n-                     * have changed and, if so, reposition the element within those new constraints\n-                     * relative to where it was before the resize.\n-                     */\n-                    VisualElementDragControls.prototype.scalePositionWithinConstraints = function() {\n-                        var _this = this;\n-                        var _a;\n-                        var _b = this.getProps(),\n-                            drag = _b.drag,\n-                            dragConstraints = _b.dragConstraints;\n-                        var projection = this.visualElement.projection;\n-                        if (!isRefObject(dragConstraints) || !projection || !this.constraints) return;\n-                        /**\n-                         * Stop current animations as there can be visual glitching if we try to do\n-                         * this mid-animation\n-                         */\n-                        this.stopAnimation();\n-                        /**\n-                         * Record the relative position of the dragged element relative to the\n-                         * constraints box and save as a progress value.\n-                         */\n-                        var boxProgress = {\n-                            x: 0,\n-                            y: 0\n-                        };\n-                        eachAxis(function(axis) {\n-                            var axisValue = _this.getAxisMotionValue(axis);\n-                            if (axisValue) {\n-                                var latest = axisValue.get();\n-                                boxProgress[axis] = calcOrigin({\n-                                    min: latest,\n-                                    max: latest\n-                                }, _this.constraints[axis]);\n-                            }\n-                        });\n-                        /**\n-                         * Update the layout of this element and resolve the latest drag constraints\n-                         */\n-                        var transformTemplate = this.visualElement.getProps().transformTemplate;\n-                        this.visualElement.getInstance().style.transform = transformTemplate ? transformTemplate({}, \"\") : \"none\";\n-                        (_a = projection.root) === null || _a === void 0 ? void 0 : _a.updateScroll();\n-                        projection.updateLayout();\n-                        this.resolveConstraints();\n-                        /**\n-                         * For each axis, calculate the current progress of the layout axis\n-                         * within the new constraints.\n-                         */\n-                        eachAxis(function(axis) {\n-                            if (!shouldDrag(axis, drag, null)) return;\n-                            /**\n-                             * Calculate a new transform based on the previous box progress\n-                             */\n-                            var axisValue = _this.getAxisMotionValue(axis);\n-                            var _a = _this.constraints[axis],\n-                                min = _a.min,\n-                                max = _a.max;\n-                            axisValue.set(popmotion.mix(min, max, boxProgress[axis]));\n-                        });\n+                    Range.prototype.empty = function() {\n+                        return this.head.line == this.anchor.line && this.head.ch == this.anchor.ch;\n                     };\n-                    VisualElementDragControls.prototype.addListeners = function() {\n-                        var _this = this;\n-                        var _a;\n-                        elementDragControls.set(this.visualElement, this);\n-                        var element = this.visualElement.getInstance();\n-                        /**\n-                         * Attach a pointerdown event listener on this DOM element to initiate drag tracking.\n-                         */\n-                        var stopPointerListener = addPointerEvent(element, \"pointerdown\", function(event) {\n-                            var _a = _this.getProps(),\n-                                drag = _a.drag,\n-                                _b = _a.dragListener,\n-                                dragListener = _b === void 0 ? true : _b;\n-                            drag && dragListener && _this.start(event);\n+\n+                    // Take an unsorted, potentially overlapping set of ranges, and\n+                    // build a selection out of it. 'Consumes' ranges array (modifying\n+                    // it).\n+                    function normalizeSelection(cm, ranges, primIndex) {\n+                        var mayTouch = cm && cm.options.selectionsMayTouch;\n+                        var prim = ranges[primIndex];\n+                        ranges.sort(function(a, b) {\n+                            return cmp(a.from(), b.from());\n                         });\n-                        var measureDragConstraints = function() {\n-                            var dragConstraints = _this.getProps().dragConstraints;\n-                            if (isRefObject(dragConstraints)) {\n-                                _this.constraints = _this.resolveRefConstraints();\n+                        primIndex = indexOf(ranges, prim);\n+                        for (var i = 1; i < ranges.length; i++) {\n+                            var cur = ranges[i],\n+                                prev = ranges[i - 1];\n+                            var diff = cmp(prev.to(), cur.from());\n+                            if (mayTouch && !cur.empty() ? diff > 0 : diff >= 0) {\n+                                var from = minPos(prev.from(), cur.from()),\n+                                    to = maxPos(prev.to(), cur.to());\n+                                var inv = prev.empty() ? cur.from() == cur.head : prev.from() == prev.head;\n+                                if (i <= primIndex) {\n+                                    --primIndex;\n+                                }\n+                                ranges.splice(--i, 2, new Range(inv ? to : from, inv ? from : to));\n                             }\n-                        };\n-                        var projection = this.visualElement.projection;\n-                        var stopMeasureLayoutListener = projection.addEventListener(\"measure\", measureDragConstraints);\n-                        if (projection && !projection.layout) {\n-                            (_a = projection.root) === null || _a === void 0 ? void 0 : _a.updateScroll();\n-                            projection.updateLayout();\n                         }\n-                        measureDragConstraints();\n-                        /**\n-                         * Attach a window resize listener to scale the draggable target within its defined\n-                         * constraints as the window resizes.\n-                         */\n-                        var stopResizeListener = addDomEvent(window, \"resize\", function() {\n-                            return _this.scalePositionWithinConstraints();\n-                        });\n-                        /**\n-                         * If the element's layout changes, calculate the delta and apply that to\n-                         * the drag gesture's origin point.\n-                         */\n-                        projection.addEventListener(\"didUpdate\", function(_a) {\n-                            var delta = _a.delta,\n-                                hasLayoutChanged = _a.hasLayoutChanged;\n-                            if (_this.isDragging && hasLayoutChanged) {\n-                                eachAxis(function(axis) {\n-                                    var motionValue = _this.getAxisMotionValue(axis);\n-                                    if (!motionValue) return;\n-                                    _this.originPoint[axis] += delta[axis].translate;\n-                                    motionValue.set(motionValue.get() + delta[axis].translate);\n-                                });\n-                                _this.visualElement.syncRender();\n-                            }\n-                        });\n-                        return function() {\n-                            stopResizeListener();\n-                            stopPointerListener();\n-                            stopMeasureLayoutListener();\n-                        };\n-                    };\n-                    VisualElementDragControls.prototype.getProps = function() {\n-                        var props = this.visualElement.getProps();\n-                        var _a = props.drag,\n-                            drag = _a === void 0 ? false : _a,\n-                            _b = props.dragDirectionLock,\n-                            dragDirectionLock = _b === void 0 ? false : _b,\n-                            _c = props.dragPropagation,\n-                            dragPropagation = _c === void 0 ? false : _c,\n-                            _d = props.dragConstraints,\n-                            dragConstraints = _d === void 0 ? false : _d,\n-                            _e = props.dragElastic,\n-                            dragElastic = _e === void 0 ? defaultElastic : _e,\n-                            _f = props.dragMomentum,\n-                            dragMomentum = _f === void 0 ? true : _f;\n-                        return tslib.__assign(tslib.__assign({}, props), {\n-                            drag: drag,\n-                            dragDirectionLock: dragDirectionLock,\n-                            dragPropagation: dragPropagation,\n-                            dragConstraints: dragConstraints,\n-                            dragElastic: dragElastic,\n-                            dragMomentum: dragMomentum\n-                        });\n-                    };\n-                    return VisualElementDragControls;\n-                }();\n+                        return new Selection(ranges, primIndex);\n+                    }\n \n-                function shouldDrag(direction, drag, currentDirection) {\n-                    return (drag === true || drag === direction) && (currentDirection === null || currentDirection === direction);\n-                }\n-                /**\n-                 * Based on an x/y offset determine the current drag direction. If both axis' offsets are lower\n-                 * than the provided threshold, return `null`.\n-                 *\n-                 * @param offset - The x/y offset from origin.\n-                 * @param lockThreshold - (Optional) - the minimum absolute offset before we can determine a drag direction.\n-                 */\n-                function getCurrentDirection(offset, lockThreshold) {\n-                    if (lockThreshold === void 0) {\n-                        lockThreshold = 10;\n+                    function simpleSelection(anchor, head) {\n+                        return new Selection([new Range(anchor, head || anchor)], 0);\n                     }\n-                    var direction = null;\n-                    if (Math.abs(offset.y) > lockThreshold) {\n-                        direction = \"y\";\n-                    } else if (Math.abs(offset.x) > lockThreshold) {\n-                        direction = \"x\";\n+\n+                    // Compute the position of the end of a change (its 'to' property\n+                    // refers to the pre-change end).\n+                    function changeEnd(change) {\n+                        if (!change.text) {\n+                            return change.to;\n+                        }\n+                        return Pos(change.from.line + change.text.length - 1, lst(change.text).length + (change.text.length == 1 ? change.from.ch : 0));\n                     }\n-                    return direction;\n-                }\n \n-                /**\n-                 * A hook that allows an element to be dragged.\n-                 *\n-                 * @internal\n-                 */\n-                function useDrag(props) {\n-                    var groupDragControls = props.dragControls,\n-                        visualElement = props.visualElement;\n-                    var dragControls = useConstant(function() {\n-                        return new VisualElementDragControls(visualElement);\n-                    });\n-                    // If we've been provided a DragControls for manual control over the drag gesture,\n-                    // subscribe this component to it on mount.\n-                    React.useEffect(function() {\n-                        return groupDragControls && groupDragControls.subscribe(dragControls);\n-                    }, [dragControls, groupDragControls]);\n-                    // Apply the event listeners to the element\n-                    React.useEffect(function() {\n-                        return dragControls.addListeners();\n-                    }, [dragControls]);\n-                }\n+                    // Adjust a position to refer to the post-change position of the\n+                    // same text, or the end of the change if the change covers it.\n+                    function adjustForChange(pos, change) {\n+                        if (cmp(pos, change.from) < 0) {\n+                            return pos;\n+                        }\n+                        if (cmp(pos, change.to) <= 0) {\n+                            return changeEnd(change);\n+                        }\n+                        var line = pos.line + change.text.length - (change.to.line - change.from.line) - 1,\n+                            ch = pos.ch;\n+                        if (pos.line == change.to.line) {\n+                            ch += changeEnd(change).ch - change.to.ch;\n+                        }\n+                        return Pos(line, ch);\n+                    }\n \n-                /**\n-                 *\n-                 * @param handlers -\n-                 * @param ref -\n-                 *\n-                 * @privateRemarks\n-                 * Currently this sets new pan gesture functions every render. The memo route has been explored\n-                 * in the past but ultimately we're still creating new functions every render. An optimisation\n-                 * to explore is creating the pan gestures and loading them into a `ref`.\n-                 *\n-                 * @internal\n-                 */\n-                function usePanGesture(_a) {\n-                    var onPan = _a.onPan,\n-                        onPanStart = _a.onPanStart,\n-                        onPanEnd = _a.onPanEnd,\n-                        onPanSessionStart = _a.onPanSessionStart,\n-                        visualElement = _a.visualElement;\n-                    var hasPanEvents = onPan || onPanStart || onPanEnd || onPanSessionStart;\n-                    var panSession = React.useRef(null);\n-                    var transformPagePoint = React.useContext(MotionConfigContext).transformPagePoint;\n-                    var handlers = {\n-                        onSessionStart: onPanSessionStart,\n-                        onStart: onPanStart,\n-                        onMove: onPan,\n-                        onEnd: function(event, info) {\n-                            panSession.current = null;\n-                            onPanEnd && onPanEnd(event, info);\n+                    function computeSelAfterChange(doc, change) {\n+                        var out = [];\n+                        for (var i = 0; i < doc.sel.ranges.length; i++) {\n+                            var range = doc.sel.ranges[i];\n+                            out.push(new Range(adjustForChange(range.anchor, change), adjustForChange(range.head, change)));\n                         }\n-                    };\n-                    React.useEffect(function() {\n-                        if (panSession.current !== null) {\n-                            panSession.current.updateHandlers(handlers);\n+                        return normalizeSelection(doc.cm, out, doc.sel.primIndex);\n+                    }\n+\n+                    function offsetPos(pos, old, nw) {\n+                        if (pos.line == old.line) {\n+                            return Pos(nw.line, pos.ch - old.ch + nw.ch);\n+                        } else {\n+                            return Pos(nw.line + (pos.line - old.line), pos.ch);\n                         }\n-                    });\n+                    }\n \n-                    function onPointerDown(event) {\n-                        panSession.current = new PanSession(event, handlers, {\n-                            transformPagePoint: transformPagePoint\n+                    // Used by replaceSelections to allow moving the selection to the\n+                    // start or around the replaced test. Hint may be \"start\" or \"around\".\n+                    function computeReplacedSel(doc, changes, hint) {\n+                        var out = [];\n+                        var oldPrev = Pos(doc.first, 0),\n+                            newPrev = oldPrev;\n+                        for (var i = 0; i < changes.length; i++) {\n+                            var change = changes[i];\n+                            var from = offsetPos(change.from, oldPrev, newPrev);\n+                            var to = offsetPos(changeEnd(change), oldPrev, newPrev);\n+                            oldPrev = change.to;\n+                            newPrev = to;\n+                            if (hint == \"around\") {\n+                                var range = doc.sel.ranges[i],\n+                                    inv = cmp(range.head, range.anchor) < 0;\n+                                out[i] = new Range(inv ? to : from, inv ? from : to);\n+                            } else {\n+                                out[i] = new Range(from, from);\n+                            }\n+                        }\n+                        return new Selection(out, doc.sel.primIndex);\n+                    }\n+\n+                    // Used to get the editor into a consistent state again when options change.\n+\n+                    function loadMode(cm) {\n+                        cm.doc.mode = getMode(cm.options, cm.doc.modeOption);\n+                        resetModeState(cm);\n+                    }\n+\n+                    function resetModeState(cm) {\n+                        cm.doc.iter(function(line) {\n+                            if (line.stateAfter) {\n+                                line.stateAfter = null;\n+                            }\n+                            if (line.styles) {\n+                                line.styles = null;\n+                            }\n                         });\n+                        cm.doc.modeFrontier = cm.doc.highlightFrontier = cm.doc.first;\n+                        startWorker(cm, 100);\n+                        cm.state.modeGen++;\n+                        if (cm.curOp) {\n+                            regChange(cm);\n+                        }\n                     }\n-                    usePointerEvent(visualElement, \"pointerdown\", hasPanEvents && onPointerDown);\n-                    useUnmountEffect(function() {\n-                        return panSession.current && panSession.current.end();\n-                    });\n-                }\n-                var drag = {\n-                    pan: makeRenderlessComponent(usePanGesture),\n-                    drag: makeRenderlessComponent(useDrag)\n-                };\n-                var names = [\"LayoutMeasure\", \"BeforeLayoutMeasure\", \"LayoutUpdate\", \"ViewportBoxUpdate\", \"Update\", \"Render\", \"AnimationComplete\", \"LayoutAnimationComplete\", \"AnimationStart\", \"LayoutAnimationStart\", \"SetAxisTarget\", \"Unmount\"];\n \n-                function createLifecycles() {\n-                    var managers = names.map(function() {\n-                        return new SubscriptionManager();\n-                    });\n-                    var propSubscriptions = {};\n-                    var lifecycles = {\n-                        clearAllListeners: function() {\n-                            return managers.forEach(function(manager) {\n-                                return manager.clear();\n-                            });\n-                        },\n-                        updatePropListeners: function(props) {\n-                            names.forEach(function(name) {\n-                                var _a;\n-                                var on = \"on\" + name;\n-                                var propListener = props[on];\n-                                // Unsubscribe existing subscription\n-                                (_a = propSubscriptions[name]) === null || _a === void 0 ? void 0 : _a.call(propSubscriptions);\n-                                // Add new subscription\n-                                if (propListener) {\n-                                    propSubscriptions[name] = lifecycles[on](propListener);\n-                                }\n-                            });\n+                    // DOCUMENT DATA STRUCTURE\n+\n+                    // By default, updates that start and end at the beginning of a line\n+                    // are treated specially, in order to make the association of line\n+                    // widgets and marker elements with the text behave more intuitive.\n+                    function isWholeLineUpdate(doc, change) {\n+                        return change.from.ch == 0 && change.to.ch == 0 && lst(change.text) == \"\" && (!doc.cm || doc.cm.options.wholeLineUpdateBefore);\n+                    }\n+\n+                    // Perform a change on the document data structure.\n+                    function updateDoc(doc, change, markedSpans, estimateHeight) {\n+                        function spansFor(n) {\n+                            return markedSpans ? markedSpans[n] : null;\n                         }\n-                    };\n-                    managers.forEach(function(manager, i) {\n-                        lifecycles[\"on\" + names[i]] = function(handler) {\n-                            return manager.add(handler);\n-                        };\n-                        lifecycles[\"notify\" + names[i]] = function() {\n-                            var args = [];\n-                            for (var _i = 0; _i < arguments.length; _i++) {\n-                                args[_i] = arguments[_i];\n-                            }\n-                            return manager.notify.apply(manager, tslib.__spreadArray([], tslib.__read(args), false));\n-                        };\n-                    });\n-                    return lifecycles;\n-                }\n \n-                function updateMotionValuesFromProps(element, next, prev) {\n-                    var _a;\n-                    for (var key in next) {\n-                        var nextValue = next[key];\n-                        var prevValue = prev[key];\n-                        if (isMotionValue(nextValue)) {\n-                            /**\n-                             * If this is a motion value found in props or style, we want to add it\n-                             * to our visual element's motion value map.\n-                             */\n-                            element.addValue(key, nextValue);\n-                            /**\n-                             * Check the version of the incoming motion value with this version\n-                             * and warn against mismatches.\n-                             */\n-                            if (true) {\n-                                warnOnce(nextValue.version === \"6.5.1\", \"Attempting to mix Framer Motion versions \".concat(nextValue.version, \" with 6.5.1 may not work as expected.\"));\n+                        function update(line, text, spans) {\n+                            updateLine(line, text, spans, estimateHeight);\n+                            signalLater(line, \"change\", line, change);\n+                        }\n+\n+                        function linesFor(start, end) {\n+                            var result = [];\n+                            for (var i = start; i < end; ++i) {\n+                                result.push(new Line(text[i], spansFor(i), estimateHeight));\n                             }\n-                        } else if (isMotionValue(prevValue)) {\n-                            /**\n-                             * If we're swapping to a new motion value, create a new motion value\n-                             * from that\n-                             */\n-                            element.addValue(key, motionValue(nextValue));\n-                        } else if (prevValue !== nextValue) {\n-                            /**\n-                             * If this is a flat value that has changed, update the motion value\n-                             * or create one if it doesn't exist. We only want to do this if we're\n-                             * not handling the value with our animation state.\n-                             */\n-                            if (element.hasValue(key)) {\n-                                var existingValue = element.getValue(key);\n-                                // TODO: Only update values that aren't being animated or even looked at\n-                                !existingValue.hasAnimated && existingValue.set(nextValue);\n+                            return result;\n+                        }\n+                        var from = change.from,\n+                            to = change.to,\n+                            text = change.text;\n+                        var firstLine = getLine(doc, from.line),\n+                            lastLine = getLine(doc, to.line);\n+                        var lastText = lst(text),\n+                            lastSpans = spansFor(text.length - 1),\n+                            nlines = to.line - from.line;\n+\n+                        // Adjust the line structure\n+                        if (change.full) {\n+                            doc.insert(0, linesFor(0, text.length));\n+                            doc.remove(text.length, doc.size - text.length);\n+                        } else if (isWholeLineUpdate(doc, change)) {\n+                            // This is a whole-line replace. Treated specially to make\n+                            // sure line objects move the way they are supposed to.\n+                            var added = linesFor(0, text.length - 1);\n+                            update(lastLine, lastLine.text, lastSpans);\n+                            if (nlines) {\n+                                doc.remove(from.line, nlines);\n+                            }\n+                            if (added.length) {\n+                                doc.insert(from.line, added);\n+                            }\n+                        } else if (firstLine == lastLine) {\n+                            if (text.length == 1) {\n+                                update(firstLine, firstLine.text.slice(0, from.ch) + lastText + firstLine.text.slice(to.ch), lastSpans);\n                             } else {\n-                                element.addValue(key, motionValue((_a = element.getStaticValue(key)) !== null && _a !== void 0 ? _a : nextValue));\n+                                var added$1 = linesFor(1, text.length - 1);\n+                                added$1.push(new Line(lastText + firstLine.text.slice(to.ch), lastSpans, estimateHeight));\n+                                update(firstLine, firstLine.text.slice(0, from.ch) + text[0], spansFor(0));\n+                                doc.insert(from.line + 1, added$1);\n+                            }\n+                        } else if (text.length == 1) {\n+                            update(firstLine, firstLine.text.slice(0, from.ch) + text[0] + lastLine.text.slice(to.ch), spansFor(0));\n+                            doc.remove(from.line + 1, nlines);\n+                        } else {\n+                            update(firstLine, firstLine.text.slice(0, from.ch) + text[0], spansFor(0));\n+                            update(lastLine, lastText + lastLine.text.slice(to.ch), lastSpans);\n+                            var added$2 = linesFor(1, text.length - 1);\n+                            if (nlines > 1) {\n+                                doc.remove(from.line + 1, nlines - 1);\n+                            }\n+                            doc.insert(from.line + 1, added$2);\n+                        }\n+                        signalLater(doc, \"change\", doc, change);\n+                    }\n+\n+                    // Call f for all linked documents.\n+                    function linkedDocs(doc, f, sharedHistOnly) {\n+                        function propagate(doc, skip, sharedHist) {\n+                            if (doc.linked) {\n+                                for (var i = 0; i < doc.linked.length; ++i) {\n+                                    var rel = doc.linked[i];\n+                                    if (rel.doc == skip) {\n+                                        continue;\n+                                    }\n+                                    var shared = sharedHist && rel.sharedHist;\n+                                    if (sharedHistOnly && !shared) {\n+                                        continue;\n+                                    }\n+                                    f(rel.doc, shared);\n+                                    propagate(rel.doc, doc, shared);\n+                                }\n                             }\n                         }\n+                        propagate(doc, null, true);\n                     }\n-                    // Handle removed values\n-                    for (var key in prev) {\n-                        if (next[key] === undefined) element.removeValue(key);\n+\n+                    // Attach a document to an editor.\n+                    function attachDoc(cm, doc) {\n+                        if (doc.cm) {\n+                            throw new Error(\"This document is already in use.\");\n+                        }\n+                        cm.doc = doc;\n+                        doc.cm = cm;\n+                        estimateLineHeights(cm);\n+                        loadMode(cm);\n+                        setDirectionClass(cm);\n+                        cm.options.direction = doc.direction;\n+                        if (!cm.options.lineWrapping) {\n+                            findMaxLine(cm);\n+                        }\n+                        cm.options.mode = doc.modeOption;\n+                        regChange(cm);\n                     }\n-                    return next;\n-                }\n-                var visualElement = function(_a) {\n-                    var _b = _a.treeType,\n-                        treeType = _b === void 0 ? \"\" : _b,\n-                        build = _a.build,\n-                        getBaseTarget = _a.getBaseTarget,\n-                        makeTargetAnimatable = _a.makeTargetAnimatable,\n-                        measureViewportBox = _a.measureViewportBox,\n-                        renderInstance = _a.render,\n-                        readValueFromInstance = _a.readValueFromInstance,\n-                        removeValueFromRenderState = _a.removeValueFromRenderState,\n-                        sortNodePosition = _a.sortNodePosition,\n-                        scrapeMotionValuesFromProps = _a.scrapeMotionValuesFromProps;\n-                    return function(_a, options) {\n-                        var parent = _a.parent,\n-                            props = _a.props,\n-                            presenceId = _a.presenceId,\n-                            blockInitialAnimation = _a.blockInitialAnimation,\n-                            visualState = _a.visualState,\n-                            shouldReduceMotion = _a.shouldReduceMotion;\n-                        if (options === void 0) {\n-                            options = {};\n+\n+                    function setDirectionClass(cm) {\n+                        (cm.doc.direction == \"rtl\" ? addClass : rmClass)(cm.display.lineDiv, \"CodeMirror-rtl\");\n+                    }\n+\n+                    function directionChanged(cm) {\n+                        runInOp(cm, function() {\n+                            setDirectionClass(cm);\n+                            regChange(cm);\n+                        });\n+                    }\n+\n+                    function History(prev) {\n+                        // Arrays of change events and selections. Doing something adds an\n+                        // event to done and clears undo. Undoing moves events from done\n+                        // to undone, redoing moves them in the other direction.\n+                        this.done = [];\n+                        this.undone = [];\n+                        this.undoDepth = prev ? prev.undoDepth : Infinity;\n+                        // Used to track when changes can be merged into a single undo\n+                        // event\n+                        this.lastModTime = this.lastSelTime = 0;\n+                        this.lastOp = this.lastSelOp = null;\n+                        this.lastOrigin = this.lastSelOrigin = null;\n+                        // Used by the isClean() method\n+                        this.generation = this.maxGeneration = prev ? prev.maxGeneration : 1;\n+                    }\n+\n+                    // Create a history change event from an updateDoc-style change\n+                    // object.\n+                    function historyChangeFromChange(doc, change) {\n+                        var histChange = {\n+                            from: copyPos(change.from),\n+                            to: changeEnd(change),\n+                            text: getBetween(doc, change.from, change.to)\n+                        };\n+                        attachLocalSpans(doc, histChange, change.from.line, change.to.line + 1);\n+                        linkedDocs(doc, function(doc) {\n+                            return attachLocalSpans(doc, histChange, change.from.line, change.to.line + 1);\n+                        }, true);\n+                        return histChange;\n+                    }\n+\n+                    // Pop all selection events off the end of a history array. Stop at\n+                    // a change event.\n+                    function clearSelectionEvents(array) {\n+                        while (array.length) {\n+                            var last = lst(array);\n+                            if (last.ranges) {\n+                                array.pop();\n+                            } else {\n+                                break;\n+                            }\n                         }\n-                        var isMounted = false;\n-                        var latestValues = visualState.latestValues,\n-                            renderState = visualState.renderState;\n-                        /**\n-                         * The instance of the render-specific node that will be hydrated by the\n-                         * exposed React ref. So for example, this visual element can host a\n-                         * HTMLElement, plain object, or Three.js object. The functions provided\n-                         * in VisualElementConfig allow us to interface with this instance.\n-                         */\n-                        var instance;\n-                        /**\n-                         * Manages the subscriptions for a visual element's lifecycle, for instance\n-                         * onRender\n-                         */\n-                        var lifecycles = createLifecycles();\n-                        /**\n-                         * A map of all motion values attached to this visual element. Motion\n-                         * values are source of truth for any given animated value. A motion\n-                         * value might be provided externally by the component via props.\n-                         */\n-                        var values = new Map();\n-                        /**\n-                         * A map of every subscription that binds the provided or generated\n-                         * motion values onChange listeners to this visual element.\n-                         */\n-                        var valueSubscriptions = new Map();\n-                        /**\n-                         * A reference to the previously-provided motion values as returned\n-                         * from scrapeMotionValuesFromProps. We use the keys in here to determine\n-                         * if any motion values need to be removed after props are updated.\n-                         */\n-                        var prevMotionValues = {};\n-                        /**\n-                         * When values are removed from all animation props we need to search\n-                         * for a fallback value to animate to. These values are tracked in baseTarget.\n-                         */\n-                        var baseTarget = tslib.__assign({}, latestValues);\n-                        // Internal methods ========================\n-                        /**\n-                         * On mount, this will be hydrated with a callback to disconnect\n-                         * this visual element from its parent on unmount.\n-                         */\n-                        var removeFromVariantTree;\n-                        /**\n-                         * Render the element with the latest styles outside of the React\n-                         * render lifecycle\n-                         */\n-                        function render() {\n-                            if (!instance || !isMounted) return;\n-                            triggerBuild();\n-                            renderInstance(instance, renderState, props.style, element.projection);\n+                    }\n+\n+                    // Find the top change event in the history. Pop off selection\n+                    // events that are in the way.\n+                    function lastChangeEvent(hist, force) {\n+                        if (force) {\n+                            clearSelectionEvents(hist.done);\n+                            return lst(hist.done);\n+                        } else if (hist.done.length && !lst(hist.done).ranges) {\n+                            return lst(hist.done);\n+                        } else if (hist.done.length > 1 && !hist.done[hist.done.length - 2].ranges) {\n+                            hist.done.pop();\n+                            return lst(hist.done);\n                         }\n+                    }\n \n-                        function triggerBuild() {\n-                            build(element, renderState, latestValues, options, props);\n+                    // Register a change in the history. Merges changes that are within\n+                    // a single operation, or are close together with an origin that\n+                    // allows merging (starting with \"+\") into a single event.\n+                    function addChangeToHistory(doc, change, selAfter, opId) {\n+                        var hist = doc.history;\n+                        hist.undone.length = 0;\n+                        var time = +new Date(),\n+                            cur;\n+                        var last;\n+                        if ((hist.lastOp == opId || hist.lastOrigin == change.origin && change.origin && (change.origin.charAt(0) == \"+\" && hist.lastModTime > time - (doc.cm ? doc.cm.options.historyEventDelay : 500) || change.origin.charAt(0) == \"*\")) && (cur = lastChangeEvent(hist, hist.lastOp == opId))) {\n+                            // Merge this change into the last event\n+                            last = lst(cur.changes);\n+                            if (cmp(change.from, change.to) == 0 && cmp(change.from, last.to) == 0) {\n+                                // Optimized case for simple insertion -- don't want to add\n+                                // new changesets for every character typed\n+                                last.to = changeEnd(change);\n+                            } else {\n+                                // Add new sub-event\n+                                cur.changes.push(historyChangeFromChange(doc, change));\n+                            }\n+                        } else {\n+                            // Can not be merged, start a new event.\n+                            var before = lst(hist.done);\n+                            if (!before || !before.ranges) {\n+                                pushSelectionToHistory(doc.sel, hist.done);\n+                            }\n+                            cur = {\n+                                changes: [historyChangeFromChange(doc, change)],\n+                                generation: hist.generation\n+                            };\n+                            hist.done.push(cur);\n+                            while (hist.done.length > hist.undoDepth) {\n+                                hist.done.shift();\n+                                if (!hist.done[0].ranges) {\n+                                    hist.done.shift();\n+                                }\n+                            }\n+                        }\n+                        hist.done.push(selAfter);\n+                        hist.generation = ++hist.maxGeneration;\n+                        hist.lastModTime = hist.lastSelTime = time;\n+                        hist.lastOp = hist.lastSelOp = opId;\n+                        hist.lastOrigin = hist.lastSelOrigin = change.origin;\n+                        if (!last) {\n+                            signal(doc, \"historyAdded\");\n                         }\n+                    }\n \n-                        function update() {\n-                            lifecycles.notifyUpdate(latestValues);\n+                    function selectionEventCanBeMerged(doc, origin, prev, sel) {\n+                        var ch = origin.charAt(0);\n+                        return ch == \"*\" || ch == \"+\" && prev.ranges.length == sel.ranges.length && prev.somethingSelected() == sel.somethingSelected() && new Date() - doc.history.lastSelTime <= (doc.cm ? doc.cm.options.historyEventDelay : 500);\n+                    }\n+\n+                    // Called whenever the selection changes, sets the new selection as\n+                    // the pending selection in the history, and pushes the old pending\n+                    // selection into the 'done' array when it was significantly\n+                    // different (in number of selected ranges, emptiness, or time).\n+                    function addSelectionToHistory(doc, sel, opId, options) {\n+                        var hist = doc.history,\n+                            origin = options && options.origin;\n+\n+                        // A new event is started when the previous origin does not match\n+                        // the current, or the origins don't allow matching. Origins\n+                        // starting with * are always merged, those starting with + are\n+                        // merged when similar and close together in time.\n+                        if (opId == hist.lastSelOp || origin && hist.lastSelOrigin == origin && (hist.lastModTime == hist.lastSelTime && hist.lastOrigin == origin || selectionEventCanBeMerged(doc, origin, lst(hist.done), sel))) {\n+                            hist.done[hist.done.length - 1] = sel;\n+                        } else {\n+                            pushSelectionToHistory(sel, hist.done);\n                         }\n-                        /**\n-                         *\n-                         */\n-                        function bindToMotionValue(key, value) {\n-                            var removeOnChange = value.onChange(function(latestValue) {\n-                                latestValues[key] = latestValue;\n-                                props.onUpdate && sync__default[\"default\"].update(update, false, true);\n-                            });\n-                            var removeOnRenderRequest = value.onRenderRequest(element.scheduleRender);\n-                            valueSubscriptions.set(key, function() {\n-                                removeOnChange();\n-                                removeOnRenderRequest();\n-                            });\n+                        hist.lastSelTime = +new Date();\n+                        hist.lastSelOrigin = origin;\n+                        hist.lastSelOp = opId;\n+                        if (options && options.clearRedo !== false) {\n+                            clearSelectionEvents(hist.undone);\n                         }\n-                        /**\n-                         * Any motion values that are provided to the element when created\n-                         * aren't yet bound to the element, as this would technically be impure.\n-                         * However, we iterate through the motion values and set them to the\n-                         * initial values for this component.\n-                         *\n-                         * TODO: This is impure and we should look at changing this to run on mount.\n-                         * Doing so will break some tests but this isn't neccessarily a breaking change,\n-                         * more a reflection of the test.\n-                         */\n-                        var initialMotionValues = scrapeMotionValuesFromProps(props);\n-                        for (var key in initialMotionValues) {\n-                            var value = initialMotionValues[key];\n-                            if (latestValues[key] !== undefined && isMotionValue(value)) {\n-                                value.set(latestValues[key], false);\n+                    }\n+\n+                    function pushSelectionToHistory(sel, dest) {\n+                        var top = lst(dest);\n+                        if (!(top && top.ranges && top.equals(sel))) {\n+                            dest.push(sel);\n+                        }\n+                    }\n+\n+                    // Used to store marked span information in the history.\n+                    function attachLocalSpans(doc, change, from, to) {\n+                        var existing = change[\"spans_\" + doc.id],\n+                            n = 0;\n+                        doc.iter(Math.max(doc.first, from), Math.min(doc.first + doc.size, to), function(line) {\n+                            if (line.markedSpans) {\n+                                (existing || (existing = change[\"spans_\" + doc.id] = {}))[n] = line.markedSpans;\n                             }\n+                            ++n;\n+                        });\n+                    }\n+\n+                    // When un/re-doing restores text containing marked spans, those\n+                    // that have been explicitly cleared should not be restored.\n+                    function removeClearedSpans(spans) {\n+                        if (!spans) {\n+                            return null;\n                         }\n-                        /**\n-                         * Determine what role this visual element should take in the variant tree.\n-                         */\n-                        var isControllingVariants = checkIfControllingVariants(props);\n-                        var isVariantNode = checkIfVariantNode(props);\n-                        var element = tslib.__assign(tslib.__assign({\n-                            treeType: treeType,\n-                            /**\n-                             * This is a mirror of the internal instance prop, which keeps\n-                             * VisualElement type-compatible with React's RefObject.\n-                             */\n-                            current: null,\n-                            /**\n-                             * The depth of this visual element within the visual element tree.\n-                             */\n-                            depth: parent ? parent.depth + 1 : 0,\n-                            parent: parent,\n-                            children: new Set(),\n-                            /**\n-                             *\n-                             */\n-                            presenceId: presenceId,\n-                            shouldReduceMotion: shouldReduceMotion,\n-                            /**\n-                             * If this component is part of the variant tree, it should track\n-                             * any children that are also part of the tree. This is essentially\n-                             * a shadow tree to simplify logic around how to stagger over children.\n-                             */\n-                            variantChildren: isVariantNode ? new Set() : undefined,\n-                            /**\n-                             * Whether this instance is visible. This can be changed imperatively\n-                             * by the projection tree, is analogous to CSS's visibility in that\n-                             * hidden elements should take up layout, and needs enacting by the configured\n-                             * render function.\n-                             */\n-                            isVisible: undefined,\n-                            /**\n-                             * Normally, if a component is controlled by a parent's variants, it can\n-                             * rely on that ancestor to trigger animations further down the tree.\n-                             * However, if a component is created after its parent is mounted, the parent\n-                             * won't trigger that mount animation so the child needs to.\n-                             *\n-                             * TODO: This might be better replaced with a method isParentMounted\n-                             */\n-                            manuallyAnimateOnMount: Boolean(parent === null || parent === void 0 ? void 0 : parent.isMounted()),\n-                            /**\n-                             * This can be set by AnimatePresence to force components that mount\n-                             * at the same time as it to mount as if they have initial={false} set.\n-                             */\n-                            blockInitialAnimation: blockInitialAnimation,\n-                            /**\n-                             * Determine whether this component has mounted yet. This is mostly used\n-                             * by variant children to determine whether they need to trigger their\n-                             * own animations on mount.\n-                             */\n-                            isMounted: function() {\n-                                return Boolean(instance);\n-                            },\n-                            mount: function(newInstance) {\n-                                isMounted = true;\n-                                instance = element.current = newInstance;\n-                                if (element.projection) {\n-                                    element.projection.mount(newInstance);\n-                                }\n-                                if (isVariantNode && parent && !isControllingVariants) {\n-                                    removeFromVariantTree = parent === null || parent === void 0 ? void 0 : parent.addVariantChild(element);\n-                                }\n-                                values.forEach(function(value, key) {\n-                                    return bindToMotionValue(key, value);\n-                                });\n-                                parent === null || parent === void 0 ? void 0 : parent.children.add(element);\n-                                element.setProps(props);\n-                            },\n-                            /**\n-                             *\n-                             */\n-                            unmount: function() {\n-                                var _a;\n-                                (_a = element.projection) === null || _a === void 0 ? void 0 : _a.unmount();\n-                                sync.cancelSync.update(update);\n-                                sync.cancelSync.render(render);\n-                                valueSubscriptions.forEach(function(remove) {\n-                                    return remove();\n-                                });\n-                                removeFromVariantTree === null || removeFromVariantTree === void 0 ? void 0 : removeFromVariantTree();\n-                                parent === null || parent === void 0 ? void 0 : parent.children.delete(element);\n-                                lifecycles.clearAllListeners();\n-                                instance = undefined;\n-                                isMounted = false;\n-                            },\n-                            /**\n-                             * Add a child visual element to our set of children.\n-                             */\n-                            addVariantChild: function(child) {\n-                                var _a;\n-                                var closestVariantNode = element.getClosestVariantNode();\n-                                if (closestVariantNode) {\n-                                    (_a = closestVariantNode.variantChildren) === null || _a === void 0 ? void 0 : _a.add(child);\n-                                    return function() {\n-                                        return closestVariantNode.variantChildren.delete(child);\n-                                    };\n-                                }\n-                            },\n-                            sortNodePosition: function(other) {\n-                                /**\n-                                 * If these nodes aren't even of the same type we can't compare their depth.\n-                                 */\n-                                if (!sortNodePosition || treeType !== other.treeType) return 0;\n-                                return sortNodePosition(element.getInstance(), other.getInstance());\n-                            },\n-                            /**\n-                             * Returns the closest variant node in the tree starting from\n-                             * this visual element.\n-                             */\n-                            getClosestVariantNode: function() {\n-                                return isVariantNode ? element : parent === null || parent === void 0 ? void 0 : parent.getClosestVariantNode();\n-                            },\n-                            /**\n-                             * Expose the latest layoutId prop.\n-                             */\n-                            getLayoutId: function() {\n-                                return props.layoutId;\n-                            },\n-                            /**\n-                             * Returns the current instance.\n-                             */\n-                            getInstance: function() {\n-                                return instance;\n-                            },\n-                            /**\n-                             * Get/set the latest static values.\n-                             */\n-                            getStaticValue: function(key) {\n-                                return latestValues[key];\n-                            },\n-                            setStaticValue: function(key, value) {\n-                                return latestValues[key] = value;\n-                            },\n-                            /**\n-                             * Returns the latest motion value state. Currently only used to take\n-                             * a snapshot of the visual element - perhaps this can return the whole\n-                             * visual state\n-                             */\n-                            getLatestValues: function() {\n-                                return latestValues;\n-                            },\n-                            /**\n-                             * Set the visiblity of the visual element. If it's changed, schedule\n-                             * a render to reflect these changes.\n-                             */\n-                            setVisibility: function(visibility) {\n-                                if (element.isVisible === visibility) return;\n-                                element.isVisible = visibility;\n-                                element.scheduleRender();\n-                            },\n-                            /**\n-                             * Make a target animatable by Popmotion. For instance, if we're\n-                             * trying to animate width from 100px to 100vw we need to measure 100vw\n-                             * in pixels to determine what we really need to animate to. This is also\n-                             * pluggable to support Framer's custom value types like Color,\n-                             * and CSS variables.\n-                             */\n-                            makeTargetAnimatable: function(target, canMutate) {\n-                                if (canMutate === void 0) {\n-                                    canMutate = true;\n-                                }\n-                                return makeTargetAnimatable(element, target, props, canMutate);\n-                            },\n-                            /**\n-                             * Measure the current viewport box with or without transforms.\n-                             * Only measures axis-aligned boxes, rotate and skew must be manually\n-                             * removed with a re-render to work.\n-                             */\n-                            measureViewportBox: function() {\n-                                return measureViewportBox(instance, props);\n-                            },\n-                            // Motion values ========================\n-                            /**\n-                             * Add a motion value and bind it to this visual element.\n-                             */\n-                            addValue: function(key, value) {\n-                                // Remove existing value if it exists\n-                                if (element.hasValue(key)) element.removeValue(key);\n-                                values.set(key, value);\n-                                latestValues[key] = value.get();\n-                                bindToMotionValue(key, value);\n-                            },\n-                            /**\n-                             * Remove a motion value and unbind any active subscriptions.\n-                             */\n-                            removeValue: function(key) {\n-                                var _a;\n-                                values.delete(key);\n-                                (_a = valueSubscriptions.get(key)) === null || _a === void 0 ? void 0 : _a();\n-                                valueSubscriptions.delete(key);\n-                                delete latestValues[key];\n-                                removeValueFromRenderState(key, renderState);\n-                            },\n-                            /**\n-                             * Check whether we have a motion value for this key\n-                             */\n-                            hasValue: function(key) {\n-                                return values.has(key);\n-                            },\n-                            /**\n-                             * Get a motion value for this key. If called with a default\n-                             * value, we'll create one if none exists.\n-                             */\n-                            getValue: function(key, defaultValue) {\n-                                var value = values.get(key);\n-                                if (value === undefined && defaultValue !== undefined) {\n-                                    value = motionValue(defaultValue);\n-                                    element.addValue(key, value);\n-                                }\n-                                return value;\n-                            },\n-                            /**\n-                             * Iterate over our motion values.\n-                             */\n-                            forEachValue: function(callback) {\n-                                return values.forEach(callback);\n-                            },\n-                            /**\n-                             * If we're trying to animate to a previously unencountered value,\n-                             * we need to check for it in our state and as a last resort read it\n-                             * directly from the instance (which might have performance implications).\n-                             */\n-                            readValue: function(key) {\n-                                var _a;\n-                                return (_a = latestValues[key]) !== null && _a !== void 0 ? _a : readValueFromInstance(instance, key, options);\n-                            },\n-                            /**\n-                             * Set the base target to later animate back to. This is currently\n-                             * only hydrated on creation and when we first read a value.\n-                             */\n-                            setBaseTarget: function(key, value) {\n-                                baseTarget[key] = value;\n-                            },\n-                            /**\n-                             * Find the base target for a value thats been removed from all animation\n-                             * props.\n-                             */\n-                            getBaseTarget: function(key) {\n-                                if (getBaseTarget) {\n-                                    var target = getBaseTarget(props, key);\n-                                    if (target !== undefined && !isMotionValue(target)) return target;\n+                        var out;\n+                        for (var i = 0; i < spans.length; ++i) {\n+                            if (spans[i].marker.explicitlyCleared) {\n+                                if (!out) {\n+                                    out = spans.slice(0, i);\n                                 }\n-                                return baseTarget[key];\n+                            } else if (out) {\n+                                out.push(spans[i]);\n                             }\n-                        }, lifecycles), {\n-                            /**\n-                             * Build the renderer state based on the latest visual state.\n-                             */\n-                            build: function() {\n-                                triggerBuild();\n-                                return renderState;\n-                            },\n-                            /**\n-                             * Schedule a render on the next animation frame.\n-                             */\n-                            scheduleRender: function() {\n-                                sync__default[\"default\"].render(render, false, true);\n-                            },\n-                            /**\n-                             * Synchronously fire render. It's prefered that we batch renders but\n-                             * in many circumstances, like layout measurement, we need to run this\n-                             * synchronously. However in those instances other measures should be taken\n-                             * to batch reads/writes.\n-                             */\n-                            syncRender: render,\n-                            /**\n-                             * Update the provided props. Ensure any newly-added motion values are\n-                             * added to our map, old ones removed, and listeners updated.\n-                             */\n-                            setProps: function(newProps) {\n-                                if (newProps.transformTemplate || props.transformTemplate) {\n-                                    element.scheduleRender();\n-                                }\n-                                props = newProps;\n-                                lifecycles.updatePropListeners(newProps);\n-                                prevMotionValues = updateMotionValuesFromProps(element, scrapeMotionValuesFromProps(props), prevMotionValues);\n-                            },\n-                            getProps: function() {\n-                                return props;\n-                            },\n-                            // Variants ==============================\n-                            /**\n-                             * Returns the variant definition with a given name.\n-                             */\n-                            getVariant: function(name) {\n-                                var _a;\n-                                return (_a = props.variants) === null || _a === void 0 ? void 0 : _a[name];\n-                            },\n-                            /**\n-                             * Returns the defined default transition on this component.\n-                             */\n-                            getDefaultTransition: function() {\n-                                return props.transition;\n-                            },\n-                            getTransformPagePoint: function() {\n-                                return props.transformPagePoint;\n-                            },\n-                            /**\n-                             * Used by child variant nodes to get the closest ancestor variant props.\n-                             */\n-                            getVariantContext: function(startAtParent) {\n-                                if (startAtParent === void 0) {\n-                                    startAtParent = false;\n-                                }\n-                                if (startAtParent) return parent === null || parent === void 0 ? void 0 : parent.getVariantContext();\n-                                if (!isControllingVariants) {\n-                                    var context_1 = (parent === null || parent === void 0 ? void 0 : parent.getVariantContext()) || {};\n-                                    if (props.initial !== undefined) {\n-                                        context_1.initial = props.initial;\n+                        }\n+                        return !out ? spans : out.length ? out : null;\n+                    }\n+\n+                    // Retrieve and filter the old marked spans stored in a change event.\n+                    function getOldSpans(doc, change) {\n+                        var found = change[\"spans_\" + doc.id];\n+                        if (!found) {\n+                            return null;\n+                        }\n+                        var nw = [];\n+                        for (var i = 0; i < change.text.length; ++i) {\n+                            nw.push(removeClearedSpans(found[i]));\n+                        }\n+                        return nw;\n+                    }\n+\n+                    // Used for un/re-doing changes from the history. Combines the\n+                    // result of computing the existing spans with the set of spans that\n+                    // existed in the history (so that deleting around a span and then\n+                    // undoing brings back the span).\n+                    function mergeOldSpans(doc, change) {\n+                        var old = getOldSpans(doc, change);\n+                        var stretched = stretchSpansOverChange(doc, change);\n+                        if (!old) {\n+                            return stretched;\n+                        }\n+                        if (!stretched) {\n+                            return old;\n+                        }\n+                        for (var i = 0; i < old.length; ++i) {\n+                            var oldCur = old[i],\n+                                stretchCur = stretched[i];\n+                            if (oldCur && stretchCur) {\n+                                spans: for (var j = 0; j < stretchCur.length; ++j) {\n+                                    var span = stretchCur[j];\n+                                    for (var k = 0; k < oldCur.length; ++k) {\n+                                        if (oldCur[k].marker == span.marker) {\n+                                            continue spans;\n+                                        }\n                                     }\n-                                    return context_1;\n+                                    oldCur.push(span);\n                                 }\n-                                var context = {};\n-                                for (var i = 0; i < numVariantProps; i++) {\n-                                    var name_1 = variantProps[i];\n-                                    var prop = props[name_1];\n-                                    if (isVariantLabel(prop) || prop === false) {\n-                                        context[name_1] = prop;\n+                            }\n+                            else if (stretchCur) {\n+                                old[i] = stretchCur;\n+                            }\n+                        }\n+                        return old;\n+                    }\n+\n+                    // Used both to provide a JSON-safe object in .getHistory, and, when\n+                    // detaching a document, to split the history in two\n+                    function copyHistoryArray(events, newGroup, instantiateSel) {\n+                        var copy = [];\n+                        for (var i = 0; i < events.length; ++i) {\n+                            var event = events[i];\n+                            if (event.ranges) {\n+                                copy.push(instantiateSel ? Selection.prototype.deepCopy.call(event) : event);\n+                                continue;\n+                            }\n+                            var changes = event.changes,\n+                                newChanges = [];\n+                            copy.push({\n+                                changes: newChanges\n+                            });\n+                            for (var j = 0; j < changes.length; ++j) {\n+                                var change = changes[j],\n+                                    m = void 0;\n+                                newChanges.push({\n+                                    from: change.from,\n+                                    to: change.to,\n+                                    text: change.text\n+                                });\n+                                if (newGroup) {\n+                                    for (var prop in change) {\n+                                        if (m = prop.match(/^spans_(\\d+)$/)) {\n+                                            if (indexOf(newGroup, Number(m[1])) > -1) {\n+                                                lst(newChanges)[prop] = change[prop];\n+                                                delete change[prop];\n+                                            }\n+                                        }\n                                     }\n                                 }\n-                                return context;\n                             }\n-                        });\n-                        return element;\n-                    };\n-                };\n-                var variantProps = tslib.__spreadArray([\"initial\"], tslib.__read(variantPriorityOrder), false);\n-                var numVariantProps = variantProps.length;\n-\n-                function isCSSVariable(value) {\n-                    return typeof value === \"string\" && value.startsWith(\"var(--\");\n-                }\n-                /**\n-                 * Parse Framer's special CSS variable format into a CSS token and a fallback.\n-                 *\n-                 * ```\n-                 * `var(--foo, #fff)` => [`--foo`, '#fff']\n-                 * ```\n-                 *\n-                 * @param current\n-                 */\n-                var cssVariableRegex = /var\\((--[a-zA-Z0-9-_]+),? ?([a-zA-Z0-9 ()%#.,-]+)?\\)/;\n+                        }\n+                        return copy;\n+                    }\n \n-                function parseCSSVariable(current) {\n-                    var match = cssVariableRegex.exec(current);\n-                    if (!match) return [, ];\n-                    var _a = tslib.__read(match, 3),\n-                        token = _a[1],\n-                        fallback = _a[2];\n-                    return [token, fallback];\n-                }\n-                var maxDepth = 4;\n+                    // The 'scroll' parameter given to many of these indicated whether\n+                    // the new cursor position should be scrolled into view after\n+                    // modifying the selection.\n+\n+                    // If shift is held or the extend flag is set, extends a range to\n+                    // include a given position (and optionally a second position).\n+                    // Otherwise, simply returns the range between the given positions.\n+                    // Used for cursor motion and such.\n+                    function extendRange(range, head, other, extend) {\n+                        if (extend) {\n+                            var anchor = range.anchor;\n+                            if (other) {\n+                                var posBefore = cmp(head, anchor) < 0;\n+                                if (posBefore != cmp(other, anchor) < 0) {\n+                                    anchor = head;\n+                                    head = other;\n+                                } else if (posBefore != cmp(head, other) < 0) {\n+                                    head = other;\n+                                }\n+                            }\n+                            return new Range(anchor, head);\n+                        } else {\n+                            return new Range(other || head, head);\n+                        }\n+                    }\n \n-                function getVariableValue(current, element, depth) {\n-                    if (depth === void 0) {\n-                        depth = 1;\n+                    // Extend the primary selection range, discard the rest.\n+                    function extendSelection(doc, head, other, options, extend) {\n+                        if (extend == null) {\n+                            extend = doc.cm && (doc.cm.display.shift || doc.extend);\n+                        }\n+                        setSelection(doc, new Selection([extendRange(doc.sel.primary(), head, other, extend)], 0), options);\n                     }\n-                    heyListen.invariant(depth <= maxDepth, \"Max CSS variable fallback depth detected in property \\\"\".concat(current, \"\\\". This may indicate a circular fallback dependency.\"));\n-                    var _a = tslib.__read(parseCSSVariable(current), 2),\n-                        token = _a[0],\n-                        fallback = _a[1];\n-                    // No CSS variable detected\n-                    if (!token) return;\n-                    // Attempt to read this CSS variable off the element\n-                    var resolved = window.getComputedStyle(element).getPropertyValue(token);\n-                    if (resolved) {\n-                        return resolved.trim();\n-                    } else if (isCSSVariable(fallback)) {\n-                        // The fallback might itself be a CSS variable, in which case we attempt to resolve it too.\n-                        return getVariableValue(fallback, element, depth + 1);\n-                    } else {\n-                        return fallback;\n+\n+                    // Extend all selections (pos is an array of selections with length\n+                    // equal the number of selections)\n+                    function extendSelections(doc, heads, options) {\n+                        var out = [];\n+                        var extend = doc.cm && (doc.cm.display.shift || doc.extend);\n+                        for (var i = 0; i < doc.sel.ranges.length; i++) {\n+                            out[i] = extendRange(doc.sel.ranges[i], heads[i], null, extend);\n+                        }\n+                        var newSel = normalizeSelection(doc.cm, out, doc.sel.primIndex);\n+                        setSelection(doc, newSel, options);\n                     }\n-                }\n-                /**\n-                 * Resolve CSS variables from\n-                 *\n-                 * @internal\n-                 */\n-                function resolveCSSVariables(visualElement, _a, transitionEnd) {\n-                    var _b;\n-                    var target = tslib.__rest(_a, []);\n-                    var element = visualElement.getInstance();\n-                    if (!(element instanceof Element)) return {\n-                        target: target,\n-                        transitionEnd: transitionEnd\n-                    };\n-                    // If `transitionEnd` isn't `undefined`, clone it. We could clone `target` and `transitionEnd`\n-                    // only if they change but I think this reads clearer and this isn't a performance-critical path.\n-                    if (transitionEnd) {\n-                        transitionEnd = tslib.__assign({}, transitionEnd);\n+\n+                    // Updates a single range in the selection.\n+                    function replaceOneSelection(doc, i, range, options) {\n+                        var ranges = doc.sel.ranges.slice(0);\n+                        ranges[i] = range;\n+                        setSelection(doc, normalizeSelection(doc.cm, ranges, doc.sel.primIndex), options);\n                     }\n-                    // Go through existing `MotionValue`s and ensure any existing CSS variables are resolved\n-                    visualElement.forEachValue(function(value) {\n-                        var current = value.get();\n-                        if (!isCSSVariable(current)) return;\n-                        var resolved = getVariableValue(current, element);\n-                        if (resolved) value.set(resolved);\n-                    });\n-                    // Cycle through every target property and resolve CSS variables. Currently\n-                    // we only read single-var properties like `var(--foo)`, not `calc(var(--foo) + 20px)`\n-                    for (var key in target) {\n-                        var current = target[key];\n-                        if (!isCSSVariable(current)) continue;\n-                        var resolved = getVariableValue(current, element);\n-                        if (!resolved) continue;\n-                        // Clone target if it hasn't already been\n-                        target[key] = resolved;\n-                        // If the user hasn't already set this key on `transitionEnd`, set it to the unresolved\n-                        // CSS variable. This will ensure that after the animation the component will reflect\n-                        // changes in the value of the CSS variable.\n-                        if (transitionEnd)(_b = transitionEnd[key]) !== null && _b !== void 0 ? _b : transitionEnd[key] = current;\n+\n+                    // Reset the selection to a single range.\n+                    function setSimpleSelection(doc, anchor, head, options) {\n+                        setSelection(doc, simpleSelection(anchor, head), options);\n                     }\n-                    return {\n-                        target: target,\n-                        transitionEnd: transitionEnd\n-                    };\n-                }\n-                var positionalKeys = new Set([\"width\", \"height\", \"top\", \"left\", \"right\", \"bottom\", \"x\", \"y\"]);\n-                var isPositionalKey = function(key) {\n-                    return positionalKeys.has(key);\n-                };\n-                var hasPositionalKey = function(target) {\n-                    return Object.keys(target).some(isPositionalKey);\n-                };\n-                var setAndResetVelocity = function(value, to) {\n-                    // Looks odd but setting it twice doesn't render, it'll just\n-                    // set both prev and current to the latest value\n-                    value.set(to, false);\n-                    value.set(to);\n-                };\n-                var isNumOrPxType = function(v) {\n-                    return v === styleValueTypes.number || v === styleValueTypes.px;\n-                };\n-                var BoundingBoxDimension;\n-                (function(BoundingBoxDimension) {\n-                    BoundingBoxDimension[\"width\"] = \"width\";\n-                    BoundingBoxDimension[\"height\"] = \"height\";\n-                    BoundingBoxDimension[\"left\"] = \"left\";\n-                    BoundingBoxDimension[\"right\"] = \"right\";\n-                    BoundingBoxDimension[\"top\"] = \"top\";\n-                    BoundingBoxDimension[\"bottom\"] = \"bottom\";\n-                })(BoundingBoxDimension || (BoundingBoxDimension = {}));\n-                var getPosFromMatrix = function(matrix, pos) {\n-                    return parseFloat(matrix.split(\", \")[pos]);\n-                };\n-                var getTranslateFromMatrix = function(pos2, pos3) {\n-                    return function(_bbox, _a) {\n-                        var transform = _a.transform;\n-                        if (transform === \"none\" || !transform) return 0;\n-                        var matrix3d = transform.match(/^matrix3d\\((.+)\\)$/);\n-                        if (matrix3d) {\n-                            return getPosFromMatrix(matrix3d[1], pos3);\n+\n+                    // Give beforeSelectionChange handlers a change to influence a\n+                    // selection update.\n+                    function filterSelectionChange(doc, sel, options) {\n+                        var obj = {\n+                            ranges: sel.ranges,\n+                            update: function(ranges) {\n+                                this.ranges = [];\n+                                for (var i = 0; i < ranges.length; i++) {\n+                                    this.ranges[i] = new Range(clipPos(doc, ranges[i].anchor), clipPos(doc, ranges[i].head));\n+                                }\n+                            },\n+                            origin: options && options.origin\n+                        };\n+                        signal(doc, \"beforeSelectionChange\", doc, obj);\n+                        if (doc.cm) {\n+                            signal(doc.cm, \"beforeSelectionChange\", doc.cm, obj);\n+                        }\n+                        if (obj.ranges != sel.ranges) {\n+                            return normalizeSelection(doc.cm, obj.ranges, obj.ranges.length - 1);\n                         } else {\n-                            var matrix = transform.match(/^matrix\\((.+)\\)$/);\n-                            if (matrix) {\n-                                return getPosFromMatrix(matrix[1], pos2);\n-                            } else {\n-                                return 0;\n-                            }\n+                            return sel;\n                         }\n-                    };\n-                };\n-                var transformKeys = new Set([\"x\", \"y\", \"z\"]);\n-                var nonTranslationalTransformKeys = transformProps.filter(function(key) {\n-                    return !transformKeys.has(key);\n-                });\n+                    }\n \n-                function removeNonTranslationalTransform(visualElement) {\n-                    var removedTransforms = [];\n-                    nonTranslationalTransformKeys.forEach(function(key) {\n-                        var value = visualElement.getValue(key);\n-                        if (value !== undefined) {\n-                            removedTransforms.push([key, value.get()]);\n-                            value.set(key.startsWith(\"scale\") ? 1 : 0);\n+                    function setSelectionReplaceHistory(doc, sel, options) {\n+                        var done = doc.history.done,\n+                            last = lst(done);\n+                        if (last && last.ranges) {\n+                            done[done.length - 1] = sel;\n+                            setSelectionNoUndo(doc, sel, options);\n+                        } else {\n+                            setSelection(doc, sel, options);\n                         }\n-                    });\n-                    // Apply changes to element before measurement\n-                    if (removedTransforms.length) visualElement.syncRender();\n-                    return removedTransforms;\n-                }\n-                var positionalValues = {\n-                    // Dimensions\n-                    width: function(_a, _b) {\n-                        var x = _a.x;\n-                        var _c = _b.paddingLeft,\n-                            paddingLeft = _c === void 0 ? \"0\" : _c,\n-                            _d = _b.paddingRight,\n-                            paddingRight = _d === void 0 ? \"0\" : _d;\n-                        return x.max - x.min - parseFloat(paddingLeft) - parseFloat(paddingRight);\n-                    },\n-                    height: function(_a, _b) {\n-                        var y = _a.y;\n-                        var _c = _b.paddingTop,\n-                            paddingTop = _c === void 0 ? \"0\" : _c,\n-                            _d = _b.paddingBottom,\n-                            paddingBottom = _d === void 0 ? \"0\" : _d;\n-                        return y.max - y.min - parseFloat(paddingTop) - parseFloat(paddingBottom);\n-                    },\n-                    top: function(_bbox, _a) {\n-                        var top = _a.top;\n-                        return parseFloat(top);\n-                    },\n-                    left: function(_bbox, _a) {\n-                        var left = _a.left;\n-                        return parseFloat(left);\n-                    },\n-                    bottom: function(_a, _b) {\n-                        var y = _a.y;\n-                        var top = _b.top;\n-                        return parseFloat(top) + (y.max - y.min);\n-                    },\n-                    right: function(_a, _b) {\n-                        var x = _a.x;\n-                        var left = _b.left;\n-                        return parseFloat(left) + (x.max - x.min);\n-                    },\n-                    // Transform\n-                    x: getTranslateFromMatrix(4, 13),\n-                    y: getTranslateFromMatrix(5, 14)\n-                };\n-                var convertChangedValueTypes = function(target, visualElement, changedKeys) {\n-                    var originBbox = visualElement.measureViewportBox();\n-                    var element = visualElement.getInstance();\n-                    var elementComputedStyle = getComputedStyle(element);\n-                    var display = elementComputedStyle.display;\n-                    var origin = {};\n-                    // If the element is currently set to display: \"none\", make it visible before\n-                    // measuring the target bounding box\n-                    if (display === \"none\") {\n-                        visualElement.setStaticValue(\"display\", target.display || \"block\");\n                     }\n-                    /**\n-                     * Record origins before we render and update styles\n-                     */\n-                    changedKeys.forEach(function(key) {\n-                        origin[key] = positionalValues[key](originBbox, elementComputedStyle);\n-                    });\n-                    // Apply the latest values (as set in checkAndConvertChangedValueTypes)\n-                    visualElement.syncRender();\n-                    var targetBbox = visualElement.measureViewportBox();\n-                    changedKeys.forEach(function(key) {\n-                        // Restore styles to their **calculated computed style**, not their actual\n-                        // originally set style. This allows us to animate between equivalent pixel units.\n-                        var value = visualElement.getValue(key);\n-                        setAndResetVelocity(value, origin[key]);\n-                        target[key] = positionalValues[key](targetBbox, elementComputedStyle);\n-                    });\n-                    return target;\n-                };\n-                var checkAndConvertChangedValueTypes = function(visualElement, target, origin, transitionEnd) {\n-                    if (origin === void 0) {\n-                        origin = {};\n+\n+                    // Set a new selection.\n+                    function setSelection(doc, sel, options) {\n+                        setSelectionNoUndo(doc, sel, options);\n+                        addSelectionToHistory(doc, doc.sel, doc.cm ? doc.cm.curOp.id : NaN, options);\n                     }\n-                    if (transitionEnd === void 0) {\n-                        transitionEnd = {};\n+\n+                    function setSelectionNoUndo(doc, sel, options) {\n+                        if (hasHandler(doc, \"beforeSelectionChange\") || doc.cm && hasHandler(doc.cm, \"beforeSelectionChange\")) {\n+                            sel = filterSelectionChange(doc, sel, options);\n+                        }\n+                        var bias = options && options.bias || (cmp(sel.primary().head, doc.sel.primary().head) < 0 ? -1 : 1);\n+                        setSelectionInner(doc, skipAtomicInSelection(doc, sel, bias, true));\n+                        if (!(options && options.scroll === false) && doc.cm && doc.cm.getOption(\"readOnly\") != \"nocursor\") {\n+                            ensureCursorVisible(doc.cm);\n+                        }\n                     }\n-                    target = tslib.__assign({}, target);\n-                    transitionEnd = tslib.__assign({}, transitionEnd);\n-                    var targetPositionalKeys = Object.keys(target).filter(isPositionalKey);\n-                    // We want to remove any transform values that could affect the element's bounding box before\n-                    // it's measured. We'll reapply these later.\n-                    var removedTransformValues = [];\n-                    var hasAttemptedToRemoveTransformValues = false;\n-                    var changedValueTypeKeys = [];\n-                    targetPositionalKeys.forEach(function(key) {\n-                        var value = visualElement.getValue(key);\n-                        if (!visualElement.hasValue(key)) return;\n-                        var from = origin[key];\n-                        var fromType = findDimensionValueType(from);\n-                        var to = target[key];\n-                        var toType;\n-                        // TODO: The current implementation of this basically throws an error\n-                        // if you try and do value conversion via keyframes. There's probably\n-                        // a way of doing this but the performance implications would need greater scrutiny,\n-                        // as it'd be doing multiple resize-remeasure operations.\n-                        if (isKeyframesTarget(to)) {\n-                            var numKeyframes = to.length;\n-                            var fromIndex = to[0] === null ? 1 : 0;\n-                            from = to[fromIndex];\n-                            fromType = findDimensionValueType(from);\n-                            for (var i = fromIndex; i < numKeyframes; i++) {\n-                                if (!toType) {\n-                                    toType = findDimensionValueType(to[i]);\n-                                    heyListen.invariant(toType === fromType || isNumOrPxType(fromType) && isNumOrPxType(toType), \"Keyframes must be of the same dimension as the current value\");\n-                                } else {\n-                                    heyListen.invariant(findDimensionValueType(to[i]) === toType, \"All keyframes must be of the same type\");\n+\n+                    function setSelectionInner(doc, sel) {\n+                        if (sel.equals(doc.sel)) {\n+                            return;\n+                        }\n+                        doc.sel = sel;\n+                        if (doc.cm) {\n+                            doc.cm.curOp.updateInput = 1;\n+                            doc.cm.curOp.selectionChanged = true;\n+                            signalCursorActivity(doc.cm);\n+                        }\n+                        signalLater(doc, \"cursorActivity\", doc);\n+                    }\n+\n+                    // Verify that the selection does not partially select any atomic\n+                    // marked ranges.\n+                    function reCheckSelection(doc) {\n+                        setSelectionInner(doc, skipAtomicInSelection(doc, doc.sel, null, false));\n+                    }\n+\n+                    // Return a selection that does not partially select any atomic\n+                    // ranges.\n+                    function skipAtomicInSelection(doc, sel, bias, mayClear) {\n+                        var out;\n+                        for (var i = 0; i < sel.ranges.length; i++) {\n+                            var range = sel.ranges[i];\n+                            var old = sel.ranges.length == doc.sel.ranges.length && doc.sel.ranges[i];\n+                            var newAnchor = skipAtomic(doc, range.anchor, old && old.anchor, bias, mayClear);\n+                            var newHead = skipAtomic(doc, range.head, old && old.head, bias, mayClear);\n+                            if (out || newAnchor != range.anchor || newHead != range.head) {\n+                                if (!out) {\n+                                    out = sel.ranges.slice(0, i);\n+                                }\n+                                out[i] = new Range(newAnchor, newHead);\n+                            }\n+                        }\n+                        return out ? normalizeSelection(doc.cm, out, sel.primIndex) : sel;\n+                    }\n+\n+                    function skipAtomicInner(doc, pos, oldPos, dir, mayClear) {\n+                        var line = getLine(doc, pos.line);\n+                        if (line.markedSpans) {\n+                            for (var i = 0; i < line.markedSpans.length; ++i) {\n+                                var sp = line.markedSpans[i],\n+                                    m = sp.marker;\n+\n+                                // Determine if we should prevent the cursor being placed to the left/right of an atomic marker\n+                                // Historically this was determined using the inclusiveLeft/Right option, but the new way to control it\n+                                // is with selectLeft/Right\n+                                var preventCursorLeft = \"selectLeft\" in m ? !m.selectLeft : m.inclusiveLeft;\n+                                var preventCursorRight = \"selectRight\" in m ? !m.selectRight : m.inclusiveRight;\n+                                if ((sp.from == null || (preventCursorLeft ? sp.from <= pos.ch : sp.from < pos.ch)) && (sp.to == null || (preventCursorRight ? sp.to >= pos.ch : sp.to > pos.ch))) {\n+                                    if (mayClear) {\n+                                        signal(m, \"beforeCursorEnter\");\n+                                        if (m.explicitlyCleared) {\n+                                            if (!line.markedSpans) {\n+                                                break;\n+                                            } else {\n+                                                --i;\n+                                                continue;\n+                                            }\n+                                        }\n+                                    }\n+                                    if (!m.atomic) {\n+                                        continue;\n+                                    }\n+                                    if (oldPos) {\n+                                        var near = m.find(dir < 0 ? 1 : -1),\n+                                            diff = void 0;\n+                                        if (dir < 0 ? preventCursorRight : preventCursorLeft) {\n+                                            near = movePos(doc, near, -dir, near && near.line == pos.line ? line : null);\n+                                        }\n+                                        if (near && near.line == pos.line && (diff = cmp(near, oldPos)) && (dir < 0 ? diff < 0 : diff > 0)) {\n+                                            return skipAtomicInner(doc, near, pos, dir, mayClear);\n+                                        }\n+                                    }\n+                                    var far = m.find(dir < 0 ? -1 : 1);\n+                                    if (dir < 0 ? preventCursorLeft : preventCursorRight) {\n+                                        far = movePos(doc, far, dir, far.line == pos.line ? line : null);\n+                                    }\n+                                    return far ? skipAtomicInner(doc, far, pos, dir, mayClear) : null;\n                                 }\n                             }\n+                        }\n+                        return pos;\n+                    }\n+\n+                    // Ensure a given position is not inside an atomic range.\n+                    function skipAtomic(doc, pos, oldPos, bias, mayClear) {\n+                        var dir = bias || 1;\n+                        var found = skipAtomicInner(doc, pos, oldPos, dir, mayClear) || !mayClear && skipAtomicInner(doc, pos, oldPos, dir, true) || skipAtomicInner(doc, pos, oldPos, -dir, mayClear) || !mayClear && skipAtomicInner(doc, pos, oldPos, -dir, true);\n+                        if (!found) {\n+                            doc.cantEdit = true;\n+                            return Pos(doc.first, 0);\n+                        }\n+                        return found;\n+                    }\n+\n+                    function movePos(doc, pos, dir, line) {\n+                        if (dir < 0 && pos.ch == 0) {\n+                            if (pos.line > doc.first) {\n+                                return clipPos(doc, Pos(pos.line - 1));\n+                            } else {\n+                                return null;\n+                            }\n+                        } else if (dir > 0 && pos.ch == (line || getLine(doc, pos.line)).text.length) {\n+                            if (pos.line < doc.first + doc.size - 1) {\n+                                return Pos(pos.line + 1, 0);\n+                            } else {\n+                                return null;\n+                            }\n                         } else {\n-                            toType = findDimensionValueType(to);\n+                            return new Pos(pos.line, pos.ch + dir);\n                         }\n-                        if (fromType !== toType) {\n-                            // If they're both just number or px, convert them both to numbers rather than\n-                            // relying on resize/remeasure to convert (which is wasteful in this situation)\n-                            if (isNumOrPxType(fromType) && isNumOrPxType(toType)) {\n-                                var current = value.get();\n-                                if (typeof current === \"string\") {\n-                                    value.set(parseFloat(current));\n+                    }\n+\n+                    function selectAll(cm) {\n+                        cm.setSelection(Pos(cm.firstLine(), 0), Pos(cm.lastLine()), sel_dontScroll);\n+                    }\n+\n+                    // UPDATING\n+\n+                    // Allow \"beforeChange\" event handlers to influence a change\n+                    function filterChange(doc, change, update) {\n+                        var obj = {\n+                            canceled: false,\n+                            from: change.from,\n+                            to: change.to,\n+                            text: change.text,\n+                            origin: change.origin,\n+                            cancel: function() {\n+                                return obj.canceled = true;\n+                            }\n+                        };\n+                        if (update) {\n+                            obj.update = function(from, to, text, origin) {\n+                                if (from) {\n+                                    obj.from = clipPos(doc, from);\n                                 }\n-                                if (typeof to === \"string\") {\n-                                    target[key] = parseFloat(to);\n-                                } else if (Array.isArray(to) && toType === styleValueTypes.px) {\n-                                    target[key] = to.map(parseFloat);\n+                                if (to) {\n+                                    obj.to = clipPos(doc, to);\n                                 }\n-                            } else if ((fromType === null || fromType === void 0 ? void 0 : fromType.transform) && (toType === null || toType === void 0 ? void 0 : toType.transform) && (from === 0 || to === 0)) {\n-                                // If one or the other value is 0, it's safe to coerce it to the\n-                                // type of the other without measurement\n-                                if (from === 0) {\n-                                    value.set(toType.transform(from));\n-                                } else {\n-                                    target[key] = fromType.transform(to);\n+                                if (text) {\n+                                    obj.text = text;\n                                 }\n-                            } else {\n-                                // If we're going to do value conversion via DOM measurements, we first\n-                                // need to remove non-positional transform values that could affect the bbox measurements.\n-                                if (!hasAttemptedToRemoveTransformValues) {\n-                                    removedTransformValues = removeNonTranslationalTransform(visualElement);\n-                                    hasAttemptedToRemoveTransformValues = true;\n+                                if (origin !== undefined) {\n+                                    obj.origin = origin;\n                                 }\n-                                changedValueTypeKeys.push(key);\n-                                transitionEnd[key] = transitionEnd[key] !== undefined ? transitionEnd[key] : target[key];\n-                                setAndResetVelocity(value, to);\n-                            }\n+                            };\n                         }\n-                    });\n-                    if (changedValueTypeKeys.length) {\n-                        var scrollY_1 = changedValueTypeKeys.indexOf(\"height\") >= 0 ? window.pageYOffset : null;\n-                        var convertedTarget = convertChangedValueTypes(target, visualElement, changedValueTypeKeys);\n-                        // If we removed transform values, reapply them before the next render\n-                        if (removedTransformValues.length) {\n-                            removedTransformValues.forEach(function(_a) {\n-                                var _b = tslib.__read(_a, 2),\n-                                    key = _b[0],\n-                                    value = _b[1];\n-                                visualElement.getValue(key).set(value);\n-                            });\n+                        signal(doc, \"beforeChange\", doc, obj);\n+                        if (doc.cm) {\n+                            signal(doc.cm, \"beforeChange\", doc.cm, obj);\n+                        }\n+                        if (obj.canceled) {\n+                            if (doc.cm) {\n+                                doc.cm.curOp.updateInput = 2;\n+                            }\n+                            return null;\n                         }\n-                        // Reapply original values\n-                        visualElement.syncRender();\n-                        // Restore scroll position\n-                        if (scrollY_1 !== null) window.scrollTo({\n-                            top: scrollY_1\n-                        });\n-                        return {\n-                            target: convertedTarget,\n-                            transitionEnd: transitionEnd\n-                        };\n-                    } else {\n                         return {\n-                            target: target,\n-                            transitionEnd: transitionEnd\n+                            from: obj.from,\n+                            to: obj.to,\n+                            text: obj.text,\n+                            origin: obj.origin\n                         };\n                     }\n-                };\n-                /**\n-                 * Convert value types for x/y/width/height/top/left/bottom/right\n-                 *\n-                 * Allows animation between `'auto'` -> `'100%'` or `0` -> `'calc(50% - 10vw)'`\n-                 *\n-                 * @internal\n-                 */\n-                function unitConversion(visualElement, target, origin, transitionEnd) {\n-                    return hasPositionalKey(target) ? checkAndConvertChangedValueTypes(visualElement, target, origin, transitionEnd) : {\n-                        target: target,\n-                        transitionEnd: transitionEnd\n-                    };\n-                }\n \n-                /**\n-                 * Parse a DOM variant to make it animatable. This involves resolving CSS variables\n-                 * and ensuring animations like \"20%\" => \"calc(50vw)\" are performed in pixels.\n-                 */\n-                var parseDomVariant = function(visualElement, target, origin, transitionEnd) {\n-                    var resolved = resolveCSSVariables(visualElement, target, transitionEnd);\n-                    target = resolved.target;\n-                    transitionEnd = resolved.transitionEnd;\n-                    return unitConversion(visualElement, target, origin, transitionEnd);\n-                };\n+                    // Apply a change to a document, and add it to the document's\n+                    // history, and propagating it to all linked documents.\n+                    function makeChange(doc, change, ignoreReadOnly) {\n+                        if (doc.cm) {\n+                            if (!doc.cm.curOp) {\n+                                return operation(doc.cm, makeChange)(doc, change, ignoreReadOnly);\n+                            }\n+                            if (doc.cm.state.suppressEdits) {\n+                                return;\n+                            }\n+                        }\n+                        if (hasHandler(doc, \"beforeChange\") || doc.cm && hasHandler(doc.cm, \"beforeChange\")) {\n+                            change = filterChange(doc, change, true);\n+                            if (!change) {\n+                                return;\n+                            }\n+                        }\n \n-                function getComputedStyle$1(element) {\n-                    return window.getComputedStyle(element);\n-                }\n-                var htmlConfig = {\n-                    treeType: \"dom\",\n-                    readValueFromInstance: function(domElement, key) {\n-                        if (isTransformProp(key)) {\n-                            var defaultType = getDefaultValueType(key);\n-                            return defaultType ? defaultType.default || 0 : 0;\n+                        // Possibly split or suppress the update based on the presence\n+                        // of read-only spans in its range.\n+                        var split = sawReadOnlySpans && !ignoreReadOnly && removeReadOnlyRanges(doc, change.from, change.to);\n+                        if (split) {\n+                            for (var i = split.length - 1; i >= 0; --i) {\n+                                makeChangeInner(doc, {\n+                                    from: split[i].from,\n+                                    to: split[i].to,\n+                                    text: i ? [\"\"] : change.text,\n+                                    origin: change.origin\n+                                });\n+                            }\n                         } else {\n-                            var computedStyle = getComputedStyle$1(domElement);\n-                            return (isCSSVariable$1(key) ? computedStyle.getPropertyValue(key) : computedStyle[key]) || 0;\n+                            makeChangeInner(doc, change);\n                         }\n-                    },\n-                    sortNodePosition: function(a, b) {\n-                        /**\n-                         * compareDocumentPosition returns a bitmask, by using the bitwise &\n-                         * we're returning true if 2 in that bitmask is set to true. 2 is set\n-                         * to true if b preceeds a.\n-                         */\n-                        return a.compareDocumentPosition(b) & 2 ? 1 : -1;\n-                    },\n-                    getBaseTarget: function(props, key) {\n-                        var _a;\n-                        return (_a = props.style) === null || _a === void 0 ? void 0 : _a[key];\n-                    },\n-                    measureViewportBox: function(element, _a) {\n-                        var transformPagePoint = _a.transformPagePoint;\n-                        return measureViewportBox(element, transformPagePoint);\n-                    },\n-                    /**\n-                     * Reset the transform on the current Element. This is called as part\n-                     * of a batched process across the entire layout tree. To remove this write\n-                     * cycle it'd be interesting to see if it's possible to \"undo\" all the current\n-                     * layout transforms up the tree in the same way this.getBoundingBoxWithoutTransforms\n-                     * works\n-                     */\n-                    resetTransform: function(element, domElement, props) {\n-                        var transformTemplate = props.transformTemplate;\n-                        domElement.style.transform = transformTemplate ? transformTemplate({}, \"\") : \"none\";\n-                        // Ensure that whatever happens next, we restore our transform on the next frame\n-                        element.scheduleRender();\n-                    },\n-                    restoreTransform: function(instance, mutableState) {\n-                        instance.style.transform = mutableState.style.transform;\n-                    },\n-                    removeValueFromRenderState: function(key, _a) {\n-                        var vars = _a.vars,\n-                            style = _a.style;\n-                        delete vars[key];\n-                        delete style[key];\n-                    },\n-                    /**\n-                     * Ensure that HTML and Framer-specific value types like `px`->`%` and `Color`\n-                     * can be animated by Motion.\n-                     */\n-                    makeTargetAnimatable: function(element, _a, _b, isMounted) {\n-                        var transformValues = _b.transformValues;\n-                        if (isMounted === void 0) {\n-                            isMounted = true;\n+                    }\n+\n+                    function makeChangeInner(doc, change) {\n+                        if (change.text.length == 1 && change.text[0] == \"\" && cmp(change.from, change.to) == 0) {\n+                            return;\n                         }\n-                        var transition = _a.transition,\n-                            transitionEnd = _a.transitionEnd,\n-                            target = tslib.__rest(_a, [\"transition\", \"transitionEnd\"]);\n-                        var origin = getOrigin(target, transition || {}, element);\n-                        /**\n-                         * If Framer has provided a function to convert `Color` etc value types, convert them\n-                         */\n-                        if (transformValues) {\n-                            if (transitionEnd) transitionEnd = transformValues(transitionEnd);\n-                            if (target) target = transformValues(target);\n-                            if (origin) origin = transformValues(origin);\n+                        var selAfter = computeSelAfterChange(doc, change);\n+                        addChangeToHistory(doc, change, selAfter, doc.cm ? doc.cm.curOp.id : NaN);\n+                        makeChangeSingleDoc(doc, change, selAfter, stretchSpansOverChange(doc, change));\n+                        var rebased = [];\n+                        linkedDocs(doc, function(doc, sharedHist) {\n+                            if (!sharedHist && indexOf(rebased, doc.history) == -1) {\n+                                rebaseHist(doc.history, change);\n+                                rebased.push(doc.history);\n+                            }\n+                            makeChangeSingleDoc(doc, change, null, stretchSpansOverChange(doc, change));\n+                        });\n+                    }\n+\n+                    // Revert a change stored in a document's history.\n+                    function makeChangeFromHistory(doc, type, allowSelectionOnly) {\n+                        var suppress = doc.cm && doc.cm.state.suppressEdits;\n+                        if (suppress && !allowSelectionOnly) {\n+                            return;\n                         }\n-                        if (isMounted) {\n-                            checkTargetForNewValues(element, target, origin);\n-                            var parsed = parseDomVariant(element, target, origin, transitionEnd);\n-                            transitionEnd = parsed.transitionEnd;\n-                            target = parsed.target;\n+                        var hist = doc.history,\n+                            event,\n+                            selAfter = doc.sel;\n+                        var source = type == \"undo\" ? hist.done : hist.undone,\n+                            dest = type == \"undo\" ? hist.undone : hist.done;\n+\n+                        // Verify that there is a useable event (so that ctrl-z won't\n+                        // needlessly clear selection events)\n+                        var i = 0;\n+                        for (; i < source.length; i++) {\n+                            event = source[i];\n+                            if (allowSelectionOnly ? event.ranges && !event.equals(doc.sel) : !event.ranges) {\n+                                break;\n+                            }\n                         }\n-                        return tslib.__assign({\n-                            transition: transition,\n-                            transitionEnd: transitionEnd\n-                        }, target);\n-                    },\n-                    scrapeMotionValuesFromProps: scrapeMotionValuesFromProps$1,\n-                    build: function(element, renderState, latestValues, options, props) {\n-                        if (element.isVisible !== undefined) {\n-                            renderState.style.visibility = element.isVisible ? \"visible\" : \"hidden\";\n+                        if (i == source.length) {\n+                            return;\n                         }\n-                        buildHTMLStyles(renderState, latestValues, options, props.transformTemplate);\n-                    },\n-                    render: renderHTML\n-                };\n-                var htmlVisualElement = visualElement(htmlConfig);\n-                var svgVisualElement = visualElement(tslib.__assign(tslib.__assign({}, htmlConfig), {\n-                    getBaseTarget: function(props, key) {\n-                        return props[key];\n-                    },\n-                    readValueFromInstance: function(domElement, key) {\n-                        var _a;\n-                        if (isTransformProp(key)) {\n-                            return ((_a = getDefaultValueType(key)) === null || _a === void 0 ? void 0 : _a.default) || 0;\n+                        hist.lastOrigin = hist.lastSelOrigin = null;\n+                        for (;;) {\n+                            event = source.pop();\n+                            if (event.ranges) {\n+                                pushSelectionToHistory(event, dest);\n+                                if (allowSelectionOnly && !event.equals(doc.sel)) {\n+                                    setSelection(doc, event, {\n+                                        clearRedo: false\n+                                    });\n+                                    return;\n+                                }\n+                                selAfter = event;\n+                            } else if (suppress) {\n+                                source.push(event);\n+                                return;\n+                            } else {\n+                                break;\n+                            }\n                         }\n-                        key = !camelCaseAttributes.has(key) ? camelToDash(key) : key;\n-                        return domElement.getAttribute(key);\n-                    },\n-                    scrapeMotionValuesFromProps: scrapeMotionValuesFromProps,\n-                    build: function(_element, renderState, latestValues, options, props) {\n-                        buildSVGAttrs(renderState, latestValues, options, props.transformTemplate);\n-                    },\n-                    render: renderSVG\n-                }));\n-                var createDomVisualElement = function(Component, options) {\n-                    return isSVGComponent(Component) ? svgVisualElement(options, {\n-                        enableHardwareAcceleration: false\n-                    }) : htmlVisualElement(options, {\n-                        enableHardwareAcceleration: true\n-                    });\n-                };\n \n-                function pixelsToPercent(pixels, axis) {\n-                    if (axis.max === axis.min) return 0;\n-                    return pixels / (axis.max - axis.min) * 100;\n-                }\n-                /**\n-                 * We always correct borderRadius as a percentage rather than pixels to reduce paints.\n-                 * For example, if you are projecting a box that is 100px wide with a 10px borderRadius\n-                 * into a box that is 200px wide with a 20px borderRadius, that is actually a 10%\n-                 * borderRadius in both states. If we animate between the two in pixels that will trigger\n-                 * a paint each time. If we animate between the two in percentage we'll avoid a paint.\n-                 */\n-                var correctBorderRadius = {\n-                    correct: function(latest, node) {\n-                        if (!node.target) return latest;\n-                        /**\n-                         * If latest is a string, if it's a percentage we can return immediately as it's\n-                         * going to be stretched appropriately. Otherwise, if it's a pixel, convert it to a number.\n-                         */\n-                        if (typeof latest === \"string\") {\n-                            if (styleValueTypes.px.test(latest)) {\n-                                latest = parseFloat(latest);\n-                            } else {\n-                                return latest;\n+                        // Build up a reverse change object to add to the opposite history\n+                        // stack (redo when undoing, and vice versa).\n+                        var antiChanges = [];\n+                        pushSelectionToHistory(selAfter, dest);\n+                        dest.push({\n+                            changes: antiChanges,\n+                            generation: hist.generation\n+                        });\n+                        hist.generation = event.generation || ++hist.maxGeneration;\n+                        var filter = hasHandler(doc, \"beforeChange\") || doc.cm && hasHandler(doc.cm, \"beforeChange\");\n+                        var loop = function(i) {\n+                            var change = event.changes[i];\n+                            change.origin = type;\n+                            if (filter && !filterChange(doc, change, false)) {\n+                                source.length = 0;\n+                                return {};\n+                            }\n+                            antiChanges.push(historyChangeFromChange(doc, change));\n+                            var after = i ? computeSelAfterChange(doc, change) : lst(source);\n+                            makeChangeSingleDoc(doc, change, after, mergeOldSpans(doc, change));\n+                            if (!i && doc.cm) {\n+                                doc.cm.scrollIntoView({\n+                                    from: change.from,\n+                                    to: changeEnd(change)\n+                                });\n                             }\n+                            var rebased = [];\n+\n+                            // Propagate to the linked documents\n+                            linkedDocs(doc, function(doc, sharedHist) {\n+                                if (!sharedHist && indexOf(rebased, doc.history) == -1) {\n+                                    rebaseHist(doc.history, change);\n+                                    rebased.push(doc.history);\n+                                }\n+                                makeChangeSingleDoc(doc, change, null, mergeOldSpans(doc, change));\n+                            });\n+                        };\n+                        for (var i$1 = event.changes.length - 1; i$1 >= 0; --i$1) {\n+                            var returned = loop(i$1);\n+                            if (returned) return returned.v;\n                         }\n-                        /**\n-                         * If latest is a number, it's a pixel value. We use the current viewportBox to calculate that\n-                         * pixel value as a percentage of each axis\n-                         */\n-                        var x = pixelsToPercent(latest, node.target.x);\n-                        var y = pixelsToPercent(latest, node.target.y);\n-                        return \"\".concat(x, \"% \").concat(y, \"%\");\n                     }\n-                };\n-                var varToken = \"_$css\";\n-                var correctBoxShadow = {\n-                    correct: function(latest, _a) {\n-                        var treeScale = _a.treeScale,\n-                            projectionDelta = _a.projectionDelta;\n-                        var original = latest;\n-                        /**\n-                         * We need to first strip and store CSS variables from the string.\n-                         */\n-                        var containsCSSVariables = latest.includes(\"var(\");\n-                        var cssVariables = [];\n-                        if (containsCSSVariables) {\n-                            latest = latest.replace(cssVariableRegex, function(match) {\n-                                cssVariables.push(match);\n-                                return varToken;\n-                            });\n+\n+                    // Sub-views need their line numbers shifted when text is added\n+                    // above or below them in the parent document.\n+                    function shiftDoc(doc, distance) {\n+                        if (distance == 0) {\n+                            return;\n                         }\n-                        var shadow = styleValueTypes.complex.parse(latest);\n-                        // TODO: Doesn't support multiple shadows\n-                        if (shadow.length > 5) return original;\n-                        var template = styleValueTypes.complex.createTransformer(latest);\n-                        var offset = typeof shadow[0] !== \"number\" ? 1 : 0;\n-                        // Calculate the overall context scale\n-                        var xScale = projectionDelta.x.scale * treeScale.x;\n-                        var yScale = projectionDelta.y.scale * treeScale.y;\n-                        shadow[0 + offset] /= xScale;\n-                        shadow[1 + offset] /= yScale;\n-                        /**\n-                         * Ideally we'd correct x and y scales individually, but because blur and\n-                         * spread apply to both we have to take a scale average and apply that instead.\n-                         * We could potentially improve the outcome of this by incorporating the ratio between\n-                         * the two scales.\n-                         */\n-                        var averageScale = popmotion.mix(xScale, yScale, 0.5);\n-                        // Blur\n-                        if (typeof shadow[2 + offset] === \"number\") shadow[2 + offset] /= averageScale;\n-                        // Spread\n-                        if (typeof shadow[3 + offset] === \"number\") shadow[3 + offset] /= averageScale;\n-                        var output = template(shadow);\n-                        if (containsCSSVariables) {\n-                            var i_1 = 0;\n-                            output = output.replace(varToken, function() {\n-                                var cssVariable = cssVariables[i_1];\n-                                i_1++;\n-                                return cssVariable;\n-                            });\n+                        doc.first += distance;\n+                        doc.sel = new Selection(map(doc.sel.ranges, function(range) {\n+                            return new Range(Pos(range.anchor.line + distance, range.anchor.ch), Pos(range.head.line + distance, range.head.ch));\n+                        }), doc.sel.primIndex);\n+                        if (doc.cm) {\n+                            regChange(doc.cm, doc.first, doc.first - distance, distance);\n+                            for (var d = doc.cm.display, l = d.viewFrom; l < d.viewTo; l++) {\n+                                regLineChange(doc.cm, l, \"gutter\");\n+                            }\n                         }\n-                        return output;\n                     }\n-                };\n-                var MeasureLayoutWithContext = /** @class */ function(_super) {\n-                    tslib.__extends(MeasureLayoutWithContext, _super);\n \n-                    function MeasureLayoutWithContext() {\n-                        return _super !== null && _super.apply(this, arguments) || this;\n+                    // More lower-level change function, handling only a single document\n+                    // (not linked ones).\n+                    function makeChangeSingleDoc(doc, change, selAfter, spans) {\n+                        if (doc.cm && !doc.cm.curOp) {\n+                            return operation(doc.cm, makeChangeSingleDoc)(doc, change, selAfter, spans);\n+                        }\n+                        if (change.to.line < doc.first) {\n+                            shiftDoc(doc, change.text.length - 1 - (change.to.line - change.from.line));\n+                            return;\n+                        }\n+                        if (change.from.line > doc.lastLine()) {\n+                            return;\n+                        }\n+\n+                        // Clip the change to the size of this doc\n+                        if (change.from.line < doc.first) {\n+                            var shift = change.text.length - 1 - (doc.first - change.from.line);\n+                            shiftDoc(doc, shift);\n+                            change = {\n+                                from: Pos(doc.first, 0),\n+                                to: Pos(change.to.line + shift, change.to.ch),\n+                                text: [lst(change.text)],\n+                                origin: change.origin\n+                            };\n+                        }\n+                        var last = doc.lastLine();\n+                        if (change.to.line > last) {\n+                            change = {\n+                                from: change.from,\n+                                to: Pos(last, getLine(doc, last).text.length),\n+                                text: [change.text[0]],\n+                                origin: change.origin\n+                            };\n+                        }\n+                        change.removed = getBetween(doc, change.from, change.to);\n+                        if (!selAfter) {\n+                            selAfter = computeSelAfterChange(doc, change);\n+                        }\n+                        if (doc.cm) {\n+                            makeChangeSingleDocInEditor(doc.cm, change, spans);\n+                        } else {\n+                            updateDoc(doc, change, spans);\n+                        }\n+                        setSelectionNoUndo(doc, selAfter, sel_dontScroll);\n+                        if (doc.cantEdit && skipAtomic(doc, Pos(doc.firstLine(), 0))) {\n+                            doc.cantEdit = false;\n+                        }\n                     }\n-                    /**\n-                     * This only mounts projection nodes for components that\n-                     * need measuring, we might want to do it for all components\n-                     * in order to incorporate transforms\n-                     */\n-                    MeasureLayoutWithContext.prototype.componentDidMount = function() {\n-                        var _this = this;\n-                        var _a = this.props,\n-                            visualElement = _a.visualElement,\n-                            layoutGroup = _a.layoutGroup,\n-                            switchLayoutGroup = _a.switchLayoutGroup,\n-                            layoutId = _a.layoutId;\n-                        var projection = visualElement.projection;\n-                        addScaleCorrector(defaultScaleCorrectors);\n-                        if (projection) {\n-                            if (layoutGroup === null || layoutGroup === void 0 ? void 0 : layoutGroup.group) layoutGroup.group.add(projection);\n-                            if ((switchLayoutGroup === null || switchLayoutGroup === void 0 ? void 0 : switchLayoutGroup.register) && layoutId) {\n-                                switchLayoutGroup.register(projection);\n-                            }\n-                            projection.root.didUpdate();\n-                            projection.addEventListener(\"animationComplete\", function() {\n-                                _this.safeToRemove();\n-                            });\n-                            projection.setOptions(tslib.__assign(tslib.__assign({}, projection.options), {\n-                                onExitComplete: function() {\n-                                    return _this.safeToRemove();\n+\n+                    // Handle the interaction of a change to a document with the editor\n+                    // that this document is part of.\n+                    function makeChangeSingleDocInEditor(cm, change, spans) {\n+                        var doc = cm.doc,\n+                            display = cm.display,\n+                            from = change.from,\n+                            to = change.to;\n+                        var recomputeMaxLength = false,\n+                            checkWidthStart = from.line;\n+                        if (!cm.options.lineWrapping) {\n+                            checkWidthStart = lineNo(visualLine(getLine(doc, from.line)));\n+                            doc.iter(checkWidthStart, to.line + 1, function(line) {\n+                                if (line == display.maxLine) {\n+                                    recomputeMaxLength = true;\n+                                    return true;\n                                 }\n-                            }));\n+                            });\n                         }\n-                        globalProjectionState.hasEverUpdated = true;\n-                    };\n-                    MeasureLayoutWithContext.prototype.getSnapshotBeforeUpdate = function(prevProps) {\n-                        var _this = this;\n-                        var _a = this.props,\n-                            layoutDependency = _a.layoutDependency,\n-                            visualElement = _a.visualElement,\n-                            drag = _a.drag,\n-                            isPresent = _a.isPresent;\n-                        var projection = visualElement.projection;\n-                        if (!projection) return null;\n-                        /**\n-                         * TODO: We use this data in relegate to determine whether to\n-                         * promote a previous element. There's no guarantee its presence data\n-                         * will have updated by this point - if a bug like this arises it will\n-                         * have to be that we markForRelegation and then find a new lead some other way,\n-                         * perhaps in didUpdate\n-                         */\n-                        projection.isPresent = isPresent;\n-                        if (drag || prevProps.layoutDependency !== layoutDependency || layoutDependency === undefined) {\n-                            projection.willUpdate();\n+                        if (doc.sel.contains(change.from, change.to) > -1) {\n+                            signalCursorActivity(cm);\n+                        }\n+                        updateDoc(doc, change, spans, estimateHeight(cm));\n+                        if (!cm.options.lineWrapping) {\n+                            doc.iter(checkWidthStart, from.line + change.text.length, function(line) {\n+                                var len = lineLength(line);\n+                                if (len > display.maxLineLength) {\n+                                    display.maxLine = line;\n+                                    display.maxLineLength = len;\n+                                    display.maxLineChanged = true;\n+                                    recomputeMaxLength = false;\n+                                }\n+                            });\n+                            if (recomputeMaxLength) {\n+                                cm.curOp.updateMaxLine = true;\n+                            }\n+                        }\n+                        retreatFrontier(doc, from.line);\n+                        startWorker(cm, 400);\n+                        var lendiff = change.text.length - (to.line - from.line) - 1;\n+                        // Remember that these lines changed, for updating the display\n+                        if (change.full) {\n+                            regChange(cm);\n+                        } else if (from.line == to.line && change.text.length == 1 && !isWholeLineUpdate(cm.doc, change)) {\n+                            regLineChange(cm, from.line, \"text\");\n                         } else {\n-                            this.safeToRemove();\n+                            regChange(cm, from.line, to.line + 1, lendiff);\n                         }\n-                        if (prevProps.isPresent !== isPresent) {\n-                            if (isPresent) {\n-                                projection.promote();\n-                            } else if (!projection.relegate()) {\n-                                /**\n-                                 * If there's another stack member taking over from this one,\n-                                 * it's in charge of the exit animation and therefore should\n-                                 * be in charge of the safe to remove. Otherwise we call it here.\n-                                 */\n-                                sync__default[\"default\"].postRender(function() {\n-                                    var _a;\n-                                    if (!((_a = projection.getStack()) === null || _a === void 0 ? void 0 : _a.members.length)) {\n-                                        _this.safeToRemove();\n-                                    }\n-                                });\n+                        var changesHandler = hasHandler(cm, \"changes\"),\n+                            changeHandler = hasHandler(cm, \"change\");\n+                        if (changeHandler || changesHandler) {\n+                            var obj = {\n+                                from: from,\n+                                to: to,\n+                                text: change.text,\n+                                removed: change.removed,\n+                                origin: change.origin\n+                            };\n+                            if (changeHandler) {\n+                                signalLater(cm, \"change\", cm, obj);\n                             }\n-                        }\n-                        return null;\n-                    };\n-                    MeasureLayoutWithContext.prototype.componentDidUpdate = function() {\n-                        var projection = this.props.visualElement.projection;\n-                        if (projection) {\n-                            projection.root.didUpdate();\n-                            if (!projection.currentAnimation && projection.isLead()) {\n-                                this.safeToRemove();\n+                            if (changesHandler) {\n+                                (cm.curOp.changeObjs || (cm.curOp.changeObjs = [])).push(obj);\n                             }\n                         }\n-                    };\n-                    MeasureLayoutWithContext.prototype.componentWillUnmount = function() {\n-                        var _a = this.props,\n-                            visualElement = _a.visualElement,\n-                            layoutGroup = _a.layoutGroup,\n-                            promoteContext = _a.switchLayoutGroup;\n-                        var projection = visualElement.projection;\n-                        if (projection) {\n-                            projection.scheduleCheckAfterUnmount();\n-                            if (layoutGroup === null || layoutGroup === void 0 ? void 0 : layoutGroup.group) layoutGroup.group.remove(projection);\n-                            if (promoteContext === null || promoteContext === void 0 ? void 0 : promoteContext.deregister) promoteContext.deregister(projection);\n+                        cm.display.selForContextMenu = null;\n+                    }\n+\n+                    function replaceRange(doc, code, from, to, origin) {\n+                        var assign;\n+                        if (!to) {\n+                            to = from;\n                         }\n-                    };\n-                    MeasureLayoutWithContext.prototype.safeToRemove = function() {\n-                        var safeToRemove = this.props.safeToRemove;\n-                        safeToRemove === null || safeToRemove === void 0 ? void 0 : safeToRemove();\n-                    };\n-                    MeasureLayoutWithContext.prototype.render = function() {\n-                        return null;\n-                    };\n-                    return MeasureLayoutWithContext;\n-                }(React__default[\"default\"].Component);\n+                        if (cmp(to, from) < 0) {\n+                            assign = [to, from], from = assign[0], to = assign[1];\n+                        }\n+                        if (typeof code == \"string\") {\n+                            code = doc.splitLines(code);\n+                        }\n+                        makeChange(doc, {\n+                            from: from,\n+                            to: to,\n+                            text: code,\n+                            origin: origin\n+                        });\n+                    }\n \n-                function MeasureLayout(props) {\n-                    var _a = tslib.__read(usePresence(), 2),\n-                        isPresent = _a[0],\n-                        safeToRemove = _a[1];\n-                    var layoutGroup = React.useContext(LayoutGroupContext);\n-                    return React__default[\"default\"].createElement(MeasureLayoutWithContext, tslib.__assign({}, props, {\n-                        layoutGroup: layoutGroup,\n-                        switchLayoutGroup: React.useContext(SwitchLayoutGroupContext),\n-                        isPresent: isPresent,\n-                        safeToRemove: safeToRemove\n-                    }));\n-                }\n-                var defaultScaleCorrectors = {\n-                    borderRadius: tslib.__assign(tslib.__assign({}, correctBorderRadius), {\n-                        applyTo: [\"borderTopLeftRadius\", \"borderTopRightRadius\", \"borderBottomLeftRadius\", \"borderBottomRightRadius\"]\n-                    }),\n-                    borderTopLeftRadius: correctBorderRadius,\n-                    borderTopRightRadius: correctBorderRadius,\n-                    borderBottomLeftRadius: correctBorderRadius,\n-                    borderBottomRightRadius: correctBorderRadius,\n-                    boxShadow: correctBoxShadow\n-                };\n-                var layoutFeatures = {\n-                    measureLayout: MeasureLayout\n-                };\n+                    // Rebasing/resetting history to deal with externally-sourced changes\n \n-                /**\n-                 * Animate a single value or a `MotionValue`.\n-                 *\n-                 * The first argument is either a `MotionValue` to animate, or an initial animation value.\n-                 *\n-                 * The second is either a value to animate to, or an array of keyframes to animate through.\n-                 *\n-                 * The third argument can be either tween or spring options, and optional lifecycle methods: `onUpdate`, `onPlay`, `onComplete`, `onRepeat` and `onStop`.\n-                 *\n-                 * Returns `AnimationPlaybackControls`, currently just a `stop` method.\n-                 *\n-                 * ```javascript\n-                 * const x = useMotionValue(0)\n-                 *\n-                 * useEffect(() => {\n-                 *   const controls = animate(x, 100, {\n-                 *     type: \"spring\",\n-                 *     stiffness: 2000,\n-                 *     onComplete: v => {}\n-                 *   })\n-                 *\n-                 *   return controls.stop\n-                 * })\n-                 * ```\n-                 *\n-                 * @public\n-                 */\n-                function animate(from, to, transition) {\n-                    if (transition === void 0) {\n-                        transition = {};\n+                    function rebaseHistSelSingle(pos, from, to, diff) {\n+                        if (to < pos.line) {\n+                            pos.line += diff;\n+                        } else if (from < pos.line) {\n+                            pos.line = from;\n+                            pos.ch = 0;\n+                        }\n                     }\n-                    var value = isMotionValue(from) ? from : motionValue(from);\n-                    startAnimation(\"\", value, to, transition);\n-                    return {\n-                        stop: function() {\n-                            return value.stop();\n-                        },\n-                        isAnimating: function() {\n-                            return value.isAnimating();\n+\n+                    // Tries to rebase an array of history events given a change in the\n+                    // document. If the change touches the same lines as the event, the\n+                    // event, and everything 'behind' it, is discarded. If the change is\n+                    // before the event, the event's positions are updated. Uses a\n+                    // copy-on-write scheme for the positions, to avoid having to\n+                    // reallocate them all on every rebase, but also avoid problems with\n+                    // shared position objects being unsafely updated.\n+                    function rebaseHistArray(array, from, to, diff) {\n+                        for (var i = 0; i < array.length; ++i) {\n+                            var sub = array[i],\n+                                ok = true;\n+                            if (sub.ranges) {\n+                                if (!sub.copied) {\n+                                    sub = array[i] = sub.deepCopy();\n+                                    sub.copied = true;\n+                                }\n+                                for (var j = 0; j < sub.ranges.length; j++) {\n+                                    rebaseHistSelSingle(sub.ranges[j].anchor, from, to, diff);\n+                                    rebaseHistSelSingle(sub.ranges[j].head, from, to, diff);\n+                                }\n+                                continue;\n+                            }\n+                            for (var j$1 = 0; j$1 < sub.changes.length; ++j$1) {\n+                                var cur = sub.changes[j$1];\n+                                if (to < cur.from.line) {\n+                                    cur.from = Pos(cur.from.line + diff, cur.from.ch);\n+                                    cur.to = Pos(cur.to.line + diff, cur.to.ch);\n+                                } else if (from <= cur.to.line) {\n+                                    ok = false;\n+                                    break;\n+                                }\n+                            }\n+                            if (!ok) {\n+                                array.splice(0, i + 1);\n+                                i = 0;\n+                            }\n                         }\n-                    };\n-                }\n-                var borders = [\"TopLeft\", \"TopRight\", \"BottomLeft\", \"BottomRight\"];\n-                var numBorders = borders.length;\n-                var asNumber = function(value) {\n-                    return typeof value === \"string\" ? parseFloat(value) : value;\n-                };\n-                var isPx = function(value) {\n-                    return typeof value === \"number\" || styleValueTypes.px.test(value);\n-                };\n+                    }\n \n-                function mixValues(target, follow, lead, progress, shouldCrossfadeOpacity, isOnlyMember) {\n-                    var _a, _b, _c, _d;\n-                    if (shouldCrossfadeOpacity) {\n-                        target.opacity = popmotion.mix(0,\n-                            // (follow?.opacity as number) ?? 0,\n-                            // TODO Reinstate this if only child\n-                            (_a = lead.opacity) !== null && _a !== void 0 ? _a : 1, easeCrossfadeIn(progress));\n-                        target.opacityExit = popmotion.mix((_b = follow.opacity) !== null && _b !== void 0 ? _b : 1, 0, easeCrossfadeOut(progress));\n-                    } else if (isOnlyMember) {\n-                        target.opacity = popmotion.mix((_c = follow.opacity) !== null && _c !== void 0 ? _c : 1, (_d = lead.opacity) !== null && _d !== void 0 ? _d : 1, progress);\n+                    function rebaseHist(hist, change) {\n+                        var from = change.from.line,\n+                            to = change.to.line,\n+                            diff = change.text.length - (to - from) - 1;\n+                        rebaseHistArray(hist.done, from, to, diff);\n+                        rebaseHistArray(hist.undone, from, to, diff);\n                     }\n-                    /**\n-                     * Mix border radius\n-                     */\n-                    for (var i = 0; i < numBorders; i++) {\n-                        var borderLabel = \"border\".concat(borders[i], \"Radius\");\n-                        var followRadius = getRadius(follow, borderLabel);\n-                        var leadRadius = getRadius(lead, borderLabel);\n-                        if (followRadius === undefined && leadRadius === undefined) continue;\n-                        followRadius || (followRadius = 0);\n-                        leadRadius || (leadRadius = 0);\n-                        var canMix = followRadius === 0 || leadRadius === 0 || isPx(followRadius) === isPx(leadRadius);\n-                        if (canMix) {\n-                            target[borderLabel] = Math.max(popmotion.mix(asNumber(followRadius), asNumber(leadRadius), progress), 0);\n-                            if (styleValueTypes.percent.test(leadRadius) || styleValueTypes.percent.test(followRadius)) {\n-                                target[borderLabel] += \"%\";\n-                            }\n+\n+                    // Utility for applying a change to a line by handle or number,\n+                    // returning the number and optionally registering the line as\n+                    // changed.\n+                    function changeLine(doc, handle, changeType, op) {\n+                        var no = handle,\n+                            line = handle;\n+                        if (typeof handle == \"number\") {\n+                            line = getLine(doc, clipLine(doc, handle));\n                         } else {\n-                            target[borderLabel] = leadRadius;\n+                            no = lineNo(handle);\n                         }\n+                        if (no == null) {\n+                            return null;\n+                        }\n+                        if (op(line, no) && doc.cm) {\n+                            regLineChange(doc.cm, no, changeType);\n+                        }\n+                        return line;\n                     }\n-                    /**\n-                     * Mix rotation\n-                     */\n-                    if (follow.rotate || lead.rotate) {\n-                        target.rotate = popmotion.mix(follow.rotate || 0, lead.rotate || 0, progress);\n-                    }\n-                }\n \n-                function getRadius(values, radiusName) {\n-                    var _a;\n-                    return (_a = values[radiusName]) !== null && _a !== void 0 ? _a : values.borderRadius;\n-                }\n-                // /**\n-                //  * We only want to mix the background color if there's a follow element\n-                //  * that we're not crossfading opacity between. For instance with switch\n-                //  * AnimateSharedLayout animations, this helps the illusion of a continuous\n-                //  * element being animated but also cuts down on the number of paints triggered\n-                //  * for elements where opacity is doing that work for us.\n-                //  */\n-                // if (\n-                //     !hasFollowElement &&\n-                //     latestLeadValues.backgroundColor &&\n-                //     latestFollowValues.backgroundColor\n-                // ) {\n-                //     /**\n-                //      * This isn't ideal performance-wise as mixColor is creating a new function every frame.\n-                //      * We could probably create a mixer that runs at the start of the animation but\n-                //      * the idea behind the crossfader is that it runs dynamically between two potentially\n-                //      * changing targets (ie opacity or borderRadius may be animating independently via variants)\n-                //      */\n-                //     leadState.backgroundColor = followState.backgroundColor = mixColor(\n-                //         latestFollowValues.backgroundColor as string,\n-                //         latestLeadValues.backgroundColor as string\n-                //     )(p)\n-                // }\n-                var easeCrossfadeIn = compress(0, 0.5, popmotion.circOut);\n-                var easeCrossfadeOut = compress(0.5, 0.95, popmotion.linear);\n+                    // The document is represented as a BTree consisting of leaves, with\n+                    // chunk of lines in them, and branches, with up to ten leaves or\n+                    // other branch nodes below them. The top node is always a branch\n+                    // node, and is the document object itself (meaning it has\n+                    // additional methods and properties).\n+                    //\n+                    // All nodes have parent links. The tree is used both to go from\n+                    // line numbers to line objects, and to go from objects to numbers.\n+                    // It also indexes by height, and is used to convert between height\n+                    // and line object, and to find the total height of the document.\n+                    //\n+                    // See also http://marijnhaverbeke.nl/blog/codemirror-line-tree.html\n \n-                function compress(min, max, easing) {\n-                    return function(p) {\n-                        // Could replace ifs with clamp\n-                        if (p < min) return 0;\n-                        if (p > max) return 1;\n-                        return easing(popmotion.progress(min, max, p));\n+                    function LeafChunk(lines) {\n+                        this.lines = lines;\n+                        this.parent = null;\n+                        var height = 0;\n+                        for (var i = 0; i < lines.length; ++i) {\n+                            lines[i].parent = this;\n+                            height += lines[i].height;\n+                        }\n+                        this.height = height;\n+                    }\n+                    LeafChunk.prototype = {\n+                        chunkSize: function() {\n+                            return this.lines.length;\n+                        },\n+                        // Remove the n lines at offset 'at'.\n+                        removeInner: function(at, n) {\n+                            for (var i = at, e = at + n; i < e; ++i) {\n+                                var line = this.lines[i];\n+                                this.height -= line.height;\n+                                cleanUpLine(line);\n+                                signalLater(line, \"delete\");\n+                            }\n+                            this.lines.splice(at, n);\n+                        },\n+                        // Helper used to collapse a small branch into a single leaf.\n+                        collapse: function(lines) {\n+                            lines.push.apply(lines, this.lines);\n+                        },\n+                        // Insert the given array of lines at offset 'at', count them as\n+                        // having the given height.\n+                        insertInner: function(at, lines, height) {\n+                            this.height += height;\n+                            this.lines = this.lines.slice(0, at).concat(lines).concat(this.lines.slice(at));\n+                            for (var i = 0; i < lines.length; ++i) {\n+                                lines[i].parent = this;\n+                            }\n+                        },\n+                        // Used to iterate over a part of the tree.\n+                        iterN: function(at, n, op) {\n+                            for (var e = at + n; at < e; ++at) {\n+                                if (op(this.lines[at])) {\n+                                    return true;\n+                                }\n+                            }\n+                        }\n                     };\n-                }\n-\n-                /**\n-                 * Reset an axis to the provided origin box.\n-                 *\n-                 * This is a mutative operation.\n-                 */\n-                function copyAxisInto(axis, originAxis) {\n-                    axis.min = originAxis.min;\n-                    axis.max = originAxis.max;\n-                }\n-                /**\n-                 * Reset a box to the provided origin box.\n-                 *\n-                 * This is a mutative operation.\n-                 */\n-                function copyBoxInto(box, originBox) {\n-                    copyAxisInto(box.x, originBox.x);\n-                    copyAxisInto(box.y, originBox.y);\n-                }\n-\n-                /**\n-                 * Remove a delta from a point. This is essentially the steps of applyPointDelta in reverse\n-                 */\n-                function removePointDelta(point, translate, scale, originPoint, boxScale) {\n-                    point -= translate;\n-                    point = scalePoint(point, 1 / scale, originPoint);\n-                    if (boxScale !== undefined) {\n-                        point = scalePoint(point, 1 / boxScale, originPoint);\n-                    }\n-                    return point;\n-                }\n-                /**\n-                 * Remove a delta from an axis. This is essentially the steps of applyAxisDelta in reverse\n-                 */\n-                function removeAxisDelta(axis, translate, scale, origin, boxScale, originAxis, sourceAxis) {\n-                    if (translate === void 0) {\n-                        translate = 0;\n-                    }\n-                    if (scale === void 0) {\n-                        scale = 1;\n-                    }\n-                    if (origin === void 0) {\n-                        origin = 0.5;\n-                    }\n-                    if (originAxis === void 0) {\n-                        originAxis = axis;\n-                    }\n-                    if (sourceAxis === void 0) {\n-                        sourceAxis = axis;\n-                    }\n-                    if (styleValueTypes.percent.test(translate)) {\n-                        translate = parseFloat(translate);\n-                        var relativeProgress = popmotion.mix(sourceAxis.min, sourceAxis.max, translate / 100);\n-                        translate = relativeProgress - sourceAxis.min;\n-                    }\n-                    if (typeof translate !== \"number\") return;\n-                    var originPoint = popmotion.mix(originAxis.min, originAxis.max, origin);\n-                    if (axis === originAxis) originPoint -= translate;\n-                    axis.min = removePointDelta(axis.min, translate, scale, originPoint, boxScale);\n-                    axis.max = removePointDelta(axis.max, translate, scale, originPoint, boxScale);\n-                }\n-                /**\n-                 * Remove a transforms from an axis. This is essentially the steps of applyAxisTransforms in reverse\n-                 * and acts as a bridge between motion values and removeAxisDelta\n-                 */\n-                function removeAxisTransforms(axis, transforms, _a, origin, sourceAxis) {\n-                    var _b = tslib.__read(_a, 3),\n-                        key = _b[0],\n-                        scaleKey = _b[1],\n-                        originKey = _b[2];\n-                    removeAxisDelta(axis, transforms[key], transforms[scaleKey], transforms[originKey], transforms.scale, origin, sourceAxis);\n-                }\n-                /**\n-                 * The names of the motion values we want to apply as translation, scale and origin.\n-                 */\n-                var xKeys = [\"x\", \"scaleX\", \"originX\"];\n-                var yKeys = [\"y\", \"scaleY\", \"originY\"];\n-                /**\n-                 * Remove a transforms from an box. This is essentially the steps of applyAxisBox in reverse\n-                 * and acts as a bridge between motion values and removeAxisDelta\n-                 */\n-                function removeBoxTransforms(box, transforms, originBox, sourceBox) {\n-                    removeAxisTransforms(box.x, transforms, xKeys, originBox === null || originBox === void 0 ? void 0 : originBox.x, sourceBox === null || sourceBox === void 0 ? void 0 : sourceBox.x);\n-                    removeAxisTransforms(box.y, transforms, yKeys, originBox === null || originBox === void 0 ? void 0 : originBox.y, sourceBox === null || sourceBox === void 0 ? void 0 : sourceBox.y);\n-                }\n \n-                function isAxisDeltaZero(delta) {\n-                    return delta.translate === 0 && delta.scale === 1;\n-                }\n+                    function BranchChunk(children) {\n+                        this.children = children;\n+                        var size = 0,\n+                            height = 0;\n+                        for (var i = 0; i < children.length; ++i) {\n+                            var ch = children[i];\n+                            size += ch.chunkSize();\n+                            height += ch.height;\n+                            ch.parent = this;\n+                        }\n+                        this.size = size;\n+                        this.height = height;\n+                        this.parent = null;\n+                    }\n+                    BranchChunk.prototype = {\n+                        chunkSize: function() {\n+                            return this.size;\n+                        },\n+                        removeInner: function(at, n) {\n+                            this.size -= n;\n+                            for (var i = 0; i < this.children.length; ++i) {\n+                                var child = this.children[i],\n+                                    sz = child.chunkSize();\n+                                if (at < sz) {\n+                                    var rm = Math.min(n, sz - at),\n+                                        oldHeight = child.height;\n+                                    child.removeInner(at, rm);\n+                                    this.height -= oldHeight - child.height;\n+                                    if (sz == rm) {\n+                                        this.children.splice(i--, 1);\n+                                        child.parent = null;\n+                                    }\n+                                    if ((n -= rm) == 0) {\n+                                        break;\n+                                    }\n+                                    at = 0;\n+                                } else {\n+                                    at -= sz;\n+                                }\n+                            }\n+                            // If the result is smaller than 25 lines, ensure that it is a\n+                            // single leaf node.\n+                            if (this.size - n < 25 && (this.children.length > 1 || !(this.children[0] instanceof LeafChunk))) {\n+                                var lines = [];\n+                                this.collapse(lines);\n+                                this.children = [new LeafChunk(lines)];\n+                                this.children[0].parent = this;\n+                            }\n+                        },\n+                        collapse: function(lines) {\n+                            for (var i = 0; i < this.children.length; ++i) {\n+                                this.children[i].collapse(lines);\n+                            }\n+                        },\n+                        insertInner: function(at, lines, height) {\n+                            this.size += lines.length;\n+                            this.height += height;\n+                            for (var i = 0; i < this.children.length; ++i) {\n+                                var child = this.children[i],\n+                                    sz = child.chunkSize();\n+                                if (at <= sz) {\n+                                    child.insertInner(at, lines, height);\n+                                    if (child.lines && child.lines.length > 50) {\n+                                        // To avoid memory thrashing when child.lines is huge (e.g. first view of a large file), it's never spliced.\n+                                        // Instead, small slices are taken. They're taken in order because sequential memory accesses are fastest.\n+                                        var remaining = child.lines.length % 25 + 25;\n+                                        for (var pos = remaining; pos < child.lines.length;) {\n+                                            var leaf = new LeafChunk(child.lines.slice(pos, pos += 25));\n+                                            child.height -= leaf.height;\n+                                            this.children.splice(++i, 0, leaf);\n+                                            leaf.parent = this;\n+                                        }\n+                                        child.lines = child.lines.slice(0, remaining);\n+                                        this.maybeSpill();\n+                                    }\n+                                    break;\n+                                }\n+                                at -= sz;\n+                            }\n+                        },\n+                        // When a node has grown, check whether it should be split.\n+                        maybeSpill: function() {\n+                            if (this.children.length <= 10) {\n+                                return;\n+                            }\n+                            var me = this;\n+                            do {\n+                                var spilled = me.children.splice(me.children.length - 5, 5);\n+                                var sibling = new BranchChunk(spilled);\n+                                if (!me.parent) {\n+                                    // Become the parent node\n+                                    var copy = new BranchChunk(me.children);\n+                                    copy.parent = me;\n+                                    me.children = [copy, sibling];\n+                                    me = copy;\n+                                } else {\n+                                    me.size -= sibling.size;\n+                                    me.height -= sibling.height;\n+                                    var myIndex = indexOf(me.parent.children, me);\n+                                    me.parent.children.splice(myIndex + 1, 0, sibling);\n+                                }\n+                                sibling.parent = me.parent;\n+                            } while (me.children.length > 10);\n+                            me.parent.maybeSpill();\n+                        },\n+                        iterN: function(at, n, op) {\n+                            for (var i = 0; i < this.children.length; ++i) {\n+                                var child = this.children[i],\n+                                    sz = child.chunkSize();\n+                                if (at < sz) {\n+                                    var used = Math.min(n, sz - at);\n+                                    if (child.iterN(at, used, op)) {\n+                                        return true;\n+                                    }\n+                                    if ((n -= used) == 0) {\n+                                        break;\n+                                    }\n+                                    at = 0;\n+                                } else {\n+                                    at -= sz;\n+                                }\n+                            }\n+                        }\n+                    };\n \n-                function isDeltaZero(delta) {\n-                    return isAxisDeltaZero(delta.x) && isAxisDeltaZero(delta.y);\n-                }\n+                    // Line widgets are block elements displayed above or below a line.\n \n-                function boxEquals(a, b) {\n-                    return a.x.min === b.x.min && a.x.max === b.x.max && a.y.min === b.y.min && a.y.max === b.y.max;\n-                }\n-                var NodeStack = /** @class */ function() {\n-                    function NodeStack() {\n-                        this.members = [];\n-                    }\n-                    NodeStack.prototype.add = function(node) {\n-                        addUniqueItem(this.members, node);\n-                        node.scheduleRender();\n+                    var LineWidget = function(doc, node, options) {\n+                        if (options) {\n+                            for (var opt in options) {\n+                                if (options.hasOwnProperty(opt)) {\n+                                    this[opt] = options[opt];\n+                                }\n+                            }\n+                        }\n+                        this.doc = doc;\n+                        this.node = node;\n                     };\n-                    NodeStack.prototype.remove = function(node) {\n-                        removeItem(this.members, node);\n-                        if (node === this.prevLead) {\n-                            this.prevLead = undefined;\n+                    LineWidget.prototype.clear = function() {\n+                        var cm = this.doc.cm,\n+                            ws = this.line.widgets,\n+                            line = this.line,\n+                            no = lineNo(line);\n+                        if (no == null || !ws) {\n+                            return;\n                         }\n-                        if (node === this.lead) {\n-                            var prevLead = this.members[this.members.length - 1];\n-                            if (prevLead) {\n-                                this.promote(prevLead);\n-                            }\n+                        for (var i = 0; i < ws.length; ++i) {\n+                            if (ws[i] == this) {\n+                                ws.splice(i--, 1);\n+                            }\n+                        }\n+                        if (!ws.length) {\n+                            line.widgets = null;\n+                        }\n+                        var height = widgetHeight(this);\n+                        updateLineHeight(line, Math.max(0, line.height - height));\n+                        if (cm) {\n+                            runInOp(cm, function() {\n+                                adjustScrollWhenAboveVisible(cm, line, -height);\n+                                regLineChange(cm, no, \"widget\");\n+                            });\n+                            signalLater(cm, \"lineWidgetCleared\", cm, this, no);\n+                        }\n+                    };\n+                    LineWidget.prototype.changed = function() {\n+                        var this$1 = this;\n+                        var oldH = this.height,\n+                            cm = this.doc.cm,\n+                            line = this.line;\n+                        this.height = null;\n+                        var diff = widgetHeight(this) - oldH;\n+                        if (!diff) {\n+                            return;\n+                        }\n+                        if (!lineIsHidden(this.doc, line)) {\n+                            updateLineHeight(line, line.height + diff);\n+                        }\n+                        if (cm) {\n+                            runInOp(cm, function() {\n+                                cm.curOp.forceUpdate = true;\n+                                adjustScrollWhenAboveVisible(cm, line, diff);\n+                                signalLater(cm, \"lineWidgetChanged\", cm, this$1, lineNo(line));\n+                            });\n                         }\n                     };\n-                    NodeStack.prototype.relegate = function(node) {\n-                        var indexOfNode = this.members.findIndex(function(member) {\n-                            return node === member;\n+                    eventMixin(LineWidget);\n+\n+                    function adjustScrollWhenAboveVisible(cm, line, diff) {\n+                        if (heightAtLine(line) < (cm.curOp && cm.curOp.scrollTop || cm.doc.scrollTop)) {\n+                            addToScrollTop(cm, diff);\n+                        }\n+                    }\n+\n+                    function addLineWidget(doc, handle, node, options) {\n+                        var widget = new LineWidget(doc, node, options);\n+                        var cm = doc.cm;\n+                        if (cm && widget.noHScroll) {\n+                            cm.display.alignWidgets = true;\n+                        }\n+                        changeLine(doc, handle, \"widget\", function(line) {\n+                            var widgets = line.widgets || (line.widgets = []);\n+                            if (widget.insertAt == null) {\n+                                widgets.push(widget);\n+                            } else {\n+                                widgets.splice(Math.min(widgets.length, Math.max(0, widget.insertAt)), 0, widget);\n+                            }\n+                            widget.line = line;\n+                            if (cm && !lineIsHidden(doc, line)) {\n+                                var aboveVisible = heightAtLine(line) < doc.scrollTop;\n+                                updateLineHeight(line, line.height + widgetHeight(widget));\n+                                if (aboveVisible) {\n+                                    addToScrollTop(cm, widget.height);\n+                                }\n+                                cm.curOp.forceUpdate = true;\n+                            }\n+                            return true;\n                         });\n-                        if (indexOfNode === 0) return false;\n-                        /**\n-                         * Find the next projection node that is present\n-                         */\n-                        var prevLead;\n-                        for (var i = indexOfNode; i >= 0; i--) {\n-                            var member = this.members[i];\n-                            if (member.isPresent !== false) {\n-                                prevLead = member;\n-                                break;\n+                        if (cm) {\n+                            signalLater(cm, \"lineWidgetAdded\", cm, widget, typeof handle == \"number\" ? handle : lineNo(handle));\n+                        }\n+                        return widget;\n+                    }\n+\n+                    // TEXTMARKERS\n+\n+                    // Created with markText and setBookmark methods. A TextMarker is a\n+                    // handle that can be used to clear or find a marked position in the\n+                    // document. Line objects hold arrays (markedSpans) containing\n+                    // {from, to, marker} object pointing to such marker objects, and\n+                    // indicating that such a marker is present on that line. Multiple\n+                    // lines may point to the same marker when it spans across lines.\n+                    // The spans will have null for their from/to properties when the\n+                    // marker continues beyond the start/end of the line. Markers have\n+                    // links back to the lines they currently touch.\n+\n+                    // Collapsed markers have unique ids, in order to be able to order\n+                    // them, which is needed for uniquely determining an outer marker\n+                    // when they overlap (they may nest, but not partially overlap).\n+                    var nextMarkerId = 0;\n+                    var TextMarker = function(doc, type) {\n+                        this.lines = [];\n+                        this.type = type;\n+                        this.doc = doc;\n+                        this.id = ++nextMarkerId;\n+                    };\n+\n+                    // Clear the marker.\n+                    TextMarker.prototype.clear = function() {\n+                        if (this.explicitlyCleared) {\n+                            return;\n+                        }\n+                        var cm = this.doc.cm,\n+                            withOp = cm && !cm.curOp;\n+                        if (withOp) {\n+                            startOperation(cm);\n+                        }\n+                        if (hasHandler(this, \"clear\")) {\n+                            var found = this.find();\n+                            if (found) {\n+                                signalLater(this, \"clear\", found.from, found.to);\n                             }\n                         }\n-                        if (prevLead) {\n-                            this.promote(prevLead);\n-                            return true;\n-                        } else {\n-                            return false;\n+                        var min = null,\n+                            max = null;\n+                        for (var i = 0; i < this.lines.length; ++i) {\n+                            var line = this.lines[i];\n+                            var span = getMarkedSpanFor(line.markedSpans, this);\n+                            if (cm && !this.collapsed) {\n+                                regLineChange(cm, lineNo(line), \"text\");\n+                            } else if (cm) {\n+                                if (span.to != null) {\n+                                    max = lineNo(line);\n+                                }\n+                                if (span.from != null) {\n+                                    min = lineNo(line);\n+                                }\n+                            }\n+                            line.markedSpans = removeMarkedSpan(line.markedSpans, span);\n+                            if (span.from == null && this.collapsed && !lineIsHidden(this.doc, line) && cm) {\n+                                updateLineHeight(line, textHeight(cm.display));\n+                            }\n                         }\n-                    };\n-                    NodeStack.prototype.promote = function(node, preserveFollowOpacity) {\n-                        var _a;\n-                        var prevLead = this.lead;\n-                        if (node === prevLead) return;\n-                        this.prevLead = prevLead;\n-                        this.lead = node;\n-                        node.show();\n-                        if (prevLead) {\n-                            prevLead.instance && prevLead.scheduleRender();\n-                            node.scheduleRender();\n-                            node.resumeFrom = prevLead;\n-                            if (preserveFollowOpacity) {\n-                                node.resumeFrom.preserveOpacity = true;\n+                        if (cm && this.collapsed && !cm.options.lineWrapping) {\n+                            for (var i$1 = 0; i$1 < this.lines.length; ++i$1) {\n+                                var visual = visualLine(this.lines[i$1]),\n+                                    len = lineLength(visual);\n+                                if (len > cm.display.maxLineLength) {\n+                                    cm.display.maxLine = visual;\n+                                    cm.display.maxLineLength = len;\n+                                    cm.display.maxLineChanged = true;\n+                                }\n                             }\n-                            if (prevLead.snapshot) {\n-                                node.snapshot = prevLead.snapshot;\n-                                node.snapshot.latestValues = prevLead.animationValues || prevLead.latestValues;\n-                                node.snapshot.isShared = true;\n+                        }\n+                        if (min != null && cm && this.collapsed) {\n+                            regChange(cm, min, max + 1);\n+                        }\n+                        this.lines.length = 0;\n+                        this.explicitlyCleared = true;\n+                        if (this.atomic && this.doc.cantEdit) {\n+                            this.doc.cantEdit = false;\n+                            if (cm) {\n+                                reCheckSelection(cm.doc);\n                             }\n-                            if ((_a = node.root) === null || _a === void 0 ? void 0 : _a.isUpdating) {\n-                                node.isLayoutDirty = true;\n+                        }\n+                        if (cm) {\n+                            signalLater(cm, \"markerCleared\", cm, this, min, max);\n+                        }\n+                        if (withOp) {\n+                            endOperation(cm);\n+                        }\n+                        if (this.parent) {\n+                            this.parent.clear();\n+                        }\n+                    };\n+\n+                    // Find the position of the marker in the document. Returns a {from,\n+                    // to} object by default. Side can be passed to get a specific side\n+                    // -- 0 (both), -1 (left), or 1 (right). When lineObj is true, the\n+                    // Pos objects returned contain a line object, rather than a line\n+                    // number (used to prevent looking up the same line twice).\n+                    TextMarker.prototype.find = function(side, lineObj) {\n+                        if (side == null && this.type == \"bookmark\") {\n+                            side = 1;\n+                        }\n+                        var from, to;\n+                        for (var i = 0; i < this.lines.length; ++i) {\n+                            var line = this.lines[i];\n+                            var span = getMarkedSpanFor(line.markedSpans, this);\n+                            if (span.from != null) {\n+                                from = Pos(lineObj ? line : lineNo(line), span.from);\n+                                if (side == -1) {\n+                                    return from;\n+                                }\n                             }\n-                            var crossfade = node.options.crossfade;\n-                            if (crossfade === false) {\n-                                prevLead.hide();\n+                            if (span.to != null) {\n+                                to = Pos(lineObj ? line : lineNo(line), span.to);\n+                                if (side == 1) {\n+                                    return to;\n+                                }\n                             }\n-                            /**\n-                             * TODO:\n-                             *   - Test border radius when previous node was deleted\n-                             *   - boxShadow mixing\n-                             *   - Shared between element A in scrolled container and element B (scroll stays the same or changes)\n-                             *   - Shared between element A in transformed container and element B (transform stays the same or changes)\n-                             *   - Shared between element A in scrolled page and element B (scroll stays the same or changes)\n-                             * ---\n-                             *   - Crossfade opacity of root nodes\n-                             *   - layoutId changes after animation\n-                             *   - layoutId changes mid animation\n-                             */\n                         }\n+                        return from && {\n+                            from: from,\n+                            to: to\n+                        };\n                     };\n \n-                    NodeStack.prototype.exitAnimationComplete = function() {\n-                        this.members.forEach(function(node) {\n-                            var _a, _b, _c, _d, _e;\n-                            (_b = (_a = node.options).onExitComplete) === null || _b === void 0 ? void 0 : _b.call(_a);\n-                            (_e = (_c = node.resumingFrom) === null || _c === void 0 ? void 0 : (_d = _c.options).onExitComplete) === null || _e === void 0 ? void 0 : _e.call(_d);\n+                    // Signals that the marker's widget changed, and surrounding layout\n+                    // should be recomputed.\n+                    TextMarker.prototype.changed = function() {\n+                        var this$1 = this;\n+                        var pos = this.find(-1, true),\n+                            widget = this,\n+                            cm = this.doc.cm;\n+                        if (!pos || !cm) {\n+                            return;\n+                        }\n+                        runInOp(cm, function() {\n+                            var line = pos.line,\n+                                lineN = lineNo(pos.line);\n+                            var view = findViewForLine(cm, lineN);\n+                            if (view) {\n+                                clearLineMeasurementCacheFor(view);\n+                                cm.curOp.selectionChanged = cm.curOp.forceUpdate = true;\n+                            }\n+                            cm.curOp.updateMaxLine = true;\n+                            if (!lineIsHidden(widget.doc, line) && widget.height != null) {\n+                                var oldHeight = widget.height;\n+                                widget.height = null;\n+                                var dHeight = widgetHeight(widget) - oldHeight;\n+                                if (dHeight) {\n+                                    updateLineHeight(line, line.height + dHeight);\n+                                }\n+                            }\n+                            signalLater(cm, \"markerChanged\", cm, this$1);\n                         });\n                     };\n-                    NodeStack.prototype.scheduleRender = function() {\n-                        this.members.forEach(function(node) {\n-                            node.instance && node.scheduleRender(false);\n-                        });\n+                    TextMarker.prototype.attachLine = function(line) {\n+                        if (!this.lines.length && this.doc.cm) {\n+                            var op = this.doc.cm.curOp;\n+                            if (!op.maybeHiddenMarkers || indexOf(op.maybeHiddenMarkers, this) == -1) {\n+                                (op.maybeUnhiddenMarkers || (op.maybeUnhiddenMarkers = [])).push(this);\n+                            }\n+                        }\n+                        this.lines.push(line);\n                     };\n-                    /**\n-                     * Clear any leads that have been removed this render to prevent them from being\n-                     * used in future animations and to prevent memory leaks\n-                     */\n-                    NodeStack.prototype.removeLeadSnapshot = function() {\n-                        if (this.lead && this.lead.snapshot) {\n-                            this.lead.snapshot = undefined;\n+                    TextMarker.prototype.detachLine = function(line) {\n+                        this.lines.splice(indexOf(this.lines, line), 1);\n+                        if (!this.lines.length && this.doc.cm) {\n+                            var op = this.doc.cm.curOp;\n+                            (op.maybeHiddenMarkers || (op.maybeHiddenMarkers = [])).push(this);\n                         }\n                     };\n-                    return NodeStack;\n-                }();\n-                var identityProjection = \"translate3d(0px, 0px, 0) scale(1, 1) scale(1, 1)\";\n+                    eventMixin(TextMarker);\n \n-                function buildProjectionTransform(delta, treeScale, latestTransform) {\n-                    /**\n-                     * The translations we use to calculate are always relative to the viewport coordinate space.\n-                     * But when we apply scales, we also scale the coordinate space of an element and its children.\n-                     * For instance if we have a treeScale (the culmination of all parent scales) of 0.5 and we need\n-                     * to move an element 100 pixels, we actually need to move it 200 in within that scaled space.\n-                     */\n-                    var xTranslate = delta.x.translate / treeScale.x;\n-                    var yTranslate = delta.y.translate / treeScale.y;\n-                    var transform = \"translate3d(\".concat(xTranslate, \"px, \").concat(yTranslate, \"px, 0) \");\n-                    /**\n-                     * Apply scale correction for the tree transform.\n-                     * This will apply scale to the screen-orientated axes.\n-                     */\n-                    transform += \"scale(\".concat(1 / treeScale.x, \", \").concat(1 / treeScale.y, \") \");\n-                    if (latestTransform) {\n-                        var rotate = latestTransform.rotate,\n-                            rotateX = latestTransform.rotateX,\n-                            rotateY = latestTransform.rotateY;\n-                        if (rotate) transform += \"rotate(\".concat(rotate, \"deg) \");\n-                        if (rotateX) transform += \"rotateX(\".concat(rotateX, \"deg) \");\n-                        if (rotateY) transform += \"rotateY(\".concat(rotateY, \"deg) \");\n-                    }\n-                    /**\n-                     * Apply scale to match the size of the element to the size we want it.\n-                     * This will apply scale to the element-orientated axes.\n-                     */\n-                    var elementScaleX = delta.x.scale * treeScale.x;\n-                    var elementScaleY = delta.y.scale * treeScale.y;\n-                    transform += \"scale(\".concat(elementScaleX, \", \").concat(elementScaleY, \")\");\n-                    return transform === identityProjection ? \"none\" : transform;\n-                }\n-                var compareByDepth = function(a, b) {\n-                    return a.depth - b.depth;\n-                };\n-                var FlatTree = /** @class */ function() {\n-                    function FlatTree() {\n-                        this.children = [];\n-                        this.isDirty = false;\n+                    // Create a marker, wire it up to the right lines, and\n+                    function markText(doc, from, to, options, type) {\n+                        // Shared markers (across linked documents) are handled separately\n+                        // (markTextShared will call out to this again, once per\n+                        // document).\n+                        if (options && options.shared) {\n+                            return markTextShared(doc, from, to, options, type);\n+                        }\n+                        // Ensure we are in an operation.\n+                        if (doc.cm && !doc.cm.curOp) {\n+                            return operation(doc.cm, markText)(doc, from, to, options, type);\n+                        }\n+                        var marker = new TextMarker(doc, type),\n+                            diff = cmp(from, to);\n+                        if (options) {\n+                            copyObj(options, marker, false);\n+                        }\n+                        // Don't connect empty markers unless clearWhenEmpty is false\n+                        if (diff > 0 || diff == 0 && marker.clearWhenEmpty !== false) {\n+                            return marker;\n+                        }\n+                        if (marker.replacedWith) {\n+                            // Showing up as a widget implies collapsed (widget replaces text)\n+                            marker.collapsed = true;\n+                            marker.widgetNode = eltP(\"span\", [marker.replacedWith], \"CodeMirror-widget\");\n+                            if (!options.handleMouseEvents) {\n+                                marker.widgetNode.setAttribute(\"cm-ignore-events\", \"true\");\n+                            }\n+                            if (options.insertLeft) {\n+                                marker.widgetNode.insertLeft = true;\n+                            }\n+                        }\n+                        if (marker.collapsed) {\n+                            if (conflictingCollapsedRange(doc, from.line, from, to, marker) || from.line != to.line && conflictingCollapsedRange(doc, to.line, from, to, marker)) {\n+                                throw new Error(\"Inserting collapsed marker partially overlapping an existing one\");\n+                            }\n+                            seeCollapsedSpans();\n+                        }\n+                        if (marker.addToHistory) {\n+                            addChangeToHistory(doc, {\n+                                from: from,\n+                                to: to,\n+                                origin: \"markText\"\n+                            }, doc.sel, NaN);\n+                        }\n+                        var curLine = from.line,\n+                            cm = doc.cm,\n+                            updateMaxLine;\n+                        doc.iter(curLine, to.line + 1, function(line) {\n+                            if (cm && marker.collapsed && !cm.options.lineWrapping && visualLine(line) == cm.display.maxLine) {\n+                                updateMaxLine = true;\n+                            }\n+                            if (marker.collapsed && curLine != from.line) {\n+                                updateLineHeight(line, 0);\n+                            }\n+                            addMarkedSpan(line, new MarkedSpan(marker, curLine == from.line ? from.ch : null, curLine == to.line ? to.ch : null), doc.cm && doc.cm.curOp);\n+                            ++curLine;\n+                        });\n+                        // lineIsHidden depends on the presence of the spans, so needs a second pass\n+                        if (marker.collapsed) {\n+                            doc.iter(from.line, to.line + 1, function(line) {\n+                                if (lineIsHidden(doc, line)) {\n+                                    updateLineHeight(line, 0);\n+                                }\n+                            });\n+                        }\n+                        if (marker.clearOnEnter) {\n+                            on(marker, \"beforeCursorEnter\", function() {\n+                                return marker.clear();\n+                            });\n+                        }\n+                        if (marker.readOnly) {\n+                            seeReadOnlySpans();\n+                            if (doc.history.done.length || doc.history.undone.length) {\n+                                doc.clearHistory();\n+                            }\n+                        }\n+                        if (marker.collapsed) {\n+                            marker.id = ++nextMarkerId;\n+                            marker.atomic = true;\n+                        }\n+                        if (cm) {\n+                            // Sync editor state\n+                            if (updateMaxLine) {\n+                                cm.curOp.updateMaxLine = true;\n+                            }\n+                            if (marker.collapsed) {\n+                                regChange(cm, from.line, to.line + 1);\n+                            } else if (marker.className || marker.startStyle || marker.endStyle || marker.css || marker.attributes || marker.title) {\n+                                for (var i = from.line; i <= to.line; i++) {\n+                                    regLineChange(cm, i, \"text\");\n+                                }\n+                            }\n+                            if (marker.atomic) {\n+                                reCheckSelection(cm.doc);\n+                            }\n+                            signalLater(cm, \"markerAdded\", cm, marker);\n+                        }\n+                        return marker;\n                     }\n-                    FlatTree.prototype.add = function(child) {\n-                        addUniqueItem(this.children, child);\n-                        this.isDirty = true;\n-                    };\n-                    FlatTree.prototype.remove = function(child) {\n-                        removeItem(this.children, child);\n-                        this.isDirty = true;\n-                    };\n-                    FlatTree.prototype.forEach = function(callback) {\n-                        this.isDirty && this.children.sort(compareByDepth);\n-                        this.isDirty = false;\n-                        this.children.forEach(callback);\n-                    };\n-                    return FlatTree;\n-                }();\n \n-                /**\n-                 * We use 1000 as the animation target as 0-1000 maps better to pixels than 0-1\n-                 * which has a noticeable difference in spring animations\n-                 */\n-                var animationTarget = 1000;\n+                    // SHARED TEXTMARKERS\n \n-                function createProjectionNode(_a) {\n-                    var attachResizeListener = _a.attachResizeListener,\n-                        defaultParent = _a.defaultParent,\n-                        measureScroll = _a.measureScroll,\n-                        checkIsScrollRoot = _a.checkIsScrollRoot,\n-                        resetTransform = _a.resetTransform;\n-                    return ( /** @class */ function() {\n-                        function ProjectionNode(id, latestValues, parent) {\n-                            var _this = this;\n-                            if (latestValues === void 0) {\n-                                latestValues = {};\n+                    // A shared marker spans multiple linked documents. It is\n+                    // implemented as a meta-marker-object controlling multiple normal\n+                    // markers.\n+                    var SharedTextMarker = function(markers, primary) {\n+                        this.markers = markers;\n+                        this.primary = primary;\n+                        for (var i = 0; i < markers.length; ++i) {\n+                            markers[i].parent = this;\n+                        }\n+                    };\n+                    SharedTextMarker.prototype.clear = function() {\n+                        if (this.explicitlyCleared) {\n+                            return;\n+                        }\n+                        this.explicitlyCleared = true;\n+                        for (var i = 0; i < this.markers.length; ++i) {\n+                            this.markers[i].clear();\n+                        }\n+                        signalLater(this, \"clear\");\n+                    };\n+                    SharedTextMarker.prototype.find = function(side, lineObj) {\n+                        return this.primary.find(side, lineObj);\n+                    };\n+                    eventMixin(SharedTextMarker);\n+\n+                    function markTextShared(doc, from, to, options, type) {\n+                        options = copyObj(options);\n+                        options.shared = false;\n+                        var markers = [markText(doc, from, to, options, type)],\n+                            primary = markers[0];\n+                        var widget = options.widgetNode;\n+                        linkedDocs(doc, function(doc) {\n+                            if (widget) {\n+                                options.widgetNode = widget.cloneNode(true);\n+                            }\n+                            markers.push(markText(doc, clipPos(doc, from), clipPos(doc, to), options, type));\n+                            for (var i = 0; i < doc.linked.length; ++i) {\n+                                if (doc.linked[i].isParent) {\n+                                    return;\n+                                }\n                             }\n-                            if (parent === void 0) {\n-                                parent = defaultParent === null || defaultParent === void 0 ? void 0 : defaultParent();\n+                            primary = lst(markers);\n+                        });\n+                        return new SharedTextMarker(markers, primary);\n+                    }\n+\n+                    function findSharedMarkers(doc) {\n+                        return doc.findMarks(Pos(doc.first, 0), doc.clipPos(Pos(doc.lastLine())), function(m) {\n+                            return m.parent;\n+                        });\n+                    }\n+\n+                    function copySharedMarkers(doc, markers) {\n+                        for (var i = 0; i < markers.length; i++) {\n+                            var marker = markers[i],\n+                                pos = marker.find();\n+                            var mFrom = doc.clipPos(pos.from),\n+                                mTo = doc.clipPos(pos.to);\n+                            if (cmp(mFrom, mTo)) {\n+                                var subMark = markText(doc, mFrom, mTo, marker.primary, marker.primary.type);\n+                                marker.markers.push(subMark);\n+                                subMark.parent = marker;\n                             }\n-                            /**\n-                             * A Set containing all this component's children. This is used to iterate\n-                             * through the children.\n-                             *\n-                             * TODO: This could be faster to iterate as a flat array stored on the root node.\n-                             */\n-                            this.children = new Set();\n-                            /**\n-                             * Options for the node. We use this to configure what kind of layout animations\n-                             * we should perform (if any).\n-                             */\n-                            this.options = {};\n-                            /**\n-                             * We use this to detect when its safe to shut down part of a projection tree.\n-                             * We have to keep projecting children for scale correction and relative projection\n-                             * until all their parents stop performing layout animations.\n-                             */\n-                            this.isTreeAnimating = false;\n-                            this.isAnimationBlocked = false;\n-                            /**\n-                             * Flag to true if we think this layout has been changed. We can't always know this,\n-                             * currently we set it to true every time a component renders, or if it has a layoutDependency\n-                             * if that has changed between renders. Additionally, components can be grouped by LayoutGroup\n-                             * and if one node is dirtied, they all are.\n-                             */\n-                            this.isLayoutDirty = false;\n-                            /**\n-                             * Block layout updates for instant layout transitions throughout the tree.\n-                             */\n-                            this.updateManuallyBlocked = false;\n-                            this.updateBlockedByResize = false;\n-                            /**\n-                             * Set to true between the start of the first `willUpdate` call and the end of the `didUpdate`\n-                             * call.\n-                             */\n-                            this.isUpdating = false;\n-                            /**\n-                             * If this is an SVG element we currently disable projection transforms\n-                             */\n-                            this.isSVG = false;\n-                            /**\n-                             * Flag to true (during promotion) if a node doing an instant layout transition needs to reset\n-                             * its projection styles.\n-                             */\n-                            this.needsReset = false;\n-                            /**\n-                             * Flags whether this node should have its transform reset prior to measuring.\n-                             */\n-                            this.shouldResetTransform = false;\n-                            /**\n-                             * An object representing the calculated contextual/accumulated/tree scale.\n-                             * This will be used to scale calculcated projection transforms, as these are\n-                             * calculated in screen-space but need to be scaled for elements to actually\n-                             * make it to their calculated destinations.\n-                             *\n-                             * TODO: Lazy-init\n-                             */\n-                            this.treeScale = {\n-                                x: 1,\n-                                y: 1\n-                            };\n-                            /**\n-                             *\n-                             */\n-                            this.eventHandlers = new Map();\n-                            // Note: Currently only running on root node\n-                            this.potentialNodes = new Map();\n-                            this.checkUpdateFailed = function() {\n-                                if (_this.isUpdating) {\n-                                    _this.isUpdating = false;\n-                                    _this.clearAllSnapshots();\n+                        }\n+                    }\n+\n+                    function detachSharedMarkers(markers) {\n+                        var loop = function(i) {\n+                            var marker = markers[i],\n+                                linked = [marker.primary.doc];\n+                            linkedDocs(marker.primary.doc, function(d) {\n+                                return linked.push(d);\n+                            });\n+                            for (var j = 0; j < marker.markers.length; j++) {\n+                                var subMarker = marker.markers[j];\n+                                if (indexOf(linked, subMarker.doc) == -1) {\n+                                    subMarker.parent = null;\n+                                    marker.markers.splice(j--, 1);\n                                 }\n-                            };\n-                            this.updateProjection = function() {\n-                                _this.nodes.forEach(resolveTargetDelta);\n-                                _this.nodes.forEach(calcProjection);\n-                            };\n-                            this.hasProjected = false;\n-                            this.isVisible = true;\n-                            this.animationProgress = 0;\n-                            /**\n-                             * Shared layout\n-                             */\n-                            // TODO Only running on root node\n-                            this.sharedNodes = new Map();\n-                            this.id = id;\n-                            this.latestValues = latestValues;\n-                            this.root = parent ? parent.root || parent : this;\n-                            this.path = parent ? tslib.__spreadArray(tslib.__spreadArray([], tslib.__read(parent.path), false), [parent], false) : [];\n-                            this.parent = parent;\n-                            this.depth = parent ? parent.depth + 1 : 0;\n-                            id && this.root.registerPotentialNode(id, this);\n-                            for (var i = 0; i < this.path.length; i++) {\n-                                this.path[i].shouldResetTransform = true;\n                             }\n-                            if (this.root === this) this.nodes = new FlatTree();\n+                        };\n+                        for (var i = 0; i < markers.length; i++) loop(i);\n+                    }\n+                    var nextDocId = 0;\n+                    var Doc = function(text, mode, firstLine, lineSep, direction) {\n+                        if (!(this instanceof Doc)) {\n+                            return new Doc(text, mode, firstLine, lineSep, direction);\n                         }\n-                        ProjectionNode.prototype.addEventListener = function(name, handler) {\n-                            if (!this.eventHandlers.has(name)) {\n-                                this.eventHandlers.set(name, new SubscriptionManager());\n+                        if (firstLine == null) {\n+                            firstLine = 0;\n+                        }\n+                        BranchChunk.call(this, [new LeafChunk([new Line(\"\", null)])]);\n+                        this.first = firstLine;\n+                        this.scrollTop = this.scrollLeft = 0;\n+                        this.cantEdit = false;\n+                        this.cleanGeneration = 1;\n+                        this.modeFrontier = this.highlightFrontier = firstLine;\n+                        var start = Pos(firstLine, 0);\n+                        this.sel = simpleSelection(start);\n+                        this.history = new History(null);\n+                        this.id = ++nextDocId;\n+                        this.modeOption = mode;\n+                        this.lineSep = lineSep;\n+                        this.direction = direction == \"rtl\" ? \"rtl\" : \"ltr\";\n+                        this.extend = false;\n+                        if (typeof text == \"string\") {\n+                            text = this.splitLines(text);\n+                        }\n+                        updateDoc(this, {\n+                            from: start,\n+                            to: start,\n+                            text: text\n+                        });\n+                        setSelection(this, simpleSelection(start), sel_dontScroll);\n+                    };\n+                    Doc.prototype = createObj(BranchChunk.prototype, {\n+                        constructor: Doc,\n+                        // Iterate over the document. Supports two forms -- with only one\n+                        // argument, it calls that for each line in the document. With\n+                        // three, it iterates over the range given by the first two (with\n+                        // the second being non-inclusive).\n+                        iter: function(from, to, op) {\n+                            if (op) {\n+                                this.iterN(from - this.first, to - from, op);\n+                            } else {\n+                                this.iterN(this.first, this.first + this.size, from);\n                             }\n-                            return this.eventHandlers.get(name).add(handler);\n-                        };\n-                        ProjectionNode.prototype.notifyListeners = function(name) {\n-                            var args = [];\n-                            for (var _i = 1; _i < arguments.length; _i++) {\n-                                args[_i - 1] = arguments[_i];\n+                        },\n+                        // Non-public interface for adding and removing lines.\n+                        insert: function(at, lines) {\n+                            var height = 0;\n+                            for (var i = 0; i < lines.length; ++i) {\n+                                height += lines[i].height;\n+                            }\n+                            this.insertInner(at - this.first, lines, height);\n+                        },\n+                        remove: function(at, n) {\n+                            this.removeInner(at - this.first, n);\n+                        },\n+                        // From here, the methods are part of the public interface. Most\n+                        // are also available from CodeMirror (editor) instances.\n+\n+                        getValue: function(lineSep) {\n+                            var lines = getLines(this, this.first, this.first + this.size);\n+                            if (lineSep === false) {\n+                                return lines;\n+                            }\n+                            return lines.join(lineSep || this.lineSeparator());\n+                        },\n+                        setValue: docMethodOp(function(code) {\n+                            var top = Pos(this.first, 0),\n+                                last = this.first + this.size - 1;\n+                            makeChange(this, {\n+                                from: top,\n+                                to: Pos(last, getLine(this, last).text.length),\n+                                text: this.splitLines(code),\n+                                origin: \"setValue\",\n+                                full: true\n+                            }, true);\n+                            if (this.cm) {\n+                                scrollToCoords(this.cm, 0, 0);\n                             }\n-                            var subscriptionManager = this.eventHandlers.get(name);\n-                            subscriptionManager === null || subscriptionManager === void 0 ? void 0 : subscriptionManager.notify.apply(subscriptionManager, tslib.__spreadArray([], tslib.__read(args), false));\n-                        };\n-                        ProjectionNode.prototype.hasListeners = function(name) {\n-                            return this.eventHandlers.has(name);\n-                        };\n-                        ProjectionNode.prototype.registerPotentialNode = function(id, node) {\n-                            this.potentialNodes.set(id, node);\n-                        };\n-                        /**\n-                         * Lifecycles\n-                         */\n-                        ProjectionNode.prototype.mount = function(instance, isLayoutDirty) {\n-                            var _this = this;\n-                            var _a;\n-                            if (isLayoutDirty === void 0) {\n-                                isLayoutDirty = false;\n+                            setSelection(this, simpleSelection(top), sel_dontScroll);\n+                        }),\n+                        replaceRange: function(code, from, to, origin) {\n+                            from = clipPos(this, from);\n+                            to = to ? clipPos(this, to) : from;\n+                            replaceRange(this, code, from, to, origin);\n+                        },\n+                        getRange: function(from, to, lineSep) {\n+                            var lines = getBetween(this, clipPos(this, from), clipPos(this, to));\n+                            if (lineSep === false) {\n+                                return lines;\n                             }\n-                            if (this.instance) return;\n-                            this.isSVG = instance instanceof SVGElement && instance.tagName !== \"svg\";\n-                            this.instance = instance;\n-                            var _b = this.options,\n-                                layoutId = _b.layoutId,\n-                                layout = _b.layout,\n-                                visualElement = _b.visualElement;\n-                            if (visualElement && !visualElement.getInstance()) {\n-                                visualElement.mount(instance);\n+                            if (lineSep === '') {\n+                                return lines.join('');\n                             }\n-                            this.root.nodes.add(this);\n-                            (_a = this.parent) === null || _a === void 0 ? void 0 : _a.children.add(this);\n-                            this.id && this.root.potentialNodes.delete(this.id);\n-                            if (isLayoutDirty && (layout || layoutId)) {\n-                                this.isLayoutDirty = true;\n+                            return lines.join(lineSep || this.lineSeparator());\n+                        },\n+                        getLine: function(line) {\n+                            var l = this.getLineHandle(line);\n+                            return l && l.text;\n+                        },\n+                        getLineHandle: function(line) {\n+                            if (isLine(this, line)) {\n+                                return getLine(this, line);\n                             }\n-                            if (attachResizeListener) {\n-                                var unblockTimeout_1;\n-                                var resizeUnblockUpdate_1 = function() {\n-                                    return _this.root.updateBlockedByResize = false;\n-                                };\n-                                attachResizeListener(instance, function() {\n-                                    _this.root.updateBlockedByResize = true;\n-                                    clearTimeout(unblockTimeout_1);\n-                                    unblockTimeout_1 = window.setTimeout(resizeUnblockUpdate_1, 250);\n-                                    if (globalProjectionState.hasAnimatedSinceResize) {\n-                                        globalProjectionState.hasAnimatedSinceResize = false;\n-                                        _this.nodes.forEach(finishAnimation);\n-                                    }\n-                                });\n+                        },\n+                        getLineNumber: function(line) {\n+                            return lineNo(line);\n+                        },\n+                        getLineHandleVisualStart: function(line) {\n+                            if (typeof line == \"number\") {\n+                                line = getLine(this, line);\n                             }\n-                            if (layoutId) {\n-                                this.root.registerSharedNode(layoutId, this);\n+                            return visualLine(line);\n+                        },\n+                        lineCount: function() {\n+                            return this.size;\n+                        },\n+                        firstLine: function() {\n+                            return this.first;\n+                        },\n+                        lastLine: function() {\n+                            return this.first + this.size - 1;\n+                        },\n+                        clipPos: function(pos) {\n+                            return clipPos(this, pos);\n+                        },\n+                        getCursor: function(start) {\n+                            var range = this.sel.primary(),\n+                                pos;\n+                            if (start == null || start == \"head\") {\n+                                pos = range.head;\n+                            } else if (start == \"anchor\") {\n+                                pos = range.anchor;\n+                            } else if (start == \"end\" || start == \"to\" || start === false) {\n+                                pos = range.to();\n+                            } else {\n+                                pos = range.from();\n                             }\n-                            // Only register the handler if it requires layout animation\n-                            if (this.options.animate !== false && visualElement && (layoutId || layout)) {\n-                                this.addEventListener(\"didUpdate\", function(_a) {\n-                                    var _b, _c, _d, _e, _f;\n-                                    var delta = _a.delta,\n-                                        hasLayoutChanged = _a.hasLayoutChanged,\n-                                        hasRelativeTargetChanged = _a.hasRelativeTargetChanged,\n-                                        newLayout = _a.layout;\n-                                    if (_this.isTreeAnimationBlocked()) {\n-                                        _this.target = undefined;\n-                                        _this.relativeTarget = undefined;\n-                                        return;\n-                                    }\n-                                    // TODO: Check here if an animation exists\n-                                    var layoutTransition = (_c = (_b = _this.options.transition) !== null && _b !== void 0 ? _b : visualElement.getDefaultTransition()) !== null && _c !== void 0 ? _c : defaultLayoutTransition;\n-                                    var _g = visualElement.getProps(),\n-                                        onLayoutAnimationStart = _g.onLayoutAnimationStart,\n-                                        onLayoutAnimationComplete = _g.onLayoutAnimationComplete;\n-                                    /**\n-                                     * The target layout of the element might stay the same,\n-                                     * but its position relative to its parent has changed.\n-                                     */\n-                                    var targetChanged = !_this.targetLayout || !boxEquals(_this.targetLayout, newLayout) || hasRelativeTargetChanged;\n-                                    /**\n-                                     * If the layout hasn't seemed to have changed, it might be that the\n-                                     * element is visually in the same place in the document but its position\n-                                     * relative to its parent has indeed changed. So here we check for that.\n-                                     */\n-                                    var hasOnlyRelativeTargetChanged = !hasLayoutChanged && hasRelativeTargetChanged;\n-                                    if (((_d = _this.resumeFrom) === null || _d === void 0 ? void 0 : _d.instance) || hasOnlyRelativeTargetChanged || hasLayoutChanged && (targetChanged || !_this.currentAnimation)) {\n-                                        if (_this.resumeFrom) {\n-                                            _this.resumingFrom = _this.resumeFrom;\n-                                            _this.resumingFrom.resumingFrom = undefined;\n-                                        }\n-                                        _this.setAnimationOrigin(delta, hasOnlyRelativeTargetChanged);\n-                                        var animationOptions = tslib.__assign(tslib.__assign({}, getValueTransition(layoutTransition, \"layout\")), {\n-                                            onPlay: onLayoutAnimationStart,\n-                                            onComplete: onLayoutAnimationComplete\n-                                        });\n-                                        if (visualElement.shouldReduceMotion) {\n-                                            animationOptions.delay = 0;\n-                                            animationOptions.type = false;\n-                                        }\n-                                        _this.startAnimation(animationOptions);\n-                                    } else {\n-                                        /**\n-                                         * If the layout hasn't changed and we have an animation that hasn't started yet,\n-                                         * finish it immediately. Otherwise it will be animating from a location\n-                                         * that was probably never commited to screen and look like a jumpy box.\n-                                         */\n-                                        if (!hasLayoutChanged && _this.animationProgress === 0) {\n-                                            _this.finishAnimation();\n-                                        }\n-                                        _this.isLead() && ((_f = (_e = _this.options).onExitComplete) === null || _f === void 0 ? void 0 : _f.call(_e));\n-                                    }\n-                                    _this.targetLayout = newLayout;\n-                                });\n+                            return pos;\n+                        },\n+                        listSelections: function() {\n+                            return this.sel.ranges;\n+                        },\n+                        somethingSelected: function() {\n+                            return this.sel.somethingSelected();\n+                        },\n+                        setCursor: docMethodOp(function(line, ch, options) {\n+                            setSimpleSelection(this, clipPos(this, typeof line == \"number\" ? Pos(line, ch || 0) : line), null, options);\n+                        }),\n+                        setSelection: docMethodOp(function(anchor, head, options) {\n+                            setSimpleSelection(this, clipPos(this, anchor), clipPos(this, head || anchor), options);\n+                        }),\n+                        extendSelection: docMethodOp(function(head, other, options) {\n+                            extendSelection(this, clipPos(this, head), other && clipPos(this, other), options);\n+                        }),\n+                        extendSelections: docMethodOp(function(heads, options) {\n+                            extendSelections(this, clipPosArray(this, heads), options);\n+                        }),\n+                        extendSelectionsBy: docMethodOp(function(f, options) {\n+                            var heads = map(this.sel.ranges, f);\n+                            extendSelections(this, clipPosArray(this, heads), options);\n+                        }),\n+                        setSelections: docMethodOp(function(ranges, primary, options) {\n+                            if (!ranges.length) {\n+                                return;\n                             }\n-                        };\n-                        ProjectionNode.prototype.unmount = function() {\n-                            var _a, _b;\n-                            this.options.layoutId && this.willUpdate();\n-                            this.root.nodes.remove(this);\n-                            (_a = this.getStack()) === null || _a === void 0 ? void 0 : _a.remove(this);\n-                            (_b = this.parent) === null || _b === void 0 ? void 0 : _b.children.delete(this);\n-                            this.instance = undefined;\n-                            sync.cancelSync.preRender(this.updateProjection);\n-                        };\n-                        // only on the root\n-                        ProjectionNode.prototype.blockUpdate = function() {\n-                            this.updateManuallyBlocked = true;\n-                        };\n-                        ProjectionNode.prototype.unblockUpdate = function() {\n-                            this.updateManuallyBlocked = false;\n-                        };\n-                        ProjectionNode.prototype.isUpdateBlocked = function() {\n-                            return this.updateManuallyBlocked || this.updateBlockedByResize;\n-                        };\n-                        ProjectionNode.prototype.isTreeAnimationBlocked = function() {\n-                            var _a;\n-                            return this.isAnimationBlocked || ((_a = this.parent) === null || _a === void 0 ? void 0 : _a.isTreeAnimationBlocked()) || false;\n-                        };\n-                        // Note: currently only running on root node\n-                        ProjectionNode.prototype.startUpdate = function() {\n-                            var _a;\n-                            if (this.isUpdateBlocked()) return;\n-                            this.isUpdating = true;\n-                            (_a = this.nodes) === null || _a === void 0 ? void 0 : _a.forEach(resetRotation);\n-                        };\n-                        ProjectionNode.prototype.willUpdate = function(shouldNotifyListeners) {\n-                            var _a, _b, _c;\n-                            if (shouldNotifyListeners === void 0) {\n-                                shouldNotifyListeners = true;\n+                            var out = [];\n+                            for (var i = 0; i < ranges.length; i++) {\n+                                out[i] = new Range(clipPos(this, ranges[i].anchor), clipPos(this, ranges[i].head || ranges[i].anchor));\n                             }\n-                            if (this.root.isUpdateBlocked()) {\n-                                (_b = (_a = this.options).onExitComplete) === null || _b === void 0 ? void 0 : _b.call(_a);\n-                                return;\n-                            }!this.root.isUpdating && this.root.startUpdate();\n-                            if (this.isLayoutDirty) return;\n-                            this.isLayoutDirty = true;\n-                            for (var i = 0; i < this.path.length; i++) {\n-                                var node = this.path[i];\n-                                node.shouldResetTransform = true;\n-                                /**\n-                                 * TODO: Check we haven't updated the scroll\n-                                 * since the last didUpdate\n-                                 */\n-                                node.updateScroll();\n+                            if (primary == null) {\n+                                primary = Math.min(ranges.length - 1, this.sel.primIndex);\n                             }\n-                            var _d = this.options,\n-                                layoutId = _d.layoutId,\n-                                layout = _d.layout;\n-                            if (layoutId === undefined && !layout) return;\n-                            var transformTemplate = (_c = this.options.visualElement) === null || _c === void 0 ? void 0 : _c.getProps().transformTemplate;\n-                            this.prevTransformTemplateValue = transformTemplate === null || transformTemplate === void 0 ? void 0 : transformTemplate(this.latestValues, \"\");\n-                            this.updateSnapshot();\n-                            shouldNotifyListeners && this.notifyListeners(\"willUpdate\");\n-                        };\n-                        // Note: Currently only running on root node\n-                        ProjectionNode.prototype.didUpdate = function() {\n-                            var updateWasBlocked = this.isUpdateBlocked();\n-                            // When doing an instant transition, we skip the layout update,\n-                            // but should still clean up the measurements so that the next\n-                            // snapshot could be taken correctly.\n-                            if (updateWasBlocked) {\n-                                this.unblockUpdate();\n-                                this.clearAllSnapshots();\n-                                this.nodes.forEach(clearMeasurements);\n-                                return;\n+                            setSelection(this, normalizeSelection(this.cm, out, primary), options);\n+                        }),\n+                        addSelection: docMethodOp(function(anchor, head, options) {\n+                            var ranges = this.sel.ranges.slice(0);\n+                            ranges.push(new Range(clipPos(this, anchor), clipPos(this, head || anchor)));\n+                            setSelection(this, normalizeSelection(this.cm, ranges, ranges.length - 1), options);\n+                        }),\n+                        getSelection: function(lineSep) {\n+                            var ranges = this.sel.ranges,\n+                                lines;\n+                            for (var i = 0; i < ranges.length; i++) {\n+                                var sel = getBetween(this, ranges[i].from(), ranges[i].to());\n+                                lines = lines ? lines.concat(sel) : sel;\n                             }\n-                            if (!this.isUpdating) return;\n-                            this.isUpdating = false;\n-                            /**\n-                             * Search for and mount newly-added projection elements.\n-                             *\n-                             * TODO: Every time a new component is rendered we could search up the tree for\n-                             * the closest mounted node and query from there rather than document.\n-                             */\n-                            if (this.potentialNodes.size) {\n-                                this.potentialNodes.forEach(mountNodeEarly);\n-                                this.potentialNodes.clear();\n+                            if (lineSep === false) {\n+                                return lines;\n+                            } else {\n+                                return lines.join(lineSep || this.lineSeparator());\n                             }\n-                            /**\n-                             * Write\n-                             */\n-                            this.nodes.forEach(resetTransformStyle);\n-                            /**\n-                             * Read ==================\n-                             */\n-                            // Update layout measurements of updated children\n-                            this.nodes.forEach(updateLayout);\n-                            /**\n-                             * Write\n-                             */\n-                            // Notify listeners that the layout is updated\n-                            this.nodes.forEach(notifyLayoutUpdate);\n-                            this.clearAllSnapshots();\n-                            // Flush any scheduled updates\n-                            sync.flushSync.update();\n-                            sync.flushSync.preRender();\n-                            sync.flushSync.render();\n-                        };\n-                        ProjectionNode.prototype.clearAllSnapshots = function() {\n-                            this.nodes.forEach(clearSnapshot);\n-                            this.sharedNodes.forEach(removeLeadSnapshots);\n-                        };\n-                        ProjectionNode.prototype.scheduleUpdateProjection = function() {\n-                            sync__default[\"default\"].preRender(this.updateProjection, false, true);\n-                        };\n-                        ProjectionNode.prototype.scheduleCheckAfterUnmount = function() {\n-                            var _this = this;\n-                            /**\n-                             * If the unmounting node is in a layoutGroup and did trigger a willUpdate,\n-                             * we manually call didUpdate to give a chance to the siblings to animate.\n-                             * Otherwise, cleanup all snapshots to prevents future nodes from reusing them.\n-                             */\n-                            sync__default[\"default\"].postRender(function() {\n-                                if (_this.isLayoutDirty) {\n-                                    _this.root.didUpdate();\n-                                } else {\n-                                    _this.root.checkUpdateFailed();\n-                                }\n-                            });\n-                        };\n-                        /**\n-                         * Update measurements\n-                         */\n-                        ProjectionNode.prototype.updateSnapshot = function() {\n-                            if (this.snapshot || !this.instance) return;\n-                            var measured = this.measure();\n-                            var layout = this.removeTransform(this.removeElementScroll(measured));\n-                            roundBox(layout);\n-                            this.snapshot = {\n-                                measured: measured,\n-                                layout: layout,\n-                                latestValues: {}\n-                            };\n-                        };\n-                        ProjectionNode.prototype.updateLayout = function() {\n-                            var _a;\n-                            if (!this.instance) return;\n-                            // TODO: Incorporate into a forwarded scroll offset\n-                            this.updateScroll();\n-                            if (!(this.options.alwaysMeasureLayout && this.isLead()) && !this.isLayoutDirty) {\n-                                return;\n+                        },\n+                        getSelections: function(lineSep) {\n+                            var parts = [],\n+                                ranges = this.sel.ranges;\n+                            for (var i = 0; i < ranges.length; i++) {\n+                                var sel = getBetween(this, ranges[i].from(), ranges[i].to());\n+                                if (lineSep !== false) {\n+                                    sel = sel.join(lineSep || this.lineSeparator());\n+                                }\n+                                parts[i] = sel;\n+                            }\n+                            return parts;\n+                        },\n+                        replaceSelection: function(code, collapse, origin) {\n+                            var dup = [];\n+                            for (var i = 0; i < this.sel.ranges.length; i++) {\n+                                dup[i] = code;\n+                            }\n+                            this.replaceSelections(dup, collapse, origin || \"+input\");\n+                        },\n+                        replaceSelections: docMethodOp(function(code, collapse, origin) {\n+                            var changes = [],\n+                                sel = this.sel;\n+                            for (var i = 0; i < sel.ranges.length; i++) {\n+                                var range = sel.ranges[i];\n+                                changes[i] = {\n+                                    from: range.from(),\n+                                    to: range.to(),\n+                                    text: this.splitLines(code[i]),\n+                                    origin: origin\n+                                };\n                             }\n-                            /**\n-                             * When a node is mounted, it simply resumes from the prevLead's\n-                             * snapshot instead of taking a new one, but the ancestors scroll\n-                             * might have updated while the prevLead is unmounted. We need to\n-                             * update the scroll again to make sure the layout we measure is\n-                             * up to date.\n-                             */\n-                            if (this.resumeFrom && !this.resumeFrom.instance) {\n-                                for (var i = 0; i < this.path.length; i++) {\n-                                    var node = this.path[i];\n-                                    node.updateScroll();\n+                            var newSel = collapse && collapse != \"end\" && computeReplacedSel(this, changes, collapse);\n+                            for (var i$1 = changes.length - 1; i$1 >= 0; i$1--) {\n+                                makeChange(this, changes[i$1]);\n+                            }\n+                            if (newSel) {\n+                                setSelectionReplaceHistory(this, newSel);\n+                            } else if (this.cm) {\n+                                ensureCursorVisible(this.cm);\n+                            }\n+                        }),\n+                        undo: docMethodOp(function() {\n+                            makeChangeFromHistory(this, \"undo\");\n+                        }),\n+                        redo: docMethodOp(function() {\n+                            makeChangeFromHistory(this, \"redo\");\n+                        }),\n+                        undoSelection: docMethodOp(function() {\n+                            makeChangeFromHistory(this, \"undo\", true);\n+                        }),\n+                        redoSelection: docMethodOp(function() {\n+                            makeChangeFromHistory(this, \"redo\", true);\n+                        }),\n+                        setExtending: function(val) {\n+                            this.extend = val;\n+                        },\n+                        getExtending: function() {\n+                            return this.extend;\n+                        },\n+                        historySize: function() {\n+                            var hist = this.history,\n+                                done = 0,\n+                                undone = 0;\n+                            for (var i = 0; i < hist.done.length; i++) {\n+                                if (!hist.done[i].ranges) {\n+                                    ++done;\n+                                }\n+                            }\n+                            for (var i$1 = 0; i$1 < hist.undone.length; i$1++) {\n+                                if (!hist.undone[i$1].ranges) {\n+                                    ++undone;\n                                 }\n                             }\n-                            var measured = this.measure();\n-                            roundBox(measured);\n-                            var prevLayout = this.layout;\n-                            this.layout = {\n-                                measured: measured,\n-                                actual: this.removeElementScroll(measured)\n+                            return {\n+                                undo: done,\n+                                redo: undone\n                             };\n-                            this.layoutCorrected = createBox();\n-                            this.isLayoutDirty = false;\n-                            this.projectionDelta = undefined;\n-                            this.notifyListeners(\"measure\", this.layout.actual);\n-                            (_a = this.options.visualElement) === null || _a === void 0 ? void 0 : _a.notifyLayoutMeasure(this.layout.actual, prevLayout === null || prevLayout === void 0 ? void 0 : prevLayout.actual);\n-                        };\n-                        ProjectionNode.prototype.updateScroll = function() {\n-                            if (this.options.layoutScroll && this.instance) {\n-                                this.isScrollRoot = checkIsScrollRoot(this.instance);\n-                                this.scroll = measureScroll(this.instance);\n+                        },\n+                        clearHistory: function() {\n+                            var this$1 = this;\n+                            this.history = new History(this.history);\n+                            linkedDocs(this, function(doc) {\n+                                return doc.history = this$1.history;\n+                            }, true);\n+                        },\n+                        markClean: function() {\n+                            this.cleanGeneration = this.changeGeneration(true);\n+                        },\n+                        changeGeneration: function(forceSplit) {\n+                            if (forceSplit) {\n+                                this.history.lastOp = this.history.lastSelOp = this.history.lastOrigin = null;\n                             }\n-                        };\n-                        ProjectionNode.prototype.resetTransform = function() {\n-                            var _a;\n-                            if (!resetTransform) return;\n-                            var isResetRequested = this.isLayoutDirty || this.shouldResetTransform;\n-                            var hasProjection = this.projectionDelta && !isDeltaZero(this.projectionDelta);\n-                            var transformTemplate = (_a = this.options.visualElement) === null || _a === void 0 ? void 0 : _a.getProps().transformTemplate;\n-                            var transformTemplateValue = transformTemplate === null || transformTemplate === void 0 ? void 0 : transformTemplate(this.latestValues, \"\");\n-                            var transformTemplateHasChanged = transformTemplateValue !== this.prevTransformTemplateValue;\n-                            if (isResetRequested && (hasProjection || hasTransform(this.latestValues) || transformTemplateHasChanged)) {\n-                                resetTransform(this.instance, transformTemplateValue);\n-                                this.shouldResetTransform = false;\n-                                this.scheduleRender();\n+                            return this.history.generation;\n+                        },\n+                        isClean: function(gen) {\n+                            return this.history.generation == (gen || this.cleanGeneration);\n+                        },\n+                        getHistory: function() {\n+                            return {\n+                                done: copyHistoryArray(this.history.done),\n+                                undone: copyHistoryArray(this.history.undone)\n+                            };\n+                        },\n+                        setHistory: function(histData) {\n+                            var hist = this.history = new History(this.history);\n+                            hist.done = copyHistoryArray(histData.done.slice(0), null, true);\n+                            hist.undone = copyHistoryArray(histData.undone.slice(0), null, true);\n+                        },\n+                        setGutterMarker: docMethodOp(function(line, gutterID, value) {\n+                            return changeLine(this, line, \"gutter\", function(line) {\n+                                var markers = line.gutterMarkers || (line.gutterMarkers = {});\n+                                markers[gutterID] = value;\n+                                if (!value && isEmpty(markers)) {\n+                                    line.gutterMarkers = null;\n+                                }\n+                                return true;\n+                            });\n+                        }),\n+                        clearGutter: docMethodOp(function(gutterID) {\n+                            var this$1 = this;\n+                            this.iter(function(line) {\n+                                if (line.gutterMarkers && line.gutterMarkers[gutterID]) {\n+                                    changeLine(this$1, line, \"gutter\", function() {\n+                                        line.gutterMarkers[gutterID] = null;\n+                                        if (isEmpty(line.gutterMarkers)) {\n+                                            line.gutterMarkers = null;\n+                                        }\n+                                        return true;\n+                                    });\n+                                }\n+                            });\n+                        }),\n+                        lineInfo: function(line) {\n+                            var n;\n+                            if (typeof line == \"number\") {\n+                                if (!isLine(this, line)) {\n+                                    return null;\n+                                }\n+                                n = line;\n+                                line = getLine(this, line);\n+                                if (!line) {\n+                                    return null;\n+                                }\n+                            } else {\n+                                n = lineNo(line);\n+                                if (n == null) {\n+                                    return null;\n+                                }\n                             }\n-                        };\n-                        ProjectionNode.prototype.measure = function() {\n-                            var visualElement = this.options.visualElement;\n-                            if (!visualElement) return createBox();\n-                            var box = visualElement.measureViewportBox();\n-                            // Remove viewport scroll to give page-relative coordinates\n-                            var scroll = this.root.scroll;\n-                            if (scroll) {\n-                                translateAxis(box.x, scroll.x);\n-                                translateAxis(box.y, scroll.y);\n+                            return {\n+                                line: n,\n+                                handle: line,\n+                                text: line.text,\n+                                gutterMarkers: line.gutterMarkers,\n+                                textClass: line.textClass,\n+                                bgClass: line.bgClass,\n+                                wrapClass: line.wrapClass,\n+                                widgets: line.widgets\n+                            };\n+                        },\n+                        addLineClass: docMethodOp(function(handle, where, cls) {\n+                            return changeLine(this, handle, where == \"gutter\" ? \"gutter\" : \"class\", function(line) {\n+                                var prop = where == \"text\" ? \"textClass\" : where == \"background\" ? \"bgClass\" : where == \"gutter\" ? \"gutterClass\" : \"wrapClass\";\n+                                if (!line[prop]) {\n+                                    line[prop] = cls;\n+                                } else if (classTest(cls).test(line[prop])) {\n+                                    return false;\n+                                } else {\n+                                    line[prop] += \" \" + cls;\n+                                }\n+                                return true;\n+                            });\n+                        }),\n+                        removeLineClass: docMethodOp(function(handle, where, cls) {\n+                            return changeLine(this, handle, where == \"gutter\" ? \"gutter\" : \"class\", function(line) {\n+                                var prop = where == \"text\" ? \"textClass\" : where == \"background\" ? \"bgClass\" : where == \"gutter\" ? \"gutterClass\" : \"wrapClass\";\n+                                var cur = line[prop];\n+                                if (!cur) {\n+                                    return false;\n+                                } else if (cls == null) {\n+                                    line[prop] = null;\n+                                } else {\n+                                    var found = cur.match(classTest(cls));\n+                                    if (!found) {\n+                                        return false;\n+                                    }\n+                                    var end = found.index + found[0].length;\n+                                    line[prop] = cur.slice(0, found.index) + (!found.index || end == cur.length ? \"\" : \" \") + cur.slice(end) || null;\n+                                }\n+                                return true;\n+                            });\n+                        }),\n+                        addLineWidget: docMethodOp(function(handle, node, options) {\n+                            return addLineWidget(this, handle, node, options);\n+                        }),\n+                        removeLineWidget: function(widget) {\n+                            widget.clear();\n+                        },\n+                        markText: function(from, to, options) {\n+                            return markText(this, clipPos(this, from), clipPos(this, to), options, options && options.type || \"range\");\n+                        },\n+                        setBookmark: function(pos, options) {\n+                            var realOpts = {\n+                                replacedWith: options && (options.nodeType == null ? options.widget : options),\n+                                insertLeft: options && options.insertLeft,\n+                                clearWhenEmpty: false,\n+                                shared: options && options.shared,\n+                                handleMouseEvents: options && options.handleMouseEvents\n+                            };\n+                            pos = clipPos(this, pos);\n+                            return markText(this, pos, pos, realOpts, \"bookmark\");\n+                        },\n+                        findMarksAt: function(pos) {\n+                            pos = clipPos(this, pos);\n+                            var markers = [],\n+                                spans = getLine(this, pos.line).markedSpans;\n+                            if (spans) {\n+                                for (var i = 0; i < spans.length; ++i) {\n+                                    var span = spans[i];\n+                                    if ((span.from == null || span.from <= pos.ch) && (span.to == null || span.to >= pos.ch)) {\n+                                        markers.push(span.marker.parent || span.marker);\n+                                    }\n+                                }\n                             }\n-                            return box;\n-                        };\n-                        ProjectionNode.prototype.removeElementScroll = function(box) {\n-                            var boxWithoutScroll = createBox();\n-                            copyBoxInto(boxWithoutScroll, box);\n-                            /**\n-                             * Performance TODO: Keep a cumulative scroll offset down the tree\n-                             * rather than loop back up the path.\n-                             */\n-                            for (var i = 0; i < this.path.length; i++) {\n-                                var node = this.path[i];\n-                                var scroll_1 = node.scroll,\n-                                    options = node.options,\n-                                    isScrollRoot = node.isScrollRoot;\n-                                if (node !== this.root && scroll_1 && options.layoutScroll) {\n-                                    /**\n-                                     * If this is a new scroll root, we want to remove all previous scrolls\n-                                     * from the viewport box.\n-                                     */\n-                                    if (isScrollRoot) {\n-                                        copyBoxInto(boxWithoutScroll, box);\n-                                        var rootScroll = this.root.scroll;\n-                                        /**\n-                                         * Undo the application of page scroll that was originally added\n-                                         * to the measured bounding box.\n-                                         */\n-                                        if (rootScroll) {\n-                                            translateAxis(boxWithoutScroll.x, -rootScroll.x);\n-                                            translateAxis(boxWithoutScroll.y, -rootScroll.y);\n+                            return markers;\n+                        },\n+                        findMarks: function(from, to, filter) {\n+                            from = clipPos(this, from);\n+                            to = clipPos(this, to);\n+                            var found = [],\n+                                lineNo = from.line;\n+                            this.iter(from.line, to.line + 1, function(line) {\n+                                var spans = line.markedSpans;\n+                                if (spans) {\n+                                    for (var i = 0; i < spans.length; i++) {\n+                                        var span = spans[i];\n+                                        if (!(span.to != null && lineNo == from.line && from.ch >= span.to || span.from == null && lineNo != from.line || span.from != null && lineNo == to.line && span.from >= to.ch) && (!filter || filter(span.marker))) {\n+                                            found.push(span.marker.parent || span.marker);\n                                         }\n                                     }\n-                                    translateAxis(boxWithoutScroll.x, scroll_1.x);\n-                                    translateAxis(boxWithoutScroll.y, scroll_1.y);\n                                 }\n+                                ++lineNo;\n+                            });\n+                            return found;\n+                        },\n+                        getAllMarks: function() {\n+                            var markers = [];\n+                            this.iter(function(line) {\n+                                var sps = line.markedSpans;\n+                                if (sps) {\n+                                    for (var i = 0; i < sps.length; ++i) {\n+                                        if (sps[i].from != null) {\n+                                            markers.push(sps[i].marker);\n+                                        }\n+                                    }\n+                                }\n+                            });\n+                            return markers;\n+                        },\n+                        posFromIndex: function(off) {\n+                            var ch,\n+                                lineNo = this.first,\n+                                sepSize = this.lineSeparator().length;\n+                            this.iter(function(line) {\n+                                var sz = line.text.length + sepSize;\n+                                if (sz > off) {\n+                                    ch = off;\n+                                    return true;\n+                                }\n+                                off -= sz;\n+                                ++lineNo;\n+                            });\n+                            return clipPos(this, Pos(lineNo, ch));\n+                        },\n+                        indexFromPos: function(coords) {\n+                            coords = clipPos(this, coords);\n+                            var index = coords.ch;\n+                            if (coords.line < this.first || coords.ch < 0) {\n+                                return 0;\n                             }\n-                            return boxWithoutScroll;\n-                        };\n-                        ProjectionNode.prototype.applyTransform = function(box, transformOnly) {\n-                            if (transformOnly === void 0) {\n-                                transformOnly = false;\n-                            }\n-                            var withTransforms = createBox();\n-                            copyBoxInto(withTransforms, box);\n-                            for (var i = 0; i < this.path.length; i++) {\n-                                var node = this.path[i];\n-                                if (!transformOnly && node.options.layoutScroll && node.scroll && node !== node.root) {\n-                                    transformBox(withTransforms, {\n-                                        x: -node.scroll.x,\n-                                        y: -node.scroll.y\n-                                    });\n+                            var sepSize = this.lineSeparator().length;\n+                            this.iter(this.first, coords.line, function(line) {\n+                                // iter aborts when callback returns a truthy value\n+                                index += line.text.length + sepSize;\n+                            });\n+                            return index;\n+                        },\n+                        copy: function(copyHistory) {\n+                            var doc = new Doc(getLines(this, this.first, this.first + this.size), this.modeOption, this.first, this.lineSep, this.direction);\n+                            doc.scrollTop = this.scrollTop;\n+                            doc.scrollLeft = this.scrollLeft;\n+                            doc.sel = this.sel;\n+                            doc.extend = false;\n+                            if (copyHistory) {\n+                                doc.history.undoDepth = this.history.undoDepth;\n+                                doc.setHistory(this.getHistory());\n+                            }\n+                            return doc;\n+                        },\n+                        linkedDoc: function(options) {\n+                            if (!options) {\n+                                options = {};\n+                            }\n+                            var from = this.first,\n+                                to = this.first + this.size;\n+                            if (options.from != null && options.from > from) {\n+                                from = options.from;\n+                            }\n+                            if (options.to != null && options.to < to) {\n+                                to = options.to;\n+                            }\n+                            var copy = new Doc(getLines(this, from, to), options.mode || this.modeOption, from, this.lineSep, this.direction);\n+                            if (options.sharedHist) {\n+                                copy.history = this.history;\n+                            }\n+                            (this.linked || (this.linked = [])).push({\n+                                doc: copy,\n+                                sharedHist: options.sharedHist\n+                            });\n+                            copy.linked = [{\n+                                doc: this,\n+                                isParent: true,\n+                                sharedHist: options.sharedHist\n+                            }];\n+                            copySharedMarkers(copy, findSharedMarkers(this));\n+                            return copy;\n+                        },\n+                        unlinkDoc: function(other) {\n+                            if (other instanceof CodeMirror) {\n+                                other = other.doc;\n+                            }\n+                            if (this.linked) {\n+                                for (var i = 0; i < this.linked.length; ++i) {\n+                                    var link = this.linked[i];\n+                                    if (link.doc != other) {\n+                                        continue;\n+                                    }\n+                                    this.linked.splice(i, 1);\n+                                    other.unlinkDoc(this);\n+                                    detachSharedMarkers(findSharedMarkers(this));\n+                                    break;\n                                 }\n-                                if (!hasTransform(node.latestValues)) continue;\n-                                transformBox(withTransforms, node.latestValues);\n                             }\n-                            if (hasTransform(this.latestValues)) {\n-                                transformBox(withTransforms, this.latestValues);\n+                            // If the histories were shared, split them again\n+                            if (other.history == this.history) {\n+                                var splitIds = [other.id];\n+                                linkedDocs(other, function(doc) {\n+                                    return splitIds.push(doc.id);\n+                                }, true);\n+                                other.history = new History(null);\n+                                other.history.done = copyHistoryArray(this.history.done, splitIds);\n+                                other.history.undone = copyHistoryArray(this.history.undone, splitIds);\n                             }\n-                            return withTransforms;\n-                        };\n-                        ProjectionNode.prototype.removeTransform = function(box) {\n-                            var _a;\n-                            var boxWithoutTransform = createBox();\n-                            copyBoxInto(boxWithoutTransform, box);\n-                            for (var i = 0; i < this.path.length; i++) {\n-                                var node = this.path[i];\n-                                if (!node.instance) continue;\n-                                if (!hasTransform(node.latestValues)) continue;\n-                                hasScale(node.latestValues) && node.updateSnapshot();\n-                                var sourceBox = createBox();\n-                                var nodeBox = node.measure();\n-                                copyBoxInto(sourceBox, nodeBox);\n-                                removeBoxTransforms(boxWithoutTransform, node.latestValues, (_a = node.snapshot) === null || _a === void 0 ? void 0 : _a.layout, sourceBox);\n+                        },\n+                        iterLinkedDocs: function(f) {\n+                            linkedDocs(this, f);\n+                        },\n+                        getMode: function() {\n+                            return this.mode;\n+                        },\n+                        getEditor: function() {\n+                            return this.cm;\n+                        },\n+                        splitLines: function(str) {\n+                            if (this.lineSep) {\n+                                return str.split(this.lineSep);\n                             }\n-                            if (hasTransform(this.latestValues)) {\n-                                removeBoxTransforms(boxWithoutTransform, this.latestValues);\n+                            return splitLinesAuto(str);\n+                        },\n+                        lineSeparator: function() {\n+                            return this.lineSep || \"\\n\";\n+                        },\n+                        setDirection: docMethodOp(function(dir) {\n+                            if (dir != \"rtl\") {\n+                                dir = \"ltr\";\n                             }\n-                            return boxWithoutTransform;\n-                        };\n-                        /**\n-                         *\n-                         */\n-                        ProjectionNode.prototype.setTargetDelta = function(delta) {\n-                            this.targetDelta = delta;\n-                            this.root.scheduleUpdateProjection();\n-                        };\n-                        ProjectionNode.prototype.setOptions = function(options) {\n-                            var _a;\n-                            this.options = tslib.__assign(tslib.__assign(tslib.__assign({}, this.options), options), {\n-                                crossfade: (_a = options.crossfade) !== null && _a !== void 0 ? _a : true\n+                            if (dir == this.direction) {\n+                                return;\n+                            }\n+                            this.direction = dir;\n+                            this.iter(function(line) {\n+                                return line.order = null;\n                             });\n-                        };\n-                        ProjectionNode.prototype.clearMeasurements = function() {\n-                            this.scroll = undefined;\n-                            this.layout = undefined;\n-                            this.snapshot = undefined;\n-                            this.prevTransformTemplateValue = undefined;\n-                            this.targetDelta = undefined;\n-                            this.target = undefined;\n-                            this.isLayoutDirty = false;\n-                        };\n-                        /**\n-                         * Frame calculations\n-                         */\n-                        ProjectionNode.prototype.resolveTargetDelta = function() {\n-                            var _a;\n-                            var _b = this.options,\n-                                layout = _b.layout,\n-                                layoutId = _b.layoutId;\n-                            /**\n-                             * If we have no layout, we can't perform projection, so early return\n-                             */\n-                            if (!this.layout || !(layout || layoutId)) return;\n-                            /**\n-                             * If we don't have a targetDelta but do have a layout, we can attempt to resolve\n-                             * a relativeParent. This will allow a component to perform scale correction\n-                             * even if no animation has started.\n-                             */\n-                            // TODO If this is unsuccessful this currently happens every frame\n-                            if (!this.targetDelta && !this.relativeTarget) {\n-                                // TODO: This is a semi-repetition of further down this function, make DRY\n-                                this.relativeParent = this.getClosestProjectingParent();\n-                                if (this.relativeParent && this.relativeParent.layout) {\n-                                    this.relativeTarget = createBox();\n-                                    this.relativeTargetOrigin = createBox();\n-                                    calcRelativePosition(this.relativeTargetOrigin, this.layout.actual, this.relativeParent.layout.actual);\n-                                    copyBoxInto(this.relativeTarget, this.relativeTargetOrigin);\n+                            if (this.cm) {\n+                                directionChanged(this.cm);\n+                            }\n+                        })\n+                    });\n+\n+                    // Public alias.\n+                    Doc.prototype.eachLine = Doc.prototype.iter;\n+\n+                    // Kludge to work around strange IE behavior where it'll sometimes\n+                    // re-fire a series of drag-related events right after the drop (#1551)\n+                    var lastDrop = 0;\n+\n+                    function onDrop(e) {\n+                        var cm = this;\n+                        clearDragCursor(cm);\n+                        if (signalDOMEvent(cm, e) || eventInWidget(cm.display, e)) {\n+                            return;\n+                        }\n+                        e_preventDefault(e);\n+                        if (ie) {\n+                            lastDrop = +new Date();\n+                        }\n+                        var pos = posFromMouse(cm, e, true),\n+                            files = e.dataTransfer.files;\n+                        if (!pos || cm.isReadOnly()) {\n+                            return;\n+                        }\n+                        // Might be a file drop, in which case we simply extract the text\n+                        // and insert it.\n+                        if (files && files.length && window.FileReader && window.File) {\n+                            var n = files.length,\n+                                text = Array(n),\n+                                read = 0;\n+                            var markAsReadAndPasteIfAllFilesAreRead = function() {\n+                                if (++read == n) {\n+                                    operation(cm, function() {\n+                                        pos = clipPos(cm.doc, pos);\n+                                        var change = {\n+                                            from: pos,\n+                                            to: pos,\n+                                            text: cm.doc.splitLines(text.filter(function(t) {\n+                                                return t != null;\n+                                            }).join(cm.doc.lineSeparator())),\n+                                            origin: \"paste\"\n+                                        };\n+                                        makeChange(cm.doc, change);\n+                                        setSelectionReplaceHistory(cm.doc, simpleSelection(clipPos(cm.doc, pos), clipPos(cm.doc, changeEnd(change))));\n+                                    })();\n+                                }\n+                            };\n+                            var readTextFromFile = function(file, i) {\n+                                if (cm.options.allowDropFileTypes && indexOf(cm.options.allowDropFileTypes, file.type) == -1) {\n+                                    markAsReadAndPasteIfAllFilesAreRead();\n+                                    return;\n                                 }\n+                                var reader = new FileReader();\n+                                reader.onerror = function() {\n+                                    return markAsReadAndPasteIfAllFilesAreRead();\n+                                };\n+                                reader.onload = function() {\n+                                    var content = reader.result;\n+                                    if (/[\\x00-\\x08\\x0e-\\x1f]{2}/.test(content)) {\n+                                        markAsReadAndPasteIfAllFilesAreRead();\n+                                        return;\n+                                    }\n+                                    text[i] = content;\n+                                    markAsReadAndPasteIfAllFilesAreRead();\n+                                };\n+                                reader.readAsText(file);\n+                            };\n+                            for (var i = 0; i < files.length; i++) {\n+                                readTextFromFile(files[i], i);\n                             }\n-                            /**\n-                             * If we have no relative target or no target delta our target isn't valid\n-                             * for this frame.\n-                             */\n-                            if (!this.relativeTarget && !this.targetDelta) return;\n-                            /**\n-                             * Lazy-init target data structure\n-                             */\n-                            if (!this.target) {\n-                                this.target = createBox();\n-                                this.targetWithTransforms = createBox();\n+                        } else {\n+                            // Normal drop\n+                            // Don't do a replace if the drop happened inside of the selected text.\n+                            if (cm.state.draggingText && cm.doc.sel.contains(pos) > -1) {\n+                                cm.state.draggingText(e);\n+                                // Ensure the editor is re-focused\n+                                setTimeout(function() {\n+                                    return cm.display.input.focus();\n+                                }, 20);\n+                                return;\n                             }\n-                            /**\n-                             * If we've got a relative box for this component, resolve it into a target relative to the parent.\n-                             */\n-                            if (this.relativeTarget && this.relativeTargetOrigin && ((_a = this.relativeParent) === null || _a === void 0 ? void 0 : _a.target)) {\n-                                calcRelativeBox(this.target, this.relativeTarget, this.relativeParent.target);\n-                                /**\n-                                 * If we've only got a targetDelta, resolve it into a target\n-                                 */\n-                            } else if (this.targetDelta) {\n-                                if (Boolean(this.resumingFrom)) {\n-                                    // TODO: This is creating a new object every frame\n-                                    this.target = this.applyTransform(this.layout.actual);\n-                                } else {\n-                                    copyBoxInto(this.target, this.layout.actual);\n+                            try {\n+                                var text$1 = e.dataTransfer.getData(\"Text\");\n+                                if (text$1) {\n+                                    var selected;\n+                                    if (cm.state.draggingText && !cm.state.draggingText.copy) {\n+                                        selected = cm.listSelections();\n+                                    }\n+                                    setSelectionNoUndo(cm.doc, simpleSelection(pos, pos));\n+                                    if (selected) {\n+                                        for (var i$1 = 0; i$1 < selected.length; ++i$1) {\n+                                            replaceRange(cm.doc, \"\", selected[i$1].anchor, selected[i$1].head, \"drag\");\n+                                        }\n+                                    }\n+                                    cm.replaceSelection(text$1, \"around\", \"paste\");\n+                                    cm.display.input.focus();\n                                 }\n-                                applyBoxDelta(this.target, this.targetDelta);\n-                            } else {\n-                                /**\n-                                 * If no target, use own layout as target\n-                                 */\n-                                copyBoxInto(this.target, this.layout.actual);\n+                            } catch (e$1) {}\n+                        }\n+                    }\n+\n+                    function onDragStart(cm, e) {\n+                        if (ie && (!cm.state.draggingText || +new Date() - lastDrop < 100)) {\n+                            e_stop(e);\n+                            return;\n+                        }\n+                        if (signalDOMEvent(cm, e) || eventInWidget(cm.display, e)) {\n+                            return;\n+                        }\n+                        e.dataTransfer.setData(\"Text\", cm.getSelection());\n+                        e.dataTransfer.effectAllowed = \"copyMove\";\n+\n+                        // Use dummy image instead of default browsers image.\n+                        // Recent Safari (~6.0.2) have a tendency to segfault when this happens, so we don't do it there.\n+                        if (e.dataTransfer.setDragImage && !safari) {\n+                            var img = elt(\"img\", null, null, \"position: fixed; left: 0; top: 0;\");\n+                            img.src = \"data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==\";\n+                            if (presto) {\n+                                img.width = img.height = 1;\n+                                cm.display.wrapper.appendChild(img);\n+                                // Force a relayout, or Opera won't use our image for some obscure reason\n+                                img._top = img.offsetTop;\n+                            }\n+                            e.dataTransfer.setDragImage(img, 0, 0);\n+                            if (presto) {\n+                                img.parentNode.removeChild(img);\n                             }\n-                            /**\n-                             * If we've been told to attempt to resolve a relative target, do so.\n-                             */\n-                            if (this.attemptToResolveRelativeTarget) {\n-                                this.attemptToResolveRelativeTarget = false;\n-                                this.relativeParent = this.getClosestProjectingParent();\n-                                if (this.relativeParent && Boolean(this.relativeParent.resumingFrom) === Boolean(this.resumingFrom) && !this.relativeParent.options.layoutScroll && this.relativeParent.target) {\n-                                    this.relativeTarget = createBox();\n-                                    this.relativeTargetOrigin = createBox();\n-                                    calcRelativePosition(this.relativeTargetOrigin, this.target, this.relativeParent.target);\n-                                    copyBoxInto(this.relativeTarget, this.relativeTargetOrigin);\n+                        }\n+                    }\n+\n+                    function onDragOver(cm, e) {\n+                        var pos = posFromMouse(cm, e);\n+                        if (!pos) {\n+                            return;\n+                        }\n+                        var frag = document.createDocumentFragment();\n+                        drawSelectionCursor(cm, pos, frag);\n+                        if (!cm.display.dragCursor) {\n+                            cm.display.dragCursor = elt(\"div\", null, \"CodeMirror-cursors CodeMirror-dragcursors\");\n+                            cm.display.lineSpace.insertBefore(cm.display.dragCursor, cm.display.cursorDiv);\n+                        }\n+                        removeChildrenAndAdd(cm.display.dragCursor, frag);\n+                    }\n+\n+                    function clearDragCursor(cm) {\n+                        if (cm.display.dragCursor) {\n+                            cm.display.lineSpace.removeChild(cm.display.dragCursor);\n+                            cm.display.dragCursor = null;\n+                        }\n+                    }\n+\n+                    // These must be handled carefully, because naively registering a\n+                    // handler for each editor will cause the editors to never be\n+                    // garbage collected.\n+\n+                    function forEachCodeMirror(f) {\n+                        if (!document.getElementsByClassName) {\n+                            return;\n+                        }\n+                        var byClass = document.getElementsByClassName(\"CodeMirror\"),\n+                            editors = [];\n+                        for (var i = 0; i < byClass.length; i++) {\n+                            var cm = byClass[i].CodeMirror;\n+                            if (cm) {\n+                                editors.push(cm);\n+                            }\n+                        }\n+                        if (editors.length) {\n+                            editors[0].operation(function() {\n+                                for (var i = 0; i < editors.length; i++) {\n+                                    f(editors[i]);\n                                 }\n+                            });\n+                        }\n+                    }\n+                    var globalsRegistered = false;\n+\n+                    function ensureGlobalHandlers() {\n+                        if (globalsRegistered) {\n+                            return;\n+                        }\n+                        registerGlobalHandlers();\n+                        globalsRegistered = true;\n+                    }\n+\n+                    function registerGlobalHandlers() {\n+                        // When the window resizes, we need to refresh active editors.\n+                        var resizeTimer;\n+                        on(window, \"resize\", function() {\n+                            if (resizeTimer == null) {\n+                                resizeTimer = setTimeout(function() {\n+                                    resizeTimer = null;\n+                                    forEachCodeMirror(onResize);\n+                                }, 100);\n                             }\n-                        };\n-                        ProjectionNode.prototype.getClosestProjectingParent = function() {\n-                            if (!this.parent || hasTransform(this.parent.latestValues)) return undefined;\n-                            if ((this.parent.relativeTarget || this.parent.targetDelta) && this.parent.layout) {\n-                                return this.parent;\n+                        });\n+                        // When the window loses focus, we want to show the editor as blurred\n+                        on(window, \"blur\", function() {\n+                            return forEachCodeMirror(onBlur);\n+                        });\n+                    }\n+                    // Called when the window resizes\n+                    function onResize(cm) {\n+                        var d = cm.display;\n+                        // Might be a text scaling operation, clear size caches.\n+                        d.cachedCharWidth = d.cachedTextHeight = d.cachedPaddingH = null;\n+                        d.scrollbarsClipped = false;\n+                        cm.setSize();\n+                    }\n+                    var keyNames = {\n+                        3: \"Pause\",\n+                        8: \"Backspace\",\n+                        9: \"Tab\",\n+                        13: \"Enter\",\n+                        16: \"Shift\",\n+                        17: \"Ctrl\",\n+                        18: \"Alt\",\n+                        19: \"Pause\",\n+                        20: \"CapsLock\",\n+                        27: \"Esc\",\n+                        32: \"Space\",\n+                        33: \"PageUp\",\n+                        34: \"PageDown\",\n+                        35: \"End\",\n+                        36: \"Home\",\n+                        37: \"Left\",\n+                        38: \"Up\",\n+                        39: \"Right\",\n+                        40: \"Down\",\n+                        44: \"PrintScrn\",\n+                        45: \"Insert\",\n+                        46: \"Delete\",\n+                        59: \";\",\n+                        61: \"=\",\n+                        91: \"Mod\",\n+                        92: \"Mod\",\n+                        93: \"Mod\",\n+                        106: \"*\",\n+                        107: \"=\",\n+                        109: \"-\",\n+                        110: \".\",\n+                        111: \"/\",\n+                        145: \"ScrollLock\",\n+                        173: \"-\",\n+                        186: \";\",\n+                        187: \"=\",\n+                        188: \",\",\n+                        189: \"-\",\n+                        190: \".\",\n+                        191: \"/\",\n+                        192: \"`\",\n+                        219: \"[\",\n+                        220: \"\\\\\",\n+                        221: \"]\",\n+                        222: \"'\",\n+                        224: \"Mod\",\n+                        63232: \"Up\",\n+                        63233: \"Down\",\n+                        63234: \"Left\",\n+                        63235: \"Right\",\n+                        63272: \"Delete\",\n+                        63273: \"Home\",\n+                        63275: \"End\",\n+                        63276: \"PageUp\",\n+                        63277: \"PageDown\",\n+                        63302: \"Insert\"\n+                    };\n+\n+                    // Number keys\n+                    for (var i = 0; i < 10; i++) {\n+                        keyNames[i + 48] = keyNames[i + 96] = String(i);\n+                    }\n+                    // Alphabetic keys\n+                    for (var i$1 = 65; i$1 <= 90; i$1++) {\n+                        keyNames[i$1] = String.fromCharCode(i$1);\n+                    }\n+                    // Function keys\n+                    for (var i$2 = 1; i$2 <= 12; i$2++) {\n+                        keyNames[i$2 + 111] = keyNames[i$2 + 63235] = \"F\" + i$2;\n+                    }\n+                    var keyMap = {};\n+                    keyMap.basic = {\n+                        \"Left\": \"goCharLeft\",\n+                        \"Right\": \"goCharRight\",\n+                        \"Up\": \"goLineUp\",\n+                        \"Down\": \"goLineDown\",\n+                        \"End\": \"goLineEnd\",\n+                        \"Home\": \"goLineStartSmart\",\n+                        \"PageUp\": \"goPageUp\",\n+                        \"PageDown\": \"goPageDown\",\n+                        \"Delete\": \"delCharAfter\",\n+                        \"Backspace\": \"delCharBefore\",\n+                        \"Shift-Backspace\": \"delCharBefore\",\n+                        \"Tab\": \"defaultTab\",\n+                        \"Shift-Tab\": \"indentAuto\",\n+                        \"Enter\": \"newlineAndIndent\",\n+                        \"Insert\": \"toggleOverwrite\",\n+                        \"Esc\": \"singleSelection\"\n+                    };\n+                    // Note that the save and find-related commands aren't defined by\n+                    // default. User code or addons can define them. Unknown commands\n+                    // are simply ignored.\n+                    keyMap.pcDefault = {\n+                        \"Ctrl-A\": \"selectAll\",\n+                        \"Ctrl-D\": \"deleteLine\",\n+                        \"Ctrl-Z\": \"undo\",\n+                        \"Shift-Ctrl-Z\": \"redo\",\n+                        \"Ctrl-Y\": \"redo\",\n+                        \"Ctrl-Home\": \"goDocStart\",\n+                        \"Ctrl-End\": \"goDocEnd\",\n+                        \"Ctrl-Up\": \"goLineUp\",\n+                        \"Ctrl-Down\": \"goLineDown\",\n+                        \"Ctrl-Left\": \"goGroupLeft\",\n+                        \"Ctrl-Right\": \"goGroupRight\",\n+                        \"Alt-Left\": \"goLineStart\",\n+                        \"Alt-Right\": \"goLineEnd\",\n+                        \"Ctrl-Backspace\": \"delGroupBefore\",\n+                        \"Ctrl-Delete\": \"delGroupAfter\",\n+                        \"Ctrl-S\": \"save\",\n+                        \"Ctrl-F\": \"find\",\n+                        \"Ctrl-G\": \"findNext\",\n+                        \"Shift-Ctrl-G\": \"findPrev\",\n+                        \"Shift-Ctrl-F\": \"replace\",\n+                        \"Shift-Ctrl-R\": \"replaceAll\",\n+                        \"Ctrl-[\": \"indentLess\",\n+                        \"Ctrl-]\": \"indentMore\",\n+                        \"Ctrl-U\": \"undoSelection\",\n+                        \"Shift-Ctrl-U\": \"redoSelection\",\n+                        \"Alt-U\": \"redoSelection\",\n+                        \"fallthrough\": \"basic\"\n+                    };\n+                    // Very basic readline/emacs-style bindings, which are standard on Mac.\n+                    keyMap.emacsy = {\n+                        \"Ctrl-F\": \"goCharRight\",\n+                        \"Ctrl-B\": \"goCharLeft\",\n+                        \"Ctrl-P\": \"goLineUp\",\n+                        \"Ctrl-N\": \"goLineDown\",\n+                        \"Ctrl-A\": \"goLineStart\",\n+                        \"Ctrl-E\": \"goLineEnd\",\n+                        \"Ctrl-V\": \"goPageDown\",\n+                        \"Shift-Ctrl-V\": \"goPageUp\",\n+                        \"Ctrl-D\": \"delCharAfter\",\n+                        \"Ctrl-H\": \"delCharBefore\",\n+                        \"Alt-Backspace\": \"delWordBefore\",\n+                        \"Ctrl-K\": \"killLine\",\n+                        \"Ctrl-T\": \"transposeChars\",\n+                        \"Ctrl-O\": \"openLine\"\n+                    };\n+                    keyMap.macDefault = {\n+                        \"Cmd-A\": \"selectAll\",\n+                        \"Cmd-D\": \"deleteLine\",\n+                        \"Cmd-Z\": \"undo\",\n+                        \"Shift-Cmd-Z\": \"redo\",\n+                        \"Cmd-Y\": \"redo\",\n+                        \"Cmd-Home\": \"goDocStart\",\n+                        \"Cmd-Up\": \"goDocStart\",\n+                        \"Cmd-End\": \"goDocEnd\",\n+                        \"Cmd-Down\": \"goDocEnd\",\n+                        \"Alt-Left\": \"goGroupLeft\",\n+                        \"Alt-Right\": \"goGroupRight\",\n+                        \"Cmd-Left\": \"goLineLeft\",\n+                        \"Cmd-Right\": \"goLineRight\",\n+                        \"Alt-Backspace\": \"delGroupBefore\",\n+                        \"Ctrl-Alt-Backspace\": \"delGroupAfter\",\n+                        \"Alt-Delete\": \"delGroupAfter\",\n+                        \"Cmd-S\": \"save\",\n+                        \"Cmd-F\": \"find\",\n+                        \"Cmd-G\": \"findNext\",\n+                        \"Shift-Cmd-G\": \"findPrev\",\n+                        \"Cmd-Alt-F\": \"replace\",\n+                        \"Shift-Cmd-Alt-F\": \"replaceAll\",\n+                        \"Cmd-[\": \"indentLess\",\n+                        \"Cmd-]\": \"indentMore\",\n+                        \"Cmd-Backspace\": \"delWrappedLineLeft\",\n+                        \"Cmd-Delete\": \"delWrappedLineRight\",\n+                        \"Cmd-U\": \"undoSelection\",\n+                        \"Shift-Cmd-U\": \"redoSelection\",\n+                        \"Ctrl-Up\": \"goDocStart\",\n+                        \"Ctrl-Down\": \"goDocEnd\",\n+                        \"fallthrough\": [\"basic\", \"emacsy\"]\n+                    };\n+                    keyMap[\"default\"] = mac ? keyMap.macDefault : keyMap.pcDefault;\n+\n+                    // KEYMAP DISPATCH\n+\n+                    function normalizeKeyName(name) {\n+                        var parts = name.split(/-(?!$)/);\n+                        name = parts[parts.length - 1];\n+                        var alt, ctrl, shift, cmd;\n+                        for (var i = 0; i < parts.length - 1; i++) {\n+                            var mod = parts[i];\n+                            if (/^(cmd|meta|m)$/i.test(mod)) {\n+                                cmd = true;\n+                            } else if (/^a(lt)?$/i.test(mod)) {\n+                                alt = true;\n+                            } else if (/^(c|ctrl|control)$/i.test(mod)) {\n+                                ctrl = true;\n+                            } else if (/^s(hift)?$/i.test(mod)) {\n+                                shift = true;\n                             } else {\n-                                return this.parent.getClosestProjectingParent();\n+                                throw new Error(\"Unrecognized modifier name: \" + mod);\n                             }\n-                        };\n-                        ProjectionNode.prototype.calcProjection = function() {\n-                            var _a;\n-                            var _b = this.options,\n-                                layout = _b.layout,\n-                                layoutId = _b.layoutId;\n-                            /**\n-                             * If this section of the tree isn't animating we can\n-                             * delete our target sources for the following frame.\n-                             */\n-                            this.isTreeAnimating = Boolean(((_a = this.parent) === null || _a === void 0 ? void 0 : _a.isTreeAnimating) || this.currentAnimation || this.pendingAnimation);\n-                            if (!this.isTreeAnimating) {\n-                                this.targetDelta = this.relativeTarget = undefined;\n+                        }\n+                        if (alt) {\n+                            name = \"Alt-\" + name;\n+                        }\n+                        if (ctrl) {\n+                            name = \"Ctrl-\" + name;\n+                        }\n+                        if (cmd) {\n+                            name = \"Cmd-\" + name;\n+                        }\n+                        if (shift) {\n+                            name = \"Shift-\" + name;\n+                        }\n+                        return name;\n+                    }\n+\n+                    // This is a kludge to keep keymaps mostly working as raw objects\n+                    // (backwards compatibility) while at the same time support features\n+                    // like normalization and multi-stroke key bindings. It compiles a\n+                    // new normalized keymap, and then updates the old object to reflect\n+                    // this.\n+                    function normalizeKeyMap(keymap) {\n+                        var copy = {};\n+                        for (var keyname in keymap) {\n+                            if (keymap.hasOwnProperty(keyname)) {\n+                                var value = keymap[keyname];\n+                                if (/^(name|fallthrough|(de|at)tach)$/.test(keyname)) {\n+                                    continue;\n+                                }\n+                                if (value == \"...\") {\n+                                    delete keymap[keyname];\n+                                    continue;\n+                                }\n+                                var keys = map(keyname.split(\" \"), normalizeKeyName);\n+                                for (var i = 0; i < keys.length; i++) {\n+                                    var val = void 0,\n+                                        name = void 0;\n+                                    if (i == keys.length - 1) {\n+                                        name = keys.join(\" \");\n+                                        val = value;\n+                                    } else {\n+                                        name = keys.slice(0, i + 1).join(\" \");\n+                                        val = \"...\";\n+                                    }\n+                                    var prev = copy[name];\n+                                    if (!prev) {\n+                                        copy[name] = val;\n+                                    } else if (prev != val) {\n+                                        throw new Error(\"Inconsistent bindings for \" + name);\n+                                    }\n+                                }\n+                                delete keymap[keyname];\n                             }\n-                            if (!this.layout || !(layout || layoutId)) return;\n-                            var lead = this.getLead();\n-                            /**\n-                             * Reset the corrected box with the latest values from box, as we're then going\n-                             * to perform mutative operations on it.\n-                             */\n-                            copyBoxInto(this.layoutCorrected, this.layout.actual);\n-                            /**\n-                             * Apply all the parent deltas to this box to produce the corrected box. This\n-                             * is the layout box, as it will appear on screen as a result of the transforms of its parents.\n-                             */\n-                            applyTreeDeltas(this.layoutCorrected, this.treeScale, this.path, Boolean(this.resumingFrom) || this !== lead);\n-                            var target = lead.target;\n-                            if (!target) return;\n-                            if (!this.projectionDelta) {\n-                                this.projectionDelta = createDelta();\n-                                this.projectionDeltaWithTransform = createDelta();\n+                        }\n+                        for (var prop in copy) {\n+                            keymap[prop] = copy[prop];\n+                        }\n+                        return keymap;\n+                    }\n+\n+                    function lookupKey(key, map, handle, context) {\n+                        map = getKeyMap(map);\n+                        var found = map.call ? map.call(key, context) : map[key];\n+                        if (found === false) {\n+                            return \"nothing\";\n+                        }\n+                        if (found === \"...\") {\n+                            return \"multi\";\n+                        }\n+                        if (found != null && handle(found)) {\n+                            return \"handled\";\n+                        }\n+                        if (map.fallthrough) {\n+                            if (Object.prototype.toString.call(map.fallthrough) != \"[object Array]\") {\n+                                return lookupKey(key, map.fallthrough, handle, context);\n                             }\n-                            var prevTreeScaleX = this.treeScale.x;\n-                            var prevTreeScaleY = this.treeScale.y;\n-                            var prevProjectionTransform = this.projectionTransform;\n-                            /**\n-                             * Update the delta between the corrected box and the target box before user-set transforms were applied.\n-                             * This will allow us to calculate the corrected borderRadius and boxShadow to compensate\n-                             * for our layout reprojection, but still allow them to be scaled correctly by the user.\n-                             * It might be that to simplify this we may want to accept that user-set scale is also corrected\n-                             * and we wouldn't have to keep and calc both deltas, OR we could support a user setting\n-                             * to allow people to choose whether these styles are corrected based on just the\n-                             * layout reprojection or the final bounding box.\n-                             */\n-                            calcBoxDelta(this.projectionDelta, this.layoutCorrected, target, this.latestValues);\n-                            this.projectionTransform = buildProjectionTransform(this.projectionDelta, this.treeScale);\n-                            if (this.projectionTransform !== prevProjectionTransform || this.treeScale.x !== prevTreeScaleX || this.treeScale.y !== prevTreeScaleY) {\n-                                this.hasProjected = true;\n-                                this.scheduleRender();\n-                                this.notifyListeners(\"projectionUpdate\", target);\n+                            for (var i = 0; i < map.fallthrough.length; i++) {\n+                                var result = lookupKey(key, map.fallthrough[i], handle, context);\n+                                if (result) {\n+                                    return result;\n+                                }\n                             }\n-                        };\n-                        ProjectionNode.prototype.hide = function() {\n-                            this.isVisible = false;\n-                            // TODO: Schedule render\n-                        };\n+                        }\n+                    }\n \n-                        ProjectionNode.prototype.show = function() {\n-                            this.isVisible = true;\n-                            // TODO: Schedule render\n-                        };\n+                    // Modifier key presses don't count as 'real' key presses for the\n+                    // purpose of keymap fallthrough.\n+                    function isModifierKey(value) {\n+                        var name = typeof value == \"string\" ? value : keyNames[value.keyCode];\n+                        return name == \"Ctrl\" || name == \"Alt\" || name == \"Shift\" || name == \"Mod\";\n+                    }\n \n-                        ProjectionNode.prototype.scheduleRender = function(notifyAll) {\n-                            var _a, _b, _c;\n-                            if (notifyAll === void 0) {\n-                                notifyAll = true;\n+                    function addModifierNames(name, event, noShift) {\n+                        var base = name;\n+                        if (event.altKey && base != \"Alt\") {\n+                            name = \"Alt-\" + name;\n+                        }\n+                        if ((flipCtrlCmd ? event.metaKey : event.ctrlKey) && base != \"Ctrl\") {\n+                            name = \"Ctrl-\" + name;\n+                        }\n+                        if ((flipCtrlCmd ? event.ctrlKey : event.metaKey) && base != \"Mod\") {\n+                            name = \"Cmd-\" + name;\n+                        }\n+                        if (!noShift && event.shiftKey && base != \"Shift\") {\n+                            name = \"Shift-\" + name;\n+                        }\n+                        return name;\n+                    }\n+\n+                    // Look up the name of a key as indicated by an event object.\n+                    function keyName(event, noShift) {\n+                        if (presto && event.keyCode == 34 && event[\"char\"]) {\n+                            return false;\n+                        }\n+                        var name = keyNames[event.keyCode];\n+                        if (name == null || event.altGraphKey) {\n+                            return false;\n+                        }\n+                        // Ctrl-ScrollLock has keyCode 3, same as Ctrl-Pause,\n+                        // so we'll use event.code when available (Chrome 48+, FF 38+, Safari 10.1+)\n+                        if (event.keyCode == 3 && event.code) {\n+                            name = event.code;\n+                        }\n+                        return addModifierNames(name, event, noShift);\n+                    }\n+\n+                    function getKeyMap(val) {\n+                        return typeof val == \"string\" ? keyMap[val] : val;\n+                    }\n+\n+                    // Helper for deleting text near the selection(s), used to implement\n+                    // backspace, delete, and similar functionality.\n+                    function deleteNearSelection(cm, compute) {\n+                        var ranges = cm.doc.sel.ranges,\n+                            kill = [];\n+                        // Build up a set of ranges to kill first, merging overlapping\n+                        // ranges.\n+                        for (var i = 0; i < ranges.length; i++) {\n+                            var toKill = compute(ranges[i]);\n+                            while (kill.length && cmp(toKill.from, lst(kill).to) <= 0) {\n+                                var replaced = kill.pop();\n+                                if (cmp(replaced.from, toKill.from) < 0) {\n+                                    toKill.from = replaced.from;\n+                                    break;\n+                                }\n                             }\n-                            (_b = (_a = this.options).scheduleRender) === null || _b === void 0 ? void 0 : _b.call(_a);\n-                            notifyAll && ((_c = this.getStack()) === null || _c === void 0 ? void 0 : _c.scheduleRender());\n-                            if (this.resumingFrom && !this.resumingFrom.instance) {\n-                                this.resumingFrom = undefined;\n+                            kill.push(toKill);\n+                        }\n+                        // Next, remove those actual ranges.\n+                        runInOp(cm, function() {\n+                            for (var i = kill.length - 1; i >= 0; i--) {\n+                                replaceRange(cm.doc, \"\", kill[i].from, kill[i].to, \"+delete\");\n+                            }\n+                            ensureCursorVisible(cm);\n+                        });\n+                    }\n+\n+                    function moveCharLogically(line, ch, dir) {\n+                        var target = skipExtendingChars(line.text, ch + dir, dir);\n+                        return target < 0 || target > line.text.length ? null : target;\n+                    }\n+\n+                    function moveLogically(line, start, dir) {\n+                        var ch = moveCharLogically(line, start.ch, dir);\n+                        return ch == null ? null : new Pos(start.line, ch, dir < 0 ? \"after\" : \"before\");\n+                    }\n+\n+                    function endOfLine(visually, cm, lineObj, lineNo, dir) {\n+                        if (visually) {\n+                            if (cm.doc.direction == \"rtl\") {\n+                                dir = -dir;\n+                            }\n+                            var order = getOrder(lineObj, cm.doc.direction);\n+                            if (order) {\n+                                var part = dir < 0 ? lst(order) : order[0];\n+                                var moveInStorageOrder = dir < 0 == (part.level == 1);\n+                                var sticky = moveInStorageOrder ? \"after\" : \"before\";\n+                                var ch;\n+                                // With a wrapped rtl chunk (possibly spanning multiple bidi parts),\n+                                // it could be that the last bidi part is not on the last visual line,\n+                                // since visual lines contain content order-consecutive chunks.\n+                                // Thus, in rtl, we are looking for the first (content-order) character\n+                                // in the rtl chunk that is on the last line (that is, the same line\n+                                // as the last (content-order) character).\n+                                if (part.level > 0 || cm.doc.direction == \"rtl\") {\n+                                    var prep = prepareMeasureForLine(cm, lineObj);\n+                                    ch = dir < 0 ? lineObj.text.length - 1 : 0;\n+                                    var targetTop = measureCharPrepared(cm, prep, ch).top;\n+                                    ch = findFirst(function(ch) {\n+                                        return measureCharPrepared(cm, prep, ch).top == targetTop;\n+                                    }, dir < 0 == (part.level == 1) ? part.from : part.to - 1, ch);\n+                                    if (sticky == \"before\") {\n+                                        ch = moveCharLogically(lineObj, ch, 1);\n+                                    }\n+                                } else {\n+                                    ch = dir < 0 ? part.to : part.from;\n+                                }\n+                                return new Pos(lineNo, ch, sticky);\n                             }\n+                        }\n+                        return new Pos(lineNo, dir < 0 ? lineObj.text.length : 0, dir < 0 ? \"before\" : \"after\");\n+                    }\n+\n+                    function moveVisually(cm, line, start, dir) {\n+                        var bidi = getOrder(line, cm.doc.direction);\n+                        if (!bidi) {\n+                            return moveLogically(line, start, dir);\n+                        }\n+                        if (start.ch >= line.text.length) {\n+                            start.ch = line.text.length;\n+                            start.sticky = \"before\";\n+                        } else if (start.ch <= 0) {\n+                            start.ch = 0;\n+                            start.sticky = \"after\";\n+                        }\n+                        var partPos = getBidiPartAt(bidi, start.ch, start.sticky),\n+                            part = bidi[partPos];\n+                        if (cm.doc.direction == \"ltr\" && part.level % 2 == 0 && (dir > 0 ? part.to > start.ch : part.from < start.ch)) {\n+                            // Case 1: We move within an ltr part in an ltr editor. Even with wrapped lines,\n+                            // nothing interesting happens.\n+                            return moveLogically(line, start, dir);\n+                        }\n+                        var mv = function(pos, dir) {\n+                            return moveCharLogically(line, pos instanceof Pos ? pos.ch : pos, dir);\n                         };\n-                        ProjectionNode.prototype.setAnimationOrigin = function(delta, hasOnlyRelativeTargetChanged) {\n-                            var _this = this;\n-                            var _a;\n-                            if (hasOnlyRelativeTargetChanged === void 0) {\n-                                hasOnlyRelativeTargetChanged = false;\n+                        var prep;\n+                        var getWrappedLineExtent = function(ch) {\n+                            if (!cm.options.lineWrapping) {\n+                                return {\n+                                    begin: 0,\n+                                    end: line.text.length\n+                                };\n                             }\n-                            var snapshot = this.snapshot;\n-                            var snapshotLatestValues = (snapshot === null || snapshot === void 0 ? void 0 : snapshot.latestValues) || {};\n-                            var mixedValues = tslib.__assign({}, this.latestValues);\n-                            var targetDelta = createDelta();\n-                            this.relativeTarget = this.relativeTargetOrigin = undefined;\n-                            this.attemptToResolveRelativeTarget = !hasOnlyRelativeTargetChanged;\n-                            var relativeLayout = createBox();\n-                            var isSharedLayoutAnimation = snapshot === null || snapshot === void 0 ? void 0 : snapshot.isShared;\n-                            var isOnlyMember = (((_a = this.getStack()) === null || _a === void 0 ? void 0 : _a.members.length) || 0) <= 1;\n-                            var shouldCrossfadeOpacity = Boolean(isSharedLayoutAnimation && !isOnlyMember && this.options.crossfade === true && !this.path.some(hasOpacityCrossfade));\n-                            this.animationProgress = 0;\n-                            this.mixTargetDelta = function(latest) {\n-                                var _a;\n-                                var progress = latest / 1000;\n-                                mixAxisDelta(targetDelta.x, delta.x, progress);\n-                                mixAxisDelta(targetDelta.y, delta.y, progress);\n-                                _this.setTargetDelta(targetDelta);\n-                                if (_this.relativeTarget && _this.relativeTargetOrigin && _this.layout && ((_a = _this.relativeParent) === null || _a === void 0 ? void 0 : _a.layout)) {\n-                                    calcRelativePosition(relativeLayout, _this.layout.actual, _this.relativeParent.layout.actual);\n-                                    mixBox(_this.relativeTarget, _this.relativeTargetOrigin, relativeLayout, progress);\n+                            prep = prep || prepareMeasureForLine(cm, line);\n+                            return wrappedLineExtentChar(cm, line, prep, ch);\n+                        };\n+                        var wrappedLineExtent = getWrappedLineExtent(start.sticky == \"before\" ? mv(start, -1) : start.ch);\n+                        if (cm.doc.direction == \"rtl\" || part.level == 1) {\n+                            var moveInStorageOrder = part.level == 1 == dir < 0;\n+                            var ch = mv(start, moveInStorageOrder ? 1 : -1);\n+                            if (ch != null && (!moveInStorageOrder ? ch >= part.from && ch >= wrappedLineExtent.begin : ch <= part.to && ch <= wrappedLineExtent.end)) {\n+                                // Case 2: We move within an rtl part or in an rtl editor on the same visual line\n+                                var sticky = moveInStorageOrder ? \"before\" : \"after\";\n+                                return new Pos(start.line, ch, sticky);\n+                            }\n+                        }\n+\n+                        // Case 3: Could not move within this bidi part in this visual line, so leave\n+                        // the current bidi part\n+\n+                        var searchInVisualLine = function(partPos, dir, wrappedLineExtent) {\n+                            var getRes = function(ch, moveInStorageOrder) {\n+                                return moveInStorageOrder ? new Pos(start.line, mv(ch, 1), \"before\") : new Pos(start.line, ch, \"after\");\n+                            };\n+                            for (; partPos >= 0 && partPos < bidi.length; partPos += dir) {\n+                                var part = bidi[partPos];\n+                                var moveInStorageOrder = dir > 0 == (part.level != 1);\n+                                var ch = moveInStorageOrder ? wrappedLineExtent.begin : mv(wrappedLineExtent.end, -1);\n+                                if (part.from <= ch && ch < part.to) {\n+                                    return getRes(ch, moveInStorageOrder);\n                                 }\n-                                if (isSharedLayoutAnimation) {\n-                                    _this.animationValues = mixedValues;\n-                                    mixValues(mixedValues, snapshotLatestValues, _this.latestValues, progress, shouldCrossfadeOpacity, isOnlyMember);\n+                                ch = moveInStorageOrder ? part.from : mv(part.to, -1);\n+                                if (wrappedLineExtent.begin <= ch && ch < wrappedLineExtent.end) {\n+                                    return getRes(ch, moveInStorageOrder);\n                                 }\n-                                _this.root.scheduleUpdateProjection();\n-                                _this.scheduleRender();\n-                                _this.animationProgress = progress;\n-                            };\n-                            this.mixTargetDelta(0);\n-                        };\n-                        ProjectionNode.prototype.startAnimation = function(options) {\n-                            var _this = this;\n-                            var _a, _b;\n-                            this.notifyListeners(\"animationStart\");\n-                            (_a = this.currentAnimation) === null || _a === void 0 ? void 0 : _a.stop();\n-                            if (this.resumingFrom) {\n-                                (_b = this.resumingFrom.currentAnimation) === null || _b === void 0 ? void 0 : _b.stop();\n                             }\n-                            if (this.pendingAnimation) {\n-                                sync.cancelSync.update(this.pendingAnimation);\n-                                this.pendingAnimation = undefined;\n+                        };\n+\n+                        // Case 3a: Look for other bidi parts on the same visual line\n+                        var res = searchInVisualLine(partPos + dir, dir, wrappedLineExtent);\n+                        if (res) {\n+                            return res;\n+                        }\n+\n+                        // Case 3b: Look for other bidi parts on the next visual line\n+                        var nextCh = dir > 0 ? wrappedLineExtent.end : mv(wrappedLineExtent.begin, -1);\n+                        if (nextCh != null && !(dir > 0 && nextCh == line.text.length)) {\n+                            res = searchInVisualLine(dir > 0 ? 0 : bidi.length - 1, dir, getWrappedLineExtent(nextCh));\n+                            if (res) {\n+                                return res;\n                             }\n-                            /**\n-                             * Start the animation in the next frame to have a frame with progress 0,\n-                             * where the target is the same as when the animation started, so we can\n-                             * calculate the relative positions correctly for instant transitions.\n-                             */\n-                            this.pendingAnimation = sync__default[\"default\"].update(function() {\n-                                globalProjectionState.hasAnimatedSinceResize = true;\n-                                _this.currentAnimation = animate(0, animationTarget, tslib.__assign(tslib.__assign({}, options), {\n-                                    onUpdate: function(latest) {\n-                                        var _a;\n-                                        _this.mixTargetDelta(latest);\n-                                        (_a = options.onUpdate) === null || _a === void 0 ? void 0 : _a.call(options, latest);\n-                                    },\n-                                    onComplete: function() {\n-                                        var _a;\n-                                        (_a = options.onComplete) === null || _a === void 0 ? void 0 : _a.call(options);\n-                                        _this.completeAnimation();\n+                        }\n+\n+                        // Case 4: Nowhere to move\n+                        return null;\n+                    }\n+\n+                    // Commands are parameter-less actions that can be performed on an\n+                    // editor, mostly used for keybindings.\n+                    var commands = {\n+                        selectAll: selectAll,\n+                        singleSelection: function(cm) {\n+                            return cm.setSelection(cm.getCursor(\"anchor\"), cm.getCursor(\"head\"), sel_dontScroll);\n+                        },\n+                        killLine: function(cm) {\n+                            return deleteNearSelection(cm, function(range) {\n+                                if (range.empty()) {\n+                                    var len = getLine(cm.doc, range.head.line).text.length;\n+                                    if (range.head.ch == len && range.head.line < cm.lastLine()) {\n+                                        return {\n+                                            from: range.head,\n+                                            to: Pos(range.head.line + 1, 0)\n+                                        };\n+                                    } else {\n+                                        return {\n+                                            from: range.head,\n+                                            to: Pos(range.head.line, len)\n+                                        };\n                                     }\n-                                }));\n-                                if (_this.resumingFrom) {\n-                                    _this.resumingFrom.currentAnimation = _this.currentAnimation;\n+                                } else {\n+                                    return {\n+                                        from: range.from(),\n+                                        to: range.to()\n+                                    };\n                                 }\n-                                _this.pendingAnimation = undefined;\n                             });\n-                        };\n-                        ProjectionNode.prototype.completeAnimation = function() {\n-                            var _a;\n-                            if (this.resumingFrom) {\n-                                this.resumingFrom.currentAnimation = undefined;\n-                                this.resumingFrom.preserveOpacity = undefined;\n-                            }\n-                            (_a = this.getStack()) === null || _a === void 0 ? void 0 : _a.exitAnimationComplete();\n-                            this.resumingFrom = this.currentAnimation = this.animationValues = undefined;\n-                            this.notifyListeners(\"animationComplete\");\n-                        };\n-                        ProjectionNode.prototype.finishAnimation = function() {\n-                            var _a;\n-                            if (this.currentAnimation) {\n-                                (_a = this.mixTargetDelta) === null || _a === void 0 ? void 0 : _a.call(this, animationTarget);\n-                                this.currentAnimation.stop();\n+                        },\n+                        deleteLine: function(cm) {\n+                            return deleteNearSelection(cm, function(range) {\n+                                return {\n+                                    from: Pos(range.from().line, 0),\n+                                    to: clipPos(cm.doc, Pos(range.to().line + 1, 0))\n+                                };\n+                            });\n+                        },\n+                        delLineLeft: function(cm) {\n+                            return deleteNearSelection(cm, function(range) {\n+                                return {\n+                                    from: Pos(range.from().line, 0),\n+                                    to: range.from()\n+                                };\n+                            });\n+                        },\n+                        delWrappedLineLeft: function(cm) {\n+                            return deleteNearSelection(cm, function(range) {\n+                                var top = cm.charCoords(range.head, \"div\").top + 5;\n+                                var leftPos = cm.coordsChar({\n+                                    left: 0,\n+                                    top: top\n+                                }, \"div\");\n+                                return {\n+                                    from: leftPos,\n+                                    to: range.from()\n+                                };\n+                            });\n+                        },\n+                        delWrappedLineRight: function(cm) {\n+                            return deleteNearSelection(cm, function(range) {\n+                                var top = cm.charCoords(range.head, \"div\").top + 5;\n+                                var rightPos = cm.coordsChar({\n+                                    left: cm.display.lineDiv.offsetWidth + 100,\n+                                    top: top\n+                                }, \"div\");\n+                                return {\n+                                    from: range.from(),\n+                                    to: rightPos\n+                                };\n+                            });\n+                        },\n+                        undo: function(cm) {\n+                            return cm.undo();\n+                        },\n+                        redo: function(cm) {\n+                            return cm.redo();\n+                        },\n+                        undoSelection: function(cm) {\n+                            return cm.undoSelection();\n+                        },\n+                        redoSelection: function(cm) {\n+                            return cm.redoSelection();\n+                        },\n+                        goDocStart: function(cm) {\n+                            return cm.extendSelection(Pos(cm.firstLine(), 0));\n+                        },\n+                        goDocEnd: function(cm) {\n+                            return cm.extendSelection(Pos(cm.lastLine()));\n+                        },\n+                        goLineStart: function(cm) {\n+                            return cm.extendSelectionsBy(function(range) {\n+                                return lineStart(cm, range.head.line);\n+                            }, {\n+                                origin: \"+move\",\n+                                bias: 1\n+                            });\n+                        },\n+                        goLineStartSmart: function(cm) {\n+                            return cm.extendSelectionsBy(function(range) {\n+                                return lineStartSmart(cm, range.head);\n+                            }, {\n+                                origin: \"+move\",\n+                                bias: 1\n+                            });\n+                        },\n+                        goLineEnd: function(cm) {\n+                            return cm.extendSelectionsBy(function(range) {\n+                                return lineEnd(cm, range.head.line);\n+                            }, {\n+                                origin: \"+move\",\n+                                bias: -1\n+                            });\n+                        },\n+                        goLineRight: function(cm) {\n+                            return cm.extendSelectionsBy(function(range) {\n+                                var top = cm.cursorCoords(range.head, \"div\").top + 5;\n+                                return cm.coordsChar({\n+                                    left: cm.display.lineDiv.offsetWidth + 100,\n+                                    top: top\n+                                }, \"div\");\n+                            }, sel_move);\n+                        },\n+                        goLineLeft: function(cm) {\n+                            return cm.extendSelectionsBy(function(range) {\n+                                var top = cm.cursorCoords(range.head, \"div\").top + 5;\n+                                return cm.coordsChar({\n+                                    left: 0,\n+                                    top: top\n+                                }, \"div\");\n+                            }, sel_move);\n+                        },\n+                        goLineLeftSmart: function(cm) {\n+                            return cm.extendSelectionsBy(function(range) {\n+                                var top = cm.cursorCoords(range.head, \"div\").top + 5;\n+                                var pos = cm.coordsChar({\n+                                    left: 0,\n+                                    top: top\n+                                }, \"div\");\n+                                if (pos.ch < cm.getLine(pos.line).search(/\\S/)) {\n+                                    return lineStartSmart(cm, range.head);\n+                                }\n+                                return pos;\n+                            }, sel_move);\n+                        },\n+                        goLineUp: function(cm) {\n+                            return cm.moveV(-1, \"line\");\n+                        },\n+                        goLineDown: function(cm) {\n+                            return cm.moveV(1, \"line\");\n+                        },\n+                        goPageUp: function(cm) {\n+                            return cm.moveV(-1, \"page\");\n+                        },\n+                        goPageDown: function(cm) {\n+                            return cm.moveV(1, \"page\");\n+                        },\n+                        goCharLeft: function(cm) {\n+                            return cm.moveH(-1, \"char\");\n+                        },\n+                        goCharRight: function(cm) {\n+                            return cm.moveH(1, \"char\");\n+                        },\n+                        goColumnLeft: function(cm) {\n+                            return cm.moveH(-1, \"column\");\n+                        },\n+                        goColumnRight: function(cm) {\n+                            return cm.moveH(1, \"column\");\n+                        },\n+                        goWordLeft: function(cm) {\n+                            return cm.moveH(-1, \"word\");\n+                        },\n+                        goGroupRight: function(cm) {\n+                            return cm.moveH(1, \"group\");\n+                        },\n+                        goGroupLeft: function(cm) {\n+                            return cm.moveH(-1, \"group\");\n+                        },\n+                        goWordRight: function(cm) {\n+                            return cm.moveH(1, \"word\");\n+                        },\n+                        delCharBefore: function(cm) {\n+                            return cm.deleteH(-1, \"codepoint\");\n+                        },\n+                        delCharAfter: function(cm) {\n+                            return cm.deleteH(1, \"char\");\n+                        },\n+                        delWordBefore: function(cm) {\n+                            return cm.deleteH(-1, \"word\");\n+                        },\n+                        delWordAfter: function(cm) {\n+                            return cm.deleteH(1, \"word\");\n+                        },\n+                        delGroupBefore: function(cm) {\n+                            return cm.deleteH(-1, \"group\");\n+                        },\n+                        delGroupAfter: function(cm) {\n+                            return cm.deleteH(1, \"group\");\n+                        },\n+                        indentAuto: function(cm) {\n+                            return cm.indentSelection(\"smart\");\n+                        },\n+                        indentMore: function(cm) {\n+                            return cm.indentSelection(\"add\");\n+                        },\n+                        indentLess: function(cm) {\n+                            return cm.indentSelection(\"subtract\");\n+                        },\n+                        insertTab: function(cm) {\n+                            return cm.replaceSelection(\"\\t\");\n+                        },\n+                        insertSoftTab: function(cm) {\n+                            var spaces = [],\n+                                ranges = cm.listSelections(),\n+                                tabSize = cm.options.tabSize;\n+                            for (var i = 0; i < ranges.length; i++) {\n+                                var pos = ranges[i].from();\n+                                var col = countColumn(cm.getLine(pos.line), pos.ch, tabSize);\n+                                spaces.push(spaceStr(tabSize - col % tabSize));\n                             }\n-                            this.completeAnimation();\n-                        };\n-                        ProjectionNode.prototype.applyTransformsToTarget = function() {\n-                            var _a = this.getLead(),\n-                                targetWithTransforms = _a.targetWithTransforms,\n-                                target = _a.target,\n-                                layout = _a.layout,\n-                                latestValues = _a.latestValues;\n-                            if (!targetWithTransforms || !target || !layout) return;\n-                            copyBoxInto(targetWithTransforms, target);\n-                            /**\n-                             * Apply the latest user-set transforms to the targetBox to produce the targetBoxFinal.\n-                             * This is the final box that we will then project into by calculating a transform delta and\n-                             * applying it to the corrected box.\n-                             */\n-                            transformBox(targetWithTransforms, latestValues);\n-                            /**\n-                             * Update the delta between the corrected box and the final target box, after\n-                             * user-set transforms are applied to it. This will be used by the renderer to\n-                             * create a transform style that will reproject the element from its actual layout\n-                             * into the desired bounding box.\n-                             */\n-                            calcBoxDelta(this.projectionDeltaWithTransform, this.layoutCorrected, targetWithTransforms, latestValues);\n-                        };\n-                        ProjectionNode.prototype.registerSharedNode = function(layoutId, node) {\n-                            var _a, _b, _c;\n-                            if (!this.sharedNodes.has(layoutId)) {\n-                                this.sharedNodes.set(layoutId, new NodeStack());\n+                            cm.replaceSelections(spaces);\n+                        },\n+                        defaultTab: function(cm) {\n+                            if (cm.somethingSelected()) {\n+                                cm.indentSelection(\"add\");\n+                            } else {\n+                                cm.execCommand(\"insertTab\");\n                             }\n-                            var stack = this.sharedNodes.get(layoutId);\n-                            stack.add(node);\n-                            node.promote({\n-                                transition: (_a = node.options.initialPromotionConfig) === null || _a === void 0 ? void 0 : _a.transition,\n-                                preserveFollowOpacity: (_c = (_b = node.options.initialPromotionConfig) === null || _b === void 0 ? void 0 : _b.shouldPreserveFollowOpacity) === null || _c === void 0 ? void 0 : _c.call(_b, node)\n+                        },\n+                        // Swap the two chars left and right of each selection's head.\n+                        // Move cursor behind the two swapped characters afterwards.\n+                        //\n+                        // Doesn't consider line feeds a character.\n+                        // Doesn't scan more than one line above to find a character.\n+                        // Doesn't do anything on an empty line.\n+                        // Doesn't do anything with non-empty selections.\n+                        transposeChars: function(cm) {\n+                            return runInOp(cm, function() {\n+                                var ranges = cm.listSelections(),\n+                                    newSel = [];\n+                                for (var i = 0; i < ranges.length; i++) {\n+                                    if (!ranges[i].empty()) {\n+                                        continue;\n+                                    }\n+                                    var cur = ranges[i].head,\n+                                        line = getLine(cm.doc, cur.line).text;\n+                                    if (line) {\n+                                        if (cur.ch == line.length) {\n+                                            cur = new Pos(cur.line, cur.ch - 1);\n+                                        }\n+                                        if (cur.ch > 0) {\n+                                            cur = new Pos(cur.line, cur.ch + 1);\n+                                            cm.replaceRange(line.charAt(cur.ch - 1) + line.charAt(cur.ch - 2), Pos(cur.line, cur.ch - 2), cur, \"+transpose\");\n+                                        } else if (cur.line > cm.doc.first) {\n+                                            var prev = getLine(cm.doc, cur.line - 1).text;\n+                                            if (prev) {\n+                                                cur = new Pos(cur.line, 1);\n+                                                cm.replaceRange(line.charAt(0) + cm.doc.lineSeparator() + prev.charAt(prev.length - 1), Pos(cur.line - 1, prev.length - 1), cur, \"+transpose\");\n+                                            }\n+                                        }\n+                                    }\n+                                    newSel.push(new Range(cur, cur));\n+                                }\n+                                cm.setSelections(newSel);\n                             });\n-                        };\n-                        ProjectionNode.prototype.isLead = function() {\n-                            var stack = this.getStack();\n-                            return stack ? stack.lead === this : true;\n-                        };\n-                        ProjectionNode.prototype.getLead = function() {\n-                            var _a;\n-                            var layoutId = this.options.layoutId;\n-                            return layoutId ? ((_a = this.getStack()) === null || _a === void 0 ? void 0 : _a.lead) || this : this;\n-                        };\n-                        ProjectionNode.prototype.getPrevLead = function() {\n-                            var _a;\n-                            var layoutId = this.options.layoutId;\n-                            return layoutId ? (_a = this.getStack()) === null || _a === void 0 ? void 0 : _a.prevLead : undefined;\n-                        };\n-                        ProjectionNode.prototype.getStack = function() {\n-                            var layoutId = this.options.layoutId;\n-                            if (layoutId) return this.root.sharedNodes.get(layoutId);\n-                        };\n-                        ProjectionNode.prototype.promote = function(_a) {\n-                            var _b = _a === void 0 ? {} : _a,\n-                                needsReset = _b.needsReset,\n-                                transition = _b.transition,\n-                                preserveFollowOpacity = _b.preserveFollowOpacity;\n-                            var stack = this.getStack();\n-                            if (stack) stack.promote(this, preserveFollowOpacity);\n-                            if (needsReset) {\n-                                this.projectionDelta = undefined;\n-                                this.needsReset = true;\n-                            }\n-                            if (transition) this.setOptions({\n-                                transition: transition\n+                        },\n+                        newlineAndIndent: function(cm) {\n+                            return runInOp(cm, function() {\n+                                var sels = cm.listSelections();\n+                                for (var i = sels.length - 1; i >= 0; i--) {\n+                                    cm.replaceRange(cm.doc.lineSeparator(), sels[i].anchor, sels[i].head, \"+input\");\n+                                }\n+                                sels = cm.listSelections();\n+                                for (var i$1 = 0; i$1 < sels.length; i$1++) {\n+                                    cm.indentLine(sels[i$1].from().line, null, true);\n+                                }\n+                                ensureCursorVisible(cm);\n                             });\n-                        };\n-                        ProjectionNode.prototype.relegate = function() {\n-                            var stack = this.getStack();\n-                            if (stack) {\n-                                return stack.relegate(this);\n-                            } else {\n+                        },\n+                        openLine: function(cm) {\n+                            return cm.replaceSelection(\"\\n\", \"start\");\n+                        },\n+                        toggleOverwrite: function(cm) {\n+                            return cm.toggleOverwrite();\n+                        }\n+                    };\n+\n+                    function lineStart(cm, lineN) {\n+                        var line = getLine(cm.doc, lineN);\n+                        var visual = visualLine(line);\n+                        if (visual != line) {\n+                            lineN = lineNo(visual);\n+                        }\n+                        return endOfLine(true, cm, visual, lineN, 1);\n+                    }\n+\n+                    function lineEnd(cm, lineN) {\n+                        var line = getLine(cm.doc, lineN);\n+                        var visual = visualLineEnd(line);\n+                        if (visual != line) {\n+                            lineN = lineNo(visual);\n+                        }\n+                        return endOfLine(true, cm, line, lineN, -1);\n+                    }\n+\n+                    function lineStartSmart(cm, pos) {\n+                        var start = lineStart(cm, pos.line);\n+                        var line = getLine(cm.doc, start.line);\n+                        var order = getOrder(line, cm.doc.direction);\n+                        if (!order || order[0].level == 0) {\n+                            var firstNonWS = Math.max(start.ch, line.text.search(/\\S/));\n+                            var inWS = pos.line == start.line && pos.ch <= firstNonWS && pos.ch;\n+                            return Pos(start.line, inWS ? 0 : firstNonWS, start.sticky);\n+                        }\n+                        return start;\n+                    }\n+\n+                    // Run a handler that was bound to a key.\n+                    function doHandleBinding(cm, bound, dropShift) {\n+                        if (typeof bound == \"string\") {\n+                            bound = commands[bound];\n+                            if (!bound) {\n                                 return false;\n                             }\n-                        };\n-                        ProjectionNode.prototype.resetRotation = function() {\n-                            var visualElement = this.options.visualElement;\n-                            if (!visualElement) return;\n-                            // If there's no detected rotation values, we can early return without a forced render.\n-                            var hasRotate = false;\n-                            // Keep a record of all the values we've reset\n-                            var resetValues = {};\n-                            // Check the rotate value of all axes and reset to 0\n-                            for (var i = 0; i < transformAxes.length; i++) {\n-                                var axis = transformAxes[i];\n-                                var key = \"rotate\" + axis;\n-                                // If this rotation doesn't exist as a motion value, then we don't\n-                                // need to reset it\n-                                if (!visualElement.getStaticValue(key)) {\n-                                    continue;\n-                                }\n-                                hasRotate = true;\n-                                // Record the rotation and then temporarily set it to 0\n-                                resetValues[key] = visualElement.getStaticValue(key);\n-                                visualElement.setStaticValue(key, 0);\n+                        }\n+                        // Ensure previous input has been read, so that the handler sees a\n+                        // consistent view of the document\n+                        cm.display.input.ensurePolled();\n+                        var prevShift = cm.display.shift,\n+                            done = false;\n+                        try {\n+                            if (cm.isReadOnly()) {\n+                                cm.state.suppressEdits = true;\n                             }\n-                            // If there's no rotation values, we don't need to do any more.\n-                            if (!hasRotate) return;\n-                            // Force a render of this element to apply the transform with all rotations\n-                            // set to 0.\n-                            visualElement === null || visualElement === void 0 ? void 0 : visualElement.syncRender();\n-                            // Put back all the values we reset\n-                            for (var key in resetValues) {\n-                                visualElement.setStaticValue(key, resetValues[key]);\n+                            if (dropShift) {\n+                                cm.display.shift = false;\n                             }\n-                            // Schedule a render for the next frame. This ensures we won't visually\n-                            // see the element with the reset rotate value applied.\n-                            visualElement.scheduleRender();\n-                        };\n-                        ProjectionNode.prototype.getProjectionStyles = function(styleProp) {\n-                            var _a, _b, _c, _d, _e, _f;\n-                            if (styleProp === void 0) {\n-                                styleProp = {};\n+                            done = bound(cm) != Pass;\n+                        } finally {\n+                            cm.display.shift = prevShift;\n+                            cm.state.suppressEdits = false;\n+                        }\n+                        return done;\n+                    }\n+\n+                    function lookupKeyForEditor(cm, name, handle) {\n+                        for (var i = 0; i < cm.state.keyMaps.length; i++) {\n+                            var result = lookupKey(name, cm.state.keyMaps[i], handle, cm);\n+                            if (result) {\n+                                return result;\n                             }\n-                            // TODO: Return lifecycle-persistent object\n-                            var styles = {};\n-                            if (!this.instance || this.isSVG) return styles;\n-                            if (!this.isVisible) {\n-                                return {\n-                                    visibility: \"hidden\"\n-                                };\n+                        }\n+                        return cm.options.extraKeys && lookupKey(name, cm.options.extraKeys, handle, cm) || lookupKey(name, cm.options.keyMap, handle, cm);\n+                    }\n+\n+                    // Note that, despite the name, this function is also used to check\n+                    // for bound mouse clicks.\n+\n+                    var stopSeq = new Delayed();\n+\n+                    function dispatchKey(cm, name, e, handle) {\n+                        var seq = cm.state.keySeq;\n+                        if (seq) {\n+                            if (isModifierKey(name)) {\n+                                return \"handled\";\n+                            }\n+                            if (/\\'$/.test(name)) {\n+                                cm.state.keySeq = null;\n                             } else {\n-                                styles.visibility = \"\";\n+                                stopSeq.set(50, function() {\n+                                    if (cm.state.keySeq == seq) {\n+                                        cm.state.keySeq = null;\n+                                        cm.display.input.reset();\n+                                    }\n+                                });\n                             }\n-                            var transformTemplate = (_a = this.options.visualElement) === null || _a === void 0 ? void 0 : _a.getProps().transformTemplate;\n-                            if (this.needsReset) {\n-                                this.needsReset = false;\n-                                styles.opacity = \"\";\n-                                styles.pointerEvents = resolveMotionValue(styleProp.pointerEvents) || \"\";\n-                                styles.transform = transformTemplate ? transformTemplate(this.latestValues, \"\") : \"none\";\n-                                return styles;\n+                            if (dispatchKeyInner(cm, seq + \" \" + name, e, handle)) {\n+                                return true;\n                             }\n-                            var lead = this.getLead();\n-                            if (!this.projectionDelta || !this.layout || !lead.target) {\n-                                var emptyStyles = {};\n-                                if (this.options.layoutId) {\n-                                    emptyStyles.opacity = (_b = this.latestValues.opacity) !== null && _b !== void 0 ? _b : 1;\n-                                    emptyStyles.pointerEvents = resolveMotionValue(styleProp.pointerEvents) || \"\";\n-                                }\n-                                if (this.hasProjected && !hasTransform(this.latestValues)) {\n-                                    emptyStyles.transform = transformTemplate ? transformTemplate({}, \"\") : \"none\";\n-                                    this.hasProjected = false;\n+                        }\n+                        return dispatchKeyInner(cm, name, e, handle);\n+                    }\n+\n+                    function dispatchKeyInner(cm, name, e, handle) {\n+                        var result = lookupKeyForEditor(cm, name, handle);\n+                        if (result == \"multi\") {\n+                            cm.state.keySeq = name;\n+                        }\n+                        if (result == \"handled\") {\n+                            signalLater(cm, \"keyHandled\", cm, name, e);\n+                        }\n+                        if (result == \"handled\" || result == \"multi\") {\n+                            e_preventDefault(e);\n+                            restartBlink(cm);\n+                        }\n+                        return !!result;\n+                    }\n+\n+                    // Handle a key from the keydown event.\n+                    function handleKeyBinding(cm, e) {\n+                        var name = keyName(e, true);\n+                        if (!name) {\n+                            return false;\n+                        }\n+                        if (e.shiftKey && !cm.state.keySeq) {\n+                            // First try to resolve full name (including 'Shift-'). Failing\n+                            // that, see if there is a cursor-motion command (starting with\n+                            // 'go') bound to the keyname without 'Shift-'.\n+                            return dispatchKey(cm, \"Shift-\" + name, e, function(b) {\n+                                return doHandleBinding(cm, b, true);\n+                            }) || dispatchKey(cm, name, e, function(b) {\n+                                if (typeof b == \"string\" ? /^go[A-Z]/.test(b) : b.motion) {\n+                                    return doHandleBinding(cm, b);\n                                 }\n-                                return emptyStyles;\n+                            });\n+                        } else {\n+                            return dispatchKey(cm, name, e, function(b) {\n+                                return doHandleBinding(cm, b);\n+                            });\n+                        }\n+                    }\n+\n+                    // Handle a key from the keypress event\n+                    function handleCharBinding(cm, e, ch) {\n+                        return dispatchKey(cm, \"'\" + ch + \"'\", e, function(b) {\n+                            return doHandleBinding(cm, b, true);\n+                        });\n+                    }\n+                    var lastStoppedKey = null;\n+\n+                    function onKeyDown(e) {\n+                        var cm = this;\n+                        if (e.target && e.target != cm.display.input.getField()) {\n+                            return;\n+                        }\n+                        cm.curOp.focus = activeElt();\n+                        if (signalDOMEvent(cm, e)) {\n+                            return;\n+                        }\n+                        // IE does strange things with escape.\n+                        if (ie && ie_version < 11 && e.keyCode == 27) {\n+                            e.returnValue = false;\n+                        }\n+                        var code = e.keyCode;\n+                        cm.display.shift = code == 16 || e.shiftKey;\n+                        var handled = handleKeyBinding(cm, e);\n+                        if (presto) {\n+                            lastStoppedKey = handled ? code : null;\n+                            // Opera has no cut event... we try to at least catch the key combo\n+                            if (!handled && code == 88 && !hasCopyEvent && (mac ? e.metaKey : e.ctrlKey)) {\n+                                cm.replaceSelection(\"\", null, \"cut\");\n                             }\n-                            var valuesToRender = lead.animationValues || lead.latestValues;\n-                            this.applyTransformsToTarget();\n-                            styles.transform = buildProjectionTransform(this.projectionDeltaWithTransform, this.treeScale, valuesToRender);\n-                            if (transformTemplate) {\n-                                styles.transform = transformTemplate(valuesToRender, styles.transform);\n+                        }\n+                        if (gecko && !mac && !handled && code == 46 && e.shiftKey && !e.ctrlKey && document.execCommand) {\n+                            document.execCommand(\"cut\");\n+                        }\n+\n+                        // Turn mouse into crosshair when Alt is held on Mac.\n+                        if (code == 18 && !/\\bCodeMirror-crosshair\\b/.test(cm.display.lineDiv.className)) {\n+                            showCrossHair(cm);\n+                        }\n+                    }\n+\n+                    function showCrossHair(cm) {\n+                        var lineDiv = cm.display.lineDiv;\n+                        addClass(lineDiv, \"CodeMirror-crosshair\");\n+\n+                        function up(e) {\n+                            if (e.keyCode == 18 || !e.altKey) {\n+                                rmClass(lineDiv, \"CodeMirror-crosshair\");\n+                                off(document, \"keyup\", up);\n+                                off(document, \"mouseover\", up);\n                             }\n-                            var _g = this.projectionDelta,\n-                                x = _g.x,\n-                                y = _g.y;\n-                            styles.transformOrigin = \"\".concat(x.origin * 100, \"% \").concat(y.origin * 100, \"% 0\");\n-                            if (lead.animationValues) {\n-                                /**\n-                                 * If the lead component is animating, assign this either the entering/leaving\n-                                 * opacity\n-                                 */\n-                                styles.opacity = lead === this ? (_d = (_c = valuesToRender.opacity) !== null && _c !== void 0 ? _c : this.latestValues.opacity) !== null && _d !== void 0 ? _d : 1 : this.preserveOpacity ? this.latestValues.opacity : valuesToRender.opacityExit;\n+                        }\n+                        on(document, \"keyup\", up);\n+                        on(document, \"mouseover\", up);\n+                    }\n+\n+                    function onKeyUp(e) {\n+                        if (e.keyCode == 16) {\n+                            this.doc.sel.shift = false;\n+                        }\n+                        signalDOMEvent(this, e);\n+                    }\n+\n+                    function onKeyPress(e) {\n+                        var cm = this;\n+                        if (e.target && e.target != cm.display.input.getField()) {\n+                            return;\n+                        }\n+                        if (eventInWidget(cm.display, e) || signalDOMEvent(cm, e) || e.ctrlKey && !e.altKey || mac && e.metaKey) {\n+                            return;\n+                        }\n+                        var keyCode = e.keyCode,\n+                            charCode = e.charCode;\n+                        if (presto && keyCode == lastStoppedKey) {\n+                            lastStoppedKey = null;\n+                            e_preventDefault(e);\n+                            return;\n+                        }\n+                        if (presto && (!e.which || e.which < 10) && handleKeyBinding(cm, e)) {\n+                            return;\n+                        }\n+                        var ch = String.fromCharCode(charCode == null ? keyCode : charCode);\n+                        // Some browsers fire keypress events for backspace\n+                        if (ch == \"\\x08\") {\n+                            return;\n+                        }\n+                        if (handleCharBinding(cm, e, ch)) {\n+                            return;\n+                        }\n+                        cm.display.input.onKeyPress(e);\n+                    }\n+                    var DOUBLECLICK_DELAY = 400;\n+                    var PastClick = function(time, pos, button) {\n+                        this.time = time;\n+                        this.pos = pos;\n+                        this.button = button;\n+                    };\n+                    PastClick.prototype.compare = function(time, pos, button) {\n+                        return this.time + DOUBLECLICK_DELAY > time && cmp(pos, this.pos) == 0 && button == this.button;\n+                    };\n+                    var lastClick, lastDoubleClick;\n+\n+                    function clickRepeat(pos, button) {\n+                        var now = +new Date();\n+                        if (lastDoubleClick && lastDoubleClick.compare(now, pos, button)) {\n+                            lastClick = lastDoubleClick = null;\n+                            return \"triple\";\n+                        } else if (lastClick && lastClick.compare(now, pos, button)) {\n+                            lastDoubleClick = new PastClick(now, pos, button);\n+                            lastClick = null;\n+                            return \"double\";\n+                        } else {\n+                            lastClick = new PastClick(now, pos, button);\n+                            lastDoubleClick = null;\n+                            return \"single\";\n+                        }\n+                    }\n+\n+                    // A mouse down can be a single click, double click, triple click,\n+                    // start of selection drag, start of text drag, new cursor\n+                    // (ctrl-click), rectangle drag (alt-drag), or xwin\n+                    // middle-click-paste. Or it might be a click on something we should\n+                    // not interfere with, such as a scrollbar or widget.\n+                    function onMouseDown(e) {\n+                        var cm = this,\n+                            display = cm.display;\n+                        if (signalDOMEvent(cm, e) || display.activeTouch && display.input.supportsTouch()) {\n+                            return;\n+                        }\n+                        display.input.ensurePolled();\n+                        display.shift = e.shiftKey;\n+                        if (eventInWidget(display, e)) {\n+                            if (!webkit) {\n+                                // Briefly turn off draggability, to allow widgets to do\n+                                // normal dragging things.\n+                                display.scroller.draggable = false;\n+                                setTimeout(function() {\n+                                    return display.scroller.draggable = true;\n+                                }, 100);\n+                            }\n+                            return;\n+                        }\n+                        if (clickInGutter(cm, e)) {\n+                            return;\n+                        }\n+                        var pos = posFromMouse(cm, e),\n+                            button = e_button(e),\n+                            repeat = pos ? clickRepeat(pos, button) : \"single\";\n+                        window.focus();\n+\n+                        // #3261: make sure, that we're not starting a second selection\n+                        if (button == 1 && cm.state.selectingText) {\n+                            cm.state.selectingText(e);\n+                        }\n+                        if (pos && handleMappedButton(cm, button, pos, repeat, e)) {\n+                            return;\n+                        }\n+                        if (button == 1) {\n+                            if (pos) {\n+                                leftButtonDown(cm, pos, repeat, e);\n+                            } else if (e_target(e) == display.scroller) {\n+                                e_preventDefault(e);\n+                            }\n+                        } else if (button == 2) {\n+                            if (pos) {\n+                                extendSelection(cm.doc, pos);\n+                            }\n+                            setTimeout(function() {\n+                                return display.input.focus();\n+                            }, 20);\n+                        } else if (button == 3) {\n+                            if (captureRightClick) {\n+                                cm.display.input.onContextMenu(e);\n                             } else {\n-                                /**\n-                                 * Or we're not animating at all, set the lead component to its actual\n-                                 * opacity and other components to hidden.\n-                                 */\n-                                styles.opacity = lead === this ? (_e = valuesToRender.opacity) !== null && _e !== void 0 ? _e : \"\" : (_f = valuesToRender.opacityExit) !== null && _f !== void 0 ? _f : 0;\n+                                delayBlurEvent(cm);\n                             }\n-                            /**\n-                             * Apply scale correction\n-                             */\n-                            for (var key in scaleCorrectors) {\n-                                if (valuesToRender[key] === undefined) continue;\n-                                var _h = scaleCorrectors[key],\n-                                    correct = _h.correct,\n-                                    applyTo = _h.applyTo;\n-                                var corrected = correct(valuesToRender[key], lead);\n-                                if (applyTo) {\n-                                    var num = applyTo.length;\n-                                    for (var i = 0; i < num; i++) {\n-                                        styles[applyTo[i]] = corrected;\n-                                    }\n+                        }\n+                    }\n+\n+                    function handleMappedButton(cm, button, pos, repeat, event) {\n+                        var name = \"Click\";\n+                        if (repeat == \"double\") {\n+                            name = \"Double\" + name;\n+                        } else if (repeat == \"triple\") {\n+                            name = \"Triple\" + name;\n+                        }\n+                        name = (button == 1 ? \"Left\" : button == 2 ? \"Middle\" : \"Right\") + name;\n+                        return dispatchKey(cm, addModifierNames(name, event), event, function(bound) {\n+                            if (typeof bound == \"string\") {\n+                                bound = commands[bound];\n+                            }\n+                            if (!bound) {\n+                                return false;\n+                            }\n+                            var done = false;\n+                            try {\n+                                if (cm.isReadOnly()) {\n+                                    cm.state.suppressEdits = true;\n+                                }\n+                                done = bound(cm, pos) != Pass;\n+                            } finally {\n+                                cm.state.suppressEdits = false;\n+                            }\n+                            return done;\n+                        });\n+                    }\n+\n+                    function configureMouse(cm, repeat, event) {\n+                        var option = cm.getOption(\"configureMouse\");\n+                        var value = option ? option(cm, repeat, event) : {};\n+                        if (value.unit == null) {\n+                            var rect = chromeOS ? event.shiftKey && event.metaKey : event.altKey;\n+                            value.unit = rect ? \"rectangle\" : repeat == \"single\" ? \"char\" : repeat == \"double\" ? \"word\" : \"line\";\n+                        }\n+                        if (value.extend == null || cm.doc.extend) {\n+                            value.extend = cm.doc.extend || event.shiftKey;\n+                        }\n+                        if (value.addNew == null) {\n+                            value.addNew = mac ? event.metaKey : event.ctrlKey;\n+                        }\n+                        if (value.moveOnDrag == null) {\n+                            value.moveOnDrag = !(mac ? event.altKey : event.ctrlKey);\n+                        }\n+                        return value;\n+                    }\n+\n+                    function leftButtonDown(cm, pos, repeat, event) {\n+                        if (ie) {\n+                            setTimeout(bind(ensureFocus, cm), 0);\n+                        } else {\n+                            cm.curOp.focus = activeElt();\n+                        }\n+                        var behavior = configureMouse(cm, repeat, event);\n+                        var sel = cm.doc.sel,\n+                            contained;\n+                        if (cm.options.dragDrop && dragAndDrop && !cm.isReadOnly() && repeat == \"single\" && (contained = sel.contains(pos)) > -1 && (cmp((contained = sel.ranges[contained]).from(), pos) < 0 || pos.xRel > 0) && (cmp(contained.to(), pos) > 0 || pos.xRel < 0)) {\n+                            leftButtonStartDrag(cm, event, pos, behavior);\n+                        } else {\n+                            leftButtonSelect(cm, event, pos, behavior);\n+                        }\n+                    }\n+\n+                    // Start a text drag. When it ends, see if any dragging actually\n+                    // happen, and treat as a click if it didn't.\n+                    function leftButtonStartDrag(cm, event, pos, behavior) {\n+                        var display = cm.display,\n+                            moved = false;\n+                        var dragEnd = operation(cm, function(e) {\n+                            if (webkit) {\n+                                display.scroller.draggable = false;\n+                            }\n+                            cm.state.draggingText = false;\n+                            if (cm.state.delayingBlurEvent) {\n+                                if (cm.hasFocus()) {\n+                                    cm.state.delayingBlurEvent = false;\n                                 } else {\n-                                    styles[key] = corrected;\n+                                    delayBlurEvent(cm);\n                                 }\n                             }\n-                            /**\n-                             * Disable pointer events on follow components. This is to ensure\n-                             * that if a follow component covers a lead component it doesn't block\n-                             * pointer events on the lead.\n-                             */\n-                            if (this.options.layoutId) {\n-                                styles.pointerEvents = lead === this ? resolveMotionValue(styleProp.pointerEvents) || \"\" : \"none\";\n+                            off(display.wrapper.ownerDocument, \"mouseup\", dragEnd);\n+                            off(display.wrapper.ownerDocument, \"mousemove\", mouseMove);\n+                            off(display.scroller, \"dragstart\", dragStart);\n+                            off(display.scroller, \"drop\", dragEnd);\n+                            if (!moved) {\n+                                e_preventDefault(e);\n+                                if (!behavior.addNew) {\n+                                    extendSelection(cm.doc, pos, null, null, behavior.extend);\n+                                }\n+                                // Work around unexplainable focus problem in IE9 (#2127) and Chrome (#3081)\n+                                if (webkit && !safari || ie && ie_version == 9) {\n+                                    setTimeout(function() {\n+                                        display.wrapper.ownerDocument.body.focus({\n+                                            preventScroll: true\n+                                        });\n+                                        display.input.focus();\n+                                    }, 20);\n+                                } else {\n+                                    display.input.focus();\n+                                }\n                             }\n-                            return styles;\n-                        };\n-                        ProjectionNode.prototype.clearSnapshot = function() {\n-                            this.resumeFrom = this.snapshot = undefined;\n+                        });\n+                        var mouseMove = function(e2) {\n+                            moved = moved || Math.abs(event.clientX - e2.clientX) + Math.abs(event.clientY - e2.clientY) >= 10;\n                         };\n-                        // Only run on root\n-                        ProjectionNode.prototype.resetTree = function() {\n-                            this.root.nodes.forEach(function(node) {\n-                                var _a;\n-                                return (_a = node.currentAnimation) === null || _a === void 0 ? void 0 : _a.stop();\n-                            });\n-                            this.root.nodes.forEach(clearMeasurements);\n-                            this.root.sharedNodes.clear();\n+                        var dragStart = function() {\n+                            return moved = true;\n                         };\n-                        return ProjectionNode;\n-                    }());\n-                }\n-\n-                function updateLayout(node) {\n-                    node.updateLayout();\n-                }\n+                        // Let the drag handler handle this.\n+                        if (webkit) {\n+                            display.scroller.draggable = true;\n+                        }\n+                        cm.state.draggingText = dragEnd;\n+                        dragEnd.copy = !behavior.moveOnDrag;\n+                        on(display.wrapper.ownerDocument, \"mouseup\", dragEnd);\n+                        on(display.wrapper.ownerDocument, \"mousemove\", mouseMove);\n+                        on(display.scroller, \"dragstart\", dragStart);\n+                        on(display.scroller, \"drop\", dragEnd);\n+                        cm.state.delayingBlurEvent = true;\n+                        setTimeout(function() {\n+                            return display.input.focus();\n+                        }, 20);\n+                        // IE's approach to draggable\n+                        if (display.scroller.dragDrop) {\n+                            display.scroller.dragDrop();\n+                        }\n+                    }\n \n-                function notifyLayoutUpdate(node) {\n-                    var _a, _b, _c, _d;\n-                    var snapshot = (_b = (_a = node.resumeFrom) === null || _a === void 0 ? void 0 : _a.snapshot) !== null && _b !== void 0 ? _b : node.snapshot;\n-                    if (node.isLead() && node.layout && snapshot && node.hasListeners(\"didUpdate\")) {\n-                        var _e = node.layout,\n-                            layout_1 = _e.actual,\n-                            measuredLayout = _e.measured;\n-                        // TODO Maybe we want to also resize the layout snapshot so we don't trigger\n-                        // animations for instance if layout=\"size\" and an element has only changed position\n-                        if (node.options.animationType === \"size\") {\n-                            eachAxis(function(axis) {\n-                                var axisSnapshot = snapshot.isShared ? snapshot.measured[axis] : snapshot.layout[axis];\n-                                var length = calcLength(axisSnapshot);\n-                                axisSnapshot.min = layout_1[axis].min;\n-                                axisSnapshot.max = axisSnapshot.min + length;\n-                            });\n-                        } else if (node.options.animationType === \"position\") {\n-                            eachAxis(function(axis) {\n-                                var axisSnapshot = snapshot.isShared ? snapshot.measured[axis] : snapshot.layout[axis];\n-                                var length = calcLength(layout_1[axis]);\n-                                axisSnapshot.max = axisSnapshot.min + length;\n-                            });\n+                    function rangeForUnit(cm, pos, unit) {\n+                        if (unit == \"char\") {\n+                            return new Range(pos, pos);\n+                        }\n+                        if (unit == \"word\") {\n+                            return cm.findWordAt(pos);\n+                        }\n+                        if (unit == \"line\") {\n+                            return new Range(Pos(pos.line, 0), clipPos(cm.doc, Pos(pos.line + 1, 0)));\n+                        }\n+                        var result = unit(cm, pos);\n+                        return new Range(result.from, result.to);\n+                    }\n+\n+                    // Normal selection, as opposed to text dragging.\n+                    function leftButtonSelect(cm, event, start, behavior) {\n+                        if (ie) {\n+                            delayBlurEvent(cm);\n+                        }\n+                        var display = cm.display,\n+                            doc = cm.doc;\n+                        e_preventDefault(event);\n+                        var ourRange,\n+                            ourIndex,\n+                            startSel = doc.sel,\n+                            ranges = startSel.ranges;\n+                        if (behavior.addNew && !behavior.extend) {\n+                            ourIndex = doc.sel.contains(start);\n+                            if (ourIndex > -1) {\n+                                ourRange = ranges[ourIndex];\n+                            } else {\n+                                ourRange = new Range(start, start);\n+                            }\n+                        } else {\n+                            ourRange = doc.sel.primary();\n+                            ourIndex = doc.sel.primIndex;\n                         }\n-                        var layoutDelta = createDelta();\n-                        calcBoxDelta(layoutDelta, layout_1, snapshot.layout);\n-                        var visualDelta = createDelta();\n-                        if (snapshot.isShared) {\n-                            calcBoxDelta(visualDelta, node.applyTransform(measuredLayout, true), snapshot.measured);\n+                        if (behavior.unit == \"rectangle\") {\n+                            if (!behavior.addNew) {\n+                                ourRange = new Range(start, start);\n+                            }\n+                            start = posFromMouse(cm, event, true, true);\n+                            ourIndex = -1;\n                         } else {\n-                            calcBoxDelta(visualDelta, layout_1, snapshot.layout);\n+                            var range = rangeForUnit(cm, start, behavior.unit);\n+                            if (behavior.extend) {\n+                                ourRange = extendRange(ourRange, range.anchor, range.head, behavior.extend);\n+                            } else {\n+                                ourRange = range;\n+                            }\n                         }\n-                        var hasLayoutChanged = !isDeltaZero(layoutDelta);\n-                        var hasRelativeTargetChanged = false;\n-                        if (!node.resumeFrom) {\n-                            node.relativeParent = node.getClosestProjectingParent();\n-                            /**\n-                             * If the relativeParent is itself resuming from a different element then\n-                             * the relative snapshot is not relavent\n-                             */\n-                            if (node.relativeParent && !node.relativeParent.resumeFrom) {\n-                                var _f = node.relativeParent,\n-                                    parentSnapshot = _f.snapshot,\n-                                    parentLayout = _f.layout;\n-                                if (parentSnapshot && parentLayout) {\n-                                    var relativeSnapshot = createBox();\n-                                    calcRelativePosition(relativeSnapshot, snapshot.layout, parentSnapshot.layout);\n-                                    var relativeLayout = createBox();\n-                                    calcRelativePosition(relativeLayout, layout_1, parentLayout.actual);\n-                                    if (!boxEquals(relativeSnapshot, relativeLayout)) {\n-                                        hasRelativeTargetChanged = true;\n-                                    }\n+                        if (!behavior.addNew) {\n+                            ourIndex = 0;\n+                            setSelection(doc, new Selection([ourRange], 0), sel_mouse);\n+                            startSel = doc.sel;\n+                        } else if (ourIndex == -1) {\n+                            ourIndex = ranges.length;\n+                            setSelection(doc, normalizeSelection(cm, ranges.concat([ourRange]), ourIndex), {\n+                                scroll: false,\n+                                origin: \"*mouse\"\n+                            });\n+                        } else if (ranges.length > 1 && ranges[ourIndex].empty() && behavior.unit == \"char\" && !behavior.extend) {\n+                            setSelection(doc, normalizeSelection(cm, ranges.slice(0, ourIndex).concat(ranges.slice(ourIndex + 1)), 0), {\n+                                scroll: false,\n+                                origin: \"*mouse\"\n+                            });\n+                            startSel = doc.sel;\n+                        } else {\n+                            replaceOneSelection(doc, ourIndex, ourRange, sel_mouse);\n+                        }\n+                        var lastPos = start;\n+\n+                        function extendTo(pos) {\n+                            if (cmp(lastPos, pos) == 0) {\n+                                return;\n+                            }\n+                            lastPos = pos;\n+                            if (behavior.unit == \"rectangle\") {\n+                                var ranges = [],\n+                                    tabSize = cm.options.tabSize;\n+                                var startCol = countColumn(getLine(doc, start.line).text, start.ch, tabSize);\n+                                var posCol = countColumn(getLine(doc, pos.line).text, pos.ch, tabSize);\n+                                var left = Math.min(startCol, posCol),\n+                                    right = Math.max(startCol, posCol);\n+                                for (var line = Math.min(start.line, pos.line), end = Math.min(cm.lastLine(), Math.max(start.line, pos.line)); line <= end; line++) {\n+                                    var text = getLine(doc, line).text,\n+                                        leftPos = findColumn(text, left, tabSize);\n+                                    if (left == right) {\n+                                        ranges.push(new Range(Pos(line, leftPos), Pos(line, leftPos)));\n+                                    } else if (text.length > leftPos) {\n+                                        ranges.push(new Range(Pos(line, leftPos), Pos(line, findColumn(text, right, tabSize))));\n+                                    }\n+                                }\n+                                if (!ranges.length) {\n+                                    ranges.push(new Range(start, start));\n+                                }\n+                                setSelection(doc, normalizeSelection(cm, startSel.ranges.slice(0, ourIndex).concat(ranges), ourIndex), {\n+                                    origin: \"*mouse\",\n+                                    scroll: false\n+                                });\n+                                cm.scrollIntoView(pos);\n+                            } else {\n+                                var oldRange = ourRange;\n+                                var range = rangeForUnit(cm, pos, behavior.unit);\n+                                var anchor = oldRange.anchor,\n+                                    head;\n+                                if (cmp(range.anchor, anchor) > 0) {\n+                                    head = range.head;\n+                                    anchor = minPos(oldRange.from(), range.anchor);\n+                                } else {\n+                                    head = range.anchor;\n+                                    anchor = maxPos(oldRange.to(), range.head);\n+                                }\n+                                var ranges$1 = startSel.ranges.slice(0);\n+                                ranges$1[ourIndex] = bidiSimplify(cm, new Range(clipPos(doc, anchor), head));\n+                                setSelection(doc, normalizeSelection(cm, ranges$1, ourIndex), sel_mouse);\n+                            }\n+                        }\n+                        var editorSize = display.wrapper.getBoundingClientRect();\n+                        // Used to ensure timeout re-tries don't fire when another extend\n+                        // happened in the meantime (clearTimeout isn't reliable -- at\n+                        // least on Chrome, the timeouts still happen even when cleared,\n+                        // if the clear happens after their scheduled firing time).\n+                        var counter = 0;\n+\n+                        function extend(e) {\n+                            var curCount = ++counter;\n+                            var cur = posFromMouse(cm, e, true, behavior.unit == \"rectangle\");\n+                            if (!cur) {\n+                                return;\n+                            }\n+                            if (cmp(cur, lastPos) != 0) {\n+                                cm.curOp.focus = activeElt();\n+                                extendTo(cur);\n+                                var visible = visibleLines(display, doc);\n+                                if (cur.line >= visible.to || cur.line < visible.from) {\n+                                    setTimeout(operation(cm, function() {\n+                                        if (counter == curCount) {\n+                                            extend(e);\n+                                        }\n+                                    }), 150);\n+                                }\n+                            } else {\n+                                var outside = e.clientY < editorSize.top ? -20 : e.clientY > editorSize.bottom ? 20 : 0;\n+                                if (outside) {\n+                                    setTimeout(operation(cm, function() {\n+                                        if (counter != curCount) {\n+                                            return;\n+                                        }\n+                                        display.scroller.scrollTop += outside;\n+                                        extend(e);\n+                                    }), 50);\n                                 }\n                             }\n                         }\n-                        node.notifyListeners(\"didUpdate\", {\n-                            layout: layout_1,\n-                            snapshot: snapshot,\n-                            delta: visualDelta,\n-                            layoutDelta: layoutDelta,\n-                            hasLayoutChanged: hasLayoutChanged,\n-                            hasRelativeTargetChanged: hasRelativeTargetChanged\n+\n+                        function done(e) {\n+                            cm.state.selectingText = false;\n+                            counter = Infinity;\n+                            // If e is null or undefined we interpret this as someone trying\n+                            // to explicitly cancel the selection rather than the user\n+                            // letting go of the mouse button.\n+                            if (e) {\n+                                e_preventDefault(e);\n+                                display.input.focus();\n+                            }\n+                            off(display.wrapper.ownerDocument, \"mousemove\", move);\n+                            off(display.wrapper.ownerDocument, \"mouseup\", up);\n+                            doc.history.lastSelOrigin = null;\n+                        }\n+                        var move = operation(cm, function(e) {\n+                            if (e.buttons === 0 || !e_button(e)) {\n+                                done(e);\n+                            } else {\n+                                extend(e);\n+                            }\n                         });\n-                    } else if (node.isLead()) {\n-                        (_d = (_c = node.options).onExitComplete) === null || _d === void 0 ? void 0 : _d.call(_c);\n+                        var up = operation(cm, done);\n+                        cm.state.selectingText = up;\n+                        on(display.wrapper.ownerDocument, \"mousemove\", move);\n+                        on(display.wrapper.ownerDocument, \"mouseup\", up);\n+                    }\n+\n+                    // Used when mouse-selecting to adjust the anchor to the proper side\n+                    // of a bidi jump depending on the visual position of the head.\n+                    function bidiSimplify(cm, range) {\n+                        var anchor = range.anchor;\n+                        var head = range.head;\n+                        var anchorLine = getLine(cm.doc, anchor.line);\n+                        if (cmp(anchor, head) == 0 && anchor.sticky == head.sticky) {\n+                            return range;\n+                        }\n+                        var order = getOrder(anchorLine);\n+                        if (!order) {\n+                            return range;\n+                        }\n+                        var index = getBidiPartAt(order, anchor.ch, anchor.sticky),\n+                            part = order[index];\n+                        if (part.from != anchor.ch && part.to != anchor.ch) {\n+                            return range;\n+                        }\n+                        var boundary = index + (part.from == anchor.ch == (part.level != 1) ? 0 : 1);\n+                        if (boundary == 0 || boundary == order.length) {\n+                            return range;\n+                        }\n+\n+                        // Compute the relative visual position of the head compared to the\n+                        // anchor (<0 is to the left, >0 to the right)\n+                        var leftSide;\n+                        if (head.line != anchor.line) {\n+                            leftSide = (head.line - anchor.line) * (cm.doc.direction == \"ltr\" ? 1 : -1) > 0;\n+                        } else {\n+                            var headIndex = getBidiPartAt(order, head.ch, head.sticky);\n+                            var dir = headIndex - index || (head.ch - anchor.ch) * (part.level == 1 ? -1 : 1);\n+                            if (headIndex == boundary - 1 || headIndex == boundary) {\n+                                leftSide = dir < 0;\n+                            } else {\n+                                leftSide = dir > 0;\n+                            }\n+                        }\n+                        var usePart = order[boundary + (leftSide ? -1 : 0)];\n+                        var from = leftSide == (usePart.level == 1);\n+                        var ch = from ? usePart.from : usePart.to,\n+                            sticky = from ? \"after\" : \"before\";\n+                        return anchor.ch == ch && anchor.sticky == sticky ? range : new Range(new Pos(anchor.line, ch, sticky), head);\n+                    }\n+\n+                    // Determines whether an event happened in the gutter, and fires the\n+                    // handlers for the corresponding event.\n+                    function gutterEvent(cm, e, type, prevent) {\n+                        var mX, mY;\n+                        if (e.touches) {\n+                            mX = e.touches[0].clientX;\n+                            mY = e.touches[0].clientY;\n+                        } else {\n+                            try {\n+                                mX = e.clientX;\n+                                mY = e.clientY;\n+                            } catch (e$1) {\n+                                return false;\n+                            }\n+                        }\n+                        if (mX >= Math.floor(cm.display.gutters.getBoundingClientRect().right)) {\n+                            return false;\n+                        }\n+                        if (prevent) {\n+                            e_preventDefault(e);\n+                        }\n+                        var display = cm.display;\n+                        var lineBox = display.lineDiv.getBoundingClientRect();\n+                        if (mY > lineBox.bottom || !hasHandler(cm, type)) {\n+                            return e_defaultPrevented(e);\n+                        }\n+                        mY -= lineBox.top - display.viewOffset;\n+                        for (var i = 0; i < cm.display.gutterSpecs.length; ++i) {\n+                            var g = display.gutters.childNodes[i];\n+                            if (g && g.getBoundingClientRect().right >= mX) {\n+                                var line = lineAtHeight(cm.doc, mY);\n+                                var gutter = cm.display.gutterSpecs[i];\n+                                signal(cm, type, cm, line, gutter.className, e);\n+                                return e_defaultPrevented(e);\n+                            }\n+                        }\n                     }\n-                    /**\n-                     * Clearing transition\n-                     * TODO: Investigate why this transition is being passed in as {type: false } from Framer\n-                     * and why we need it at all\n-                     */\n-                    node.options.transition = undefined;\n-                }\n \n-                function clearSnapshot(node) {\n-                    node.clearSnapshot();\n-                }\n+                    function clickInGutter(cm, e) {\n+                        return gutterEvent(cm, e, \"gutterClick\", true);\n+                    }\n \n-                function clearMeasurements(node) {\n-                    node.clearMeasurements();\n-                }\n+                    // CONTEXT MENU HANDLING\n \n-                function resetTransformStyle(node) {\n-                    var visualElement = node.options.visualElement;\n-                    if (visualElement === null || visualElement === void 0 ? void 0 : visualElement.getProps().onBeforeLayoutMeasure) {\n-                        visualElement.notifyBeforeLayoutMeasure();\n+                    // To make the context menu work, we need to briefly unhide the\n+                    // textarea (making it as unobtrusive as possible) to let the\n+                    // right-click take effect on it.\n+                    function onContextMenu(cm, e) {\n+                        if (eventInWidget(cm.display, e) || contextMenuInGutter(cm, e)) {\n+                            return;\n+                        }\n+                        if (signalDOMEvent(cm, e, \"contextmenu\")) {\n+                            return;\n+                        }\n+                        if (!captureRightClick) {\n+                            cm.display.input.onContextMenu(e);\n+                        }\n                     }\n-                    node.resetTransform();\n-                }\n \n-                function finishAnimation(node) {\n-                    node.finishAnimation();\n-                    node.targetDelta = node.relativeTarget = node.target = undefined;\n-                }\n+                    function contextMenuInGutter(cm, e) {\n+                        if (!hasHandler(cm, \"gutterContextMenu\")) {\n+                            return false;\n+                        }\n+                        return gutterEvent(cm, e, \"gutterContextMenu\", false);\n+                    }\n \n-                function resolveTargetDelta(node) {\n-                    node.resolveTargetDelta();\n-                }\n+                    function themeChanged(cm) {\n+                        cm.display.wrapper.className = cm.display.wrapper.className.replace(/\\s*cm-s-\\S+/g, \"\") + cm.options.theme.replace(/(^|\\s)\\s*/g, \" cm-s-\");\n+                        clearCaches(cm);\n+                    }\n+                    var Init = {\n+                        toString: function() {\n+                            return \"CodeMirror.Init\";\n+                        }\n+                    };\n+                    var defaults = {};\n+                    var optionHandlers = {};\n+\n+                    function defineOptions(CodeMirror) {\n+                        var optionHandlers = CodeMirror.optionHandlers;\n+\n+                        function option(name, deflt, handle, notOnInit) {\n+                            CodeMirror.defaults[name] = deflt;\n+                            if (handle) {\n+                                optionHandlers[name] = notOnInit ? function(cm, val, old) {\n+                                    if (old != Init) {\n+                                        handle(cm, val, old);\n+                                    }\n+                                } : handle;\n+                            }\n+                        }\n+                        CodeMirror.defineOption = option;\n+\n+                        // Passed to option handlers when there is no old value.\n+                        CodeMirror.Init = Init;\n+\n+                        // These two are, on init, called from the constructor because they\n+                        // have to be initialized before the editor can start at all.\n+                        option(\"value\", \"\", function(cm, val) {\n+                            return cm.setValue(val);\n+                        }, true);\n+                        option(\"mode\", null, function(cm, val) {\n+                            cm.doc.modeOption = val;\n+                            loadMode(cm);\n+                        }, true);\n+                        option(\"indentUnit\", 2, loadMode, true);\n+                        option(\"indentWithTabs\", false);\n+                        option(\"smartIndent\", true);\n+                        option(\"tabSize\", 4, function(cm) {\n+                            resetModeState(cm);\n+                            clearCaches(cm);\n+                            regChange(cm);\n+                        }, true);\n+                        option(\"lineSeparator\", null, function(cm, val) {\n+                            cm.doc.lineSep = val;\n+                            if (!val) {\n+                                return;\n+                            }\n+                            var newBreaks = [],\n+                                lineNo = cm.doc.first;\n+                            cm.doc.iter(function(line) {\n+                                for (var pos = 0;;) {\n+                                    var found = line.text.indexOf(val, pos);\n+                                    if (found == -1) {\n+                                        break;\n+                                    }\n+                                    pos = found + val.length;\n+                                    newBreaks.push(Pos(lineNo, found));\n+                                }\n+                                lineNo++;\n+                            });\n+                            for (var i = newBreaks.length - 1; i >= 0; i--) {\n+                                replaceRange(cm.doc, val, newBreaks[i], Pos(newBreaks[i].line, newBreaks[i].ch + val.length));\n+                            }\n+                        });\n+                        option(\"specialChars\", /[\\u0000-\\u001f\\u007f-\\u009f\\u00ad\\u061c\\u200b\\u200e\\u200f\\u2028\\u2029\\ufeff\\ufff9-\\ufffc]/g, function(cm, val, old) {\n+                            cm.state.specialChars = new RegExp(val.source + (val.test(\"\\t\") ? \"\" : \"|\\t\"), \"g\");\n+                            if (old != Init) {\n+                                cm.refresh();\n+                            }\n+                        });\n+                        option(\"specialCharPlaceholder\", defaultSpecialCharPlaceholder, function(cm) {\n+                            return cm.refresh();\n+                        }, true);\n+                        option(\"electricChars\", true);\n+                        option(\"inputStyle\", mobile ? \"contenteditable\" : \"textarea\", function() {\n+                            throw new Error(\"inputStyle can not (yet) be changed in a running editor\"); // FIXME\n+                        }, true);\n+                        option(\"spellcheck\", false, function(cm, val) {\n+                            return cm.getInputField().spellcheck = val;\n+                        }, true);\n+                        option(\"autocorrect\", false, function(cm, val) {\n+                            return cm.getInputField().autocorrect = val;\n+                        }, true);\n+                        option(\"autocapitalize\", false, function(cm, val) {\n+                            return cm.getInputField().autocapitalize = val;\n+                        }, true);\n+                        option(\"rtlMoveVisually\", !windows);\n+                        option(\"wholeLineUpdateBefore\", true);\n+                        option(\"theme\", \"default\", function(cm) {\n+                            themeChanged(cm);\n+                            updateGutters(cm);\n+                        }, true);\n+                        option(\"keyMap\", \"default\", function(cm, val, old) {\n+                            var next = getKeyMap(val);\n+                            var prev = old != Init && getKeyMap(old);\n+                            if (prev && prev.detach) {\n+                                prev.detach(cm, next);\n+                            }\n+                            if (next.attach) {\n+                                next.attach(cm, prev || null);\n+                            }\n+                        });\n+                        option(\"extraKeys\", null);\n+                        option(\"configureMouse\", null);\n+                        option(\"lineWrapping\", false, wrappingChanged, true);\n+                        option(\"gutters\", [], function(cm, val) {\n+                            cm.display.gutterSpecs = getGutters(val, cm.options.lineNumbers);\n+                            updateGutters(cm);\n+                        }, true);\n+                        option(\"fixedGutter\", true, function(cm, val) {\n+                            cm.display.gutters.style.left = val ? compensateForHScroll(cm.display) + \"px\" : \"0\";\n+                            cm.refresh();\n+                        }, true);\n+                        option(\"coverGutterNextToScrollbar\", false, function(cm) {\n+                            return updateScrollbars(cm);\n+                        }, true);\n+                        option(\"scrollbarStyle\", \"native\", function(cm) {\n+                            initScrollbars(cm);\n+                            updateScrollbars(cm);\n+                            cm.display.scrollbars.setScrollTop(cm.doc.scrollTop);\n+                            cm.display.scrollbars.setScrollLeft(cm.doc.scrollLeft);\n+                        }, true);\n+                        option(\"lineNumbers\", false, function(cm, val) {\n+                            cm.display.gutterSpecs = getGutters(cm.options.gutters, val);\n+                            updateGutters(cm);\n+                        }, true);\n+                        option(\"firstLineNumber\", 1, updateGutters, true);\n+                        option(\"lineNumberFormatter\", function(integer) {\n+                            return integer;\n+                        }, updateGutters, true);\n+                        option(\"showCursorWhenSelecting\", false, updateSelection, true);\n+                        option(\"resetSelectionOnContextMenu\", true);\n+                        option(\"lineWiseCopyCut\", true);\n+                        option(\"pasteLinesPerSelection\", true);\n+                        option(\"selectionsMayTouch\", false);\n+                        option(\"readOnly\", false, function(cm, val) {\n+                            if (val == \"nocursor\") {\n+                                onBlur(cm);\n+                                cm.display.input.blur();\n+                            }\n+                            cm.display.input.readOnlyChanged(val);\n+                        });\n+                        option(\"screenReaderLabel\", null, function(cm, val) {\n+                            val = val === '' ? null : val;\n+                            cm.display.input.screenReaderLabelChanged(val);\n+                        });\n+                        option(\"disableInput\", false, function(cm, val) {\n+                            if (!val) {\n+                                cm.display.input.reset();\n+                            }\n+                        }, true);\n+                        option(\"dragDrop\", true, dragDropChanged);\n+                        option(\"allowDropFileTypes\", null);\n+                        option(\"cursorBlinkRate\", 530);\n+                        option(\"cursorScrollMargin\", 0);\n+                        option(\"cursorHeight\", 1, updateSelection, true);\n+                        option(\"singleCursorHeightPerLine\", true, updateSelection, true);\n+                        option(\"workTime\", 100);\n+                        option(\"workDelay\", 100);\n+                        option(\"flattenSpans\", true, resetModeState, true);\n+                        option(\"addModeClass\", false, resetModeState, true);\n+                        option(\"pollInterval\", 100);\n+                        option(\"undoDepth\", 200, function(cm, val) {\n+                            return cm.doc.history.undoDepth = val;\n+                        });\n+                        option(\"historyEventDelay\", 1250);\n+                        option(\"viewportMargin\", 10, function(cm) {\n+                            return cm.refresh();\n+                        }, true);\n+                        option(\"maxHighlightLength\", 10000, resetModeState, true);\n+                        option(\"moveInputWithCursor\", true, function(cm, val) {\n+                            if (!val) {\n+                                cm.display.input.resetPosition();\n+                            }\n+                        });\n+                        option(\"tabindex\", null, function(cm, val) {\n+                            return cm.display.input.getField().tabIndex = val || \"\";\n+                        });\n+                        option(\"autofocus\", null);\n+                        option(\"direction\", \"ltr\", function(cm, val) {\n+                            return cm.doc.setDirection(val);\n+                        }, true);\n+                        option(\"phrases\", null);\n+                    }\n+\n+                    function dragDropChanged(cm, value, old) {\n+                        var wasOn = old && old != Init;\n+                        if (!value != !wasOn) {\n+                            var funcs = cm.display.dragFunctions;\n+                            var toggle = value ? on : off;\n+                            toggle(cm.display.scroller, \"dragstart\", funcs.start);\n+                            toggle(cm.display.scroller, \"dragenter\", funcs.enter);\n+                            toggle(cm.display.scroller, \"dragover\", funcs.over);\n+                            toggle(cm.display.scroller, \"dragleave\", funcs.leave);\n+                            toggle(cm.display.scroller, \"drop\", funcs.drop);\n+                        }\n+                    }\n+\n+                    function wrappingChanged(cm) {\n+                        if (cm.options.lineWrapping) {\n+                            addClass(cm.display.wrapper, \"CodeMirror-wrap\");\n+                            cm.display.sizer.style.minWidth = \"\";\n+                            cm.display.sizerWidth = null;\n+                        } else {\n+                            rmClass(cm.display.wrapper, \"CodeMirror-wrap\");\n+                            findMaxLine(cm);\n+                        }\n+                        estimateLineHeights(cm);\n+                        regChange(cm);\n+                        clearCaches(cm);\n+                        setTimeout(function() {\n+                            return updateScrollbars(cm);\n+                        }, 100);\n+                    }\n \n-                function calcProjection(node) {\n-                    node.calcProjection();\n-                }\n+                    // A CodeMirror instance represents an editor. This is the object\n+                    // that user code is usually dealing with.\n \n-                function resetRotation(node) {\n-                    node.resetRotation();\n-                }\n+                    function CodeMirror(place, options) {\n+                        var this$1 = this;\n+                        if (!(this instanceof CodeMirror)) {\n+                            return new CodeMirror(place, options);\n+                        }\n+                        this.options = options = options ? copyObj(options) : {};\n+                        // Determine effective options based on given values and defaults.\n+                        copyObj(defaults, options, false);\n+                        var doc = options.value;\n+                        if (typeof doc == \"string\") {\n+                            doc = new Doc(doc, options.mode, null, options.lineSeparator, options.direction);\n+                        } else if (options.mode) {\n+                            doc.modeOption = options.mode;\n+                        }\n+                        this.doc = doc;\n+                        var input = new CodeMirror.inputStyles[options.inputStyle](this);\n+                        var display = this.display = new Display(place, doc, input, options);\n+                        display.wrapper.CodeMirror = this;\n+                        themeChanged(this);\n+                        if (options.lineWrapping) {\n+                            this.display.wrapper.className += \" CodeMirror-wrap\";\n+                        }\n+                        initScrollbars(this);\n+                        this.state = {\n+                            keyMaps: [],\n+                            // stores maps added by addKeyMap\n+                            overlays: [],\n+                            // highlighting overlays, as added by addOverlay\n+                            modeGen: 0,\n+                            // bumped when mode/overlay changes, used to invalidate highlighting info\n+                            overwrite: false,\n+                            delayingBlurEvent: false,\n+                            focused: false,\n+                            suppressEdits: false,\n+                            // used to disable editing during key handlers when in readOnly mode\n+                            pasteIncoming: -1,\n+                            cutIncoming: -1,\n+                            // help recognize paste/cut edits in input.poll\n+                            selectingText: false,\n+                            draggingText: false,\n+                            highlight: new Delayed(),\n+                            // stores highlight worker timeout\n+                            keySeq: null,\n+                            // Unfinished key sequence\n+                            specialChars: null\n+                        };\n+                        if (options.autofocus && !mobile) {\n+                            display.input.focus();\n+                        }\n+\n+                        // Override magic textarea content restore that IE sometimes does\n+                        // on our hidden textarea on reload\n+                        if (ie && ie_version < 11) {\n+                            setTimeout(function() {\n+                                return this$1.display.input.reset(true);\n+                            }, 20);\n+                        }\n+                        registerEventHandlers(this);\n+                        ensureGlobalHandlers();\n+                        startOperation(this);\n+                        this.curOp.forceUpdate = true;\n+                        attachDoc(this, doc);\n+                        if (options.autofocus && !mobile || this.hasFocus()) {\n+                            setTimeout(function() {\n+                                if (this$1.hasFocus() && !this$1.state.focused) {\n+                                    onFocus(this$1);\n+                                }\n+                            }, 20);\n+                        } else {\n+                            onBlur(this);\n+                        }\n+                        for (var opt in optionHandlers) {\n+                            if (optionHandlers.hasOwnProperty(opt)) {\n+                                optionHandlers[opt](this, options[opt], Init);\n+                            }\n+                        }\n+                        maybeUpdateLineNumberWidth(this);\n+                        if (options.finishInit) {\n+                            options.finishInit(this);\n+                        }\n+                        for (var i = 0; i < initHooks.length; ++i) {\n+                            initHooks[i](this);\n+                        }\n+                        endOperation(this);\n+                        // Suppress optimizelegibility in Webkit, since it breaks text\n+                        // measuring on line wrapping boundaries.\n+                        if (webkit && options.lineWrapping && getComputedStyle(display.lineDiv).textRendering == \"optimizelegibility\") {\n+                            display.lineDiv.style.textRendering = \"auto\";\n+                        }\n+                    }\n \n-                function removeLeadSnapshots(stack) {\n-                    stack.removeLeadSnapshot();\n-                }\n+                    // The default configuration options.\n+                    CodeMirror.defaults = defaults;\n+                    // Functions to run when options are changed.\n+                    CodeMirror.optionHandlers = optionHandlers;\n \n-                function mixAxisDelta(output, delta, p) {\n-                    output.translate = popmotion.mix(delta.translate, 0, p);\n-                    output.scale = popmotion.mix(delta.scale, 1, p);\n-                    output.origin = delta.origin;\n-                    output.originPoint = delta.originPoint;\n-                }\n+                    // Attach the necessary event handlers when initializing the editor\n+                    function registerEventHandlers(cm) {\n+                        var d = cm.display;\n+                        on(d.scroller, \"mousedown\", operation(cm, onMouseDown));\n+                        // Older IE's will not fire a second mousedown for a double click\n+                        if (ie && ie_version < 11) {\n+                            on(d.scroller, \"dblclick\", operation(cm, function(e) {\n+                                if (signalDOMEvent(cm, e)) {\n+                                    return;\n+                                }\n+                                var pos = posFromMouse(cm, e);\n+                                if (!pos || clickInGutter(cm, e) || eventInWidget(cm.display, e)) {\n+                                    return;\n+                                }\n+                                e_preventDefault(e);\n+                                var word = cm.findWordAt(pos);\n+                                extendSelection(cm.doc, word.anchor, word.head);\n+                            }));\n+                        } else {\n+                            on(d.scroller, \"dblclick\", function(e) {\n+                                return signalDOMEvent(cm, e) || e_preventDefault(e);\n+                            });\n+                        }\n+                        // Some browsers fire contextmenu *after* opening the menu, at\n+                        // which point we can't mess with it anymore. Context menu is\n+                        // handled in onMouseDown for these browsers.\n+                        on(d.scroller, \"contextmenu\", function(e) {\n+                            return onContextMenu(cm, e);\n+                        });\n+                        on(d.input.getField(), \"contextmenu\", function(e) {\n+                            if (!d.scroller.contains(e.target)) {\n+                                onContextMenu(cm, e);\n+                            }\n+                        });\n \n-                function mixAxis(output, from, to, p) {\n-                    output.min = popmotion.mix(from.min, to.min, p);\n-                    output.max = popmotion.mix(from.max, to.max, p);\n-                }\n+                        // Used to suppress mouse event handling when a touch happens\n+                        var touchFinished,\n+                            prevTouch = {\n+                                end: 0\n+                            };\n \n-                function mixBox(output, from, to, p) {\n-                    mixAxis(output.x, from.x, to.x, p);\n-                    mixAxis(output.y, from.y, to.y, p);\n-                }\n+                        function finishTouch() {\n+                            if (d.activeTouch) {\n+                                touchFinished = setTimeout(function() {\n+                                    return d.activeTouch = null;\n+                                }, 1000);\n+                                prevTouch = d.activeTouch;\n+                                prevTouch.end = +new Date();\n+                            }\n+                        }\n \n-                function hasOpacityCrossfade(node) {\n-                    return node.animationValues && node.animationValues.opacityExit !== undefined;\n-                }\n-                var defaultLayoutTransition = {\n-                    duration: 0.45,\n-                    ease: [0.4, 0, 0.1, 1]\n-                };\n+                        function isMouseLikeTouchEvent(e) {\n+                            if (e.touches.length != 1) {\n+                                return false;\n+                            }\n+                            var touch = e.touches[0];\n+                            return touch.radiusX <= 1 && touch.radiusY <= 1;\n+                        }\n \n-                function mountNodeEarly(node, id) {\n-                    /**\n-                     * Rather than searching the DOM from document we can search the\n-                     * path for the deepest mounted ancestor and search from there\n-                     */\n-                    var searchNode = node.root;\n-                    for (var i = node.path.length - 1; i >= 0; i--) {\n-                        if (Boolean(node.path[i].instance)) {\n-                            searchNode = node.path[i];\n-                            break;\n-                        }\n-                    }\n-                    var searchElement = searchNode && searchNode !== node.root ? searchNode.instance : document;\n-                    var element = searchElement.querySelector(\"[data-projection-id=\\\"\".concat(id, \"\\\"]\"));\n-                    if (element) node.mount(element, true);\n-                }\n+                        function farAway(touch, other) {\n+                            if (other.left == null) {\n+                                return true;\n+                            }\n+                            var dx = other.left - touch.left,\n+                                dy = other.top - touch.top;\n+                            return dx * dx + dy * dy > 20 * 20;\n+                        }\n+                        on(d.scroller, \"touchstart\", function(e) {\n+                            if (!signalDOMEvent(cm, e) && !isMouseLikeTouchEvent(e) && !clickInGutter(cm, e)) {\n+                                d.input.ensurePolled();\n+                                clearTimeout(touchFinished);\n+                                var now = +new Date();\n+                                d.activeTouch = {\n+                                    start: now,\n+                                    moved: false,\n+                                    prev: now - prevTouch.end <= 300 ? prevTouch : null\n+                                };\n+                                if (e.touches.length == 1) {\n+                                    d.activeTouch.left = e.touches[0].pageX;\n+                                    d.activeTouch.top = e.touches[0].pageY;\n+                                }\n+                            }\n+                        });\n+                        on(d.scroller, \"touchmove\", function() {\n+                            if (d.activeTouch) {\n+                                d.activeTouch.moved = true;\n+                            }\n+                        });\n+                        on(d.scroller, \"touchend\", function(e) {\n+                            var touch = d.activeTouch;\n+                            if (touch && !eventInWidget(d, e) && touch.left != null && !touch.moved && new Date() - touch.start < 300) {\n+                                var pos = cm.coordsChar(d.activeTouch, \"page\"),\n+                                    range;\n+                                if (!touch.prev || farAway(touch, touch.prev))\n+                                // Single tap\n+                                {\n+                                    range = new Range(pos, pos);\n+                                } else if (!touch.prev.prev || farAway(touch, touch.prev.prev))\n+                                // Double tap\n+                                {\n+                                    range = cm.findWordAt(pos);\n+                                } else\n+                                // Triple tap\n+                                {\n+                                    range = new Range(Pos(pos.line, 0), clipPos(cm.doc, Pos(pos.line + 1, 0)));\n+                                }\n+                                cm.setSelection(range.anchor, range.head);\n+                                cm.focus();\n+                                e_preventDefault(e);\n+                            }\n+                            finishTouch();\n+                        });\n+                        on(d.scroller, \"touchcancel\", finishTouch);\n \n-                function roundAxis(axis) {\n-                    axis.min = Math.round(axis.min);\n-                    axis.max = Math.round(axis.max);\n-                }\n+                        // Sync scrolling between fake scrollbars and real scrollable\n+                        // area, ensure viewport is updated when scrolling.\n+                        on(d.scroller, \"scroll\", function() {\n+                            if (d.scroller.clientHeight) {\n+                                updateScrollTop(cm, d.scroller.scrollTop);\n+                                setScrollLeft(cm, d.scroller.scrollLeft, true);\n+                                signal(cm, \"scroll\", cm);\n+                            }\n+                        });\n \n-                function roundBox(box) {\n-                    roundAxis(box.x);\n-                    roundAxis(box.y);\n-                }\n-                var DocumentProjectionNode = createProjectionNode({\n-                    attachResizeListener: function(ref, notify) {\n-                        return addDomEvent(ref, \"resize\", notify);\n-                    },\n-                    measureScroll: function() {\n-                        return {\n-                            x: document.documentElement.scrollLeft || document.body.scrollLeft,\n-                            y: document.documentElement.scrollTop || document.body.scrollTop\n+                        // Listen to wheel events in order to try and update the viewport on time.\n+                        on(d.scroller, \"mousewheel\", function(e) {\n+                            return onScrollWheel(cm, e);\n+                        });\n+                        on(d.scroller, \"DOMMouseScroll\", function(e) {\n+                            return onScrollWheel(cm, e);\n+                        });\n+\n+                        // Prevent wrapper from ever scrolling\n+                        on(d.wrapper, \"scroll\", function() {\n+                            return d.wrapper.scrollTop = d.wrapper.scrollLeft = 0;\n+                        });\n+                        d.dragFunctions = {\n+                            enter: function(e) {\n+                                if (!signalDOMEvent(cm, e)) {\n+                                    e_stop(e);\n+                                }\n+                            },\n+                            over: function(e) {\n+                                if (!signalDOMEvent(cm, e)) {\n+                                    onDragOver(cm, e);\n+                                    e_stop(e);\n+                                }\n+                            },\n+                            start: function(e) {\n+                                return onDragStart(cm, e);\n+                            },\n+                            drop: operation(cm, onDrop),\n+                            leave: function(e) {\n+                                if (!signalDOMEvent(cm, e)) {\n+                                    clearDragCursor(cm);\n+                                }\n+                            }\n                         };\n-                    },\n-                    checkIsScrollRoot: function() {\n-                        return true;\n+                        var inp = d.input.getField();\n+                        on(inp, \"keyup\", function(e) {\n+                            return onKeyUp.call(cm, e);\n+                        });\n+                        on(inp, \"keydown\", operation(cm, onKeyDown));\n+                        on(inp, \"keypress\", operation(cm, onKeyPress));\n+                        on(inp, \"focus\", function(e) {\n+                            return onFocus(cm, e);\n+                        });\n+                        on(inp, \"blur\", function(e) {\n+                            return onBlur(cm, e);\n+                        });\n+                    }\n+                    var initHooks = [];\n+                    CodeMirror.defineInitHook = function(f) {\n+                        return initHooks.push(f);\n+                    };\n+\n+                    // Indent the given line. The how parameter can be \"smart\",\n+                    // \"add\"/null, \"subtract\", or \"prev\". When aggressive is false\n+                    // (typically set to true for forced single-line indents), empty\n+                    // lines are not indented, and places where the mode returns Pass\n+                    // are left alone.\n+                    function indentLine(cm, n, how, aggressive) {\n+                        var doc = cm.doc,\n+                            state;\n+                        if (how == null) {\n+                            how = \"add\";\n+                        }\n+                        if (how == \"smart\") {\n+                            // Fall back to \"prev\" when the mode doesn't have an indentation\n+                            // method.\n+                            if (!doc.mode.indent) {\n+                                how = \"prev\";\n+                            } else {\n+                                state = getContextBefore(cm, n).state;\n+                            }\n+                        }\n+                        var tabSize = cm.options.tabSize;\n+                        var line = getLine(doc, n),\n+                            curSpace = countColumn(line.text, null, tabSize);\n+                        if (line.stateAfter) {\n+                            line.stateAfter = null;\n+                        }\n+                        var curSpaceString = line.text.match(/^\\s*/)[0],\n+                            indentation;\n+                        if (!aggressive && !/\\S/.test(line.text)) {\n+                            indentation = 0;\n+                            how = \"not\";\n+                        } else if (how == \"smart\") {\n+                            indentation = doc.mode.indent(state, line.text.slice(curSpaceString.length), line.text);\n+                            if (indentation == Pass || indentation > 150) {\n+                                if (!aggressive) {\n+                                    return;\n+                                }\n+                                how = \"prev\";\n+                            }\n+                        }\n+                        if (how == \"prev\") {\n+                            if (n > doc.first) {\n+                                indentation = countColumn(getLine(doc, n - 1).text, null, tabSize);\n+                            } else {\n+                                indentation = 0;\n+                            }\n+                        } else if (how == \"add\") {\n+                            indentation = curSpace + cm.options.indentUnit;\n+                        } else if (how == \"subtract\") {\n+                            indentation = curSpace - cm.options.indentUnit;\n+                        } else if (typeof how == \"number\") {\n+                            indentation = curSpace + how;\n+                        }\n+                        indentation = Math.max(0, indentation);\n+                        var indentString = \"\",\n+                            pos = 0;\n+                        if (cm.options.indentWithTabs) {\n+                            for (var i = Math.floor(indentation / tabSize); i; --i) {\n+                                pos += tabSize;\n+                                indentString += \"\\t\";\n+                            }\n+                        }\n+                        if (pos < indentation) {\n+                            indentString += spaceStr(indentation - pos);\n+                        }\n+                        if (indentString != curSpaceString) {\n+                            replaceRange(doc, indentString, Pos(n, 0), Pos(n, curSpaceString.length), \"+input\");\n+                            line.stateAfter = null;\n+                            return true;\n+                        } else {\n+                            // Ensure that, if the cursor was in the whitespace at the start\n+                            // of the line, it is moved to the end of that space.\n+                            for (var i$1 = 0; i$1 < doc.sel.ranges.length; i$1++) {\n+                                var range = doc.sel.ranges[i$1];\n+                                if (range.head.line == n && range.head.ch < curSpaceString.length) {\n+                                    var pos$1 = Pos(n, curSpaceString.length);\n+                                    replaceOneSelection(doc, i$1, new Range(pos$1, pos$1));\n+                                    break;\n+                                }\n+                            }\n+                        }\n                     }\n-                });\n-                var rootProjectionNode = {\n-                    current: undefined\n-                };\n-                var HTMLProjectionNode = createProjectionNode({\n-                    measureScroll: function(instance) {\n-                        return {\n-                            x: instance.scrollLeft,\n-                            y: instance.scrollTop\n-                        };\n-                    },\n-                    defaultParent: function() {\n-                        if (!rootProjectionNode.current) {\n-                            var documentNode = new DocumentProjectionNode(0, {});\n-                            documentNode.mount(window);\n-                            documentNode.setOptions({\n-                                layoutScroll: true\n-                            });\n-                            rootProjectionNode.current = documentNode;\n+\n+                    // This will be set to a {lineWise: bool, text: [string]} object, so\n+                    // that, when pasting, we know what kind of selections the copied\n+                    // text was made out of.\n+                    var lastCopied = null;\n+\n+                    function setLastCopied(newLastCopied) {\n+                        lastCopied = newLastCopied;\n+                    }\n+\n+                    function applyTextInput(cm, inserted, deleted, sel, origin) {\n+                        var doc = cm.doc;\n+                        cm.display.shift = false;\n+                        if (!sel) {\n+                            sel = doc.sel;\n+                        }\n+                        var recent = +new Date() - 200;\n+                        var paste = origin == \"paste\" || cm.state.pasteIncoming > recent;\n+                        var textLines = splitLinesAuto(inserted),\n+                            multiPaste = null;\n+                        // When pasting N lines into N selections, insert one line per selection\n+                        if (paste && sel.ranges.length > 1) {\n+                            if (lastCopied && lastCopied.text.join(\"\\n\") == inserted) {\n+                                if (sel.ranges.length % lastCopied.text.length == 0) {\n+                                    multiPaste = [];\n+                                    for (var i = 0; i < lastCopied.text.length; i++) {\n+                                        multiPaste.push(doc.splitLines(lastCopied.text[i]));\n+                                    }\n+                                }\n+                            } else if (textLines.length == sel.ranges.length && cm.options.pasteLinesPerSelection) {\n+                                multiPaste = map(textLines, function(l) {\n+                                    return [l];\n+                                });\n+                            }\n+                        }\n+                        var updateInput = cm.curOp.updateInput;\n+                        // Normal behavior is to insert the new text into every selection\n+                        for (var i$1 = sel.ranges.length - 1; i$1 >= 0; i$1--) {\n+                            var range = sel.ranges[i$1];\n+                            var from = range.from(),\n+                                to = range.to();\n+                            if (range.empty()) {\n+                                if (deleted && deleted > 0)\n+                                // Handle deletion\n+                                {\n+                                    from = Pos(from.line, from.ch - deleted);\n+                                } else if (cm.state.overwrite && !paste)\n+                                // Handle overwrite\n+                                {\n+                                    to = Pos(to.line, Math.min(getLine(doc, to.line).text.length, to.ch + lst(textLines).length));\n+                                } else if (paste && lastCopied && lastCopied.lineWise && lastCopied.text.join(\"\\n\") == textLines.join(\"\\n\")) {\n+                                    from = to = Pos(from.line, 0);\n+                                }\n+                            }\n+                            var changeEvent = {\n+                                from: from,\n+                                to: to,\n+                                text: multiPaste ? multiPaste[i$1 % multiPaste.length] : textLines,\n+                                origin: origin || (paste ? \"paste\" : cm.state.cutIncoming > recent ? \"cut\" : \"+input\")\n+                            };\n+                            makeChange(cm.doc, changeEvent);\n+                            signalLater(cm, \"inputRead\", cm, changeEvent);\n+                        }\n+                        if (inserted && !paste) {\n+                            triggerElectric(cm, inserted);\n+                        }\n+                        ensureCursorVisible(cm);\n+                        if (cm.curOp.updateInput < 2) {\n+                            cm.curOp.updateInput = updateInput;\n+                        }\n+                        cm.curOp.typing = true;\n+                        cm.state.pasteIncoming = cm.state.cutIncoming = -1;\n+                    }\n+\n+                    function handlePaste(e, cm) {\n+                        var pasted = e.clipboardData && e.clipboardData.getData(\"Text\");\n+                        if (pasted) {\n+                            e.preventDefault();\n+                            if (!cm.isReadOnly() && !cm.options.disableInput) {\n+                                runInOp(cm, function() {\n+                                    return applyTextInput(cm, pasted, 0, null, \"paste\");\n+                                });\n+                            }\n+                            return true;\n                         }\n-                        return rootProjectionNode.current;\n-                    },\n-                    resetTransform: function(instance, value) {\n-                        instance.style.transform = value !== null && value !== void 0 ? value : \"none\";\n-                    },\n-                    checkIsScrollRoot: function(instance) {\n-                        return Boolean(window.getComputedStyle(instance).position === \"fixed\");\n                     }\n-                });\n-                var featureBundle = tslib.__assign(tslib.__assign(tslib.__assign(tslib.__assign({}, animations), gestureAnimations), drag), layoutFeatures);\n-                /**\n-                 * HTML & SVG components, optimised for use with gestures and animation. These can be used as\n-                 * drop-in replacements for any HTML & SVG component, all CSS & SVG properties are supported.\n-                 *\n-                 * @public\n-                 */\n-                var motion = /*@__PURE__*/ createMotionProxy(function(Component, config) {\n-                    return createDomMotionConfig(Component, config, featureBundle, createDomVisualElement, HTMLProjectionNode);\n-                });\n-                /**\n-                 * Create a DOM `motion` component with the provided string. This is primarily intended\n-                 * as a full alternative to `motion` for consumers who have to support environments that don't\n-                 * support `Proxy`.\n-                 *\n-                 * ```javascript\n-                 * import { createDomMotionComponent } from \"framer-motion\"\n-                 *\n-                 * const motion = {\n-                 *   div: createDomMotionComponent('div')\n-                 * }\n-                 * ```\n-                 *\n-                 * @public\n-                 */\n-                function createDomMotionComponent(key) {\n-                    return createMotionComponent(createDomMotionConfig(key, {\n-                        forwardMotionProps: false\n-                    }, featureBundle, createDomVisualElement, HTMLProjectionNode));\n-                }\n \n-                /**\n-                 * @public\n-                 */\n-                var m = createMotionProxy(createDomMotionConfig);\n+                    function triggerElectric(cm, inserted) {\n+                        // When an 'electric' character is inserted, immediately trigger a reindent\n+                        if (!cm.options.electricChars || !cm.options.smartIndent) {\n+                            return;\n+                        }\n+                        var sel = cm.doc.sel;\n+                        for (var i = sel.ranges.length - 1; i >= 0; i--) {\n+                            var range = sel.ranges[i];\n+                            if (range.head.ch > 100 || i && sel.ranges[i - 1].head.line == range.head.line) {\n+                                continue;\n+                            }\n+                            var mode = cm.getModeAt(range.head);\n+                            var indented = false;\n+                            if (mode.electricChars) {\n+                                for (var j = 0; j < mode.electricChars.length; j++) {\n+                                    if (inserted.indexOf(mode.electricChars.charAt(j)) > -1) {\n+                                        indented = indentLine(cm, range.head.line, \"smart\");\n+                                        break;\n+                                    }\n+                                }\n+                            } else if (mode.electricInput) {\n+                                if (mode.electricInput.test(getLine(cm.doc, range.head.line).text.slice(0, range.head.ch))) {\n+                                    indented = indentLine(cm, range.head.line, \"smart\");\n+                                }\n+                            }\n+                            if (indented) {\n+                                signalLater(cm, \"electricInput\", cm, range.head.line);\n+                            }\n+                        }\n+                    }\n \n-                function useIsMounted() {\n-                    var isMounted = React.useRef(false);\n-                    useIsomorphicLayoutEffect(function() {\n-                        isMounted.current = true;\n-                        return function() {\n-                            isMounted.current = false;\n+                    function copyableRanges(cm) {\n+                        var text = [],\n+                            ranges = [];\n+                        for (var i = 0; i < cm.doc.sel.ranges.length; i++) {\n+                            var line = cm.doc.sel.ranges[i].head.line;\n+                            var lineRange = {\n+                                anchor: Pos(line, 0),\n+                                head: Pos(line + 1, 0)\n+                            };\n+                            ranges.push(lineRange);\n+                            text.push(cm.getRange(lineRange.anchor, lineRange.head));\n+                        }\n+                        return {\n+                            text: text,\n+                            ranges: ranges\n                         };\n-                    }, []);\n-                    return isMounted;\n-                }\n+                    }\n \n-                function useForceUpdate() {\n-                    var isMounted = useIsMounted();\n-                    var _a = tslib.__read(React.useState(0), 2),\n-                        forcedRenderCount = _a[0],\n-                        setForcedRenderCount = _a[1];\n-                    var forceRender = React.useCallback(function() {\n-                        isMounted.current && setForcedRenderCount(forcedRenderCount + 1);\n-                    }, [forcedRenderCount]);\n-                    /**\n-                     * Defer this to the end of the next animation frame in case there are multiple\n-                     * synchronous calls.\n-                     */\n-                    var deferredForceRender = React.useCallback(function() {\n-                        return sync__default[\"default\"].postRender(forceRender);\n-                    }, [forceRender]);\n-                    return [deferredForceRender, forcedRenderCount];\n-                }\n-                var PresenceChild = function(_a) {\n-                    var children = _a.children,\n-                        initial = _a.initial,\n-                        isPresent = _a.isPresent,\n-                        onExitComplete = _a.onExitComplete,\n-                        custom = _a.custom,\n-                        presenceAffectsLayout = _a.presenceAffectsLayout;\n-                    var presenceChildren = useConstant(newChildrenMap);\n-                    var id = useId();\n-                    var context = React.useMemo(function() {\n-                            return {\n-                                id: id,\n-                                initial: initial,\n-                                isPresent: isPresent,\n-                                custom: custom,\n-                                onExitComplete: function(childId) {\n-                                    var e_1, _a;\n-                                    presenceChildren.set(childId, true);\n-                                    try {\n-                                        for (var _b = tslib.__values(presenceChildren.values()), _c = _b.next(); !_c.done; _c = _b.next()) {\n-                                            var isComplete = _c.value;\n-                                            if (!isComplete) return; // can stop searching when any is incomplete\n+                    function disableBrowserMagic(field, spellcheck, autocorrect, autocapitalize) {\n+                        field.setAttribute(\"autocorrect\", autocorrect ? \"\" : \"off\");\n+                        field.setAttribute(\"autocapitalize\", autocapitalize ? \"\" : \"off\");\n+                        field.setAttribute(\"spellcheck\", !!spellcheck);\n+                    }\n+\n+                    function hiddenTextarea() {\n+                        var te = elt(\"textarea\", null, null, \"position: absolute; bottom: -1em; padding: 0; width: 1px; height: 1em; min-height: 1em; outline: none\");\n+                        var div = elt(\"div\", [te], null, \"overflow: hidden; position: relative; width: 3px; height: 0px;\");\n+                        // The textarea is kept positioned near the cursor to prevent the\n+                        // fact that it'll be scrolled into view on input from scrolling\n+                        // our fake cursor out of view. On webkit, when wrap=off, paste is\n+                        // very slow. So make the area wide instead.\n+                        if (webkit) {\n+                            te.style.width = \"1000px\";\n+                        } else {\n+                            te.setAttribute(\"wrap\", \"off\");\n+                        }\n+                        // If border: 0; -- iOS fails to open keyboard (issue #1287)\n+                        if (ios) {\n+                            te.style.border = \"1px solid black\";\n+                        }\n+                        disableBrowserMagic(te);\n+                        return div;\n+                    }\n+\n+                    // The publicly visible API. Note that methodOp(f) means\n+                    // 'wrap f in an operation, performed on its `this` parameter'.\n+\n+                    // This is not the complete set of editor methods. Most of the\n+                    // methods defined on the Doc type are also injected into\n+                    // CodeMirror.prototype, for backwards compatibility and\n+                    // convenience.\n+\n+                    function addEditorMethods(CodeMirror) {\n+                        var optionHandlers = CodeMirror.optionHandlers;\n+                        var helpers = CodeMirror.helpers = {};\n+                        CodeMirror.prototype = {\n+                            constructor: CodeMirror,\n+                            focus: function() {\n+                                window.focus();\n+                                this.display.input.focus();\n+                            },\n+                            setOption: function(option, value) {\n+                                var options = this.options,\n+                                    old = options[option];\n+                                if (options[option] == value && option != \"mode\") {\n+                                    return;\n+                                }\n+                                options[option] = value;\n+                                if (optionHandlers.hasOwnProperty(option)) {\n+                                    operation(this, optionHandlers[option])(this, value, old);\n+                                }\n+                                signal(this, \"optionChange\", this, option);\n+                            },\n+                            getOption: function(option) {\n+                                return this.options[option];\n+                            },\n+                            getDoc: function() {\n+                                return this.doc;\n+                            },\n+                            addKeyMap: function(map, bottom) {\n+                                this.state.keyMaps[bottom ? \"push\" : \"unshift\"](getKeyMap(map));\n+                            },\n+                            removeKeyMap: function(map) {\n+                                var maps = this.state.keyMaps;\n+                                for (var i = 0; i < maps.length; ++i) {\n+                                    if (maps[i] == map || maps[i].name == map) {\n+                                        maps.splice(i, 1);\n+                                        return true;\n+                                    }\n+                                }\n+                            },\n+                            addOverlay: methodOp(function(spec, options) {\n+                                var mode = spec.token ? spec : CodeMirror.getMode(this.options, spec);\n+                                if (mode.startState) {\n+                                    throw new Error(\"Overlays may not be stateful.\");\n+                                }\n+                                insertSorted(this.state.overlays, {\n+                                    mode: mode,\n+                                    modeSpec: spec,\n+                                    opaque: options && options.opaque,\n+                                    priority: options && options.priority || 0\n+                                }, function(overlay) {\n+                                    return overlay.priority;\n+                                });\n+                                this.state.modeGen++;\n+                                regChange(this);\n+                            }),\n+                            removeOverlay: methodOp(function(spec) {\n+                                var overlays = this.state.overlays;\n+                                for (var i = 0; i < overlays.length; ++i) {\n+                                    var cur = overlays[i].modeSpec;\n+                                    if (cur == spec || typeof spec == \"string\" && cur.name == spec) {\n+                                        overlays.splice(i, 1);\n+                                        this.state.modeGen++;\n+                                        regChange(this);\n+                                        return;\n+                                    }\n+                                }\n+                            }),\n+                            indentLine: methodOp(function(n, dir, aggressive) {\n+                                if (typeof dir != \"string\" && typeof dir != \"number\") {\n+                                    if (dir == null) {\n+                                        dir = this.options.smartIndent ? \"smart\" : \"prev\";\n+                                    } else {\n+                                        dir = dir ? \"add\" : \"subtract\";\n+                                    }\n+                                }\n+                                if (isLine(this.doc, n)) {\n+                                    indentLine(this, n, dir, aggressive);\n+                                }\n+                            }),\n+                            indentSelection: methodOp(function(how) {\n+                                var ranges = this.doc.sel.ranges,\n+                                    end = -1;\n+                                for (var i = 0; i < ranges.length; i++) {\n+                                    var range = ranges[i];\n+                                    if (!range.empty()) {\n+                                        var from = range.from(),\n+                                            to = range.to();\n+                                        var start = Math.max(end, from.line);\n+                                        end = Math.min(this.lastLine(), to.line - (to.ch ? 0 : 1)) + 1;\n+                                        for (var j = start; j < end; ++j) {\n+                                            indentLine(this, j, how);\n                                         }\n-                                    } catch (e_1_1) {\n-                                        e_1 = {\n-                                            error: e_1_1\n-                                        };\n-                                    } finally {\n-                                        try {\n-                                            if (_c && !_c.done && (_a = _b.return)) _a.call(_b);\n-                                        } finally {\n-                                            if (e_1) throw e_1.error;\n+                                        var newRanges = this.doc.sel.ranges;\n+                                        if (from.ch == 0 && ranges.length == newRanges.length && newRanges[i].from().ch > 0) {\n+                                            replaceOneSelection(this.doc, i, new Range(from, newRanges[i].to()), sel_dontScroll);\n+                                        }\n+                                    } else if (range.head.line > end) {\n+                                        indentLine(this, range.head.line, how, true);\n+                                        end = range.head.line;\n+                                        if (i == this.doc.sel.primIndex) {\n+                                            ensureCursorVisible(this);\n                                         }\n                                     }\n-                                    onExitComplete === null || onExitComplete === void 0 ? void 0 : onExitComplete();\n-                                },\n-                                register: function(childId) {\n-                                    presenceChildren.set(childId, false);\n-                                    return function() {\n-                                        return presenceChildren.delete(childId);\n+                                }\n+                            }),\n+                            // Fetch the parser token for a given character. Useful for hacks\n+                            // that want to inspect the mode state (say, for completion).\n+                            getTokenAt: function(pos, precise) {\n+                                return takeToken(this, pos, precise);\n+                            },\n+                            getLineTokens: function(line, precise) {\n+                                return takeToken(this, Pos(line), precise, true);\n+                            },\n+                            getTokenTypeAt: function(pos) {\n+                                pos = clipPos(this.doc, pos);\n+                                var styles = getLineStyles(this, getLine(this.doc, pos.line));\n+                                var before = 0,\n+                                    after = (styles.length - 1) / 2,\n+                                    ch = pos.ch;\n+                                var type;\n+                                if (ch == 0) {\n+                                    type = styles[2];\n+                                } else {\n+                                    for (;;) {\n+                                        var mid = before + after >> 1;\n+                                        if ((mid ? styles[mid * 2 - 1] : 0) >= ch) {\n+                                            after = mid;\n+                                        } else if (styles[mid * 2 + 1] < ch) {\n+                                            before = mid + 1;\n+                                        } else {\n+                                            type = styles[mid * 2 + 2];\n+                                            break;\n+                                        }\n+                                    }\n+                                }\n+                                var cut = type ? type.indexOf(\"overlay \") : -1;\n+                                return cut < 0 ? type : cut == 0 ? null : type.slice(0, cut - 1);\n+                            },\n+                            getModeAt: function(pos) {\n+                                var mode = this.doc.mode;\n+                                if (!mode.innerMode) {\n+                                    return mode;\n+                                }\n+                                return CodeMirror.innerMode(mode, this.getTokenAt(pos).state).mode;\n+                            },\n+                            getHelper: function(pos, type) {\n+                                return this.getHelpers(pos, type)[0];\n+                            },\n+                            getHelpers: function(pos, type) {\n+                                var found = [];\n+                                if (!helpers.hasOwnProperty(type)) {\n+                                    return found;\n+                                }\n+                                var help = helpers[type],\n+                                    mode = this.getModeAt(pos);\n+                                if (typeof mode[type] == \"string\") {\n+                                    if (help[mode[type]]) {\n+                                        found.push(help[mode[type]]);\n+                                    }\n+                                } else if (mode[type]) {\n+                                    for (var i = 0; i < mode[type].length; i++) {\n+                                        var val = help[mode[type][i]];\n+                                        if (val) {\n+                                            found.push(val);\n+                                        }\n+                                    }\n+                                } else if (mode.helperType && help[mode.helperType]) {\n+                                    found.push(help[mode.helperType]);\n+                                } else if (help[mode.name]) {\n+                                    found.push(help[mode.name]);\n+                                }\n+                                for (var i$1 = 0; i$1 < help._global.length; i$1++) {\n+                                    var cur = help._global[i$1];\n+                                    if (cur.pred(mode, this) && indexOf(found, cur.val) == -1) {\n+                                        found.push(cur.val);\n+                                    }\n+                                }\n+                                return found;\n+                            },\n+                            getStateAfter: function(line, precise) {\n+                                var doc = this.doc;\n+                                line = clipLine(doc, line == null ? doc.first + doc.size - 1 : line);\n+                                return getContextBefore(this, line + 1, precise).state;\n+                            },\n+                            cursorCoords: function(start, mode) {\n+                                var pos,\n+                                    range = this.doc.sel.primary();\n+                                if (start == null) {\n+                                    pos = range.head;\n+                                } else if (typeof start == \"object\") {\n+                                    pos = clipPos(this.doc, start);\n+                                } else {\n+                                    pos = start ? range.from() : range.to();\n+                                }\n+                                return cursorCoords(this, pos, mode || \"page\");\n+                            },\n+                            charCoords: function(pos, mode) {\n+                                return charCoords(this, clipPos(this.doc, pos), mode || \"page\");\n+                            },\n+                            coordsChar: function(coords, mode) {\n+                                coords = fromCoordSystem(this, coords, mode || \"page\");\n+                                return coordsChar(this, coords.left, coords.top);\n+                            },\n+                            lineAtHeight: function(height, mode) {\n+                                height = fromCoordSystem(this, {\n+                                    top: height,\n+                                    left: 0\n+                                }, mode || \"page\").top;\n+                                return lineAtHeight(this.doc, height + this.display.viewOffset);\n+                            },\n+                            heightAtLine: function(line, mode, includeWidgets) {\n+                                var end = false,\n+                                    lineObj;\n+                                if (typeof line == \"number\") {\n+                                    var last = this.doc.first + this.doc.size - 1;\n+                                    if (line < this.doc.first) {\n+                                        line = this.doc.first;\n+                                    } else if (line > last) {\n+                                        line = last;\n+                                        end = true;\n+                                    }\n+                                    lineObj = getLine(this.doc, line);\n+                                } else {\n+                                    lineObj = line;\n+                                }\n+                                return intoCoordSystem(this, lineObj, {\n+                                    top: 0,\n+                                    left: 0\n+                                }, mode || \"page\", includeWidgets || end).top + (end ? this.doc.height - heightAtLine(lineObj) : 0);\n+                            },\n+                            defaultTextHeight: function() {\n+                                return textHeight(this.display);\n+                            },\n+                            defaultCharWidth: function() {\n+                                return charWidth(this.display);\n+                            },\n+                            getViewport: function() {\n+                                return {\n+                                    from: this.display.viewFrom,\n+                                    to: this.display.viewTo\n+                                };\n+                            },\n+                            addWidget: function(pos, node, scroll, vert, horiz) {\n+                                var display = this.display;\n+                                pos = cursorCoords(this, clipPos(this.doc, pos));\n+                                var top = pos.bottom,\n+                                    left = pos.left;\n+                                node.style.position = \"absolute\";\n+                                node.setAttribute(\"cm-ignore-events\", \"true\");\n+                                this.display.input.setUneditable(node);\n+                                display.sizer.appendChild(node);\n+                                if (vert == \"over\") {\n+                                    top = pos.top;\n+                                } else if (vert == \"above\" || vert == \"near\") {\n+                                    var vspace = Math.max(display.wrapper.clientHeight, this.doc.height),\n+                                        hspace = Math.max(display.sizer.clientWidth, display.lineSpace.clientWidth);\n+                                    // Default to positioning above (if specified and possible); otherwise default to positioning below\n+                                    if ((vert == 'above' || pos.bottom + node.offsetHeight > vspace) && pos.top > node.offsetHeight) {\n+                                        top = pos.top - node.offsetHeight;\n+                                    } else if (pos.bottom + node.offsetHeight <= vspace) {\n+                                        top = pos.bottom;\n+                                    }\n+                                    if (left + node.offsetWidth > hspace) {\n+                                        left = hspace - node.offsetWidth;\n+                                    }\n+                                }\n+                                node.style.top = top + \"px\";\n+                                node.style.left = node.style.right = \"\";\n+                                if (horiz == \"right\") {\n+                                    left = display.sizer.clientWidth - node.offsetWidth;\n+                                    node.style.right = \"0px\";\n+                                } else {\n+                                    if (horiz == \"left\") {\n+                                        left = 0;\n+                                    } else if (horiz == \"middle\") {\n+                                        left = (display.sizer.clientWidth - node.offsetWidth) / 2;\n+                                    }\n+                                    node.style.left = left + \"px\";\n+                                }\n+                                if (scroll) {\n+                                    scrollIntoView(this, {\n+                                        left: left,\n+                                        top: top,\n+                                        right: left + node.offsetWidth,\n+                                        bottom: top + node.offsetHeight\n+                                    });\n+                                }\n+                            },\n+                            triggerOnKeyDown: methodOp(onKeyDown),\n+                            triggerOnKeyPress: methodOp(onKeyPress),\n+                            triggerOnKeyUp: onKeyUp,\n+                            triggerOnMouseDown: methodOp(onMouseDown),\n+                            execCommand: function(cmd) {\n+                                if (commands.hasOwnProperty(cmd)) {\n+                                    return commands[cmd].call(null, this);\n+                                }\n+                            },\n+                            triggerElectric: methodOp(function(text) {\n+                                triggerElectric(this, text);\n+                            }),\n+                            findPosH: function(from, amount, unit, visually) {\n+                                var dir = 1;\n+                                if (amount < 0) {\n+                                    dir = -1;\n+                                    amount = -amount;\n+                                }\n+                                var cur = clipPos(this.doc, from);\n+                                for (var i = 0; i < amount; ++i) {\n+                                    cur = findPosH(this.doc, cur, dir, unit, visually);\n+                                    if (cur.hitSide) {\n+                                        break;\n+                                    }\n+                                }\n+                                return cur;\n+                            },\n+                            moveH: methodOp(function(dir, unit) {\n+                                var this$1 = this;\n+                                this.extendSelectionsBy(function(range) {\n+                                    if (this$1.display.shift || this$1.doc.extend || range.empty()) {\n+                                        return findPosH(this$1.doc, range.head, dir, unit, this$1.options.rtlMoveVisually);\n+                                    } else {\n+                                        return dir < 0 ? range.from() : range.to();\n+                                    }\n+                                }, sel_move);\n+                            }),\n+                            deleteH: methodOp(function(dir, unit) {\n+                                var sel = this.doc.sel,\n+                                    doc = this.doc;\n+                                if (sel.somethingSelected()) {\n+                                    doc.replaceSelection(\"\", null, \"+delete\");\n+                                } else {\n+                                    deleteNearSelection(this, function(range) {\n+                                        var other = findPosH(doc, range.head, dir, unit, false);\n+                                        return dir < 0 ? {\n+                                            from: other,\n+                                            to: range.head\n+                                        } : {\n+                                            from: range.head,\n+                                            to: other\n+                                        };\n+                                    });\n+                                }\n+                            }),\n+                            findPosV: function(from, amount, unit, goalColumn) {\n+                                var dir = 1,\n+                                    x = goalColumn;\n+                                if (amount < 0) {\n+                                    dir = -1;\n+                                    amount = -amount;\n+                                }\n+                                var cur = clipPos(this.doc, from);\n+                                for (var i = 0; i < amount; ++i) {\n+                                    var coords = cursorCoords(this, cur, \"div\");\n+                                    if (x == null) {\n+                                        x = coords.left;\n+                                    } else {\n+                                        coords.left = x;\n+                                    }\n+                                    cur = findPosV(this, coords, dir, unit);\n+                                    if (cur.hitSide) {\n+                                        break;\n+                                    }\n+                                }\n+                                return cur;\n+                            },\n+                            moveV: methodOp(function(dir, unit) {\n+                                var this$1 = this;\n+                                var doc = this.doc,\n+                                    goals = [];\n+                                var collapse = !this.display.shift && !doc.extend && doc.sel.somethingSelected();\n+                                doc.extendSelectionsBy(function(range) {\n+                                    if (collapse) {\n+                                        return dir < 0 ? range.from() : range.to();\n+                                    }\n+                                    var headPos = cursorCoords(this$1, range.head, \"div\");\n+                                    if (range.goalColumn != null) {\n+                                        headPos.left = range.goalColumn;\n+                                    }\n+                                    goals.push(headPos.left);\n+                                    var pos = findPosV(this$1, headPos, dir, unit);\n+                                    if (unit == \"page\" && range == doc.sel.primary()) {\n+                                        addToScrollTop(this$1, charCoords(this$1, pos, \"div\").top - headPos.top);\n+                                    }\n+                                    return pos;\n+                                }, sel_move);\n+                                if (goals.length) {\n+                                    for (var i = 0; i < doc.sel.ranges.length; i++) {\n+                                        doc.sel.ranges[i].goalColumn = goals[i];\n+                                    }\n+                                }\n+                            }),\n+                            // Find the word at the given position (as returned by coordsChar).\n+                            findWordAt: function(pos) {\n+                                var doc = this.doc,\n+                                    line = getLine(doc, pos.line).text;\n+                                var start = pos.ch,\n+                                    end = pos.ch;\n+                                if (line) {\n+                                    var helper = this.getHelper(pos, \"wordChars\");\n+                                    if ((pos.sticky == \"before\" || end == line.length) && start) {\n+                                        --start;\n+                                    } else {\n+                                        ++end;\n+                                    }\n+                                    var startChar = line.charAt(start);\n+                                    var check = isWordChar(startChar, helper) ? function(ch) {\n+                                        return isWordChar(ch, helper);\n+                                    } : /\\s/.test(startChar) ? function(ch) {\n+                                        return /\\s/.test(ch);\n+                                    } : function(ch) {\n+                                        return !/\\s/.test(ch) && !isWordChar(ch);\n                                     };\n+                                    while (start > 0 && check(line.charAt(start - 1))) {\n+                                        --start;\n+                                    }\n+                                    while (end < line.length && check(line.charAt(end))) {\n+                                        ++end;\n+                                    }\n                                 }\n-                            };\n-                        },\n-                        /**\n-                         * If the presence of a child affects the layout of the components around it,\n-                         * we want to make a new context value to ensure they get re-rendered\n-                         * so they can detect that layout change.\n-                         */\n-                        presenceAffectsLayout ? undefined : [isPresent]);\n-                    React.useMemo(function() {\n-                        presenceChildren.forEach(function(_, key) {\n-                            return presenceChildren.set(key, false);\n-                        });\n-                    }, [isPresent]);\n-                    /**\n-                     * If there's no `motion` components to fire exit animations, we want to remove this\n-                     * component immediately.\n-                     */\n-                    React__namespace.useEffect(function() {\n-                        !isPresent && !presenceChildren.size && (onExitComplete === null || onExitComplete === void 0 ? void 0 : onExitComplete());\n-                    }, [isPresent]);\n-                    return React__namespace.createElement(PresenceContext.Provider, {\n-                        value: context\n-                    }, children);\n-                };\n-\n-                function newChildrenMap() {\n-                    return new Map();\n-                }\n-                var getChildKey = function(child) {\n-                    return child.key || \"\";\n-                };\n+                                return new Range(Pos(pos.line, start), Pos(pos.line, end));\n+                            },\n+                            toggleOverwrite: function(value) {\n+                                if (value != null && value == this.state.overwrite) {\n+                                    return;\n+                                }\n+                                if (this.state.overwrite = !this.state.overwrite) {\n+                                    addClass(this.display.cursorDiv, \"CodeMirror-overwrite\");\n+                                } else {\n+                                    rmClass(this.display.cursorDiv, \"CodeMirror-overwrite\");\n+                                }\n+                                signal(this, \"overwriteToggle\", this, this.state.overwrite);\n+                            },\n+                            hasFocus: function() {\n+                                return this.display.input.getField() == activeElt();\n+                            },\n+                            isReadOnly: function() {\n+                                return !!(this.options.readOnly || this.doc.cantEdit);\n+                            },\n+                            scrollTo: methodOp(function(x, y) {\n+                                scrollToCoords(this, x, y);\n+                            }),\n+                            getScrollInfo: function() {\n+                                var scroller = this.display.scroller;\n+                                return {\n+                                    left: scroller.scrollLeft,\n+                                    top: scroller.scrollTop,\n+                                    height: scroller.scrollHeight - scrollGap(this) - this.display.barHeight,\n+                                    width: scroller.scrollWidth - scrollGap(this) - this.display.barWidth,\n+                                    clientHeight: displayHeight(this),\n+                                    clientWidth: displayWidth(this)\n+                                };\n+                            },\n+                            scrollIntoView: methodOp(function(range, margin) {\n+                                if (range == null) {\n+                                    range = {\n+                                        from: this.doc.sel.primary().head,\n+                                        to: null\n+                                    };\n+                                    if (margin == null) {\n+                                        margin = this.options.cursorScrollMargin;\n+                                    }\n+                                } else if (typeof range == \"number\") {\n+                                    range = {\n+                                        from: Pos(range, 0),\n+                                        to: null\n+                                    };\n+                                } else if (range.from == null) {\n+                                    range = {\n+                                        from: range,\n+                                        to: null\n+                                    };\n+                                }\n+                                if (!range.to) {\n+                                    range.to = range.from;\n+                                }\n+                                range.margin = margin || 0;\n+                                if (range.from.line != null) {\n+                                    scrollToRange(this, range);\n+                                } else {\n+                                    scrollToCoordsRange(this, range.from, range.to, range.margin);\n+                                }\n+                            }),\n+                            setSize: methodOp(function(width, height) {\n+                                var this$1 = this;\n+                                var interpret = function(val) {\n+                                    return typeof val == \"number\" || /^\\d+$/.test(String(val)) ? val + \"px\" : val;\n+                                };\n+                                if (width != null) {\n+                                    this.display.wrapper.style.width = interpret(width);\n+                                }\n+                                if (height != null) {\n+                                    this.display.wrapper.style.height = interpret(height);\n+                                }\n+                                if (this.options.lineWrapping) {\n+                                    clearLineMeasurementCache(this);\n+                                }\n+                                var lineNo = this.display.viewFrom;\n+                                this.doc.iter(lineNo, this.display.viewTo, function(line) {\n+                                    if (line.widgets) {\n+                                        for (var i = 0; i < line.widgets.length; i++) {\n+                                            if (line.widgets[i].noHScroll) {\n+                                                regLineChange(this$1, lineNo, \"widget\");\n+                                                break;\n+                                            }\n+                                        }\n+                                    }\n+                                    ++lineNo;\n+                                });\n+                                this.curOp.forceUpdate = true;\n+                                signal(this, \"refresh\", this);\n+                            }),\n+                            operation: function(f) {\n+                                return runInOp(this, f);\n+                            },\n+                            startOperation: function() {\n+                                return startOperation(this);\n+                            },\n+                            endOperation: function() {\n+                                return endOperation(this);\n+                            },\n+                            refresh: methodOp(function() {\n+                                var oldHeight = this.display.cachedTextHeight;\n+                                regChange(this);\n+                                this.curOp.forceUpdate = true;\n+                                clearCaches(this);\n+                                scrollToCoords(this, this.doc.scrollLeft, this.doc.scrollTop);\n+                                updateGutterSpace(this.display);\n+                                if (oldHeight == null || Math.abs(oldHeight - textHeight(this.display)) > .5 || this.options.lineWrapping) {\n+                                    estimateLineHeights(this);\n+                                }\n+                                signal(this, \"refresh\", this);\n+                            }),\n+                            swapDoc: methodOp(function(doc) {\n+                                var old = this.doc;\n+                                old.cm = null;\n+                                // Cancel the current text selection if any (#5821)\n+                                if (this.state.selectingText) {\n+                                    this.state.selectingText();\n+                                }\n+                                attachDoc(this, doc);\n+                                clearCaches(this);\n+                                this.display.input.reset();\n+                                scrollToCoords(this, doc.scrollLeft, doc.scrollTop);\n+                                this.curOp.forceScroll = true;\n+                                signalLater(this, \"swapDoc\", this, old);\n+                                return old;\n+                            }),\n+                            phrase: function(phraseText) {\n+                                var phrases = this.options.phrases;\n+                                return phrases && Object.prototype.hasOwnProperty.call(phrases, phraseText) ? phrases[phraseText] : phraseText;\n+                            },\n+                            getInputField: function() {\n+                                return this.display.input.getField();\n+                            },\n+                            getWrapperElement: function() {\n+                                return this.display.wrapper;\n+                            },\n+                            getScrollerElement: function() {\n+                                return this.display.scroller;\n+                            },\n+                            getGutterElement: function() {\n+                                return this.display.gutters;\n+                            }\n+                        };\n+                        eventMixin(CodeMirror);\n+                        CodeMirror.registerHelper = function(type, name, value) {\n+                            if (!helpers.hasOwnProperty(type)) {\n+                                helpers[type] = CodeMirror[type] = {\n+                                    _global: []\n+                                };\n+                            }\n+                            helpers[type][name] = value;\n+                        };\n+                        CodeMirror.registerGlobalHelper = function(type, name, predicate, value) {\n+                            CodeMirror.registerHelper(type, name, value);\n+                            helpers[type]._global.push({\n+                                pred: predicate,\n+                                val: value\n+                            });\n+                        };\n+                    }\n \n-                function updateChildLookup(children, allChildren) {\n-                    children.forEach(function(child) {\n-                        var key = getChildKey(child);\n-                        allChildren.set(key, child);\n-                    });\n-                }\n+                    // Used for horizontal relative motion. Dir is -1 or 1 (left or\n+                    // right), unit can be \"codepoint\", \"char\", \"column\" (like char, but\n+                    // doesn't cross line boundaries), \"word\" (across next word), or\n+                    // \"group\" (to the start of next group of word or\n+                    // non-word-non-whitespace chars). The visually param controls\n+                    // whether, in right-to-left text, direction 1 means to move towards\n+                    // the next index in the string, or towards the character to the right\n+                    // of the current position. The resulting position will have a\n+                    // hitSide=true property if it reached the end of the document.\n+                    function findPosH(doc, pos, dir, unit, visually) {\n+                        var oldPos = pos;\n+                        var origDir = dir;\n+                        var lineObj = getLine(doc, pos.line);\n+                        var lineDir = visually && doc.direction == \"rtl\" ? -dir : dir;\n+\n+                        function findNextLine() {\n+                            var l = pos.line + lineDir;\n+                            if (l < doc.first || l >= doc.first + doc.size) {\n+                                return false;\n+                            }\n+                            pos = new Pos(l, pos.ch, pos.sticky);\n+                            return lineObj = getLine(doc, l);\n+                        }\n \n-                function onlyElements(children) {\n-                    var filtered = [];\n-                    // We use forEach here instead of map as map mutates the component key by preprending `.$`\n-                    React.Children.forEach(children, function(child) {\n-                        if (React.isValidElement(child)) filtered.push(child);\n-                    });\n-                    return filtered;\n-                }\n-                /**\n-                 * `AnimatePresence` enables the animation of components that have been removed from the tree.\n-                 *\n-                 * When adding/removing more than a single child, every child **must** be given a unique `key` prop.\n-                 *\n-                 * Any `motion` components that have an `exit` property defined will animate out when removed from\n-                 * the tree.\n-                 *\n-                 * ```jsx\n-                 * import { motion, AnimatePresence } from 'framer-motion'\n-                 *\n-                 * export const Items = ({ items }) => (\n-                 *   <AnimatePresence>\n-                 *     {items.map(item => (\n-                 *       <motion.div\n-                 *         key={item.id}\n-                 *         initial={{ opacity: 0 }}\n-                 *         animate={{ opacity: 1 }}\n-                 *         exit={{ opacity: 0 }}\n-                 *       />\n-                 *     ))}\n-                 *   </AnimatePresence>\n-                 * )\n-                 * ```\n-                 *\n-                 * You can sequence exit animations throughout a tree using variants.\n-                 *\n-                 * If a child contains multiple `motion` components with `exit` props, it will only unmount the child\n-                 * once all `motion` components have finished animating out. Likewise, any components using\n-                 * `usePresence` all need to call `safeToRemove`.\n-                 *\n-                 * @public\n-                 */\n-                var AnimatePresence = function(_a) {\n-                    var children = _a.children,\n-                        custom = _a.custom,\n-                        _b = _a.initial,\n-                        initial = _b === void 0 ? true : _b,\n-                        onExitComplete = _a.onExitComplete,\n-                        exitBeforeEnter = _a.exitBeforeEnter,\n-                        _c = _a.presenceAffectsLayout,\n-                        presenceAffectsLayout = _c === void 0 ? true : _c;\n-                    // We want to force a re-render once all exiting animations have finished. We\n-                    // either use a local forceRender function, or one from a parent context if it exists.\n-                    var _d = tslib.__read(useForceUpdate(), 1),\n-                        forceRender = _d[0];\n-                    var forceRenderLayoutGroup = React.useContext(LayoutGroupContext).forceRender;\n-                    if (forceRenderLayoutGroup) forceRender = forceRenderLayoutGroup;\n-                    var isMounted = useIsMounted();\n-                    // Filter out any children that aren't ReactElements. We can only track ReactElements with a props.key\n-                    var filteredChildren = onlyElements(children);\n-                    var childrenToRender = filteredChildren;\n-                    var exiting = new Set();\n-                    // Keep a living record of the children we're actually rendering so we\n-                    // can diff to figure out which are entering and exiting\n-                    var presentChildren = React.useRef(childrenToRender);\n-                    // A lookup table to quickly reference components by key\n-                    var allChildren = React.useRef(new Map()).current;\n-                    // If this is the initial component render, just deal with logic surrounding whether\n-                    // we play onMount animations or not.\n-                    var isInitialRender = React.useRef(true);\n-                    useIsomorphicLayoutEffect(function() {\n-                        isInitialRender.current = false;\n-                        updateChildLookup(filteredChildren, allChildren);\n-                        presentChildren.current = childrenToRender;\n-                    });\n-                    useUnmountEffect(function() {\n-                        isInitialRender.current = true;\n-                        allChildren.clear();\n-                        exiting.clear();\n-                    });\n-                    if (isInitialRender.current) {\n-                        return React__namespace.createElement(React__namespace.Fragment, null, childrenToRender.map(function(child) {\n-                            return React__namespace.createElement(PresenceChild, {\n-                                key: getChildKey(child),\n-                                isPresent: true,\n-                                initial: initial ? undefined : false,\n-                                presenceAffectsLayout: presenceAffectsLayout\n-                            }, child);\n-                        }));\n-                    }\n-                    // If this is a subsequent render, deal with entering and exiting children\n-                    childrenToRender = tslib.__spreadArray([], tslib.__read(childrenToRender), false);\n-                    // Diff the keys of the currently-present and target children to update our\n-                    // exiting list.\n-                    var presentKeys = presentChildren.current.map(getChildKey);\n-                    var targetKeys = filteredChildren.map(getChildKey);\n-                    // Diff the present children with our target children and mark those that are exiting\n-                    var numPresent = presentKeys.length;\n-                    for (var i = 0; i < numPresent; i++) {\n-                        var key = presentKeys[i];\n-                        if (targetKeys.indexOf(key) === -1) {\n-                            exiting.add(key);\n+                        function moveOnce(boundToLine) {\n+                            var next;\n+                            if (unit == \"codepoint\") {\n+                                var ch = lineObj.text.charCodeAt(pos.ch + (dir > 0 ? 0 : -1));\n+                                if (isNaN(ch)) {\n+                                    next = null;\n+                                } else {\n+                                    var astral = dir > 0 ? ch >= 0xD800 && ch < 0xDC00 : ch >= 0xDC00 && ch < 0xDFFF;\n+                                    next = new Pos(pos.line, Math.max(0, Math.min(lineObj.text.length, pos.ch + dir * (astral ? 2 : 1))), -dir);\n+                                }\n+                            } else if (visually) {\n+                                next = moveVisually(doc.cm, lineObj, pos, dir);\n+                            } else {\n+                                next = moveLogically(lineObj, pos, dir);\n+                            }\n+                            if (next == null) {\n+                                if (!boundToLine && findNextLine()) {\n+                                    pos = endOfLine(visually, doc.cm, lineObj, pos.line, lineDir);\n+                                } else {\n+                                    return false;\n+                                }\n+                            } else {\n+                                pos = next;\n+                            }\n+                            return true;\n                         }\n+                        if (unit == \"char\" || unit == \"codepoint\") {\n+                            moveOnce();\n+                        } else if (unit == \"column\") {\n+                            moveOnce(true);\n+                        } else if (unit == \"word\" || unit == \"group\") {\n+                            var sawType = null,\n+                                group = unit == \"group\";\n+                            var helper = doc.cm && doc.cm.getHelper(pos, \"wordChars\");\n+                            for (var first = true;; first = false) {\n+                                if (dir < 0 && !moveOnce(!first)) {\n+                                    break;\n+                                }\n+                                var cur = lineObj.text.charAt(pos.ch) || \"\\n\";\n+                                var type = isWordChar(cur, helper) ? \"w\" : group && cur == \"\\n\" ? \"n\" : !group || /\\s/.test(cur) ? null : \"p\";\n+                                if (group && !first && !type) {\n+                                    type = \"s\";\n+                                }\n+                                if (sawType && sawType != type) {\n+                                    if (dir < 0) {\n+                                        dir = 1;\n+                                        moveOnce();\n+                                        pos.sticky = \"after\";\n+                                    }\n+                                    break;\n+                                }\n+                                if (type) {\n+                                    sawType = type;\n+                                }\n+                                if (dir > 0 && !moveOnce(!first)) {\n+                                    break;\n+                                }\n+                            }\n+                        }\n+                        var result = skipAtomic(doc, pos, oldPos, origDir, true);\n+                        if (equalCursorPos(oldPos, result)) {\n+                            result.hitSide = true;\n+                        }\n+                        return result;\n                     }\n-                    // If we currently have exiting children, and we're deferring rendering incoming children\n-                    // until after all current children have exiting, empty the childrenToRender array\n-                    if (exitBeforeEnter && exiting.size) {\n-                        childrenToRender = [];\n-                    }\n-                    // Loop through all currently exiting components and clone them to overwrite `animate`\n-                    // with any `exit` prop they might have defined.\n-                    exiting.forEach(function(key) {\n-                        // If this component is actually entering again, early return\n-                        if (targetKeys.indexOf(key) !== -1) return;\n-                        var child = allChildren.get(key);\n-                        if (!child) return;\n-                        var insertionIndex = presentKeys.indexOf(key);\n-                        var onExit = function() {\n-                            allChildren.delete(key);\n-                            exiting.delete(key);\n-                            // Remove this child from the present children\n-                            var removeIndex = presentChildren.current.findIndex(function(presentChild) {\n-                                return presentChild.key === key;\n-                            });\n-                            presentChildren.current.splice(removeIndex, 1);\n-                            // Defer re-rendering until all exiting children have indeed left\n-                            if (!exiting.size) {\n-                                presentChildren.current = filteredChildren;\n-                                if (isMounted.current === false) return;\n-                                forceRender();\n-                                onExitComplete && onExitComplete();\n+\n+                    // For relative vertical movement. Dir may be -1 or 1. Unit can be\n+                    // \"page\" or \"line\". The resulting position will have a hitSide=true\n+                    // property if it reached the end of the document.\n+                    function findPosV(cm, pos, dir, unit) {\n+                        var doc = cm.doc,\n+                            x = pos.left,\n+                            y;\n+                        if (unit == \"page\") {\n+                            var pageSize = Math.min(cm.display.wrapper.clientHeight, window.innerHeight || document.documentElement.clientHeight);\n+                            var moveAmount = Math.max(pageSize - .5 * textHeight(cm.display), 3);\n+                            y = (dir > 0 ? pos.bottom : pos.top) + dir * moveAmount;\n+                        } else if (unit == \"line\") {\n+                            y = dir > 0 ? pos.bottom + 3 : pos.top - 3;\n+                        }\n+                        var target;\n+                        for (;;) {\n+                            target = coordsChar(cm, x, y);\n+                            if (!target.outside) {\n+                                break;\n                             }\n-                        };\n-                        childrenToRender.splice(insertionIndex, 0, React__namespace.createElement(PresenceChild, {\n-                            key: getChildKey(child),\n-                            isPresent: false,\n-                            onExitComplete: onExit,\n-                            custom: custom,\n-                            presenceAffectsLayout: presenceAffectsLayout\n-                        }, child));\n-                    });\n-                    // Add `MotionContext` even to children that don't need it to ensure we're rendering\n-                    // the same tree between renders\n-                    childrenToRender = childrenToRender.map(function(child) {\n-                        var key = child.key;\n-                        return exiting.has(key) ? child : React__namespace.createElement(PresenceChild, {\n-                            key: getChildKey(child),\n-                            isPresent: true,\n-                            presenceAffectsLayout: presenceAffectsLayout\n-                        }, child);\n-                    });\n-                    if (env !== \"production\" && exitBeforeEnter && childrenToRender.length > 1) {\n-                        console.warn(\"You're attempting to animate multiple children within AnimatePresence, but its exitBeforeEnter prop is set to true. This will lead to odd visual behaviour.\");\n+                            if (dir < 0 ? y <= 0 : y >= doc.height) {\n+                                target.hitSide = true;\n+                                break;\n+                            }\n+                            y += dir * 5;\n+                        }\n+                        return target;\n                     }\n-                    return React__namespace.createElement(React__namespace.Fragment, null, exiting.size ? childrenToRender : childrenToRender.map(function(child) {\n-                        return React.cloneElement(child);\n-                    }));\n-                };\n \n-                /**\n-                 * @deprecated\n-                 */\n-                var DeprecatedLayoutGroupContext = React.createContext(null);\n-                var notify = function(node) {\n-                    return !node.isLayoutDirty && node.willUpdate(false);\n-                };\n+                    // CONTENTEDITABLE INPUT STYLE\n \n-                function nodeGroup() {\n-                    var nodes = new Set();\n-                    var subscriptions = new WeakMap();\n-                    var dirtyAll = function() {\n-                        return nodes.forEach(notify);\n-                    };\n-                    return {\n-                        add: function(node) {\n-                            nodes.add(node);\n-                            subscriptions.set(node, node.addEventListener(\"willUpdate\", dirtyAll));\n-                        },\n-                        remove: function(node) {\n-                            var _a;\n-                            nodes.delete(node);\n-                            (_a = subscriptions.get(node)) === null || _a === void 0 ? void 0 : _a();\n-                            subscriptions.delete(node);\n-                            dirtyAll();\n-                        },\n-                        dirty: dirtyAll\n-                    };\n-                }\n-                var shouldInheritGroup = function(inherit) {\n-                    return inherit === true;\n-                };\n-                var shouldInheritId = function(inherit) {\n-                    return shouldInheritGroup(inherit === true) || inherit === \"id\";\n-                };\n-                var LayoutGroup = function(_a) {\n-                    var _b, _c;\n-                    var children = _a.children,\n-                        id = _a.id,\n-                        inheritId = _a.inheritId,\n-                        _d = _a.inherit,\n-                        inherit = _d === void 0 ? true : _d;\n-                    // Maintain backwards-compatibility with inheritId until 7.0\n-                    if (inheritId !== undefined) inherit = inheritId;\n-                    var layoutGroupContext = React.useContext(LayoutGroupContext);\n-                    var deprecatedLayoutGroupContext = React.useContext(DeprecatedLayoutGroupContext);\n-                    var _e = tslib.__read(useForceUpdate(), 2),\n-                        forceRender = _e[0],\n-                        key = _e[1];\n-                    var context = React.useRef(null);\n-                    var upstreamId = (_b = layoutGroupContext.id) !== null && _b !== void 0 ? _b : deprecatedLayoutGroupContext;\n-                    if (context.current === null) {\n-                        if (shouldInheritId(inherit) && upstreamId) {\n-                            id = id ? upstreamId + \"-\" + id : upstreamId;\n+                    var ContentEditableInput = function(cm) {\n+                        this.cm = cm;\n+                        this.lastAnchorNode = this.lastAnchorOffset = this.lastFocusNode = this.lastFocusOffset = null;\n+                        this.polling = new Delayed();\n+                        this.composing = null;\n+                        this.gracePeriod = false;\n+                        this.readDOMTimeout = null;\n+                    };\n+                    ContentEditableInput.prototype.init = function(display) {\n+                        var this$1 = this;\n+                        var input = this,\n+                            cm = input.cm;\n+                        var div = input.div = display.lineDiv;\n+                        div.contentEditable = true;\n+                        disableBrowserMagic(div, cm.options.spellcheck, cm.options.autocorrect, cm.options.autocapitalize);\n+\n+                        function belongsToInput(e) {\n+                            for (var t = e.target; t; t = t.parentNode) {\n+                                if (t == div) {\n+                                    return true;\n+                                }\n+                                if (/\\bCodeMirror-(?:line)?widget\\b/.test(t.className)) {\n+                                    break;\n+                                }\n+                            }\n+                            return false;\n                         }\n-                        context.current = {\n-                            id: id,\n-                            group: shouldInheritGroup(inherit) ? (_c = layoutGroupContext === null || layoutGroupContext === void 0 ? void 0 : layoutGroupContext.group) !== null && _c !== void 0 ? _c : nodeGroup() : nodeGroup()\n-                        };\n-                    }\n-                    var memoizedContext = React.useMemo(function() {\n-                        return tslib.__assign(tslib.__assign({}, context.current), {\n-                            forceRender: forceRender\n+                        on(div, \"paste\", function(e) {\n+                            if (!belongsToInput(e) || signalDOMEvent(cm, e) || handlePaste(e, cm)) {\n+                                return;\n+                            }\n+                            // IE doesn't fire input events, so we schedule a read for the pasted content in this way\n+                            if (ie_version <= 11) {\n+                                setTimeout(operation(cm, function() {\n+                                    return this$1.updateFromDOM();\n+                                }), 20);\n+                            }\n+                        });\n+                        on(div, \"compositionstart\", function(e) {\n+                            this$1.composing = {\n+                                data: e.data,\n+                                done: false\n+                            };\n+                        });\n+                        on(div, \"compositionupdate\", function(e) {\n+                            if (!this$1.composing) {\n+                                this$1.composing = {\n+                                    data: e.data,\n+                                    done: false\n+                                };\n+                            }\n+                        });\n+                        on(div, \"compositionend\", function(e) {\n+                            if (this$1.composing) {\n+                                if (e.data != this$1.composing.data) {\n+                                    this$1.readFromDOMSoon();\n+                                }\n+                                this$1.composing.done = true;\n+                            }\n+                        });\n+                        on(div, \"touchstart\", function() {\n+                            return input.forceCompositionEnd();\n+                        });\n+                        on(div, \"input\", function() {\n+                            if (!this$1.composing) {\n+                                this$1.readFromDOMSoon();\n+                            }\n                         });\n-                    }, [key]);\n-                    return React__namespace.createElement(LayoutGroupContext.Provider, {\n-                        value: memoizedContext\n-                    }, children);\n-                };\n-                var id = 0;\n-                var AnimateSharedLayout = function(_a) {\n-                    var children = _a.children;\n-                    React__namespace.useEffect(function() {\n-                        heyListen.warning(false, \"AnimateSharedLayout is deprecated: https://www.framer.com/docs/guide-upgrade/##shared-layout-animations\");\n-                    }, []);\n-                    return React__namespace.createElement(LayoutGroup, {\n-                        id: useConstant(function() {\n-                            return \"asl-\".concat(id++);\n-                        })\n-                    }, children);\n-                };\n-\n-                /**\n-                 * `MotionConfig` is used to set configuration options for all children `motion` components.\n-                 *\n-                 * ```jsx\n-                 * import { motion, MotionConfig } from \"framer-motion\"\n-                 *\n-                 * export function App() {\n-                 *   return (\n-                 *     <MotionConfig transition={{ type: \"spring\" }}>\n-                 *       <motion.div animate={{ x: 100 }} />\n-                 *     </MotionConfig>\n-                 *   )\n-                 * }\n-                 * ```\n-                 *\n-                 * @public\n-                 */\n-                function MotionConfig(_a) {\n-                    var children = _a.children,\n-                        isValidProp = _a.isValidProp,\n-                        config = tslib.__rest(_a, [\"children\", \"isValidProp\"]);\n-                    isValidProp && loadExternalIsValidProp(isValidProp);\n-                    /**\n-                     * Inherit props from any parent MotionConfig components\n-                     */\n-                    config = tslib.__assign(tslib.__assign({}, React.useContext(MotionConfigContext)), config);\n-                    /**\n-                     * Don't allow isStatic to change between renders as it affects how many hooks\n-                     * motion components fire.\n-                     */\n-                    config.isStatic = useConstant(function() {\n-                        return config.isStatic;\n-                    });\n-                    /**\n-                     * Creating a new config context object will re-render every `motion` component\n-                     * every time it renders. So we only want to create a new one sparingly.\n-                     */\n-                    var context = React.useMemo(function() {\n-                        return config;\n-                    }, [JSON.stringify(config.transition), config.transformPagePoint, config.reducedMotion]);\n-                    return React__namespace.createElement(MotionConfigContext.Provider, {\n-                        value: context\n-                    }, children);\n-                }\n \n-                /**\n-                 * Used in conjunction with the `m` component to reduce bundle size.\n-                 *\n-                 * `m` is a version of the `motion` component that only loads functionality\n-                 * critical for the initial render.\n-                 *\n-                 * `LazyMotion` can then be used to either synchronously or asynchronously\n-                 * load animation and gesture support.\n-                 *\n-                 * ```jsx\n-                 * // Synchronous loading\n-                 * import { LazyMotion, m, domAnimations } from \"framer-motion\"\n-                 *\n-                 * function App() {\n-                 *   return (\n-                 *     <LazyMotion features={domAnimations}>\n-                 *       <m.div animate={{ scale: 2 }} />\n-                 *     </LazyMotion>\n-                 *   )\n-                 * }\n-                 *\n-                 * // Asynchronous loading\n-                 * import { LazyMotion, m } from \"framer-motion\"\n-                 *\n-                 * function App() {\n-                 *   return (\n-                 *     <LazyMotion features={() => import('./path/to/domAnimations')}>\n-                 *       <m.div animate={{ scale: 2 }} />\n-                 *     </LazyMotion>\n-                 *   )\n-                 * }\n-                 * ```\n-                 *\n-                 * @public\n-                 */\n-                function LazyMotion(_a) {\n-                    var children = _a.children,\n-                        features = _a.features,\n-                        _b = _a.strict,\n-                        strict = _b === void 0 ? false : _b;\n-                    var _c = tslib.__read(React.useState(!isLazyBundle(features)), 2),\n-                        setIsLoaded = _c[1];\n-                    var loadedRenderer = React.useRef(undefined);\n-                    /**\n-                     * If this is a synchronous load, load features immediately\n-                     */\n-                    if (!isLazyBundle(features)) {\n-                        var renderer = features.renderer,\n-                            loadedFeatures = tslib.__rest(features, [\"renderer\"]);\n-                        loadedRenderer.current = renderer;\n-                        loadFeatures(loadedFeatures);\n-                    }\n-                    React.useEffect(function() {\n-                        if (isLazyBundle(features)) {\n-                            features().then(function(_a) {\n-                                var renderer = _a.renderer,\n-                                    loadedFeatures = tslib.__rest(_a, [\"renderer\"]);\n-                                loadFeatures(loadedFeatures);\n-                                loadedRenderer.current = renderer;\n-                                setIsLoaded(true);\n-                            });\n+                        function onCopyCut(e) {\n+                            if (!belongsToInput(e) || signalDOMEvent(cm, e)) {\n+                                return;\n+                            }\n+                            if (cm.somethingSelected()) {\n+                                setLastCopied({\n+                                    lineWise: false,\n+                                    text: cm.getSelections()\n+                                });\n+                                if (e.type == \"cut\") {\n+                                    cm.replaceSelection(\"\", null, \"cut\");\n+                                }\n+                            } else if (!cm.options.lineWiseCopyCut) {\n+                                return;\n+                            } else {\n+                                var ranges = copyableRanges(cm);\n+                                setLastCopied({\n+                                    lineWise: true,\n+                                    text: ranges.text\n+                                });\n+                                if (e.type == \"cut\") {\n+                                    cm.operation(function() {\n+                                        cm.setSelections(ranges.ranges, 0, sel_dontScroll);\n+                                        cm.replaceSelection(\"\", null, \"cut\");\n+                                    });\n+                                }\n+                            }\n+                            if (e.clipboardData) {\n+                                e.clipboardData.clearData();\n+                                var content = lastCopied.text.join(\"\\n\");\n+                                // iOS exposes the clipboard API, but seems to discard content inserted into it\n+                                e.clipboardData.setData(\"Text\", content);\n+                                if (e.clipboardData.getData(\"Text\") == content) {\n+                                    e.preventDefault();\n+                                    return;\n+                                }\n+                            }\n+                            // Old-fashioned briefly-focus-a-textarea hack\n+                            var kludge = hiddenTextarea(),\n+                                te = kludge.firstChild;\n+                            cm.display.lineSpace.insertBefore(kludge, cm.display.lineSpace.firstChild);\n+                            te.value = lastCopied.text.join(\"\\n\");\n+                            var hadFocus = activeElt();\n+                            selectInput(te);\n+                            setTimeout(function() {\n+                                cm.display.lineSpace.removeChild(kludge);\n+                                hadFocus.focus();\n+                                if (hadFocus == div) {\n+                                    input.showPrimarySelection();\n+                                }\n+                            }, 50);\n+                        }\n+                        on(div, \"copy\", onCopyCut);\n+                        on(div, \"cut\", onCopyCut);\n+                    };\n+                    ContentEditableInput.prototype.screenReaderLabelChanged = function(label) {\n+                        // Label for screenreaders, accessibility\n+                        if (label) {\n+                            this.div.setAttribute('aria-label', label);\n+                        } else {\n+                            this.div.removeAttribute('aria-label');\n                         }\n-                    }, []);\n-                    return React__namespace.createElement(LazyContext.Provider, {\n-                        value: {\n-                            renderer: loadedRenderer.current,\n-                            strict: strict\n+                    };\n+                    ContentEditableInput.prototype.prepareSelection = function() {\n+                        var result = prepareSelection(this.cm, false);\n+                        result.focus = activeElt() == this.div;\n+                        return result;\n+                    };\n+                    ContentEditableInput.prototype.showSelection = function(info, takeFocus) {\n+                        if (!info || !this.cm.display.view.length) {\n+                            return;\n                         }\n-                    }, children);\n-                }\n-\n-                function isLazyBundle(features) {\n-                    return typeof features === \"function\";\n-                }\n-                var ReorderContext = React.createContext(null);\n-\n-                function checkReorder(order, value, offset, velocity) {\n-                    if (!velocity) return order;\n-                    var index = order.findIndex(function(item) {\n-                        return item.value === value;\n-                    });\n-                    if (index === -1) return order;\n-                    var nextOffset = velocity > 0 ? 1 : -1;\n-                    var nextItem = order[index + nextOffset];\n-                    if (!nextItem) return order;\n-                    var item = order[index];\n-                    var nextLayout = nextItem.layout;\n-                    var nextItemCenter = popmotion.mix(nextLayout.min, nextLayout.max, 0.5);\n-                    if (nextOffset === 1 && item.layout.max + offset > nextItemCenter || nextOffset === -1 && item.layout.min + offset < nextItemCenter) {\n-                        return moveItem(order, index, index + nextOffset);\n-                    }\n-                    return order;\n-                }\n-\n-                function ReorderGroup(_a, externalRef) {\n-                    var children = _a.children,\n-                        _b = _a.as,\n-                        as = _b === void 0 ? \"ul\" : _b,\n-                        _c = _a.axis,\n-                        axis = _c === void 0 ? \"y\" : _c,\n-                        onReorder = _a.onReorder,\n-                        values = _a.values,\n-                        props = tslib.__rest(_a, [\"children\", \"as\", \"axis\", \"onReorder\", \"values\"]);\n-                    var Component = useConstant(function() {\n-                        return motion(as);\n-                    });\n-                    var order = [];\n-                    var isReordering = React.useRef(false);\n-                    heyListen.invariant(Boolean(values), \"Reorder.Group must be provided a values prop\");\n-                    var context = {\n-                        axis: axis,\n-                        registerItem: function(value, layout) {\n-                            /**\n-                             * Ensure entries can't add themselves more than once\n-                             */\n-                            if (layout && order.findIndex(function(entry) {\n-                                    return value === entry.value;\n-                                }) === -1) {\n-                                order.push({\n-                                    value: value,\n-                                    layout: layout[axis]\n+                        if (info.focus || takeFocus) {\n+                            this.showPrimarySelection();\n+                        }\n+                        this.showMultipleSelections(info);\n+                    };\n+                    ContentEditableInput.prototype.getSelection = function() {\n+                        return this.cm.display.wrapper.ownerDocument.getSelection();\n+                    };\n+                    ContentEditableInput.prototype.showPrimarySelection = function() {\n+                        var sel = this.getSelection(),\n+                            cm = this.cm,\n+                            prim = cm.doc.sel.primary();\n+                        var from = prim.from(),\n+                            to = prim.to();\n+                        if (cm.display.viewTo == cm.display.viewFrom || from.line >= cm.display.viewTo || to.line < cm.display.viewFrom) {\n+                            sel.removeAllRanges();\n+                            return;\n+                        }\n+                        var curAnchor = domToPos(cm, sel.anchorNode, sel.anchorOffset);\n+                        var curFocus = domToPos(cm, sel.focusNode, sel.focusOffset);\n+                        if (curAnchor && !curAnchor.bad && curFocus && !curFocus.bad && cmp(minPos(curAnchor, curFocus), from) == 0 && cmp(maxPos(curAnchor, curFocus), to) == 0) {\n+                            return;\n+                        }\n+                        var view = cm.display.view;\n+                        var start = from.line >= cm.display.viewFrom && posToDOM(cm, from) || {\n+                            node: view[0].measure.map[2],\n+                            offset: 0\n+                        };\n+                        var end = to.line < cm.display.viewTo && posToDOM(cm, to);\n+                        if (!end) {\n+                            var measure = view[view.length - 1].measure;\n+                            var map = measure.maps ? measure.maps[measure.maps.length - 1] : measure.map;\n+                            end = {\n+                                node: map[map.length - 1],\n+                                offset: map[map.length - 2] - map[map.length - 3]\n+                            };\n+                        }\n+                        if (!start || !end) {\n+                            sel.removeAllRanges();\n+                            return;\n+                        }\n+                        var old = sel.rangeCount && sel.getRangeAt(0),\n+                            rng;\n+                        try {\n+                            rng = range(start.node, start.offset, end.offset, end.node);\n+                        } catch (e) {} // Our model of the DOM might be outdated, in which case the range we try to set can be impossible\n+                        if (rng) {\n+                            if (!gecko && cm.state.focused) {\n+                                sel.collapse(start.node, start.offset);\n+                                if (!rng.collapsed) {\n+                                    sel.removeAllRanges();\n+                                    sel.addRange(rng);\n+                                }\n+                            } else {\n+                                sel.removeAllRanges();\n+                                sel.addRange(rng);\n+                            }\n+                            if (old && sel.anchorNode == null) {\n+                                sel.addRange(old);\n+                            } else if (gecko) {\n+                                this.startGracePeriod();\n+                            }\n+                        }\n+                        this.rememberSelection();\n+                    };\n+                    ContentEditableInput.prototype.startGracePeriod = function() {\n+                        var this$1 = this;\n+                        clearTimeout(this.gracePeriod);\n+                        this.gracePeriod = setTimeout(function() {\n+                            this$1.gracePeriod = false;\n+                            if (this$1.selectionChanged()) {\n+                                this$1.cm.operation(function() {\n+                                    return this$1.cm.curOp.selectionChanged = true;\n                                 });\n-                                order.sort(compareMin);\n                             }\n-                        },\n-                        updateOrder: function(id, offset, velocity) {\n-                            if (isReordering.current) return;\n-                            var newOrder = checkReorder(order, id, offset, velocity);\n-                            if (order !== newOrder) {\n-                                isReordering.current = true;\n-                                onReorder(newOrder.map(getValue).filter(function(value) {\n-                                    return values.indexOf(value) !== -1;\n-                                }));\n+                        }, 20);\n+                    };\n+                    ContentEditableInput.prototype.showMultipleSelections = function(info) {\n+                        removeChildrenAndAdd(this.cm.display.cursorDiv, info.cursors);\n+                        removeChildrenAndAdd(this.cm.display.selectionDiv, info.selection);\n+                    };\n+                    ContentEditableInput.prototype.rememberSelection = function() {\n+                        var sel = this.getSelection();\n+                        this.lastAnchorNode = sel.anchorNode;\n+                        this.lastAnchorOffset = sel.anchorOffset;\n+                        this.lastFocusNode = sel.focusNode;\n+                        this.lastFocusOffset = sel.focusOffset;\n+                    };\n+                    ContentEditableInput.prototype.selectionInEditor = function() {\n+                        var sel = this.getSelection();\n+                        if (!sel.rangeCount) {\n+                            return false;\n+                        }\n+                        var node = sel.getRangeAt(0).commonAncestorContainer;\n+                        return contains(this.div, node);\n+                    };\n+                    ContentEditableInput.prototype.focus = function() {\n+                        if (this.cm.options.readOnly != \"nocursor\") {\n+                            if (!this.selectionInEditor() || activeElt() != this.div) {\n+                                this.showSelection(this.prepareSelection(), true);\n                             }\n+                            this.div.focus();\n                         }\n                     };\n-                    React.useEffect(function() {\n-                        isReordering.current = false;\n-                    });\n-                    return React__namespace.createElement(Component, tslib.__assign({}, props, {\n-                        ref: externalRef\n-                    }), React__namespace.createElement(ReorderContext.Provider, {\n-                        value: context\n-                    }, children));\n-                }\n-                var Group = React.forwardRef(ReorderGroup);\n-\n-                function getValue(item) {\n-                    return item.value;\n-                }\n-\n-                function compareMin(a, b) {\n-                    return a.layout.min - b.layout.min;\n-                }\n-\n-                /**\n-                 * Creates a `MotionValue` to track the state and velocity of a value.\n-                 *\n-                 * Usually, these are created automatically. For advanced use-cases, like use with `useTransform`, you can create `MotionValue`s externally and pass them into the animated component via the `style` prop.\n-                 *\n-                 * ```jsx\n-                 * export const MyComponent = () => {\n-                 *   const scale = useMotionValue(1)\n-                 *\n-                 *   return <motion.div style={{ scale }} />\n-                 * }\n-                 * ```\n-                 *\n-                 * @param initial - The initial state.\n-                 *\n-                 * @public\n-                 */\n-                function useMotionValue(initial) {\n-                    var value = useConstant(function() {\n-                        return motionValue(initial);\n-                    });\n-                    /**\n-                     * If this motion value is being used in static mode, like on\n-                     * the Framer canvas, force components to rerender when the motion\n-                     * value is updated.\n-                     */\n-                    var isStatic = React.useContext(MotionConfigContext).isStatic;\n-                    if (isStatic) {\n-                        var _a = tslib.__read(React.useState(initial), 2),\n-                            setLatest_1 = _a[1];\n-                        React.useEffect(function() {\n-                            return value.onChange(setLatest_1);\n-                        }, []);\n-                    }\n-                    return value;\n-                }\n-                var isCustomValueType = function(v) {\n-                    return typeof v === \"object\" && v.mix;\n-                };\n-                var getMixer = function(v) {\n-                    return isCustomValueType(v) ? v.mix : undefined;\n-                };\n-\n-                function transform() {\n-                    var args = [];\n-                    for (var _i = 0; _i < arguments.length; _i++) {\n-                        args[_i] = arguments[_i];\n-                    }\n-                    var useImmediate = !Array.isArray(args[0]);\n-                    var argOffset = useImmediate ? 0 : -1;\n-                    var inputValue = args[0 + argOffset];\n-                    var inputRange = args[1 + argOffset];\n-                    var outputRange = args[2 + argOffset];\n-                    var options = args[3 + argOffset];\n-                    var interpolator = popmotion.interpolate(inputRange, outputRange, tslib.__assign({\n-                        mixer: getMixer(outputRange[0])\n-                    }, options));\n-                    return useImmediate ? interpolator(inputValue) : interpolator;\n-                }\n-\n-                function useOnChange(value, callback) {\n-                    useIsomorphicLayoutEffect(function() {\n-                        if (isMotionValue(value)) return value.onChange(callback);\n-                    }, [callback]);\n-                }\n-\n-                function useMultiOnChange(values, handler) {\n-                    useIsomorphicLayoutEffect(function() {\n-                        var subscriptions = values.map(function(value) {\n-                            return value.onChange(handler);\n-                        });\n-                        return function() {\n-                            return subscriptions.forEach(function(unsubscribe) {\n-                                return unsubscribe();\n+                    ContentEditableInput.prototype.blur = function() {\n+                        this.div.blur();\n+                    };\n+                    ContentEditableInput.prototype.getField = function() {\n+                        return this.div;\n+                    };\n+                    ContentEditableInput.prototype.supportsTouch = function() {\n+                        return true;\n+                    };\n+                    ContentEditableInput.prototype.receivedFocus = function() {\n+                        var this$1 = this;\n+                        var input = this;\n+                        if (this.selectionInEditor()) {\n+                            setTimeout(function() {\n+                                return this$1.pollSelection();\n+                            }, 20);\n+                        } else {\n+                            runInOp(this.cm, function() {\n+                                return input.cm.curOp.selectionChanged = true;\n                             });\n-                        };\n-                    });\n-                }\n+                        }\n \n-                function useCombineMotionValues(values, combineValues) {\n-                    /**\n-                     * Initialise the returned motion value. This remains the same between renders.\n-                     */\n-                    var value = useMotionValue(combineValues());\n-                    /**\n-                     * Create a function that will update the template motion value with the latest values.\n-                     * This is pre-bound so whenever a motion value updates it can schedule its\n-                     * execution in Framesync. If it's already been scheduled it won't be fired twice\n-                     * in a single frame.\n-                     */\n-                    var updateValue = function() {\n-                        return value.set(combineValues());\n+                        function poll() {\n+                            if (input.cm.state.focused) {\n+                                input.pollSelection();\n+                                input.polling.set(input.cm.options.pollInterval, poll);\n+                            }\n+                        }\n+                        this.polling.set(this.cm.options.pollInterval, poll);\n                     };\n-                    /**\n-                     * Synchronously update the motion value with the latest values during the render.\n-                     * This ensures that within a React render, the styles applied to the DOM are up-to-date.\n-                     */\n-                    updateValue();\n-                    /**\n-                     * Subscribe to all motion values found within the template. Whenever any of them change,\n-                     * schedule an update.\n-                     */\n-                    useMultiOnChange(values, function() {\n-                        return sync__default[\"default\"].update(updateValue, false, true);\n-                    });\n-                    return value;\n-                }\n+                    ContentEditableInput.prototype.selectionChanged = function() {\n+                        var sel = this.getSelection();\n+                        return sel.anchorNode != this.lastAnchorNode || sel.anchorOffset != this.lastAnchorOffset || sel.focusNode != this.lastFocusNode || sel.focusOffset != this.lastFocusOffset;\n+                    };\n+                    ContentEditableInput.prototype.pollSelection = function() {\n+                        if (this.readDOMTimeout != null || this.gracePeriod || !this.selectionChanged()) {\n+                            return;\n+                        }\n+                        var sel = this.getSelection(),\n+                            cm = this.cm;\n+                        // On Android Chrome (version 56, at least), backspacing into an\n+                        // uneditable block element will put the cursor in that element,\n+                        // and then, because it's not editable, hide the virtual keyboard.\n+                        // Because Android doesn't allow us to actually detect backspace\n+                        // presses in a sane way, this code checks for when that happens\n+                        // and simulates a backspace press in this case.\n+                        if (android && chrome && this.cm.display.gutterSpecs.length && isInGutter(sel.anchorNode)) {\n+                            this.cm.triggerOnKeyDown({\n+                                type: \"keydown\",\n+                                keyCode: 8,\n+                                preventDefault: Math.abs\n+                            });\n+                            this.blur();\n+                            this.focus();\n+                            return;\n+                        }\n+                        if (this.composing) {\n+                            return;\n+                        }\n+                        this.rememberSelection();\n+                        var anchor = domToPos(cm, sel.anchorNode, sel.anchorOffset);\n+                        var head = domToPos(cm, sel.focusNode, sel.focusOffset);\n+                        if (anchor && head) {\n+                            runInOp(cm, function() {\n+                                setSelection(cm.doc, simpleSelection(anchor, head), sel_dontScroll);\n+                                if (anchor.bad || head.bad) {\n+                                    cm.curOp.selectionChanged = true;\n+                                }\n+                            });\n+                        }\n+                    };\n+                    ContentEditableInput.prototype.pollContent = function() {\n+                        if (this.readDOMTimeout != null) {\n+                            clearTimeout(this.readDOMTimeout);\n+                            this.readDOMTimeout = null;\n+                        }\n+                        var cm = this.cm,\n+                            display = cm.display,\n+                            sel = cm.doc.sel.primary();\n+                        var from = sel.from(),\n+                            to = sel.to();\n+                        if (from.ch == 0 && from.line > cm.firstLine()) {\n+                            from = Pos(from.line - 1, getLine(cm.doc, from.line - 1).length);\n+                        }\n+                        if (to.ch == getLine(cm.doc, to.line).text.length && to.line < cm.lastLine()) {\n+                            to = Pos(to.line + 1, 0);\n+                        }\n+                        if (from.line < display.viewFrom || to.line > display.viewTo - 1) {\n+                            return false;\n+                        }\n+                        var fromIndex, fromLine, fromNode;\n+                        if (from.line == display.viewFrom || (fromIndex = findViewIndex(cm, from.line)) == 0) {\n+                            fromLine = lineNo(display.view[0].line);\n+                            fromNode = display.view[0].node;\n+                        } else {\n+                            fromLine = lineNo(display.view[fromIndex].line);\n+                            fromNode = display.view[fromIndex - 1].node.nextSibling;\n+                        }\n+                        var toIndex = findViewIndex(cm, to.line);\n+                        var toLine, toNode;\n+                        if (toIndex == display.view.length - 1) {\n+                            toLine = display.viewTo - 1;\n+                            toNode = display.lineDiv.lastChild;\n+                        } else {\n+                            toLine = lineNo(display.view[toIndex + 1].line) - 1;\n+                            toNode = display.view[toIndex + 1].node.previousSibling;\n+                        }\n+                        if (!fromNode) {\n+                            return false;\n+                        }\n+                        var newText = cm.doc.splitLines(domTextBetween(cm, fromNode, toNode, fromLine, toLine));\n+                        var oldText = getBetween(cm.doc, Pos(fromLine, 0), Pos(toLine, getLine(cm.doc, toLine).text.length));\n+                        while (newText.length > 1 && oldText.length > 1) {\n+                            if (lst(newText) == lst(oldText)) {\n+                                newText.pop();\n+                                oldText.pop();\n+                                toLine--;\n+                            } else if (newText[0] == oldText[0]) {\n+                                newText.shift();\n+                                oldText.shift();\n+                                fromLine++;\n+                            } else {\n+                                break;\n+                            }\n+                        }\n+                        var cutFront = 0,\n+                            cutEnd = 0;\n+                        var newTop = newText[0],\n+                            oldTop = oldText[0],\n+                            maxCutFront = Math.min(newTop.length, oldTop.length);\n+                        while (cutFront < maxCutFront && newTop.charCodeAt(cutFront) == oldTop.charCodeAt(cutFront)) {\n+                            ++cutFront;\n+                        }\n+                        var newBot = lst(newText),\n+                            oldBot = lst(oldText);\n+                        var maxCutEnd = Math.min(newBot.length - (newText.length == 1 ? cutFront : 0), oldBot.length - (oldText.length == 1 ? cutFront : 0));\n+                        while (cutEnd < maxCutEnd && newBot.charCodeAt(newBot.length - cutEnd - 1) == oldBot.charCodeAt(oldBot.length - cutEnd - 1)) {\n+                            ++cutEnd;\n+                        }\n+                        // Try to move start of change to start of selection if ambiguous\n+                        if (newText.length == 1 && oldText.length == 1 && fromLine == from.line) {\n+                            while (cutFront && cutFront > from.ch && newBot.charCodeAt(newBot.length - cutEnd - 1) == oldBot.charCodeAt(oldBot.length - cutEnd - 1)) {\n+                                cutFront--;\n+                                cutEnd++;\n+                            }\n+                        }\n+                        newText[newText.length - 1] = newBot.slice(0, newBot.length - cutEnd).replace(/^\\u200b+/, \"\");\n+                        newText[0] = newText[0].slice(cutFront).replace(/\\u200b+$/, \"\");\n+                        var chFrom = Pos(fromLine, cutFront);\n+                        var chTo = Pos(toLine, oldText.length ? lst(oldText).length - cutEnd : 0);\n+                        if (newText.length > 1 || newText[0] || cmp(chFrom, chTo)) {\n+                            replaceRange(cm.doc, newText, chFrom, chTo, \"+input\");\n+                            return true;\n+                        }\n+                    };\n+                    ContentEditableInput.prototype.ensurePolled = function() {\n+                        this.forceCompositionEnd();\n+                    };\n+                    ContentEditableInput.prototype.reset = function() {\n+                        this.forceCompositionEnd();\n+                    };\n+                    ContentEditableInput.prototype.forceCompositionEnd = function() {\n+                        if (!this.composing) {\n+                            return;\n+                        }\n+                        clearTimeout(this.readDOMTimeout);\n+                        this.composing = null;\n+                        this.updateFromDOM();\n+                        this.div.blur();\n+                        this.div.focus();\n+                    };\n+                    ContentEditableInput.prototype.readFromDOMSoon = function() {\n+                        var this$1 = this;\n+                        if (this.readDOMTimeout != null) {\n+                            return;\n+                        }\n+                        this.readDOMTimeout = setTimeout(function() {\n+                            this$1.readDOMTimeout = null;\n+                            if (this$1.composing) {\n+                                if (this$1.composing.done) {\n+                                    this$1.composing = null;\n+                                } else {\n+                                    return;\n+                                }\n+                            }\n+                            this$1.updateFromDOM();\n+                        }, 80);\n+                    };\n+                    ContentEditableInput.prototype.updateFromDOM = function() {\n+                        var this$1 = this;\n+                        if (this.cm.isReadOnly() || !this.pollContent()) {\n+                            runInOp(this.cm, function() {\n+                                return regChange(this$1.cm);\n+                            });\n+                        }\n+                    };\n+                    ContentEditableInput.prototype.setUneditable = function(node) {\n+                        node.contentEditable = \"false\";\n+                    };\n+                    ContentEditableInput.prototype.onKeyPress = function(e) {\n+                        if (e.charCode == 0 || this.composing) {\n+                            return;\n+                        }\n+                        e.preventDefault();\n+                        if (!this.cm.isReadOnly()) {\n+                            operation(this.cm, applyTextInput)(this.cm, String.fromCharCode(e.charCode == null ? e.keyCode : e.charCode), 0);\n+                        }\n+                    };\n+                    ContentEditableInput.prototype.readOnlyChanged = function(val) {\n+                        this.div.contentEditable = String(val != \"nocursor\");\n+                    };\n+                    ContentEditableInput.prototype.onContextMenu = function() {};\n+                    ContentEditableInput.prototype.resetPosition = function() {};\n+                    ContentEditableInput.prototype.needsContentAttribute = true;\n \n-                function useTransform(input, inputRangeOrTransformer, outputRange, options) {\n-                    var transformer = typeof inputRangeOrTransformer === \"function\" ? inputRangeOrTransformer : transform(inputRangeOrTransformer, outputRange, options);\n-                    return Array.isArray(input) ? useListTransform(input, transformer) : useListTransform([input], function(_a) {\n-                        var _b = tslib.__read(_a, 1),\n-                            latest = _b[0];\n-                        return transformer(latest);\n-                    });\n-                }\n+                    function posToDOM(cm, pos) {\n+                        var view = findViewForLine(cm, pos.line);\n+                        if (!view || view.hidden) {\n+                            return null;\n+                        }\n+                        var line = getLine(cm.doc, pos.line);\n+                        var info = mapFromLineView(view, line, pos.line);\n+                        var order = getOrder(line, cm.doc.direction),\n+                            side = \"left\";\n+                        if (order) {\n+                            var partPos = getBidiPartAt(order, pos.ch);\n+                            side = partPos % 2 ? \"right\" : \"left\";\n+                        }\n+                        var result = nodeAndOffsetInLineMap(info.map, pos.ch, side);\n+                        result.offset = result.collapse == \"right\" ? result.end : result.start;\n+                        return result;\n+                    }\n \n-                function useListTransform(values, transformer) {\n-                    var latest = useConstant(function() {\n-                        return [];\n-                    });\n-                    return useCombineMotionValues(values, function() {\n-                        latest.length = 0;\n-                        var numValues = values.length;\n-                        for (var i = 0; i < numValues; i++) {\n-                            latest[i] = values[i].get();\n+                    function isInGutter(node) {\n+                        for (var scan = node; scan; scan = scan.parentNode) {\n+                            if (/CodeMirror-gutter-wrapper/.test(scan.className)) {\n+                                return true;\n+                            }\n                         }\n-                        return transformer(latest);\n-                    });\n-                }\n+                        return false;\n+                    }\n \n-                function useDefaultMotionValue(value, defaultValue) {\n-                    if (defaultValue === void 0) {\n-                        defaultValue = 0;\n+                    function badPos(pos, bad) {\n+                        if (bad) {\n+                            pos.bad = true;\n+                        }\n+                        return pos;\n                     }\n-                    return isMotionValue(value) ? value : useMotionValue(defaultValue);\n-                }\n \n-                function ReorderItem(_a, externalRef) {\n-                    var children = _a.children,\n-                        style = _a.style,\n-                        value = _a.value,\n-                        _b = _a.as,\n-                        as = _b === void 0 ? \"li\" : _b,\n-                        onDrag = _a.onDrag,\n-                        _c = _a.layout,\n-                        layout = _c === void 0 ? true : _c,\n-                        props = tslib.__rest(_a, [\"children\", \"style\", \"value\", \"as\", \"onDrag\", \"layout\"]);\n-                    var Component = useConstant(function() {\n-                        return motion(as);\n-                    });\n-                    var context = React.useContext(ReorderContext);\n-                    var point = {\n-                        x: useDefaultMotionValue(style === null || style === void 0 ? void 0 : style.x),\n-                        y: useDefaultMotionValue(style === null || style === void 0 ? void 0 : style.y)\n-                    };\n-                    var zIndex = useTransform([point.x, point.y], function(_a) {\n-                        var _b = tslib.__read(_a, 2),\n-                            latestX = _b[0],\n-                            latestY = _b[1];\n-                        return latestX || latestY ? 1 : \"unset\";\n-                    });\n-                    var measuredLayout = React.useRef(null);\n-                    heyListen.invariant(Boolean(context), \"Reorder.Item must be a child of Reorder.Group\");\n-                    var _d = context,\n-                        axis = _d.axis,\n-                        registerItem = _d.registerItem,\n-                        updateOrder = _d.updateOrder;\n-                    React.useEffect(function() {\n-                        registerItem(value, measuredLayout.current);\n-                    }, [context]);\n-                    return React__namespace.createElement(Component, tslib.__assign({\n-                        drag: axis\n-                    }, props, {\n-                        dragSnapToOrigin: true,\n-                        style: tslib.__assign(tslib.__assign({}, style), {\n-                            x: point.x,\n-                            y: point.y,\n-                            zIndex: zIndex\n-                        }),\n-                        layout: layout,\n-                        onDrag: function(event, gesturePoint) {\n-                            var velocity = gesturePoint.velocity;\n-                            velocity[axis] && updateOrder(value, point[axis].get(), velocity[axis]);\n-                            onDrag === null || onDrag === void 0 ? void 0 : onDrag(event, gesturePoint);\n-                        },\n-                        onLayoutMeasure: function(measured) {\n-                            measuredLayout.current = measured;\n-                        },\n-                        ref: externalRef\n-                    }), children);\n-                }\n-                var Item = React.forwardRef(ReorderItem);\n-                var Reorder = {\n-                    Group: Group,\n-                    Item: Item\n-                };\n+                    function domTextBetween(cm, from, to, fromLine, toLine) {\n+                        var text = \"\",\n+                            closing = false,\n+                            lineSep = cm.doc.lineSeparator(),\n+                            extraLinebreak = false;\n+\n+                        function recognizeMarker(id) {\n+                            return function(marker) {\n+                                return marker.id == id;\n+                            };\n+                        }\n \n-                /**\n-                 * @public\n-                 */\n-                var domAnimation = tslib.__assign(tslib.__assign({\n-                    renderer: createDomVisualElement\n-                }, animations), gestureAnimations);\n+                        function close() {\n+                            if (closing) {\n+                                text += lineSep;\n+                                if (extraLinebreak) {\n+                                    text += lineSep;\n+                                }\n+                                closing = extraLinebreak = false;\n+                            }\n+                        }\n \n-                /**\n-                 * @public\n-                 */\n-                var domMax = tslib.__assign(tslib.__assign(tslib.__assign(tslib.__assign({}, domAnimation), drag), layoutFeatures), {\n-                    projectionNodeConstructor: HTMLProjectionNode\n-                });\n+                        function addText(str) {\n+                            if (str) {\n+                                close();\n+                                text += str;\n+                            }\n+                        }\n \n-                /**\n-                 * Combine multiple motion values into a new one using a string template literal.\n-                 *\n-                 * ```jsx\n-                 * import {\n-                 *   motion,\n-                 *   useSpring,\n-                 *   useMotionValue,\n-                 *   useMotionTemplate\n-                 * } from \"framer-motion\"\n-                 *\n-                 * function Component() {\n-                 *   const shadowX = useSpring(0)\n-                 *   const shadowY = useMotionValue(0)\n-                 *   const shadow = useMotionTemplate`drop-shadow(${shadowX}px ${shadowY}px 20px rgba(0,0,0,0.3))`\n-                 *\n-                 *   return <motion.div style={{ filter: shadow }} />\n-                 * }\n-                 * ```\n-                 *\n-                 * @public\n-                 */\n-                function useMotionTemplate(fragments) {\n-                    var values = [];\n-                    for (var _i = 1; _i < arguments.length; _i++) {\n-                        values[_i - 1] = arguments[_i];\n+                        function walk(node) {\n+                            if (node.nodeType == 1) {\n+                                var cmText = node.getAttribute(\"cm-text\");\n+                                if (cmText) {\n+                                    addText(cmText);\n+                                    return;\n+                                }\n+                                var markerID = node.getAttribute(\"cm-marker\"),\n+                                    range;\n+                                if (markerID) {\n+                                    var found = cm.findMarks(Pos(fromLine, 0), Pos(toLine + 1, 0), recognizeMarker(+markerID));\n+                                    if (found.length && (range = found[0].find(0))) {\n+                                        addText(getBetween(cm.doc, range.from, range.to).join(lineSep));\n+                                    }\n+                                    return;\n+                                }\n+                                if (node.getAttribute(\"contenteditable\") == \"false\") {\n+                                    return;\n+                                }\n+                                var isBlock = /^(pre|div|p|li|table|br)$/i.test(node.nodeName);\n+                                if (!/^br$/i.test(node.nodeName) && node.textContent.length == 0) {\n+                                    return;\n+                                }\n+                                if (isBlock) {\n+                                    close();\n+                                }\n+                                for (var i = 0; i < node.childNodes.length; i++) {\n+                                    walk(node.childNodes[i]);\n+                                }\n+                                if (/^(pre|p)$/i.test(node.nodeName)) {\n+                                    extraLinebreak = true;\n+                                }\n+                                if (isBlock) {\n+                                    closing = true;\n+                                }\n+                            } else if (node.nodeType == 3) {\n+                                addText(node.nodeValue.replace(/\\u200b/g, \"\").replace(/\\u00a0/g, \" \"));\n+                            }\n+                        }\n+                        for (;;) {\n+                            walk(from);\n+                            if (from == to) {\n+                                break;\n+                            }\n+                            from = from.nextSibling;\n+                            extraLinebreak = false;\n+                        }\n+                        return text;\n                     }\n-                    /**\n-                     * Create a function that will build a string from the latest motion values.\n-                     */\n-                    var numFragments = fragments.length;\n \n-                    function buildValue() {\n-                        var output = \"\";\n-                        for (var i = 0; i < numFragments; i++) {\n-                            output += fragments[i];\n-                            var value = values[i];\n-                            if (value) output += values[i].get();\n+                    function domToPos(cm, node, offset) {\n+                        var lineNode;\n+                        if (node == cm.display.lineDiv) {\n+                            lineNode = cm.display.lineDiv.childNodes[offset];\n+                            if (!lineNode) {\n+                                return badPos(cm.clipPos(Pos(cm.display.viewTo - 1)), true);\n+                            }\n+                            node = null;\n+                            offset = 0;\n+                        } else {\n+                            for (lineNode = node;; lineNode = lineNode.parentNode) {\n+                                if (!lineNode || lineNode == cm.display.lineDiv) {\n+                                    return null;\n+                                }\n+                                if (lineNode.parentNode && lineNode.parentNode == cm.display.lineDiv) {\n+                                    break;\n+                                }\n+                            }\n+                        }\n+                        for (var i = 0; i < cm.display.view.length; i++) {\n+                            var lineView = cm.display.view[i];\n+                            if (lineView.node == lineNode) {\n+                                return locateNodeInLineView(lineView, node, offset);\n+                            }\n                         }\n-                        return output;\n                     }\n-                    return useCombineMotionValues(values, buildValue);\n-                }\n \n-                /**\n-                 * Creates a `MotionValue` that, when `set`, will use a spring animation to animate to its new state.\n-                 *\n-                 * It can either work as a stand-alone `MotionValue` by initialising it with a value, or as a subscriber\n-                 * to another `MotionValue`.\n-                 *\n-                 * @remarks\n-                 *\n-                 * ```jsx\n-                 * const x = useSpring(0, { stiffness: 300 })\n-                 * const y = useSpring(x, { damping: 10 })\n-                 * ```\n-                 *\n-                 * @param inputValue - `MotionValue` or number. If provided a `MotionValue`, when the input `MotionValue` changes, the created `MotionValue` will spring towards that value.\n-                 * @param springConfig - Configuration options for the spring.\n-                 * @returns `MotionValue`\n-                 *\n-                 * @public\n-                 */\n-                function useSpring(source, config) {\n-                    if (config === void 0) {\n-                        config = {};\n-                    }\n-                    var isStatic = React.useContext(MotionConfigContext).isStatic;\n-                    var activeSpringAnimation = React.useRef(null);\n-                    var value = useMotionValue(isMotionValue(source) ? source.get() : source);\n-                    React.useMemo(function() {\n-                        return value.attach(function(v, set) {\n-                            /**\n-                             * A more hollistic approach to this might be to use isStatic to fix VisualElement animations\n-                             * at that level, but this will work for now\n-                             */\n-                            if (isStatic) return set(v);\n-                            if (activeSpringAnimation.current) {\n-                                activeSpringAnimation.current.stop();\n+                    function locateNodeInLineView(lineView, node, offset) {\n+                        var wrapper = lineView.text.firstChild,\n+                            bad = false;\n+                        if (!node || !contains(wrapper, node)) {\n+                            return badPos(Pos(lineNo(lineView.line), 0), true);\n+                        }\n+                        if (node == wrapper) {\n+                            bad = true;\n+                            node = wrapper.childNodes[offset];\n+                            offset = 0;\n+                            if (!node) {\n+                                var line = lineView.rest ? lst(lineView.rest) : lineView.line;\n+                                return badPos(Pos(lineNo(line), line.text.length), bad);\n+                            }\n+                        }\n+                        var textNode = node.nodeType == 3 ? node : null,\n+                            topNode = node;\n+                        if (!textNode && node.childNodes.length == 1 && node.firstChild.nodeType == 3) {\n+                            textNode = node.firstChild;\n+                            if (offset) {\n+                                offset = textNode.nodeValue.length;\n+                            }\n+                        }\n+                        while (topNode.parentNode != wrapper) {\n+                            topNode = topNode.parentNode;\n+                        }\n+                        var measure = lineView.measure,\n+                            maps = measure.maps;\n+\n+                        function find(textNode, topNode, offset) {\n+                            for (var i = -1; i < (maps ? maps.length : 0); i++) {\n+                                var map = i < 0 ? measure.map : maps[i];\n+                                for (var j = 0; j < map.length; j += 3) {\n+                                    var curNode = map[j + 2];\n+                                    if (curNode == textNode || curNode == topNode) {\n+                                        var line = lineNo(i < 0 ? lineView.line : lineView.rest[i]);\n+                                        var ch = map[j] + offset;\n+                                        if (offset < 0 || curNode != textNode) {\n+                                            ch = map[j + (offset ? 1 : 0)];\n+                                        }\n+                                        return Pos(line, ch);\n+                                    }\n+                                }\n                             }\n-                            activeSpringAnimation.current = popmotion.animate(tslib.__assign(tslib.__assign({\n-                                from: value.get(),\n-                                to: v,\n-                                velocity: value.getVelocity()\n-                            }, config), {\n-                                onUpdate: set\n-                            }));\n-                            return value.get();\n-                        });\n-                    }, [JSON.stringify(config)]);\n-                    useOnChange(source, function(v) {\n-                        return value.set(parseFloat(v));\n-                    });\n-                    return value;\n-                }\n-\n-                /**\n-                 * Creates a `MotionValue` that updates when the velocity of the provided `MotionValue` changes.\n-                 *\n-                 * ```javascript\n-                 * const x = useMotionValue(0)\n-                 * const xVelocity = useVelocity(x)\n-                 * const xAcceleration = useVelocity(xVelocity)\n-                 * ```\n-                 *\n-                 * @public\n-                 */\n-                function useVelocity(value) {\n-                    var velocity = useMotionValue(value.getVelocity());\n-                    React.useEffect(function() {\n-                        return value.velocityUpdateSubscribers.add(function(newVelocity) {\n-                            velocity.set(newVelocity);\n-                        });\n-                    }, [value]);\n-                    return velocity;\n-                }\n-                var createScrollMotionValues = function() {\n-                    return {\n-                        scrollX: motionValue(0),\n-                        scrollY: motionValue(0),\n-                        scrollXProgress: motionValue(0),\n-                        scrollYProgress: motionValue(0)\n-                    };\n-                };\n+                        }\n+                        var found = find(textNode, topNode, offset);\n+                        if (found) {\n+                            return badPos(found, bad);\n+                        }\n \n-                function useScroll(_a) {\n-                    if (_a === void 0) {\n-                        _a = {};\n+                        // FIXME this is all really shaky. might handle the few cases it needs to handle, but likely to cause problems\n+                        for (var after = topNode.nextSibling, dist = textNode ? textNode.nodeValue.length - offset : 0; after; after = after.nextSibling) {\n+                            found = find(after, after.firstChild, 0);\n+                            if (found) {\n+                                return badPos(Pos(found.line, found.ch - dist), bad);\n+                            } else {\n+                                dist += after.textContent.length;\n+                            }\n+                        }\n+                        for (var before = topNode.previousSibling, dist$1 = offset; before; before = before.previousSibling) {\n+                            found = find(before, before.firstChild, -1);\n+                            if (found) {\n+                                return badPos(Pos(found.line, found.ch + dist$1), bad);\n+                            } else {\n+                                dist$1 += before.textContent.length;\n+                            }\n+                        }\n                     }\n-                    var container = _a.container,\n-                        target = _a.target,\n-                        options = tslib.__rest(_a, [\"container\", \"target\"]);\n-                    var values = useConstant(createScrollMotionValues);\n-                    useIsomorphicLayoutEffect(function() {\n-                        return dom.scroll(function(_a) {\n-                            var x = _a.x,\n-                                y = _a.y;\n-                            values.scrollX.set(x.current);\n-                            values.scrollXProgress.set(x.progress);\n-                            values.scrollY.set(y.current);\n-                            values.scrollYProgress.set(y.progress);\n-                        }, tslib.__assign(tslib.__assign({}, options), {\n-                            container: (container === null || container === void 0 ? void 0 : container.current) || undefined,\n-                            target: (target === null || target === void 0 ? void 0 : target.current) || undefined\n-                        }));\n-                    }, []);\n-                    return values;\n-                }\n \n-                function useElementScroll(ref) {\n-                    warnOnce(false, \"useElementScroll is deprecated. Convert to useScroll({ container: ref }).\");\n-                    return useScroll({\n-                        container: ref\n-                    });\n-                }\n+                    // TEXTAREA INPUT STYLE\n \n-                function useViewportScroll() {\n-                    warnOnce(false, \"useViewportScroll is deprecated. Convert to useScroll().\");\n-                    return useScroll();\n-                }\n-                var getCurrentTime = typeof performance !== \"undefined\" ? function() {\n-                    return performance.now();\n-                } : function() {\n-                    return Date.now();\n-                };\n+                    var TextareaInput = function(cm) {\n+                        this.cm = cm;\n+                        // See input.poll and input.reset\n+                        this.prevInput = \"\";\n \n-                function useAnimationFrame(callback) {\n-                    var initialTimestamp = useConstant(getCurrentTime);\n-                    var isStatic = React.useContext(MotionConfigContext).isStatic;\n-                    React.useEffect(function() {\n-                        if (isStatic) return;\n-                        var provideTimeSinceStart = function(_a) {\n-                            var timestamp = _a.timestamp;\n-                            callback(timestamp - initialTimestamp);\n-                        };\n-                        sync__default[\"default\"].update(provideTimeSinceStart, true);\n-                        return function() {\n-                            return sync.cancelSync.update(provideTimeSinceStart);\n-                        };\n-                    }, [callback]);\n-                }\n+                        // Flag that indicates whether we expect input to appear real soon\n+                        // now (after some event like 'keypress' or 'input') and are\n+                        // polling intensively.\n+                        this.pollingFast = false;\n+                        // Self-resetting timeout for the poller\n+                        this.polling = new Delayed();\n+                        // Used to work around IE issue with selection being forgotten when focus moves away from textarea\n+                        this.hasSelection = false;\n+                        this.composing = null;\n+                    };\n+                    TextareaInput.prototype.init = function(display) {\n+                        var this$1 = this;\n+                        var input = this,\n+                            cm = this.cm;\n+                        this.createField(display);\n+                        var te = this.textarea;\n+                        display.wrapper.insertBefore(this.wrapper, display.wrapper.firstChild);\n \n-                function useTime() {\n-                    var time = useMotionValue(0);\n-                    useAnimationFrame(function(t) {\n-                        return time.set(t);\n-                    });\n-                    return time;\n-                }\n+                        // Needed to hide big blue blinking cursor on Mobile Safari (doesn't seem to work in iOS 8 anymore)\n+                        if (ios) {\n+                            te.style.width = \"0px\";\n+                        }\n+                        on(te, \"input\", function() {\n+                            if (ie && ie_version >= 9 && this$1.hasSelection) {\n+                                this$1.hasSelection = null;\n+                            }\n+                            input.poll();\n+                        });\n+                        on(te, \"paste\", function(e) {\n+                            if (signalDOMEvent(cm, e) || handlePaste(e, cm)) {\n+                                return;\n+                            }\n+                            cm.state.pasteIncoming = +new Date();\n+                            input.fastPoll();\n+                        });\n \n-                /**\n-                 * @public\n-                 */\n-                function animationControls() {\n-                    /**\n-                     * Track whether the host component has mounted.\n-                     */\n-                    var hasMounted = false;\n-                    /**\n-                     * Pending animations that are started before a component is mounted.\n-                     * TODO: Remove this as animations should only run in effects\n-                     */\n-                    var pendingAnimations = [];\n-                    /**\n-                     * A collection of linked component animation controls.\n-                     */\n-                    var subscribers = new Set();\n-                    var controls = {\n-                        subscribe: function(visualElement) {\n-                            subscribers.add(visualElement);\n-                            return function() {\n-                                return void subscribers.delete(visualElement);\n-                            };\n-                        },\n-                        start: function(definition, transitionOverride) {\n-                            /**\n-                             * TODO: We only perform this hasMounted check because in Framer we used to\n-                             * encourage the ability to start an animation within the render phase. This\n-                             * isn't behaviour concurrent-safe so when we make Framer concurrent-safe\n-                             * we can ditch this.\n-                             */\n-                            if (hasMounted) {\n-                                var animations_1 = [];\n-                                subscribers.forEach(function(visualElement) {\n-                                    animations_1.push(animateVisualElement(visualElement, definition, {\n-                                        transitionOverride: transitionOverride\n-                                    }));\n+                        function prepareCopyCut(e) {\n+                            if (signalDOMEvent(cm, e)) {\n+                                return;\n+                            }\n+                            if (cm.somethingSelected()) {\n+                                setLastCopied({\n+                                    lineWise: false,\n+                                    text: cm.getSelections()\n                                 });\n-                                return Promise.all(animations_1);\n+                            } else if (!cm.options.lineWiseCopyCut) {\n+                                return;\n                             } else {\n-                                return new Promise(function(resolve) {\n-                                    pendingAnimations.push({\n-                                        animation: [definition, transitionOverride],\n-                                        resolve: resolve\n-                                    });\n+                                var ranges = copyableRanges(cm);\n+                                setLastCopied({\n+                                    lineWise: true,\n+                                    text: ranges.text\n                                 });\n+                                if (e.type == \"cut\") {\n+                                    cm.setSelections(ranges.ranges, null, sel_dontScroll);\n+                                } else {\n+                                    input.prevInput = \"\";\n+                                    te.value = ranges.text.join(\"\\n\");\n+                                    selectInput(te);\n+                                }\n+                            }\n+                            if (e.type == \"cut\") {\n+                                cm.state.cutIncoming = +new Date();\n                             }\n-                        },\n-                        set: function(definition) {\n-                            heyListen.invariant(hasMounted, \"controls.set() should only be called after a component has mounted. Consider calling within a useEffect hook.\");\n-                            return subscribers.forEach(function(visualElement) {\n-                                setValues(visualElement, definition);\n-                            });\n-                        },\n-                        stop: function() {\n-                            subscribers.forEach(function(visualElement) {\n-                                stopAnimation(visualElement);\n-                            });\n-                        },\n-                        mount: function() {\n-                            hasMounted = true;\n-                            pendingAnimations.forEach(function(_a) {\n-                                var animation = _a.animation,\n-                                    resolve = _a.resolve;\n-                                controls.start.apply(controls, tslib.__spreadArray([], tslib.__read(animation), false)).then(resolve);\n-                            });\n-                            return function() {\n-                                hasMounted = false;\n-                                controls.stop();\n-                            };\n                         }\n-                    };\n-                    return controls;\n-                }\n-\n-                /**\n-                 * Creates `AnimationControls`, which can be used to manually start, stop\n-                 * and sequence animations on one or more components.\n-                 *\n-                 * The returned `AnimationControls` should be passed to the `animate` property\n-                 * of the components you want to animate.\n-                 *\n-                 * These components can then be animated with the `start` method.\n-                 *\n-                 * ```jsx\n-                 * import * as React from 'react'\n-                 * import { motion, useAnimation } from 'framer-motion'\n-                 *\n-                 * export function MyComponent(props) {\n-                 *    const controls = useAnimation()\n-                 *\n-                 *    controls.start({\n-                 *        x: 100,\n-                 *        transition: { duration: 0.5 },\n-                 *    })\n-                 *\n-                 *    return <motion.div animate={controls} />\n-                 * }\n-                 * ```\n-                 *\n-                 * @returns Animation controller with `start` and `stop` methods\n-                 *\n-                 * @public\n-                 */\n-                function useAnimationControls() {\n-                    var controls = useConstant(animationControls);\n-                    React.useEffect(controls.mount, []);\n-                    return controls;\n-                }\n-                var useAnimation = useAnimationControls;\n-\n-                /**\n-                 * Cycles through a series of visual properties. Can be used to toggle between or cycle through animations. It works similar to `useState` in React. It is provided an initial array of possible states, and returns an array of two arguments.\n-                 *\n-                 * An index value can be passed to the returned `cycle` function to cycle to a specific index.\n-                 *\n-                 * ```jsx\n-                 * import * as React from \"react\"\n-                 * import { motion, useCycle } from \"framer-motion\"\n-                 *\n-                 * export const MyComponent = () => {\n-                 *   const [x, cycleX] = useCycle(0, 50, 100)\n-                 *\n-                 *   return (\n-                 *     <motion.div\n-                 *       animate={{ x: x }}\n-                 *       onTap={() => cycleX()}\n-                 *      />\n-                 *    )\n-                 * }\n-                 * ```\n-                 *\n-                 * @param items - items to cycle through\n-                 * @returns [currentState, cycleState]\n-                 *\n-                 * @public\n-                 */\n-                function useCycle() {\n-                    var items = [];\n-                    for (var _i = 0; _i < arguments.length; _i++) {\n-                        items[_i] = arguments[_i];\n-                    }\n-                    var index = React.useRef(0);\n-                    var _a = tslib.__read(React.useState(items[index.current]), 2),\n-                        item = _a[0],\n-                        setItem = _a[1];\n-                    var runCycle = React.useCallback(function(next) {\n-                        index.current = typeof next !== \"number\" ? popmotion.wrap(0, items.length, index.current + 1) : next;\n-                        setItem(items[index.current]);\n-                    }, tslib.__spreadArray([items.length], tslib.__read(items), false));\n-                    return [item, runCycle];\n-                }\n+                        on(te, \"cut\", prepareCopyCut);\n+                        on(te, \"copy\", prepareCopyCut);\n+                        on(display.scroller, \"paste\", function(e) {\n+                            if (eventInWidget(display, e) || signalDOMEvent(cm, e)) {\n+                                return;\n+                            }\n+                            if (!te.dispatchEvent) {\n+                                cm.state.pasteIncoming = +new Date();\n+                                input.focus();\n+                                return;\n+                            }\n \n-                function useInView(ref, _a) {\n-                    var _b = _a === void 0 ? {} : _a,\n-                        root = _b.root,\n-                        margin = _b.margin,\n-                        amount = _b.amount,\n-                        _c = _b.once,\n-                        once = _c === void 0 ? false : _c;\n-                    var _d = tslib.__read(React.useState(false), 2),\n-                        isInView = _d[0],\n-                        setInView = _d[1];\n-                    React.useEffect(function() {\n-                        var _a;\n-                        if (!ref.current || once && isInView) return;\n-                        var onEnter = function() {\n-                            setInView(true);\n-                            return once ? undefined : function() {\n-                                return setInView(false);\n+                            // Pass the `paste` event to the textarea so it's handled by its event listener.\n+                            var event = new Event(\"paste\");\n+                            event.clipboardData = e.clipboardData;\n+                            te.dispatchEvent(event);\n+                        });\n+\n+                        // Prevent normal selection in the editor (we handle our own)\n+                        on(display.lineSpace, \"selectstart\", function(e) {\n+                            if (!eventInWidget(display, e)) {\n+                                e_preventDefault(e);\n+                            }\n+                        });\n+                        on(te, \"compositionstart\", function() {\n+                            var start = cm.getCursor(\"from\");\n+                            if (input.composing) {\n+                                input.composing.range.clear();\n+                            }\n+                            input.composing = {\n+                                start: start,\n+                                range: cm.markText(start, cm.getCursor(\"to\"), {\n+                                    className: \"CodeMirror-composing\"\n+                                })\n                             };\n-                        };\n-                        var options = {\n-                            root: (_a = root === null || root === void 0 ? void 0 : root.current) !== null && _a !== void 0 ? _a : undefined,\n-                            margin: margin,\n-                            amount: amount === \"some\" ? \"any\" : amount\n-                        };\n-                        return dom.inView(ref.current, onEnter, options);\n-                    }, [root, ref, margin, once]);\n-                    return isInView;\n-                }\n-\n-                /**\n-                 * Can manually trigger a drag gesture on one or more `drag`-enabled `motion` components.\n-                 *\n-                 * ```jsx\n-                 * const dragControls = useDragControls()\n-                 *\n-                 * function startDrag(event) {\n-                 *   dragControls.start(event, { snapToCursor: true })\n-                 * }\n-                 *\n-                 * return (\n-                 *   <>\n-                 *     <div onPointerDown={startDrag} />\n-                 *     <motion.div drag=\"x\" dragControls={dragControls} />\n-                 *   </>\n-                 * )\n-                 * ```\n-                 *\n-                 * @public\n-                 */\n-                var DragControls = /** @class */ function() {\n-                    function DragControls() {\n-                        this.componentControls = new Set();\n-                    }\n-                    /**\n-                     * Subscribe a component's internal `VisualElementDragControls` to the user-facing API.\n-                     *\n-                     * @internal\n-                     */\n-                    DragControls.prototype.subscribe = function(controls) {\n-                        var _this = this;\n-                        this.componentControls.add(controls);\n-                        return function() {\n-                            return _this.componentControls.delete(controls);\n-                        };\n-                    };\n-                    /**\n-                     * Start a drag gesture on every `motion` component that has this set of drag controls\n-                     * passed into it via the `dragControls` prop.\n-                     *\n-                     * ```jsx\n-                     * dragControls.start(e, {\n-                     *   snapToCursor: true\n-                     * })\n-                     * ```\n-                     *\n-                     * @param event - PointerEvent\n-                     * @param options - Options\n-                     *\n-                     * @public\n-                     */\n-                    DragControls.prototype.start = function(event, options) {\n-                        this.componentControls.forEach(function(controls) {\n-                            controls.start(event.nativeEvent || event, options);\n+                        });\n+                        on(te, \"compositionend\", function() {\n+                            if (input.composing) {\n+                                input.poll();\n+                                input.composing.range.clear();\n+                                input.composing = null;\n+                            }\n                         });\n                     };\n-                    return DragControls;\n-                }();\n-                var createDragControls = function() {\n-                    return new DragControls();\n-                };\n-                /**\n-                 * Usually, dragging is initiated by pressing down on a `motion` component with a `drag` prop\n-                 * and moving it. For some use-cases, for instance clicking at an arbitrary point on a video scrubber, we\n-                 * might want to initiate that dragging from a different component than the draggable one.\n-                 *\n-                 * By creating a `dragControls` using the `useDragControls` hook, we can pass this into\n-                 * the draggable component's `dragControls` prop. It exposes a `start` method\n-                 * that can start dragging from pointer events on other components.\n-                 *\n-                 * ```jsx\n-                 * const dragControls = useDragControls()\n-                 *\n-                 * function startDrag(event) {\n-                 *   dragControls.start(event, { snapToCursor: true })\n-                 * }\n-                 *\n-                 * return (\n-                 *   <>\n-                 *     <div onPointerDown={startDrag} />\n-                 *     <motion.div drag=\"x\" dragControls={dragControls} />\n-                 *   </>\n-                 * )\n-                 * ```\n-                 *\n-                 * @public\n-                 */\n-                function useDragControls() {\n-                    return useConstant(createDragControls);\n-                }\n-\n-                function useInstantLayoutTransition() {\n-                    return startTransition;\n-                }\n-\n-                function startTransition(cb) {\n-                    if (!rootProjectionNode.current) return;\n-                    rootProjectionNode.current.isUpdating = false;\n-                    rootProjectionNode.current.blockUpdate();\n-                    cb === null || cb === void 0 ? void 0 : cb();\n-                }\n+                    TextareaInput.prototype.createField = function(_display) {\n+                        // Wraps and hides input textarea\n+                        this.wrapper = hiddenTextarea();\n+                        // The semihidden textarea that is focused when the editor is\n+                        // focused, and receives input.\n+                        this.textarea = this.wrapper.firstChild;\n+                    };\n+                    TextareaInput.prototype.screenReaderLabelChanged = function(label) {\n+                        // Label for screenreaders, accessibility\n+                        if (label) {\n+                            this.textarea.setAttribute('aria-label', label);\n+                        } else {\n+                            this.textarea.removeAttribute('aria-label');\n+                        }\n+                    };\n+                    TextareaInput.prototype.prepareSelection = function() {\n+                        // Redraw the selection and/or cursor\n+                        var cm = this.cm,\n+                            display = cm.display,\n+                            doc = cm.doc;\n+                        var result = prepareSelection(cm);\n+\n+                        // Move the hidden textarea near the cursor to prevent scrolling artifacts\n+                        if (cm.options.moveInputWithCursor) {\n+                            var headPos = cursorCoords(cm, doc.sel.primary().head, \"div\");\n+                            var wrapOff = display.wrapper.getBoundingClientRect(),\n+                                lineOff = display.lineDiv.getBoundingClientRect();\n+                            result.teTop = Math.max(0, Math.min(display.wrapper.clientHeight - 10, headPos.top + lineOff.top - wrapOff.top));\n+                            result.teLeft = Math.max(0, Math.min(display.wrapper.clientWidth - 10, headPos.left + lineOff.left - wrapOff.left));\n+                        }\n+                        return result;\n+                    };\n+                    TextareaInput.prototype.showSelection = function(drawn) {\n+                        var cm = this.cm,\n+                            display = cm.display;\n+                        removeChildrenAndAdd(display.cursorDiv, drawn.cursors);\n+                        removeChildrenAndAdd(display.selectionDiv, drawn.selection);\n+                        if (drawn.teTop != null) {\n+                            this.wrapper.style.top = drawn.teTop + \"px\";\n+                            this.wrapper.style.left = drawn.teLeft + \"px\";\n+                        }\n+                    };\n \n-                function useInstantTransition() {\n-                    var _a = tslib.__read(useForceUpdate(), 2),\n-                        forceUpdate = _a[0],\n-                        forcedRenderCount = _a[1];\n-                    var startInstantLayoutTransition = useInstantLayoutTransition();\n-                    React.useEffect(function() {\n-                        /**\n-                         * Unblock after two animation frames, otherwise this will unblock too soon.\n-                         */\n-                        sync__default[\"default\"].postRender(function() {\n-                            return sync__default[\"default\"].postRender(function() {\n-                                return instantAnimationState.current = false;\n-                            });\n-                        });\n-                    }, [forcedRenderCount]);\n-                    return function(callback) {\n-                        startInstantLayoutTransition(function() {\n-                            instantAnimationState.current = true;\n-                            forceUpdate();\n-                            callback();\n-                        });\n+                    // Reset the input to correspond to the selection (or to be empty,\n+                    // when not typing and nothing is selected)\n+                    TextareaInput.prototype.reset = function(typing) {\n+                        if (this.contextMenuPending || this.composing) {\n+                            return;\n+                        }\n+                        var cm = this.cm;\n+                        if (cm.somethingSelected()) {\n+                            this.prevInput = \"\";\n+                            var content = cm.getSelection();\n+                            this.textarea.value = content;\n+                            if (cm.state.focused) {\n+                                selectInput(this.textarea);\n+                            }\n+                            if (ie && ie_version >= 9) {\n+                                this.hasSelection = content;\n+                            }\n+                        } else if (!typing) {\n+                            this.prevInput = this.textarea.value = \"\";\n+                            if (ie && ie_version >= 9) {\n+                                this.hasSelection = null;\n+                            }\n+                        }\n+                    };\n+                    TextareaInput.prototype.getField = function() {\n+                        return this.textarea;\n+                    };\n+                    TextareaInput.prototype.supportsTouch = function() {\n+                        return false;\n+                    };\n+                    TextareaInput.prototype.focus = function() {\n+                        if (this.cm.options.readOnly != \"nocursor\" && (!mobile || activeElt() != this.textarea)) {\n+                            try {\n+                                this.textarea.focus();\n+                            } catch (e) {} // IE8 will throw if the textarea is display: none or not in DOM\n+                        }\n+                    };\n+                    TextareaInput.prototype.blur = function() {\n+                        this.textarea.blur();\n+                    };\n+                    TextareaInput.prototype.resetPosition = function() {\n+                        this.wrapper.style.top = this.wrapper.style.left = 0;\n+                    };\n+                    TextareaInput.prototype.receivedFocus = function() {\n+                        this.slowPoll();\n                     };\n-                }\n \n-                function useResetProjection() {\n-                    var reset = React__namespace.useCallback(function() {\n-                        var root = rootProjectionNode.current;\n-                        if (!root) return;\n-                        root.resetTree();\n-                    }, []);\n-                    return reset;\n-                }\n-                var createObject = function() {\n-                    return {};\n-                };\n-                var stateVisualElement = visualElement({\n-                    build: function() {},\n-                    measureViewportBox: createBox,\n-                    resetTransform: function() {},\n-                    restoreTransform: function() {},\n-                    removeValueFromRenderState: function() {},\n-                    render: function() {},\n-                    scrapeMotionValuesFromProps: createObject,\n-                    readValueFromInstance: function(_state, key, options) {\n-                        return options.initialState[key] || 0;\n-                    },\n-                    makeTargetAnimatable: function(element, _a) {\n-                        var transition = _a.transition,\n-                            transitionEnd = _a.transitionEnd,\n-                            target = tslib.__rest(_a, [\"transition\", \"transitionEnd\"]);\n-                        var origin = getOrigin(target, transition || {}, element);\n-                        checkTargetForNewValues(element, target, origin);\n-                        return tslib.__assign({\n-                            transition: transition,\n-                            transitionEnd: transitionEnd\n-                        }, target);\n-                    }\n-                });\n-                var useVisualState = makeUseVisualState({\n-                    scrapeMotionValuesFromProps: createObject,\n-                    createRenderState: createObject\n-                });\n-                /**\n-                 * This is not an officially supported API and may be removed\n-                 * on any version.\n-                 */\n-                function useAnimatedState(initialState) {\n-                    var _a = tslib.__read(React.useState(initialState), 2),\n-                        animationState = _a[0],\n-                        setAnimationState = _a[1];\n-                    var visualState = useVisualState({}, false);\n-                    var element = useConstant(function() {\n-                        return stateVisualElement({\n-                            props: {},\n-                            visualState: visualState\n-                        }, {\n-                            initialState: initialState\n-                        });\n-                    });\n-                    React.useEffect(function() {\n-                        element.mount({});\n-                        return element.unmount;\n-                    }, [element]);\n-                    React.useEffect(function() {\n-                        element.setProps({\n-                            onUpdate: function(v) {\n-                                setAnimationState(tslib.__assign({}, v));\n+                    // Poll for input changes, using the normal rate of polling. This\n+                    // runs as long as the editor is focused.\n+                    TextareaInput.prototype.slowPoll = function() {\n+                        var this$1 = this;\n+                        if (this.pollingFast) {\n+                            return;\n+                        }\n+                        this.polling.set(this.cm.options.pollInterval, function() {\n+                            this$1.poll();\n+                            if (this$1.cm.state.focused) {\n+                                this$1.slowPoll();\n                             }\n                         });\n-                    }, [setAnimationState, element]);\n-                    var startAnimation = useConstant(function() {\n-                        return function(animationDefinition) {\n-                            return animateVisualElement(element, animationDefinition);\n-                        };\n-                    });\n-                    return [animationState, startAnimation];\n-                }\n-\n-                // Keep things reasonable and avoid scale: Infinity. In practise we might need\n-                // to add another value, opacity, that could interpolate scaleX/Y [0,0.01] => [0,1]\n-                // to simply hide content at unreasonable scales.\n-                var maxScale = 100000;\n-                var invertScale = function(scale) {\n-                    return scale > 0.001 ? 1 / scale : maxScale;\n-                };\n-                var hasWarned = false;\n-                /**\n-                 * Returns a `MotionValue` each for `scaleX` and `scaleY` that update with the inverse\n-                 * of their respective parent scales.\n-                 *\n-                 * This is useful for undoing the distortion of content when scaling a parent component.\n-                 *\n-                 * By default, `useInvertedScale` will automatically fetch `scaleX` and `scaleY` from the nearest parent.\n-                 * By passing other `MotionValue`s in as `useInvertedScale({ scaleX, scaleY })`, it will invert the output\n-                 * of those instead.\n-                 *\n-                 * ```jsx\n-                 * const MyComponent = () => {\n-                 *   const { scaleX, scaleY } = useInvertedScale()\n-                 *   return <motion.div style={{ scaleX, scaleY }} />\n-                 * }\n-                 * ```\n-                 *\n-                 * @deprecated\n-                 */\n-                function useInvertedScale(scale) {\n-                    var parentScaleX = useMotionValue(1);\n-                    var parentScaleY = useMotionValue(1);\n-                    var visualElement = useVisualElementContext();\n-                    heyListen.invariant(!!(scale || visualElement), \"If no scale values are provided, useInvertedScale must be used within a child of another motion component.\");\n-                    heyListen.warning(hasWarned, \"useInvertedScale is deprecated and will be removed in 3.0. Use the layout prop instead.\");\n-                    hasWarned = true;\n-                    if (scale) {\n-                        parentScaleX = scale.scaleX || parentScaleX;\n-                        parentScaleY = scale.scaleY || parentScaleY;\n-                    } else if (visualElement) {\n-                        parentScaleX = visualElement.getValue(\"scaleX\", 1);\n-                        parentScaleY = visualElement.getValue(\"scaleY\", 1);\n-                    }\n-                    var scaleX = useTransform(parentScaleX, invertScale);\n-                    var scaleY = useTransform(parentScaleY, invertScale);\n-                    return {\n-                        scaleX: scaleX,\n-                        scaleY: scaleY\n                     };\n-                }\n-                exports.AnimatePresence = AnimatePresence;\n-                exports.AnimateSharedLayout = AnimateSharedLayout;\n-                exports.DeprecatedLayoutGroupContext = DeprecatedLayoutGroupContext;\n-                exports.DragControls = DragControls;\n-                exports.FlatTree = FlatTree;\n-                exports.LayoutGroup = LayoutGroup;\n-                exports.LayoutGroupContext = LayoutGroupContext;\n-                exports.LazyMotion = LazyMotion;\n-                exports.MotionConfig = MotionConfig;\n-                exports.MotionConfigContext = MotionConfigContext;\n-                exports.MotionContext = MotionContext;\n-                exports.MotionValue = MotionValue;\n-                exports.PresenceContext = PresenceContext;\n-                exports.Reorder = Reorder;\n-                exports.SwitchLayoutGroupContext = SwitchLayoutGroupContext;\n-                exports.addPointerEvent = addPointerEvent;\n-                exports.addScaleCorrector = addScaleCorrector;\n-                exports.animate = animate;\n-                exports.animateVisualElement = animateVisualElement;\n-                exports.animationControls = animationControls;\n-                exports.animations = animations;\n-                exports.calcLength = calcLength;\n-                exports.checkTargetForNewValues = checkTargetForNewValues;\n-                exports.createBox = createBox;\n-                exports.createDomMotionComponent = createDomMotionComponent;\n-                exports.createMotionComponent = createMotionComponent;\n-                exports.domAnimation = domAnimation;\n-                exports.domMax = domMax;\n-                exports.filterProps = filterProps;\n-                exports.isBrowser = isBrowser;\n-                exports.isDragActive = isDragActive;\n-                exports.isMotionValue = isMotionValue;\n-                exports.isValidMotionProp = isValidMotionProp;\n-                exports.m = m;\n-                exports.makeUseVisualState = makeUseVisualState;\n-                exports.motion = motion;\n-                exports.motionValue = motionValue;\n-                exports.resolveMotionValue = resolveMotionValue;\n-                exports.transform = transform;\n-                exports.useAnimation = useAnimation;\n-                exports.useAnimationControls = useAnimationControls;\n-                exports.useAnimationFrame = useAnimationFrame;\n-                exports.useCycle = useCycle;\n-                exports.useDeprecatedAnimatedState = useAnimatedState;\n-                exports.useDeprecatedInvertedScale = useInvertedScale;\n-                exports.useDomEvent = useDomEvent;\n-                exports.useDragControls = useDragControls;\n-                exports.useElementScroll = useElementScroll;\n-                exports.useForceUpdate = useForceUpdate;\n-                exports.useInView = useInView;\n-                exports.useInstantLayoutTransition = useInstantLayoutTransition;\n-                exports.useInstantTransition = useInstantTransition;\n-                exports.useIsPresent = useIsPresent;\n-                exports.useIsomorphicLayoutEffect = useIsomorphicLayoutEffect;\n-                exports.useMotionTemplate = useMotionTemplate;\n-                exports.useMotionValue = useMotionValue;\n-                exports.usePresence = usePresence;\n-                exports.useReducedMotion = useReducedMotion;\n-                exports.useReducedMotionConfig = useReducedMotionConfig;\n-                exports.useResetProjection = useResetProjection;\n-                exports.useScroll = useScroll;\n-                exports.useSpring = useSpring;\n-                exports.useTime = useTime;\n-                exports.useTransform = useTransform;\n-                exports.useUnmountEffect = useUnmountEffect;\n-                exports.useVelocity = useVelocity;\n-                exports.useViewportScroll = useViewportScroll;\n-                exports.useVisualElementContext = useVisualElementContext;\n-                exports.visualElement = visualElement;\n-                exports.wrapHandler = wrapHandler;\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/framesync/dist/framesync.cjs.js\":\n-            /*!*************************************************************!*\\\n-              !*** ../../../node_modules/framesync/dist/framesync.cjs.js ***!\n-              \\*************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports) {\n-\n \n+                    // When an event has just come in that is likely to add or change\n+                    // something in the input textarea, we poll faster, to ensure that\n+                    // the change appears on the screen quickly.\n+                    TextareaInput.prototype.fastPoll = function() {\n+                        var missed = false,\n+                            input = this;\n+                        input.pollingFast = true;\n+\n+                        function p() {\n+                            var changed = input.poll();\n+                            if (!changed && !missed) {\n+                                missed = true;\n+                                input.polling.set(60, p);\n+                            } else {\n+                                input.pollingFast = false;\n+                                input.slowPoll();\n+                            }\n+                        }\n+                        input.polling.set(20, p);\n+                    };\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                const defaultTimestep = 1 / 60 * 1000;\n-                const getCurrentTime = typeof performance !== \"undefined\" ? () => performance.now() : () => Date.now();\n-                const onNextFrame = typeof window !== \"undefined\" ? callback => window.requestAnimationFrame(callback) : callback => setTimeout(() => callback(getCurrentTime()), defaultTimestep);\n+                    // Read input from the textarea, and update the document to match.\n+                    // When something is selected, it is present in the textarea, and\n+                    // selected (unless it is huge, in which case a placeholder is\n+                    // used). When nothing is selected, the cursor sits after previously\n+                    // seen text (can be empty), which is stored in prevInput (we must\n+                    // not reset the textarea when typing, because that breaks IME).\n+                    TextareaInput.prototype.poll = function() {\n+                        var this$1 = this;\n+                        var cm = this.cm,\n+                            input = this.textarea,\n+                            prevInput = this.prevInput;\n+                        // Since this is called a *lot*, try to bail out as cheaply as\n+                        // possible when it is clear that nothing happened. hasSelection\n+                        // will be the case when there is a lot of text in the textarea,\n+                        // in which case reading its value would be expensive.\n+                        if (this.contextMenuPending || !cm.state.focused || hasSelection(input) && !prevInput && !this.composing || cm.isReadOnly() || cm.options.disableInput || cm.state.keySeq) {\n+                            return false;\n+                        }\n+                        var text = input.value;\n+                        // If nothing changed, bail.\n+                        if (text == prevInput && !cm.somethingSelected()) {\n+                            return false;\n+                        }\n+                        // Work around nonsensical selection resetting in IE9/10, and\n+                        // inexplicable appearance of private area unicode characters on\n+                        // some key combos in Mac (#2689).\n+                        if (ie && ie_version >= 9 && this.hasSelection === text || mac && /[\\uf700-\\uf7ff]/.test(text)) {\n+                            cm.display.input.reset();\n+                            return false;\n+                        }\n+                        if (cm.doc.sel == cm.display.selForContextMenu) {\n+                            var first = text.charCodeAt(0);\n+                            if (first == 0x200b && !prevInput) {\n+                                prevInput = \"\\u200b\";\n+                            }\n+                            if (first == 0x21da) {\n+                                this.reset();\n+                                return this.cm.execCommand(\"undo\");\n+                            }\n+                        }\n+                        // Find the part of the input that is actually new\n+                        var same = 0,\n+                            l = Math.min(prevInput.length, text.length);\n+                        while (same < l && prevInput.charCodeAt(same) == text.charCodeAt(same)) {\n+                            ++same;\n+                        }\n+                        runInOp(cm, function() {\n+                            applyTextInput(cm, text.slice(same), prevInput.length - same, null, this$1.composing ? \"*compose\" : null);\n+\n+                            // Don't leave long text in the textarea, since it makes further polling slow\n+                            if (text.length > 1000 || text.indexOf(\"\\n\") > -1) {\n+                                input.value = this$1.prevInput = \"\";\n+                            } else {\n+                                this$1.prevInput = text;\n+                            }\n+                            if (this$1.composing) {\n+                                this$1.composing.range.clear();\n+                                this$1.composing.range = cm.markText(this$1.composing.start, cm.getCursor(\"to\"), {\n+                                    className: \"CodeMirror-composing\"\n+                                });\n+                            }\n+                        });\n+                        return true;\n+                    };\n+                    TextareaInput.prototype.ensurePolled = function() {\n+                        if (this.pollingFast && this.poll()) {\n+                            this.pollingFast = false;\n+                        }\n+                    };\n+                    TextareaInput.prototype.onKeyPress = function() {\n+                        if (ie && ie_version >= 9) {\n+                            this.hasSelection = null;\n+                        }\n+                        this.fastPoll();\n+                    };\n+                    TextareaInput.prototype.onContextMenu = function(e) {\n+                        var input = this,\n+                            cm = input.cm,\n+                            display = cm.display,\n+                            te = input.textarea;\n+                        if (input.contextMenuPending) {\n+                            input.contextMenuPending();\n+                        }\n+                        var pos = posFromMouse(cm, e),\n+                            scrollPos = display.scroller.scrollTop;\n+                        if (!pos || presto) {\n+                            return;\n+                        } // Opera is difficult.\n \n-                function createRenderStep(runNextFrame) {\n-                    let toRun = [];\n-                    let toRunNextFrame = [];\n-                    let numToRun = 0;\n-                    let isProcessing = false;\n-                    let flushNextFrame = false;\n-                    const toKeepAlive = new WeakSet();\n-                    const step = {\n-                        schedule: function(callback) {\n-                            let keepAlive = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n-                            let immediate = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;\n-                            const addToCurrentFrame = immediate && isProcessing;\n-                            const buffer = addToCurrentFrame ? toRun : toRunNextFrame;\n-                            if (keepAlive) toKeepAlive.add(callback);\n-                            if (buffer.indexOf(callback) === -1) {\n-                                buffer.push(callback);\n-                                if (addToCurrentFrame && isProcessing) numToRun = toRun.length;\n+                        // Reset the current text selection only if the click is done outside of the selection\n+                        // and 'resetSelectionOnContextMenu' option is true.\n+                        var reset = cm.options.resetSelectionOnContextMenu;\n+                        if (reset && cm.doc.sel.contains(pos) == -1) {\n+                            operation(cm, setSelection)(cm.doc, simpleSelection(pos), sel_dontScroll);\n+                        }\n+                        var oldCSS = te.style.cssText,\n+                            oldWrapperCSS = input.wrapper.style.cssText;\n+                        var wrapperBox = input.wrapper.offsetParent.getBoundingClientRect();\n+                        input.wrapper.style.cssText = \"position: static\";\n+                        te.style.cssText = \"position: absolute; width: 30px; height: 30px;\\n      top: \" + (e.clientY - wrapperBox.top - 5) + \"px; left: \" + (e.clientX - wrapperBox.left - 5) + \"px;\\n      z-index: 1000; background: \" + (ie ? \"rgba(255, 255, 255, .05)\" : \"transparent\") + \";\\n      outline: none; border-width: 0; outline: none; overflow: hidden; opacity: .05; filter: alpha(opacity=5);\";\n+                        var oldScrollY;\n+                        if (webkit) {\n+                            oldScrollY = window.scrollY;\n+                        } // Work around Chrome issue (#2712)\n+                        display.input.focus();\n+                        if (webkit) {\n+                            window.scrollTo(null, oldScrollY);\n+                        }\n+                        display.input.reset();\n+                        // Adds \"Select all\" to context menu in FF\n+                        if (!cm.somethingSelected()) {\n+                            te.value = input.prevInput = \" \";\n+                        }\n+                        input.contextMenuPending = rehide;\n+                        display.selForContextMenu = cm.doc.sel;\n+                        clearTimeout(display.detectingSelectAll);\n+\n+                        // Select-all will be greyed out if there's nothing to select, so\n+                        // this adds a zero-width space so that we can later check whether\n+                        // it got selected.\n+                        function prepareSelectAllHack() {\n+                            if (te.selectionStart != null) {\n+                                var selected = cm.somethingSelected();\n+                                var extval = \"\\u200b\" + (selected ? te.value : \"\");\n+                                te.value = \"\\u21da\"; // Used to catch context-menu undo\n+                                te.value = extval;\n+                                input.prevInput = selected ? \"\" : \"\\u200b\";\n+                                te.selectionStart = 1;\n+                                te.selectionEnd = extval.length;\n+                                // Re-set this, in case some other handler touched the\n+                                // selection in the meantime.\n+                                display.selForContextMenu = cm.doc.sel;\n                             }\n-                            return callback;\n-                        },\n-                        cancel: callback => {\n-                            const index = toRunNextFrame.indexOf(callback);\n-                            if (index !== -1) toRunNextFrame.splice(index, 1);\n-                            toKeepAlive.delete(callback);\n-                        },\n-                        process: frameData => {\n-                            if (isProcessing) {\n-                                flushNextFrame = true;\n+                        }\n+\n+                        function rehide() {\n+                            if (input.contextMenuPending != rehide) {\n                                 return;\n                             }\n-                            isProcessing = true;\n-                            [toRun, toRunNextFrame] = [toRunNextFrame, toRun];\n-                            toRunNextFrame.length = 0;\n-                            numToRun = toRun.length;\n-                            if (numToRun) {\n-                                for (let i = 0; i < numToRun; i++) {\n-                                    const callback = toRun[i];\n-                                    callback(frameData);\n-                                    if (toKeepAlive.has(callback)) {\n-                                        step.schedule(callback);\n-                                        runNextFrame();\n-                                    }\n-                                }\n-                            }\n-                            isProcessing = false;\n-                            if (flushNextFrame) {\n-                                flushNextFrame = false;\n-                                step.process(frameData);\n+                            input.contextMenuPending = false;\n+                            input.wrapper.style.cssText = oldWrapperCSS;\n+                            te.style.cssText = oldCSS;\n+                            if (ie && ie_version < 9) {\n+                                display.scrollbars.setScrollTop(display.scroller.scrollTop = scrollPos);\n+                            }\n+\n+                            // Try to detect the user choosing select-all\n+                            if (te.selectionStart != null) {\n+                                if (!ie || ie && ie_version < 9) {\n+                                    prepareSelectAllHack();\n+                                }\n+                                var i = 0,\n+                                    poll = function() {\n+                                        if (display.selForContextMenu == cm.doc.sel && te.selectionStart == 0 && te.selectionEnd > 0 && input.prevInput == \"\\u200b\") {\n+                                            operation(cm, selectAll)(cm);\n+                                        } else if (i++ < 10) {\n+                                            display.detectingSelectAll = setTimeout(poll, 500);\n+                                        } else {\n+                                            display.selForContextMenu = null;\n+                                            display.input.reset();\n+                                        }\n+                                    };\n+                                display.detectingSelectAll = setTimeout(poll, 200);\n                             }\n                         }\n+                        if (ie && ie_version >= 9) {\n+                            prepareSelectAllHack();\n+                        }\n+                        if (captureRightClick) {\n+                            e_stop(e);\n+                            var mouseup = function() {\n+                                off(window, \"mouseup\", mouseup);\n+                                setTimeout(rehide, 20);\n+                            };\n+                            on(window, \"mouseup\", mouseup);\n+                        } else {\n+                            setTimeout(rehide, 50);\n+                        }\n                     };\n-                    return step;\n-                }\n-                const maxElapsed = 40;\n-                let useDefaultElapsed = true;\n-                let runNextFrame = false;\n-                let isProcessing = false;\n-                const frame = {\n-                    delta: 0,\n-                    timestamp: 0\n-                };\n-                const stepsOrder = [\"read\", \"update\", \"preRender\", \"render\", \"postRender\"];\n-                const steps = stepsOrder.reduce((acc, key) => {\n-                    acc[key] = createRenderStep(() => runNextFrame = true);\n-                    return acc;\n-                }, {});\n-                const sync = stepsOrder.reduce((acc, key) => {\n-                    const step = steps[key];\n-                    acc[key] = function(process) {\n-                        let keepAlive = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n-                        let immediate = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;\n-                        if (!runNextFrame) startLoop();\n-                        return step.schedule(process, keepAlive, immediate);\n+                    TextareaInput.prototype.readOnlyChanged = function(val) {\n+                        if (!val) {\n+                            this.reset();\n+                        }\n+                        this.textarea.disabled = val == \"nocursor\";\n+                        this.textarea.readOnly = !!val;\n                     };\n-                    return acc;\n-                }, {});\n-                const cancelSync = stepsOrder.reduce((acc, key) => {\n-                    acc[key] = steps[key].cancel;\n-                    return acc;\n-                }, {});\n-                const flushSync = stepsOrder.reduce((acc, key) => {\n-                    acc[key] = () => steps[key].process(frame);\n-                    return acc;\n-                }, {});\n-                const processStep = stepId => steps[stepId].process(frame);\n-                const processFrame = timestamp => {\n-                    runNextFrame = false;\n-                    frame.delta = useDefaultElapsed ? defaultTimestep : Math.max(Math.min(timestamp - frame.timestamp, maxElapsed), 1);\n-                    frame.timestamp = timestamp;\n-                    isProcessing = true;\n-                    stepsOrder.forEach(processStep);\n-                    isProcessing = false;\n-                    if (runNextFrame) {\n-                        useDefaultElapsed = false;\n-                        onNextFrame(processFrame);\n-                    }\n-                };\n-                const startLoop = () => {\n-                    runNextFrame = true;\n-                    useDefaultElapsed = true;\n-                    if (!isProcessing) onNextFrame(processFrame);\n-                };\n-                const getFrameData = () => frame;\n-                exports.cancelSync = cancelSync;\n-                exports[\"default\"] = sync;\n-                exports.flushSync = flushSync;\n-                exports.getFrameData = getFrameData;\n+                    TextareaInput.prototype.setUneditable = function() {};\n+                    TextareaInput.prototype.needsContentAttribute = false;\n \n-                /***/\n-            }),\n+                    function fromTextArea(textarea, options) {\n+                        options = options ? copyObj(options) : {};\n+                        options.value = textarea.value;\n+                        if (!options.tabindex && textarea.tabIndex) {\n+                            options.tabindex = textarea.tabIndex;\n+                        }\n+                        if (!options.placeholder && textarea.placeholder) {\n+                            options.placeholder = textarea.placeholder;\n+                        }\n+                        // Set autofocus to true if this textarea is focused, or if it has\n+                        // autofocus and no other element is focused.\n+                        if (options.autofocus == null) {\n+                            var hasFocus = activeElt();\n+                            options.autofocus = hasFocus == textarea || textarea.getAttribute(\"autofocus\") != null && hasFocus == document.body;\n+                        }\n \n-        /***/\n-        \"../../../node_modules/get-nonce/dist/es2015/index.js\":\n-            /*!************************************************************!*\\\n-              !*** ../../../node_modules/get-nonce/dist/es2015/index.js ***!\n-              \\************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                        function save() {\n+                            textarea.value = cm.getValue();\n+                        }\n+                        var realSubmit;\n+                        if (textarea.form) {\n+                            on(textarea.form, \"submit\", save);\n+                            // Deplorable hack to make the submit method do the right thing.\n+                            if (!options.leaveSubmitMethodAlone) {\n+                                var form = textarea.form;\n+                                realSubmit = form.submit;\n+                                try {\n+                                    var wrappedSubmit = form.submit = function() {\n+                                        save();\n+                                        form.submit = realSubmit;\n+                                        form.submit();\n+                                        form.submit = wrappedSubmit;\n+                                    };\n+                                } catch (e) {}\n+                            }\n+                        }\n+                        options.finishInit = function(cm) {\n+                            cm.save = save;\n+                            cm.getTextArea = function() {\n+                                return textarea;\n+                            };\n+                            cm.toTextArea = function() {\n+                                cm.toTextArea = isNaN; // Prevent this from being ran twice\n+                                save();\n+                                textarea.parentNode.removeChild(cm.getWrapperElement());\n+                                textarea.style.display = \"\";\n+                                if (textarea.form) {\n+                                    off(textarea.form, \"submit\", save);\n+                                    if (!options.leaveSubmitMethodAlone && typeof textarea.form.submit == \"function\") {\n+                                        textarea.form.submit = realSubmit;\n+                                    }\n+                                }\n+                            };\n+                        };\n+                        textarea.style.display = \"none\";\n+                        var cm = CodeMirror(function(node) {\n+                            return textarea.parentNode.insertBefore(node, textarea.nextSibling);\n+                        }, options);\n+                        return cm;\n+                    }\n+\n+                    function addLegacyProps(CodeMirror) {\n+                        CodeMirror.off = off;\n+                        CodeMirror.on = on;\n+                        CodeMirror.wheelEventPixels = wheelEventPixels;\n+                        CodeMirror.Doc = Doc;\n+                        CodeMirror.splitLines = splitLinesAuto;\n+                        CodeMirror.countColumn = countColumn;\n+                        CodeMirror.findColumn = findColumn;\n+                        CodeMirror.isWordChar = isWordCharBasic;\n+                        CodeMirror.Pass = Pass;\n+                        CodeMirror.signal = signal;\n+                        CodeMirror.Line = Line;\n+                        CodeMirror.changeEnd = changeEnd;\n+                        CodeMirror.scrollbarModel = scrollbarModel;\n+                        CodeMirror.Pos = Pos;\n+                        CodeMirror.cmpPos = cmp;\n+                        CodeMirror.modes = modes;\n+                        CodeMirror.mimeModes = mimeModes;\n+                        CodeMirror.resolveMode = resolveMode;\n+                        CodeMirror.getMode = getMode;\n+                        CodeMirror.modeExtensions = modeExtensions;\n+                        CodeMirror.extendMode = extendMode;\n+                        CodeMirror.copyState = copyState;\n+                        CodeMirror.startState = startState;\n+                        CodeMirror.innerMode = innerMode;\n+                        CodeMirror.commands = commands;\n+                        CodeMirror.keyMap = keyMap;\n+                        CodeMirror.keyName = keyName;\n+                        CodeMirror.isModifierKey = isModifierKey;\n+                        CodeMirror.lookupKey = lookupKey;\n+                        CodeMirror.normalizeKeyMap = normalizeKeyMap;\n+                        CodeMirror.StringStream = StringStream;\n+                        CodeMirror.SharedTextMarker = SharedTextMarker;\n+                        CodeMirror.TextMarker = TextMarker;\n+                        CodeMirror.LineWidget = LineWidget;\n+                        CodeMirror.e_preventDefault = e_preventDefault;\n+                        CodeMirror.e_stopPropagation = e_stopPropagation;\n+                        CodeMirror.e_stop = e_stop;\n+                        CodeMirror.addClass = addClass;\n+                        CodeMirror.contains = contains;\n+                        CodeMirror.rmClass = rmClass;\n+                        CodeMirror.keyNames = keyNames;\n+                    }\n+\n+                    // EDITOR CONSTRUCTOR\n+\n+                    defineOptions(CodeMirror);\n+                    addEditorMethods(CodeMirror);\n+\n+                    // Set up methods on CodeMirror's prototype to redirect to the editor's document.\n+                    var dontDelegate = \"iter insert remove copy getEditor constructor\".split(\" \");\n+                    for (var prop in Doc.prototype) {\n+                        if (Doc.prototype.hasOwnProperty(prop) && indexOf(dontDelegate, prop) < 0) {\n+                            CodeMirror.prototype[prop] = function(method) {\n+                                return function() {\n+                                    return method.apply(this.doc, arguments);\n+                                };\n+                            }(Doc.prototype[prop]);\n+                        }\n+                    }\n+                    eventMixin(Doc);\n+                    CodeMirror.inputStyles = {\n+                        \"textarea\": TextareaInput,\n+                        \"contenteditable\": ContentEditableInput\n+                    };\n \n+                    // Extra arguments are stored as the mode's dependencies, which is\n+                    // used by (legacy) mechanisms like loadmode.js to automatically\n+                    // load a mode. (Preferred mechanism is the require/define calls.)\n+                    CodeMirror.defineMode = function(name /*, mode, \u2026*/ ) {\n+                        if (!CodeMirror.defaults.mode && name != \"null\") {\n+                            CodeMirror.defaults.mode = name;\n+                        }\n+                        defineMode.apply(this, arguments);\n+                    };\n+                    CodeMirror.defineMIME = defineMIME;\n \n+                    // Minimal default mode.\n+                    CodeMirror.defineMode(\"null\", function() {\n+                        return {\n+                            token: function(stream) {\n+                                return stream.skipToEnd();\n+                            }\n+                        };\n+                    });\n+                    CodeMirror.defineMIME(\"text/plain\", \"null\");\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.setNonce = exports.getNonce = void 0;\n-                var currentNonce;\n-                var setNonce = function(nonce) {\n-                    currentNonce = nonce;\n-                };\n-                exports.setNonce = setNonce;\n-                var getNonce = function() {\n-                    if (currentNonce) {\n-                        return currentNonce;\n-                    }\n-                    if (true) {\n-                        return __webpack_require__.nc;\n-                    }\n-                    return undefined;\n-                };\n-                exports.getNonce = getNonce;\n+                    // EXTENSIONS\n+\n+                    CodeMirror.defineExtension = function(name, func) {\n+                        CodeMirror.prototype[name] = func;\n+                    };\n+                    CodeMirror.defineDocExtension = function(name, func) {\n+                        Doc.prototype[name] = func;\n+                    };\n+                    CodeMirror.fromTextArea = fromTextArea;\n+                    addLegacyProps(CodeMirror);\n+                    CodeMirror.version = \"5.65.3\";\n+                    return CodeMirror;\n+                });\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/graphql-ws/lib/client.mjs\":\n-            /*!*******************************************************!*\\\n-              !*** ../../../node_modules/graphql-ws/lib/client.mjs ***!\n-              \\*******************************************************/\n+        \"../../../node_modules/codemirror/mode/javascript/javascript.js\":\n+            /*!**********************************************************************!*\\\n+              !*** ../../../node_modules/codemirror/mode/javascript/javascript.js ***!\n+              \\**********************************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                var _exportNames = {\n-                    createClient: true\n-                };\n-                exports.createClient = createClient;\n-                var _common = __webpack_require__( /*! ./common.mjs */ \"../../../node_modules/graphql-ws/lib/common.mjs\");\n-                Object.keys(_common).forEach(function(key) {\n-                    if (key === \"default\" || key === \"__esModule\") return;\n-                    if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;\n-                    if (key in exports && exports[key] === _common[key]) return;\n-                    Object.defineProperty(exports, key, {\n-                        enumerable: true,\n-                        get: function() {\n-                            return _common[key];\n-                        }\n-                    });\n-                });\n-                var _utils = __webpack_require__( /*! ./utils.mjs */ \"../../../node_modules/graphql-ws/lib/utils.mjs\");\n-                /**\n-                 *\n-                 * client\n-                 *\n-                 */\n+                // CodeMirror, copyright (c) by Marijn Haverbeke and others\n+                // Distributed under an MIT license: https://codemirror.net/LICENSE\n \n-                /** This file is the entry point for browsers, re-export common elements. */\n+                (function(mod) {\n+                    if (true)\n+                        // CommonJS\n+                        mod(__webpack_require__( /*! ../../lib/codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"));\n+                    else {}\n+                })(function(CodeMirror) {\n+                    \"use strict\";\n+\n+                    CodeMirror.defineMode(\"javascript\", function(config, parserConfig) {\n+                        var indentUnit = config.indentUnit;\n+                        var statementIndent = parserConfig.statementIndent;\n+                        var jsonldMode = parserConfig.jsonld;\n+                        var jsonMode = parserConfig.json || jsonldMode;\n+                        var trackScope = parserConfig.trackScope !== false;\n+                        var isTS = parserConfig.typescript;\n+                        var wordRE = parserConfig.wordCharacters || /[\\w$\\xa1-\\uffff]/;\n \n-                /**\n-                 * Creates a disposable GraphQL over WebSocket client.\n-                 *\n-                 * @category Client\n-                 */\n-                function createClient(options) {\n-                    const {\n-                        url,\n-                        connectionParams,\n-                        lazy = true,\n-                        onNonLazyError = console.error,\n-                        lazyCloseTimeout = 0,\n-                        keepAlive = 0,\n-                        disablePong,\n-                        connectionAckWaitTimeout = 0,\n-                        retryAttempts = 5,\n-                        retryWait = async function randomisedExponentialBackoff(retries) {\n-                            let retryDelay = 1000; // start with 1s delay\n-                            for (let i = 0; i < retries; i++) {\n-                                retryDelay *= 2;\n+                        // Tokenizer\n+\n+                        var keywords = function() {\n+                            function kw(type) {\n+                                return {\n+                                    type: type,\n+                                    style: \"keyword\"\n+                                };\n                             }\n-                            await new Promise(resolve => setTimeout(resolve, retryDelay +\n-                                // add random timeout from 300ms to 3s\n-                                Math.floor(Math.random() * (3000 - 300) + 300)));\n-                        },\n-                        isFatalConnectionProblem = errOrCloseEvent =>\n-                        // non `CloseEvent`s are fatal by default\n-                        !isLikeCloseEvent(errOrCloseEvent),\n-                        on,\n-                        webSocketImpl,\n-                        /**\n-                         * Generates a v4 UUID to be used as the ID using `Math`\n-                         * as the random number generator. Supply your own generator\n-                         * in case you need more uniqueness.\n-                         *\n-                         * Reference: https://gist.github.com/jed/982883\n-                         */\n-                        generateID = function generateUUID() {\n-                            return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, c => {\n-                                const r = Math.random() * 16 | 0,\n-                                    v = c == 'x' ? r : r & 0x3 | 0x8;\n-                                return v.toString(16);\n-                            });\n-                        },\n-                        jsonMessageReplacer: replacer,\n-                        jsonMessageReviver: reviver\n-                    } = options;\n-                    let ws;\n-                    if (webSocketImpl) {\n-                        if (!isWebSocket(webSocketImpl)) {\n-                            throw new Error('Invalid WebSocket implementation provided');\n-                        }\n-                        ws = webSocketImpl;\n-                    } else if (typeof WebSocket !== 'undefined') {\n-                        ws = WebSocket;\n-                    } else if (typeof __webpack_require__.g !== 'undefined') {\n-                        ws = __webpack_require__.g.WebSocket ||\n-                            // @ts-expect-error: Support more browsers\n-                            __webpack_require__.g.MozWebSocket;\n-                    } else if (typeof window !== 'undefined') {\n-                        ws = window.WebSocket ||\n-                            // @ts-expect-error: Support more browsers\n-                            window.MozWebSocket;\n-                    }\n-                    if (!ws) throw new Error('WebSocket implementation missing');\n-                    const WebSocketImpl = ws;\n-                    // websocket status emitter, subscriptions are handled differently\n-                    const emitter = (() => {\n-                        const message = (() => {\n-                            const listeners = {};\n+                            var A = kw(\"keyword a\"),\n+                                B = kw(\"keyword b\"),\n+                                C = kw(\"keyword c\"),\n+                                D = kw(\"keyword d\");\n+                            var operator = kw(\"operator\"),\n+                                atom = {\n+                                    type: \"atom\",\n+                                    style: \"atom\"\n+                                };\n                             return {\n-                                on(id, listener) {\n-                                    listeners[id] = listener;\n-                                    return () => {\n-                                        delete listeners[id];\n-                                    };\n-                                },\n-                                emit(message) {\n-                                    var _a;\n-                                    if ('id' in message)(_a = listeners[message.id]) === null || _a === void 0 ? void 0 : _a.call(listeners, message);\n-                                }\n+                                \"if\": kw(\"if\"),\n+                                \"while\": A,\n+                                \"with\": A,\n+                                \"else\": B,\n+                                \"do\": B,\n+                                \"try\": B,\n+                                \"finally\": B,\n+                                \"return\": D,\n+                                \"break\": D,\n+                                \"continue\": D,\n+                                \"new\": kw(\"new\"),\n+                                \"delete\": C,\n+                                \"void\": C,\n+                                \"throw\": C,\n+                                \"debugger\": kw(\"debugger\"),\n+                                \"var\": kw(\"var\"),\n+                                \"const\": kw(\"var\"),\n+                                \"let\": kw(\"var\"),\n+                                \"function\": kw(\"function\"),\n+                                \"catch\": kw(\"catch\"),\n+                                \"for\": kw(\"for\"),\n+                                \"switch\": kw(\"switch\"),\n+                                \"case\": kw(\"case\"),\n+                                \"default\": kw(\"default\"),\n+                                \"in\": operator,\n+                                \"typeof\": operator,\n+                                \"instanceof\": operator,\n+                                \"true\": atom,\n+                                \"false\": atom,\n+                                \"null\": atom,\n+                                \"undefined\": atom,\n+                                \"NaN\": atom,\n+                                \"Infinity\": atom,\n+                                \"this\": kw(\"this\"),\n+                                \"class\": kw(\"class\"),\n+                                \"super\": kw(\"atom\"),\n+                                \"yield\": C,\n+                                \"export\": kw(\"export\"),\n+                                \"import\": kw(\"import\"),\n+                                \"extends\": C,\n+                                \"await\": C\n                             };\n-                        })();\n-                        const listeners = {\n-                            connecting: (on === null || on === void 0 ? void 0 : on.connecting) ? [on.connecting] : [],\n-                            opened: (on === null || on === void 0 ? void 0 : on.opened) ? [on.opened] : [],\n-                            connected: (on === null || on === void 0 ? void 0 : on.connected) ? [on.connected] : [],\n-                            ping: (on === null || on === void 0 ? void 0 : on.ping) ? [on.ping] : [],\n-                            pong: (on === null || on === void 0 ? void 0 : on.pong) ? [on.pong] : [],\n-                            message: (on === null || on === void 0 ? void 0 : on.message) ? [message.emit, on.message] : [message.emit],\n-                            closed: (on === null || on === void 0 ? void 0 : on.closed) ? [on.closed] : [],\n-                            error: (on === null || on === void 0 ? void 0 : on.error) ? [on.error] : []\n-                        };\n-                        return {\n-                            onMessage: message.on,\n-                            on(event, listener) {\n-                                const l = listeners[event];\n-                                l.push(listener);\n-                                return () => {\n-                                    l.splice(l.indexOf(listener), 1);\n-                                };\n-                            },\n-                            emit(event) {\n-                                for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n-                                    args[_key - 1] = arguments[_key];\n-                                }\n-                                // we copy the listeners so that unlistens dont \"pull the rug under our feet\"\n-                                for (const listener of [...listeners[event]]) {\n-                                    // @ts-expect-error: The args should fit\n-                                    listener(...args);\n-                                }\n-                            }\n-                        };\n-                    })();\n-                    // invokes the callback either when an error or closed event is emitted,\n-                    // first one that gets called prevails, other emissions are ignored\n-                    function errorOrClosed(cb) {\n-                        const listening = [\n-                            // errors are fatal and more critical than close events, throw them first\n-                            emitter.on('error', err => {\n-                                listening.forEach(unlisten => unlisten());\n-                                cb(err);\n-                            }),\n-                            // closes can be graceful and not fatal, throw them second (if error didnt throw)\n-                            emitter.on('closed', event => {\n-                                listening.forEach(unlisten => unlisten());\n-                                cb(event);\n-                            })\n-                        ];\n-                    }\n-                    let connecting,\n-                        locks = 0,\n-                        retrying = false,\n-                        retries = 0,\n-                        disposed = false;\n-                    async function connect() {\n-                        const [socket, throwOnClose] = await (connecting !== null && connecting !== void 0 ? connecting : connecting = new Promise((connected, denied) => (async () => {\n-                            if (retrying) {\n-                                await retryWait(retries);\n-                                // subscriptions might complete while waiting for retry\n-                                if (!locks) {\n-                                    connecting = undefined;\n-                                    return denied({\n-                                        code: 1000,\n-                                        reason: 'All Subscriptions Gone'\n-                                    });\n-                                }\n-                                retries++;\n+                        }();\n+                        var isOperatorChar = /[+\\-*&%=<>!?|~^@]/;\n+                        var isJsonldKeyword = /^@(context|id|value|language|type|container|list|set|reverse|index|base|vocab|graph)\"/;\n+\n+                        function readRegexp(stream) {\n+                            var escaped = false,\n+                                next,\n+                                inSet = false;\n+                            while ((next = stream.next()) != null) {\n+                                if (!escaped) {\n+                                    if (next == \"/\" && !inSet) return;\n+                                    if (next == \"[\") inSet = true;\n+                                    else if (inSet && next == \"]\") inSet = false;\n+                                }\n+                                escaped = !escaped && next == \"\\\\\";\n                             }\n-                            emitter.emit('connecting');\n-                            const socket = new WebSocketImpl(typeof url === 'function' ? await url() : url, _common.GRAPHQL_TRANSPORT_WS_PROTOCOL);\n-                            let connectionAckTimeout, queuedPing;\n+                        }\n \n-                            function enqueuePing() {\n-                                if (isFinite(keepAlive) && keepAlive > 0) {\n-                                    clearTimeout(queuedPing); // in case where a pong was received before a ping (this is valid behaviour)\n-                                    queuedPing = setTimeout(() => {\n-                                        if (socket.readyState === WebSocketImpl.OPEN) {\n-                                            socket.send((0, _common.stringifyMessage)({\n-                                                type: _common.MessageType.Ping\n-                                            }));\n-                                            emitter.emit('ping', false, undefined);\n-                                        }\n-                                    }, keepAlive);\n+                        // Used as scratch variables to communicate multiple values without\n+                        // consing up tons of objects.\n+                        var type, content;\n+\n+                        function ret(tp, style, cont) {\n+                            type = tp;\n+                            content = cont;\n+                            return style;\n+                        }\n+\n+                        function tokenBase(stream, state) {\n+                            var ch = stream.next();\n+                            if (ch == '\"' || ch == \"'\") {\n+                                state.tokenize = tokenString(ch);\n+                                return state.tokenize(stream, state);\n+                            } else if (ch == \".\" && stream.match(/^\\d[\\d_]*(?:[eE][+\\-]?[\\d_]+)?/)) {\n+                                return ret(\"number\", \"number\");\n+                            } else if (ch == \".\" && stream.match(\"..\")) {\n+                                return ret(\"spread\", \"meta\");\n+                            } else if (/[\\[\\]{}\\(\\),;\\:\\.]/.test(ch)) {\n+                                return ret(ch);\n+                            } else if (ch == \"=\" && stream.eat(\">\")) {\n+                                return ret(\"=>\", \"operator\");\n+                            } else if (ch == \"0\" && stream.match(/^(?:x[\\dA-Fa-f_]+|o[0-7_]+|b[01_]+)n?/)) {\n+                                return ret(\"number\", \"number\");\n+                            } else if (/\\d/.test(ch)) {\n+                                stream.match(/^[\\d_]*(?:n|(?:\\.[\\d_]*)?(?:[eE][+\\-]?[\\d_]+)?)?/);\n+                                return ret(\"number\", \"number\");\n+                            } else if (ch == \"/\") {\n+                                if (stream.eat(\"*\")) {\n+                                    state.tokenize = tokenComment;\n+                                    return tokenComment(stream, state);\n+                                } else if (stream.eat(\"/\")) {\n+                                    stream.skipToEnd();\n+                                    return ret(\"comment\", \"comment\");\n+                                } else if (expressionAllowed(stream, state, 1)) {\n+                                    readRegexp(stream);\n+                                    stream.match(/^\\b(([gimyus])(?![gimyus]*\\2))+\\b/);\n+                                    return ret(\"regexp\", \"string-2\");\n+                                } else {\n+                                    stream.eat(\"=\");\n+                                    return ret(\"operator\", \"operator\", stream.current());\n                                 }\n+                            } else if (ch == \"`\") {\n+                                state.tokenize = tokenQuasi;\n+                                return tokenQuasi(stream, state);\n+                            } else if (ch == \"#\" && stream.peek() == \"!\") {\n+                                stream.skipToEnd();\n+                                return ret(\"meta\", \"meta\");\n+                            } else if (ch == \"#\" && stream.eatWhile(wordRE)) {\n+                                return ret(\"variable\", \"property\");\n+                            } else if (ch == \"<\" && stream.match(\"!--\") || ch == \"-\" && stream.match(\"->\") && !/\\S/.test(stream.string.slice(0, stream.start))) {\n+                                stream.skipToEnd();\n+                                return ret(\"comment\", \"comment\");\n+                            } else if (isOperatorChar.test(ch)) {\n+                                if (ch != \">\" || !state.lexical || state.lexical.type != \">\") {\n+                                    if (stream.eat(\"=\")) {\n+                                        if (ch == \"!\" || ch == \"=\") stream.eat(\"=\");\n+                                    } else if (/[<>*+\\-|&?]/.test(ch)) {\n+                                        stream.eat(ch);\n+                                        if (ch == \">\") stream.eat(ch);\n+                                    }\n+                                }\n+                                if (ch == \"?\" && stream.eat(\".\")) return ret(\".\");\n+                                return ret(\"operator\", \"operator\", stream.current());\n+                            } else if (wordRE.test(ch)) {\n+                                stream.eatWhile(wordRE);\n+                                var word = stream.current();\n+                                if (state.lastType != \".\") {\n+                                    if (keywords.propertyIsEnumerable(word)) {\n+                                        var kw = keywords[word];\n+                                        return ret(kw.type, kw.style, word);\n+                                    }\n+                                    if (word == \"async\" && stream.match(/^(\\s|\\/\\*([^*]|\\*(?!\\/))*?\\*\\/)*[\\[\\(\\w]/, false)) return ret(\"async\", \"keyword\", word);\n+                                }\n+                                return ret(\"variable\", \"variable\", word);\n                             }\n-                            errorOrClosed(errOrEvent => {\n-                                connecting = undefined;\n-                                clearTimeout(connectionAckTimeout);\n-                                clearTimeout(queuedPing);\n-                                denied(errOrEvent);\n-                            });\n-                            socket.onerror = err => emitter.emit('error', err);\n-                            socket.onclose = event => emitter.emit('closed', event);\n-                            socket.onopen = async () => {\n-                                try {\n-                                    emitter.emit('opened', socket);\n-                                    const payload = typeof connectionParams === 'function' ? await connectionParams() : connectionParams;\n-                                    socket.send((0, _common.stringifyMessage)(payload ? {\n-                                        type: _common.MessageType.ConnectionInit,\n-                                        payload\n-                                    } : {\n-                                        type: _common.MessageType.ConnectionInit\n-                                        // payload is completely absent if not provided\n-                                    }, replacer));\n-                                    if (isFinite(connectionAckWaitTimeout) && connectionAckWaitTimeout > 0) {\n-                                        connectionAckTimeout = setTimeout(() => {\n-                                            socket.close(_common.CloseCode.ConnectionAcknowledgementTimeout, 'Connection acknowledgement timeout');\n-                                        }, connectionAckWaitTimeout);\n-                                    }\n-                                    enqueuePing(); // enqueue ping (noop if disabled)\n-                                } catch (err) {\n-                                    emitter.emit('error', err);\n-                                    socket.close(_common.CloseCode.InternalClientError, (0, _utils.limitCloseReason)(err instanceof Error ? err.message : new Error(err).message, 'Internal client error'));\n+                        }\n+\n+                        function tokenString(quote) {\n+                            return function(stream, state) {\n+                                var escaped = false,\n+                                    next;\n+                                if (jsonldMode && stream.peek() == \"@\" && stream.match(isJsonldKeyword)) {\n+                                    state.tokenize = tokenBase;\n+                                    return ret(\"jsonld-keyword\", \"meta\");\n+                                }\n+                                while ((next = stream.next()) != null) {\n+                                    if (next == quote && !escaped) break;\n+                                    escaped = !escaped && next == \"\\\\\";\n                                 }\n+                                if (!escaped) state.tokenize = tokenBase;\n+                                return ret(\"string\", \"string\");\n                             };\n-                            let acknowledged = false;\n-                            socket.onmessage = _ref => {\n-                                let {\n-                                    data\n-                                } = _ref;\n-                                try {\n-                                    const message = (0, _common.parseMessage)(data, reviver);\n-                                    emitter.emit('message', message);\n-                                    if (message.type === 'ping' || message.type === 'pong') {\n-                                        emitter.emit(message.type, true, message.payload); // received\n-                                        if (message.type === 'pong') {\n-                                            enqueuePing(); // enqueue next ping (noop if disabled)\n-                                        } else if (!disablePong) {\n-                                            // respond with pong on ping\n-                                            socket.send((0, _common.stringifyMessage)(message.payload ? {\n-                                                type: _common.MessageType.Pong,\n-                                                payload: message.payload\n-                                            } : {\n-                                                type: _common.MessageType.Pong\n-                                                // payload is completely absent if not provided\n-                                            }));\n+                        }\n \n-                                            emitter.emit('pong', false, message.payload);\n-                                        }\n-                                        return; // ping and pongs can be received whenever\n-                                    }\n+                        function tokenComment(stream, state) {\n+                            var maybeEnd = false,\n+                                ch;\n+                            while (ch = stream.next()) {\n+                                if (ch == \"/\" && maybeEnd) {\n+                                    state.tokenize = tokenBase;\n+                                    break;\n+                                }\n+                                maybeEnd = ch == \"*\";\n+                            }\n+                            return ret(\"comment\", \"comment\");\n+                        }\n \n-                                    if (acknowledged) return; // already connected and acknowledged\n-                                    if (message.type !== _common.MessageType.ConnectionAck) throw new Error(`First message cannot be of type ${message.type}`);\n-                                    clearTimeout(connectionAckTimeout);\n-                                    acknowledged = true;\n-                                    emitter.emit('connected', socket, message.payload); // connected = socket opened + acknowledged\n-                                    retrying = false; // future lazy connects are not retries\n-                                    retries = 0; // reset the retries on connect\n-                                    connected([socket, new Promise((_, reject) => errorOrClosed(reject))]);\n-                                } catch (err) {\n-                                    socket.onmessage = null; // stop reading messages as soon as reading breaks once\n-                                    emitter.emit('error', err);\n-                                    socket.close(_common.CloseCode.BadResponse, (0, _utils.limitCloseReason)(err instanceof Error ? err.message : new Error(err).message, 'Bad response'));\n+                        function tokenQuasi(stream, state) {\n+                            var escaped = false,\n+                                next;\n+                            while ((next = stream.next()) != null) {\n+                                if (!escaped && (next == \"`\" || next == \"$\" && stream.eat(\"{\"))) {\n+                                    state.tokenize = tokenBase;\n+                                    break;\n                                 }\n-                            };\n-                        })()));\n-                        // if the provided socket is in a closing state, wait for the throw on close\n-                        if (socket.readyState === WebSocketImpl.CLOSING) await throwOnClose;\n-                        let release = () => {\n-                            // releases this connection\n-                        };\n-                        const released = new Promise(resolve => release = resolve);\n-                        return [socket, release, Promise.race([\n-                            // wait for\n-                            released.then(() => {\n-                                if (!locks) {\n-                                    // and if no more locks are present, complete the connection\n-                                    const complete = () => socket.close(1000, 'Normal Closure');\n-                                    if (isFinite(lazyCloseTimeout) && lazyCloseTimeout > 0) {\n-                                        // if the keepalive is set, allow for the specified calmdown time and\n-                                        // then complete. but only if no lock got created in the meantime and\n-                                        // if the socket is still open\n-                                        setTimeout(() => {\n-                                            if (!locks && socket.readyState === WebSocketImpl.OPEN) complete();\n-                                        }, lazyCloseTimeout);\n-                                    } else {\n-                                        // otherwise complete immediately\n-                                        complete();\n+                                escaped = !escaped && next == \"\\\\\";\n+                            }\n+                            return ret(\"quasi\", \"string-2\", stream.current());\n+                        }\n+                        var brackets = \"([{}])\";\n+                        // This is a crude lookahead trick to try and notice that we're\n+                        // parsing the argument patterns for a fat-arrow function before we\n+                        // actually hit the arrow token. It only works if the arrow is on\n+                        // the same line as the arguments and there's no strange noise\n+                        // (comments) in between. Fallback is to only notice when we hit the\n+                        // arrow, and not declare the arguments as locals for the arrow\n+                        // body.\n+                        function findFatArrow(stream, state) {\n+                            if (state.fatArrowAt) state.fatArrowAt = null;\n+                            var arrow = stream.string.indexOf(\"=>\", stream.start);\n+                            if (arrow < 0) return;\n+                            if (isTS) {\n+                                // Try to skip TypeScript return type declarations after the arguments\n+                                var m = /:\\s*(?:\\w+(?:<[^>]*>|\\[\\])?|\\{[^}]*\\})\\s*$/.exec(stream.string.slice(stream.start, arrow));\n+                                if (m) arrow = m.index;\n+                            }\n+                            var depth = 0,\n+                                sawSomething = false;\n+                            for (var pos = arrow - 1; pos >= 0; --pos) {\n+                                var ch = stream.string.charAt(pos);\n+                                var bracket = brackets.indexOf(ch);\n+                                if (bracket >= 0 && bracket < 3) {\n+                                    if (!depth) {\n+                                        ++pos;\n+                                        break;\n                                     }\n-                                }\n-                            }),\n-                            // or\n-                            throwOnClose\n-                        ])];\n-                    }\n-                    /**\n-                     * Checks the `connect` problem and evaluates if the client should retry.\n-                     */\n-                    function shouldRetryConnectOrThrow(errOrCloseEvent) {\n-                        // some close codes are worth reporting immediately\n-                        if (isLikeCloseEvent(errOrCloseEvent) && (isFatalInternalCloseCode(errOrCloseEvent.code) || [_common.CloseCode.InternalServerError, _common.CloseCode.InternalClientError, _common.CloseCode.BadRequest, _common.CloseCode.BadResponse, _common.CloseCode.Unauthorized,\n-                                // CloseCode.Forbidden, might grant access out after retry\n-                                _common.CloseCode.SubprotocolNotAcceptable,\n-                                // CloseCode.ConnectionInitialisationTimeout, might not time out after retry\n-                                // CloseCode.ConnectionAcknowledgementTimeout, might not time out after retry\n-                                _common.CloseCode.SubscriberAlreadyExists, _common.CloseCode.TooManyInitialisationRequests\n-                            ].includes(errOrCloseEvent.code))) throw errOrCloseEvent;\n-                        // client was disposed, no retries should proceed regardless\n-                        if (disposed) return false;\n-                        // normal closure (possibly all subscriptions have completed)\n-                        // if no locks were acquired in the meantime, shouldnt try again\n-                        if (isLikeCloseEvent(errOrCloseEvent) && errOrCloseEvent.code === 1000) return locks > 0;\n-                        // retries are not allowed or we tried to many times, report error\n-                        if (!retryAttempts || retries >= retryAttempts) throw errOrCloseEvent;\n-                        // throw fatal connection problems immediately\n-                        if (isFatalConnectionProblem(errOrCloseEvent)) throw errOrCloseEvent;\n-                        // looks good, start retrying\n-                        return retrying = true;\n-                    }\n-                    // in non-lazy (hot?) mode always hold one connection lock to persist the socket\n-                    if (!lazy) {\n-                        (async () => {\n-                            locks++;\n-                            for (;;) {\n-                                try {\n-                                    const [, , throwOnClose] = await connect();\n-                                    await throwOnClose; // will always throw because releaser is not used\n-                                } catch (errOrCloseEvent) {\n-                                    try {\n-                                        if (!shouldRetryConnectOrThrow(errOrCloseEvent)) return;\n-                                    } catch (errOrCloseEvent) {\n-                                        // report thrown error, no further retries\n-                                        return onNonLazyError === null || onNonLazyError === void 0 ? void 0 : onNonLazyError(errOrCloseEvent);\n+                                    if (--depth == 0) {\n+                                        if (ch == \"(\") sawSomething = true;\n+                                        break;\n                                     }\n-                                }\n-                            }\n-                        })();\n-                    }\n-                    return {\n-                        on: emitter.on,\n-                        subscribe(payload, sink) {\n-                            const id = generateID();\n-                            let done = false,\n-                                errored = false,\n-                                releaser = () => {\n-                                    // for handling completions before connect\n-                                    locks--;\n-                                    done = true;\n-                                };\n-                            (async () => {\n-                                locks++;\n-                                for (;;) {\n-                                    try {\n-                                        const [socket, release, waitForReleaseOrThrowOnClose] = await connect();\n-                                        // if done while waiting for connect, release the connection lock right away\n-                                        if (done) return release();\n-                                        const unlisten = emitter.onMessage(id, message => {\n-                                            switch (message.type) {\n-                                                case _common.MessageType.Next: {\n-                                                    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n-                                                    sink.next(message.payload);\n-                                                    return;\n-                                                }\n-                                                case _common.MessageType.Error: {\n-                                                    errored = true, done = true;\n-                                                    sink.error(message.payload);\n-                                                    releaser();\n-                                                    return;\n-                                                }\n-                                                case _common.MessageType.Complete: {\n-                                                    done = true;\n-                                                    releaser(); // release completes the sink\n-                                                    return;\n-                                                }\n-                                            }\n-                                        });\n-                                        socket.send((0, _common.stringifyMessage)({\n-                                            id,\n-                                            type: _common.MessageType.Subscribe,\n-                                            payload\n-                                        }, replacer));\n-                                        releaser = () => {\n-                                            if (!done && socket.readyState === WebSocketImpl.OPEN)\n-                                                // if not completed already and socket is open, send complete message to server on release\n-                                                socket.send((0, _common.stringifyMessage)({\n-                                                    id,\n-                                                    type: _common.MessageType.Complete\n-                                                }, replacer));\n-                                            locks--;\n-                                            done = true;\n-                                            release();\n-                                        };\n-                                        // either the releaser will be called, connection completed and\n-                                        // the promise resolved or the socket closed and the promise rejected.\n-                                        // whatever happens though, we want to stop listening for messages\n-                                        await waitForReleaseOrThrowOnClose.finally(unlisten);\n-                                        return; // completed, shouldnt try again\n-                                    } catch (errOrCloseEvent) {\n-                                        if (!shouldRetryConnectOrThrow(errOrCloseEvent)) return;\n+                                } else if (bracket >= 3 && bracket < 6) {\n+                                    ++depth;\n+                                } else if (wordRE.test(ch)) {\n+                                    sawSomething = true;\n+                                } else if (/[\"'\\/`]/.test(ch)) {\n+                                    for (;; --pos) {\n+                                        if (pos == 0) return;\n+                                        var next = stream.string.charAt(pos - 1);\n+                                        if (next == ch && stream.string.charAt(pos - 2) != \"\\\\\") {\n+                                            pos--;\n+                                            break;\n+                                        }\n                                     }\n+                                } else if (sawSomething && !depth) {\n+                                    ++pos;\n+                                    break;\n                                 }\n-                            })().then(() => {\n-                                    // delivering either an error or a complete terminates the sequence\n-                                    if (!errored) sink.complete();\n-                                }) // resolves on release or normal closure\n-                                .catch(err => {\n-                                    sink.error(err);\n-                                }); // rejects on close events and errors\n-                            return () => {\n-                                // dispose only of active subscriptions\n-                                if (!done) releaser();\n-                            };\n-                        },\n-                        async dispose() {\n-                            disposed = true;\n-                            if (connecting) {\n-                                // if there is a connection, close it\n-                                const [socket] = await connecting;\n-                                socket.close(1000, 'Normal Closure');\n                             }\n+                            if (sawSomething && !depth) state.fatArrowAt = pos;\n                         }\n-                    };\n-                }\n \n-                function isLikeCloseEvent(val) {\n-                    return (0, _utils.isObject)(val) && 'code' in val && 'reason' in val;\n-                }\n+                        // Parser\n \n-                function isFatalInternalCloseCode(code) {\n-                    if ([1000, 1001, 1006, 1005, 1012, 1013, 1013 // Bad Gateway\n-                        ].includes(code)) return false;\n-                    // all other internal errors are fatal\n-                    return code >= 1000 && code <= 1999;\n-                }\n+                        var atomicTypes = {\n+                            \"atom\": true,\n+                            \"number\": true,\n+                            \"variable\": true,\n+                            \"string\": true,\n+                            \"regexp\": true,\n+                            \"this\": true,\n+                            \"import\": true,\n+                            \"jsonld-keyword\": true\n+                        };\n \n-                function isWebSocket(val) {\n-                    return typeof val === 'function' && 'constructor' in val && 'CLOSED' in val && 'CLOSING' in val && 'CONNECTING' in val && 'OPEN' in val;\n-                }\n+                        function JSLexical(indented, column, type, align, prev, info) {\n+                            this.indented = indented;\n+                            this.column = column;\n+                            this.type = type;\n+                            this.prev = prev;\n+                            this.info = info;\n+                            if (align != null) this.align = align;\n+                        }\n \n-                /***/\n-            }),\n+                        function inScope(state, varname) {\n+                            if (!trackScope) return false;\n+                            for (var v = state.localVars; v; v = v.next)\n+                                if (v.name == varname) return true;\n+                            for (var cx = state.context; cx; cx = cx.prev) {\n+                                for (var v = cx.vars; v; v = v.next)\n+                                    if (v.name == varname) return true;\n+                            }\n+                        }\n \n-        /***/\n-        \"../../../node_modules/graphql-ws/lib/common.mjs\":\n-            /*!*******************************************************!*\\\n-              !*** ../../../node_modules/graphql-ws/lib/common.mjs ***!\n-              \\*******************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                        function parseJS(state, style, type, content, stream) {\n+                            var cc = state.cc;\n+                            // Communicate our context to the combinators.\n+                            // (Less wasteful than consing up a hundred closures on every call.)\n+                            cx.state = state;\n+                            cx.stream = stream;\n+                            cx.marked = null, cx.cc = cc;\n+                            cx.style = style;\n+                            if (!state.lexical.hasOwnProperty(\"align\")) state.lexical.align = true;\n+                            while (true) {\n+                                var combinator = cc.length ? cc.pop() : jsonMode ? expression : statement;\n+                                if (combinator(type, content)) {\n+                                    while (cc.length && cc[cc.length - 1].lex) cc.pop()();\n+                                    if (cx.marked) return cx.marked;\n+                                    if (type == \"variable\" && inScope(state, content)) return \"variable-2\";\n+                                    return style;\n+                                }\n+                            }\n+                        }\n \n+                        // Combinator utils\n \n+                        var cx = {\n+                            state: null,\n+                            column: null,\n+                            marked: null,\n+                            cc: null\n+                        };\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.MessageType = exports.GRAPHQL_TRANSPORT_WS_PROTOCOL = exports.CloseCode = void 0;\n-                exports.isMessage = isMessage;\n-                exports.parseMessage = parseMessage;\n-                exports.stringifyMessage = stringifyMessage;\n-                var _utils = __webpack_require__( /*! ./utils.mjs */ \"../../../node_modules/graphql-ws/lib/utils.mjs\");\n-                /**\n-                 *\n-                 * common\n-                 *\n-                 */\n+                        function pass() {\n+                            for (var i = arguments.length - 1; i >= 0; i--) cx.cc.push(arguments[i]);\n+                        }\n \n-                /**\n-                 * The WebSocket sub-protocol used for the [GraphQL over WebSocket Protocol](/PROTOCOL.md).\n-                 *\n-                 * @category Common\n-                 */\n-                const GRAPHQL_TRANSPORT_WS_PROTOCOL = 'graphql-transport-ws';\n-                /**\n-                 * `graphql-ws` expected and standard close codes of the [GraphQL over WebSocket Protocol](/PROTOCOL.md).\n-                 *\n-                 * @category Common\n-                 */\n-                exports.GRAPHQL_TRANSPORT_WS_PROTOCOL = GRAPHQL_TRANSPORT_WS_PROTOCOL;\n-                var CloseCode;\n-                exports.CloseCode = CloseCode;\n-                (function(CloseCode) {\n-                    CloseCode[CloseCode[\"InternalServerError\"] = 4500] = \"InternalServerError\";\n-                    CloseCode[CloseCode[\"InternalClientError\"] = 4005] = \"InternalClientError\";\n-                    CloseCode[CloseCode[\"BadRequest\"] = 4400] = \"BadRequest\";\n-                    CloseCode[CloseCode[\"BadResponse\"] = 4004] = \"BadResponse\";\n-                    /** Tried subscribing before connect ack */\n-                    CloseCode[CloseCode[\"Unauthorized\"] = 4401] = \"Unauthorized\";\n-                    CloseCode[CloseCode[\"Forbidden\"] = 4403] = \"Forbidden\";\n-                    CloseCode[CloseCode[\"SubprotocolNotAcceptable\"] = 4406] = \"SubprotocolNotAcceptable\";\n-                    CloseCode[CloseCode[\"ConnectionInitialisationTimeout\"] = 4408] = \"ConnectionInitialisationTimeout\";\n-                    CloseCode[CloseCode[\"ConnectionAcknowledgementTimeout\"] = 4504] = \"ConnectionAcknowledgementTimeout\";\n-                    /** Subscriber distinction is very important */\n-                    CloseCode[CloseCode[\"SubscriberAlreadyExists\"] = 4409] = \"SubscriberAlreadyExists\";\n-                    CloseCode[CloseCode[\"TooManyInitialisationRequests\"] = 4429] = \"TooManyInitialisationRequests\";\n-                })(CloseCode || (exports.CloseCode = CloseCode = {}));\n-                /**\n-                 * Types of messages allowed to be sent by the client/server over the WS protocol.\n-                 *\n-                 * @category Common\n-                 */\n-                var MessageType;\n-                exports.MessageType = MessageType;\n-                (function(MessageType) {\n-                    MessageType[\"ConnectionInit\"] = \"connection_init\";\n-                    MessageType[\"ConnectionAck\"] = \"connection_ack\";\n-                    MessageType[\"Ping\"] = \"ping\";\n-                    MessageType[\"Pong\"] = \"pong\";\n-                    MessageType[\"Subscribe\"] = \"subscribe\";\n-                    MessageType[\"Next\"] = \"next\";\n-                    MessageType[\"Error\"] = \"error\";\n-                    MessageType[\"Complete\"] = \"complete\";\n-                })(MessageType || (exports.MessageType = MessageType = {}));\n-                /**\n-                 * Checks if the provided value is a message.\n-                 *\n-                 * @category Common\n-                 */\n-                function isMessage(val) {\n-                    if ((0, _utils.isObject)(val)) {\n-                        // all messages must have the `type` prop\n-                        if (!(0, _utils.hasOwnStringProperty)(val, 'type')) {\n+                        function cont() {\n+                            pass.apply(null, arguments);\n+                            return true;\n+                        }\n+\n+                        function inList(name, list) {\n+                            for (var v = list; v; v = v.next)\n+                                if (v.name == name) return true;\n                             return false;\n                         }\n-                        // validate other properties depending on the `type`\n-                        switch (val.type) {\n-                            case MessageType.ConnectionInit:\n-                                // the connection init message can have optional payload object\n-                                return !(0, _utils.hasOwnProperty)(val, 'payload') || val.payload === undefined || (0, _utils.isObject)(val.payload);\n-                            case MessageType.ConnectionAck:\n-                            case MessageType.Ping:\n-                            case MessageType.Pong:\n-                                // the connection ack, ping and pong messages can have optional payload object too\n-                                return !(0, _utils.hasOwnProperty)(val, 'payload') || val.payload === undefined || (0, _utils.isObject)(val.payload);\n-                            case MessageType.Subscribe:\n-                                return (0, _utils.hasOwnStringProperty)(val, 'id') && (0, _utils.hasOwnObjectProperty)(val, 'payload') && (!(0, _utils.hasOwnProperty)(val.payload, 'operationName') || val.payload.operationName === undefined || val.payload.operationName === null || typeof val.payload.operationName === 'string') && (0, _utils.hasOwnStringProperty)(val.payload, 'query') && (!(0, _utils.hasOwnProperty)(val.payload, 'variables') || val.payload.variables === undefined || val.payload.variables === null || (0, _utils.hasOwnObjectProperty)(val.payload, 'variables')) && (!(0, _utils.hasOwnProperty)(val.payload, 'extensions') || val.payload.extensions === undefined || val.payload.extensions === null || (0, _utils.hasOwnObjectProperty)(val.payload, 'extensions'));\n-                            case MessageType.Next:\n-                                return (0, _utils.hasOwnStringProperty)(val, 'id') && (0, _utils.hasOwnObjectProperty)(val, 'payload');\n-                            case MessageType.Error:\n-                                return (0, _utils.hasOwnStringProperty)(val, 'id') && (0, _utils.areGraphQLErrors)(val.payload);\n-                            case MessageType.Complete:\n-                                return (0, _utils.hasOwnStringProperty)(val, 'id');\n-                            default:\n-                                return false;\n+\n+                        function register(varname) {\n+                            var state = cx.state;\n+                            cx.marked = \"def\";\n+                            if (!trackScope) return;\n+                            if (state.context) {\n+                                if (state.lexical.info == \"var\" && state.context && state.context.block) {\n+                                    // FIXME function decls are also not block scoped\n+                                    var newContext = registerVarScoped(varname, state.context);\n+                                    if (newContext != null) {\n+                                        state.context = newContext;\n+                                        return;\n+                                    }\n+                                } else if (!inList(varname, state.localVars)) {\n+                                    state.localVars = new Var(varname, state.localVars);\n+                                    return;\n+                                }\n+                            }\n+                            // Fall through means this is global\n+                            if (parserConfig.globalVars && !inList(varname, state.globalVars)) state.globalVars = new Var(varname, state.globalVars);\n                         }\n-                    }\n-                    return false;\n-                }\n-                /**\n-                 * Parses the raw websocket message data to a valid message.\n-                 *\n-                 * @category Common\n-                 */\n-                function parseMessage(data, reviver) {\n-                    if (isMessage(data)) {\n-                        return data;\n-                    }\n-                    if (typeof data !== 'string') {\n-                        throw new Error('Message not parsable');\n-                    }\n-                    const message = JSON.parse(data, reviver);\n-                    if (!isMessage(message)) {\n-                        throw new Error('Invalid message');\n-                    }\n-                    return message;\n-                }\n-                /**\n-                 * Stringifies a valid message ready to be sent through the socket.\n-                 *\n-                 * @category Common\n-                 */\n-                function stringifyMessage(msg, replacer) {\n-                    if (!isMessage(msg)) {\n-                        throw new Error('Cannot stringify invalid message');\n-                    }\n-                    return JSON.stringify(msg, replacer);\n-                }\n \n-                /***/\n-            }),\n+                        function registerVarScoped(varname, context) {\n+                            if (!context) {\n+                                return null;\n+                            } else if (context.block) {\n+                                var inner = registerVarScoped(varname, context.prev);\n+                                if (!inner) return null;\n+                                if (inner == context.prev) return context;\n+                                return new Context(inner, context.vars, true);\n+                            } else if (inList(varname, context.vars)) {\n+                                return context;\n+                            } else {\n+                                return new Context(context.prev, new Var(varname, context.vars), false);\n+                            }\n+                        }\n \n-        /***/\n-        \"../../../node_modules/graphql-ws/lib/index.js\":\n-            /*!*****************************************************!*\\\n-              !*** ../../../node_modules/graphql-ws/lib/index.js ***!\n-              \\*****************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                        function isModifier(name) {\n+                            return name == \"public\" || name == \"private\" || name == \"protected\" || name == \"abstract\" || name == \"readonly\";\n+                        }\n \n+                        // Combinators\n \n+                        function Context(prev, vars, block) {\n+                            this.prev = prev;\n+                            this.vars = vars;\n+                            this.block = block;\n+                        }\n \n-                var __createBinding = void 0 && (void 0).__createBinding || (Object.create ? function(o, m, k, k2) {\n-                    if (k2 === undefined) k2 = k;\n-                    Object.defineProperty(o, k2, {\n-                        enumerable: true,\n-                        get: function() {\n-                            return m[k];\n+                        function Var(name, next) {\n+                            this.name = name;\n+                            this.next = next;\n                         }\n-                    });\n-                } : function(o, m, k, k2) {\n-                    if (k2 === undefined) k2 = k;\n-                    o[k2] = m[k];\n-                });\n-                var __exportStar = void 0 && (void 0).__exportStar || function(m, exports) {\n-                    for (var p in m)\n-                        if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);\n-                };\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                __exportStar(__webpack_require__( /*! ./client */ \"../../../node_modules/graphql-ws/lib/client.mjs\"), exports);\n-                __exportStar(__webpack_require__( /*! ./server */ \"../../../node_modules/graphql-ws/lib/server.mjs\"), exports);\n-                __exportStar(__webpack_require__( /*! ./common */ \"../../../node_modules/graphql-ws/lib/common.mjs\"), exports);\n+                        var defaultVars = new Var(\"this\", new Var(\"arguments\", null));\n \n-                /***/\n-            }),\n+                        function pushcontext() {\n+                            cx.state.context = new Context(cx.state.context, cx.state.localVars, false);\n+                            cx.state.localVars = defaultVars;\n+                        }\n \n-        /***/\n-        \"../../../node_modules/graphql-ws/lib/server.mjs\":\n-            /*!*******************************************************!*\\\n-              !*** ../../../node_modules/graphql-ws/lib/server.mjs ***!\n-              \\*******************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                        function pushblockcontext() {\n+                            cx.state.context = new Context(cx.state.context, cx.state.localVars, true);\n+                            cx.state.localVars = null;\n+                        }\n+                        pushcontext.lex = pushblockcontext.lex = true;\n \n+                        function popcontext() {\n+                            cx.state.localVars = cx.state.context.vars;\n+                            cx.state.context = cx.state.context.prev;\n+                        }\n+                        popcontext.lex = true;\n \n+                        function pushlex(type, info) {\n+                            var result = function() {\n+                                var state = cx.state,\n+                                    indent = state.indented;\n+                                if (state.lexical.type == \"stat\") indent = state.lexical.indented;\n+                                else\n+                                    for (var outer = state.lexical; outer && outer.type == \")\" && outer.align; outer = outer.prev) indent = outer.indented;\n+                                state.lexical = new JSLexical(indent, cx.stream.column(), type, null, state.lexical, info);\n+                            };\n+                            result.lex = true;\n+                            return result;\n+                        }\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.makeServer = makeServer;\n-                var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n-                var _common = __webpack_require__( /*! ./common.mjs */ \"../../../node_modules/graphql-ws/lib/common.mjs\");\n-                var _utils = __webpack_require__( /*! ./utils.mjs */ \"../../../node_modules/graphql-ws/lib/utils.mjs\");\n-                /**\n-                 *\n-                 * server\n-                 *\n-                 */\n-                var __asyncValues = void 0 && (void 0).__asyncValues || function(o) {\n-                    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n-                    var m = o[Symbol.asyncIterator],\n-                        i;\n-                    return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function() {\n-                        return this;\n-                    }, i);\n+                        function poplex() {\n+                            var state = cx.state;\n+                            if (state.lexical.prev) {\n+                                if (state.lexical.type == \")\") state.indented = state.lexical.indented;\n+                                state.lexical = state.lexical.prev;\n+                            }\n+                        }\n+                        poplex.lex = true;\n+\n+                        function expect(wanted) {\n+                            function exp(type) {\n+                                if (type == wanted) return cont();\n+                                else if (wanted == \";\" || type == \"}\" || type == \")\" || type == \"]\") return pass();\n+                                else return cont(exp);\n+                            };\n+                            return exp;\n+                        }\n \n-                    function verb(n) {\n-                        i[n] = o[n] && function(v) {\n-                            return new Promise(function(resolve, reject) {\n-                                v = o[n](v), settle(resolve, reject, v.done, v.value);\n-                            });\n-                        };\n-                    }\n+                        function statement(type, value) {\n+                            if (type == \"var\") return cont(pushlex(\"vardef\", value), vardef, expect(\";\"), poplex);\n+                            if (type == \"keyword a\") return cont(pushlex(\"form\"), parenExpr, statement, poplex);\n+                            if (type == \"keyword b\") return cont(pushlex(\"form\"), statement, poplex);\n+                            if (type == \"keyword d\") return cx.stream.match(/^\\s*$/, false) ? cont() : cont(pushlex(\"stat\"), maybeexpression, expect(\";\"), poplex);\n+                            if (type == \"debugger\") return cont(expect(\";\"));\n+                            if (type == \"{\") return cont(pushlex(\"}\"), pushblockcontext, block, poplex, popcontext);\n+                            if (type == \";\") return cont();\n+                            if (type == \"if\") {\n+                                if (cx.state.lexical.info == \"else\" && cx.state.cc[cx.state.cc.length - 1] == poplex) cx.state.cc.pop()();\n+                                return cont(pushlex(\"form\"), parenExpr, statement, poplex, maybeelse);\n+                            }\n+                            if (type == \"function\") return cont(functiondef);\n+                            if (type == \"for\") return cont(pushlex(\"form\"), pushblockcontext, forspec, statement, popcontext, poplex);\n+                            if (type == \"class\" || isTS && value == \"interface\") {\n+                                cx.marked = \"keyword\";\n+                                return cont(pushlex(\"form\", type == \"class\" ? type : value), className, poplex);\n+                            }\n+                            if (type == \"variable\") {\n+                                if (isTS && value == \"declare\") {\n+                                    cx.marked = \"keyword\";\n+                                    return cont(statement);\n+                                } else if (isTS && (value == \"module\" || value == \"enum\" || value == \"type\") && cx.stream.match(/^\\s*\\w/, false)) {\n+                                    cx.marked = \"keyword\";\n+                                    if (value == \"enum\") return cont(enumdef);\n+                                    else if (value == \"type\") return cont(typename, expect(\"operator\"), typeexpr, expect(\";\"));\n+                                    else return cont(pushlex(\"form\"), pattern, expect(\"{\"), pushlex(\"}\"), block, poplex, poplex);\n+                                } else if (isTS && value == \"namespace\") {\n+                                    cx.marked = \"keyword\";\n+                                    return cont(pushlex(\"form\"), expression, statement, poplex);\n+                                } else if (isTS && value == \"abstract\") {\n+                                    cx.marked = \"keyword\";\n+                                    return cont(statement);\n+                                } else {\n+                                    return cont(pushlex(\"stat\"), maybelabel);\n+                                }\n+                            }\n+                            if (type == \"switch\") return cont(pushlex(\"form\"), parenExpr, expect(\"{\"), pushlex(\"}\", \"switch\"), pushblockcontext, block, poplex, poplex, popcontext);\n+                            if (type == \"case\") return cont(expression, expect(\":\"));\n+                            if (type == \"default\") return cont(expect(\":\"));\n+                            if (type == \"catch\") return cont(pushlex(\"form\"), pushcontext, maybeCatchBinding, statement, poplex, popcontext);\n+                            if (type == \"export\") return cont(pushlex(\"stat\"), afterExport, poplex);\n+                            if (type == \"import\") return cont(pushlex(\"stat\"), afterImport, poplex);\n+                            if (type == \"async\") return cont(statement);\n+                            if (value == \"@\") return cont(expression, statement);\n+                            return pass(pushlex(\"stat\"), expression, expect(\";\"), poplex);\n+                        }\n \n-                    function settle(resolve, reject, d, v) {\n-                        Promise.resolve(v).then(function(v) {\n-                            resolve({\n-                                value: v,\n-                                done: d\n-                            });\n-                        }, reject);\n-                    }\n-                };\n-                /**\n-                 * Makes a Protocol complient WebSocket GraphQL server. The server\n-                 * is actually an API which is to be used with your favourite WebSocket\n-                 * server library!\n-                 *\n-                 * Read more about the Protocol in the PROTOCOL.md documentation file.\n-                 *\n-                 * @category Server\n-                 */\n-                function makeServer(options) {\n-                    const {\n-                        schema,\n-                        context,\n-                        roots,\n-                        validate,\n-                        execute,\n-                        subscribe,\n-                        connectionInitWaitTimeout = 3000,\n-                        // 3 seconds\n-                        onConnect,\n-                        onDisconnect,\n-                        onClose,\n-                        onSubscribe,\n-                        onOperation,\n-                        onNext,\n-                        onError,\n-                        onComplete,\n-                        jsonMessageReviver: reviver,\n-                        jsonMessageReplacer: replacer\n-                    } = options;\n-                    return {\n-                        opened(socket, extra) {\n-                            const ctx = {\n-                                connectionInitReceived: false,\n-                                acknowledged: false,\n-                                subscriptions: {},\n-                                extra\n-                            };\n-                            if (socket.protocol !== _common.GRAPHQL_TRANSPORT_WS_PROTOCOL) {\n-                                socket.close(_common.CloseCode.SubprotocolNotAcceptable, 'Subprotocol not acceptable');\n-                                return async (code, reason) => {\n-                                    /* nothing was set up, just notify the closure */\n-                                    await (onClose === null || onClose === void 0 ? void 0 : onClose(ctx, code, reason));\n-                                };\n+                        function maybeCatchBinding(type) {\n+                            if (type == \"(\") return cont(funarg, expect(\")\"));\n+                        }\n+\n+                        function expression(type, value) {\n+                            return expressionInner(type, value, false);\n+                        }\n+\n+                        function expressionNoComma(type, value) {\n+                            return expressionInner(type, value, true);\n+                        }\n+\n+                        function parenExpr(type) {\n+                            if (type != \"(\") return pass();\n+                            return cont(pushlex(\")\"), maybeexpression, expect(\")\"), poplex);\n+                        }\n+\n+                        function expressionInner(type, value, noComma) {\n+                            if (cx.state.fatArrowAt == cx.stream.start) {\n+                                var body = noComma ? arrowBodyNoComma : arrowBody;\n+                                if (type == \"(\") return cont(pushcontext, pushlex(\")\"), commasep(funarg, \")\"), poplex, expect(\"=>\"), body, popcontext);\n+                                else if (type == \"variable\") return pass(pushcontext, pattern, expect(\"=>\"), body, popcontext);\n                             }\n-                            // kick the client off (close socket) if the connection has\n-                            // not been initialised after the specified wait timeout\n-                            const connectionInitWait = connectionInitWaitTimeout > 0 && isFinite(connectionInitWaitTimeout) ? setTimeout(() => {\n-                                if (!ctx.connectionInitReceived) socket.close(_common.CloseCode.ConnectionInitialisationTimeout, 'Connection initialisation timeout');\n-                            }, connectionInitWaitTimeout) : null;\n-                            socket.onMessage(async function onMessage(data) {\n-                                var e_1, _a;\n-                                var _b;\n-                                let message;\n-                                try {\n-                                    message = (0, _common.parseMessage)(data, reviver);\n-                                } catch (err) {\n-                                    return socket.close(_common.CloseCode.BadRequest, 'Invalid message received');\n-                                }\n-                                switch (message.type) {\n-                                    case _common.MessageType.ConnectionInit: {\n-                                        if (ctx.connectionInitReceived) return socket.close(_common.CloseCode.TooManyInitialisationRequests, 'Too many initialisation requests');\n-                                        // @ts-expect-error: I can write\n-                                        ctx.connectionInitReceived = true;\n-                                        if ((0, _utils.isObject)(message.payload))\n-                                            // @ts-expect-error: I can write\n-                                            ctx.connectionParams = message.payload;\n-                                        const permittedOrPayload = await (onConnect === null || onConnect === void 0 ? void 0 : onConnect(ctx));\n-                                        if (permittedOrPayload === false) return socket.close(_common.CloseCode.Forbidden, 'Forbidden');\n-                                        await socket.send((0, _common.stringifyMessage)((0, _utils.isObject)(permittedOrPayload) ? {\n-                                            type: _common.MessageType.ConnectionAck,\n-                                            payload: permittedOrPayload\n-                                        } : {\n-                                            type: _common.MessageType.ConnectionAck\n-                                            // payload is completely absent if not provided\n-                                        }, replacer));\n-                                        // @ts-expect-error: I can write\n-                                        ctx.acknowledged = true;\n-                                        return;\n-                                    }\n-                                    case _common.MessageType.Ping: {\n-                                        if (socket.onPing)\n-                                            // if the onPing listener is registered, automatic pong is disabled\n-                                            return await socket.onPing(message.payload);\n-                                        await socket.send((0, _common.stringifyMessage)(message.payload ? {\n-                                            type: _common.MessageType.Pong,\n-                                            payload: message.payload\n-                                        } : {\n-                                            type: _common.MessageType.Pong\n-                                            // payload is completely absent if not provided\n-                                        }));\n+                            var maybeop = noComma ? maybeoperatorNoComma : maybeoperatorComma;\n+                            if (atomicTypes.hasOwnProperty(type)) return cont(maybeop);\n+                            if (type == \"function\") return cont(functiondef, maybeop);\n+                            if (type == \"class\" || isTS && value == \"interface\") {\n+                                cx.marked = \"keyword\";\n+                                return cont(pushlex(\"form\"), classExpression, poplex);\n+                            }\n+                            if (type == \"keyword c\" || type == \"async\") return cont(noComma ? expressionNoComma : expression);\n+                            if (type == \"(\") return cont(pushlex(\")\"), maybeexpression, expect(\")\"), poplex, maybeop);\n+                            if (type == \"operator\" || type == \"spread\") return cont(noComma ? expressionNoComma : expression);\n+                            if (type == \"[\") return cont(pushlex(\"]\"), arrayLiteral, poplex, maybeop);\n+                            if (type == \"{\") return contCommasep(objprop, \"}\", null, maybeop);\n+                            if (type == \"quasi\") return pass(quasi, maybeop);\n+                            if (type == \"new\") return cont(maybeTarget(noComma));\n+                            return cont();\n+                        }\n \n-                                        return;\n-                                    }\n-                                    case _common.MessageType.Pong:\n-                                        return await ((_b = socket.onPong) === null || _b === void 0 ? void 0 : _b.call(socket, message.payload));\n-                                    case _common.MessageType.Subscribe: {\n-                                        if (!ctx.acknowledged) return socket.close(_common.CloseCode.Unauthorized, 'Unauthorized');\n-                                        const {\n-                                            id,\n-                                            payload\n-                                        } = message;\n-                                        if (id in ctx.subscriptions) return socket.close(_common.CloseCode.SubscriberAlreadyExists, `Subscriber for ${id} already exists`);\n-                                        // if this turns out to be a streaming operation, the subscription value\n-                                        // will change to an `AsyncIterable`, otherwise it will stay as is\n-                                        ctx.subscriptions[id] = null;\n-                                        const emit = {\n-                                            next: async (result, args) => {\n-                                                let nextMessage = {\n-                                                    id,\n-                                                    type: _common.MessageType.Next,\n-                                                    payload: result\n-                                                };\n-                                                const maybeResult = await (onNext === null || onNext === void 0 ? void 0 : onNext(ctx, nextMessage, args, result));\n-                                                if (maybeResult) nextMessage = Object.assign(Object.assign({}, nextMessage), {\n-                                                    payload: maybeResult\n-                                                });\n-                                                await socket.send((0, _common.stringifyMessage)(nextMessage, replacer));\n-                                            },\n-                                            error: async errors => {\n-                                                let errorMessage = {\n-                                                    id,\n-                                                    type: _common.MessageType.Error,\n-                                                    payload: errors\n-                                                };\n-                                                const maybeErrors = await (onError === null || onError === void 0 ? void 0 : onError(ctx, errorMessage, errors));\n-                                                if (maybeErrors) errorMessage = Object.assign(Object.assign({}, errorMessage), {\n-                                                    payload: maybeErrors\n-                                                });\n-                                                await socket.send((0, _common.stringifyMessage)(errorMessage, replacer));\n-                                            },\n-                                            complete: async notifyClient => {\n-                                                const completeMessage = {\n-                                                    id,\n-                                                    type: _common.MessageType.Complete\n-                                                };\n-                                                await (onComplete === null || onComplete === void 0 ? void 0 : onComplete(ctx, completeMessage));\n-                                                if (notifyClient) await socket.send((0, _common.stringifyMessage)(completeMessage, replacer));\n-                                            }\n-                                        };\n-                                        let execArgs;\n-                                        const maybeExecArgsOrErrors = await (onSubscribe === null || onSubscribe === void 0 ? void 0 : onSubscribe(ctx, message));\n-                                        if (maybeExecArgsOrErrors) {\n-                                            if ((0, _utils.areGraphQLErrors)(maybeExecArgsOrErrors)) return await emit.error(maybeExecArgsOrErrors);\n-                                            else if (Array.isArray(maybeExecArgsOrErrors)) throw new Error('Invalid return value from onSubscribe hook, expected an array of GraphQLError objects');\n-                                            // not errors, is exec args\n-                                            execArgs = maybeExecArgsOrErrors;\n-                                        } else {\n-                                            // you either provide a schema dynamically through\n-                                            // `onSubscribe` or you set one up during the server setup\n-                                            if (!schema) throw new Error('The GraphQL schema is not provided');\n-                                            const args = {\n-                                                operationName: payload.operationName,\n-                                                document: (0, _graphql.parse)(payload.query),\n-                                                variableValues: payload.variables\n-                                            };\n-                                            execArgs = Object.assign(Object.assign({}, args), {\n-                                                schema: typeof schema === 'function' ? await schema(ctx, message, args) : schema\n-                                            });\n-                                            const validationErrors = (validate !== null && validate !== void 0 ? validate : _graphql.validate)(execArgs.schema, execArgs.document);\n-                                            if (validationErrors.length > 0) return await emit.error(validationErrors);\n-                                        }\n-                                        const operationAST = (0, _graphql.getOperationAST)(execArgs.document, execArgs.operationName);\n-                                        if (!operationAST) return await emit.error([new _graphql.GraphQLError('Unable to identify operation')]);\n-                                        // if `onSubscribe` didnt specify a rootValue, inject one\n-                                        if (!('rootValue' in execArgs)) execArgs.rootValue = roots === null || roots === void 0 ? void 0 : roots[operationAST.operation];\n-                                        // if `onSubscribe` didn't specify a context, inject one\n-                                        if (!('contextValue' in execArgs)) execArgs.contextValue = typeof context === 'function' ? await context(ctx, message, execArgs) : context;\n-                                        // the execution arguments have been prepared\n-                                        // perform the operation and act accordingly\n-                                        let operationResult;\n-                                        if (operationAST.operation === 'subscription') operationResult = await (subscribe !== null && subscribe !== void 0 ? subscribe : _graphql.subscribe)(execArgs);\n-                                        // operation === 'query' || 'mutation'\n-                                        else operationResult = await (execute !== null && execute !== void 0 ? execute : _graphql.execute)(execArgs);\n-                                        const maybeResult = await (onOperation === null || onOperation === void 0 ? void 0 : onOperation(ctx, message, execArgs, operationResult));\n-                                        if (maybeResult) operationResult = maybeResult;\n-                                        if ((0, _utils.isAsyncIterable)(operationResult)) {\n-                                            /** multiple emitted results */\n-                                            if (!(id in ctx.subscriptions)) {\n-                                                // subscription was completed/canceled before the operation settled\n-                                                if ((0, _utils.isAsyncGenerator)(operationResult)) operationResult.return(undefined);\n-                                            } else {\n-                                                ctx.subscriptions[id] = operationResult;\n-                                                try {\n-                                                    for (var operationResult_1 = __asyncValues(operationResult), operationResult_1_1; operationResult_1_1 = await operationResult_1.next(), !operationResult_1_1.done;) {\n-                                                        const result = operationResult_1_1.value;\n-                                                        await emit.next(result, execArgs);\n-                                                    }\n-                                                } catch (e_1_1) {\n-                                                    e_1 = {\n-                                                        error: e_1_1\n-                                                    };\n-                                                } finally {\n-                                                    try {\n-                                                        if (operationResult_1_1 && !operationResult_1_1.done && (_a = operationResult_1.return)) await _a.call(operationResult_1);\n-                                                    } finally {\n-                                                        if (e_1) throw e_1.error;\n-                                                    }\n-                                                }\n-                                            }\n-                                        } else {\n-                                            /** single emitted result */\n-                                            // if the client completed the subscription before the single result\n-                                            // became available, he effectively canceled it and no data should be sent\n-                                            if (id in ctx.subscriptions) await emit.next(operationResult, execArgs);\n-                                        }\n-                                        // lack of subscription at this point indicates that the client\n-                                        // completed the subscription, he doesnt need to be reminded\n-                                        await emit.complete(id in ctx.subscriptions);\n-                                        delete ctx.subscriptions[id];\n-                                        return;\n-                                    }\n-                                    case _common.MessageType.Complete: {\n-                                        const subscription = ctx.subscriptions[message.id];\n-                                        if ((0, _utils.isAsyncGenerator)(subscription)) await subscription.return(undefined);\n-                                        delete ctx.subscriptions[message.id]; // deleting the subscription means no further activity should take place\n-                                        return;\n-                                    }\n-                                    default:\n-                                        throw new Error(`Unexpected message of type ${message.type} received`);\n-                                }\n-                            });\n-                            // wait for close, cleanup and the disconnect callback\n-                            return async (code, reason) => {\n-                                if (connectionInitWait) clearTimeout(connectionInitWait);\n-                                for (const sub of Object.values(ctx.subscriptions)) {\n-                                    if ((0, _utils.isAsyncGenerator)(sub)) await sub.return(undefined);\n-                                }\n-                                if (ctx.acknowledged) await (onDisconnect === null || onDisconnect === void 0 ? void 0 : onDisconnect(ctx, code, reason));\n-                                await (onClose === null || onClose === void 0 ? void 0 : onClose(ctx, code, reason));\n-                            };\n+                        function maybeexpression(type) {\n+                            if (type.match(/[;\\}\\)\\],]/)) return pass();\n+                            return pass(expression);\n                         }\n-                    };\n-                }\n \n-                /***/\n-            }),\n+                        function maybeoperatorComma(type, value) {\n+                            if (type == \",\") return cont(maybeexpression);\n+                            return maybeoperatorNoComma(type, value, false);\n+                        }\n \n-        /***/\n-        \"../../../node_modules/graphql-ws/lib/utils.mjs\":\n-            /*!******************************************************!*\\\n-              !*** ../../../node_modules/graphql-ws/lib/utils.mjs ***!\n-              \\******************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports) {\n+                        function maybeoperatorNoComma(type, value, noComma) {\n+                            var me = noComma == false ? maybeoperatorComma : maybeoperatorNoComma;\n+                            var expr = noComma == false ? expression : expressionNoComma;\n+                            if (type == \"=>\") return cont(pushcontext, noComma ? arrowBodyNoComma : arrowBody, popcontext);\n+                            if (type == \"operator\") {\n+                                if (/\\+\\+|--/.test(value) || isTS && value == \"!\") return cont(me);\n+                                if (isTS && value == \"<\" && cx.stream.match(/^([^<>]|<[^<>]*>)*>\\s*\\(/, false)) return cont(pushlex(\">\"), commasep(typeexpr, \">\"), poplex, me);\n+                                if (value == \"?\") return cont(expression, expect(\":\"), expr);\n+                                return cont(expr);\n+                            }\n+                            if (type == \"quasi\") {\n+                                return pass(quasi, me);\n+                            }\n+                            if (type == \";\") return;\n+                            if (type == \"(\") return contCommasep(expressionNoComma, \")\", \"call\", me);\n+                            if (type == \".\") return cont(property, me);\n+                            if (type == \"[\") return cont(pushlex(\"]\"), maybeexpression, expect(\"]\"), poplex, me);\n+                            if (isTS && value == \"as\") {\n+                                cx.marked = \"keyword\";\n+                                return cont(typeexpr, me);\n+                            }\n+                            if (type == \"regexp\") {\n+                                cx.state.lastType = cx.marked = \"operator\";\n+                                cx.stream.backUp(cx.stream.pos - cx.stream.start - 1);\n+                                return cont(expr);\n+                            }\n+                        }\n \n+                        function quasi(type, value) {\n+                            if (type != \"quasi\") return pass();\n+                            if (value.slice(value.length - 2) != \"${\") return cont(quasi);\n+                            return cont(maybeexpression, continueQuasi);\n+                        }\n \n+                        function continueQuasi(type) {\n+                            if (type == \"}\") {\n+                                cx.marked = \"string-2\";\n+                                cx.state.tokenize = tokenQuasi;\n+                                return cont(quasi);\n+                            }\n+                        }\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.areGraphQLErrors = areGraphQLErrors;\n-                exports.hasOwnArrayProperty = hasOwnArrayProperty;\n-                exports.hasOwnObjectProperty = hasOwnObjectProperty;\n-                exports.hasOwnProperty = hasOwnProperty;\n-                exports.hasOwnStringProperty = hasOwnStringProperty;\n-                exports.isAsyncGenerator = isAsyncGenerator;\n-                exports.isAsyncIterable = isAsyncIterable;\n-                exports.isObject = isObject;\n-                exports.limitCloseReason = limitCloseReason;\n-                // Extremely small optimisation, reduces runtime prototype traversal\n-                const baseHasOwnProperty = Object.prototype.hasOwnProperty;\n-                /** @private */\n-                function isObject(val) {\n-                    return typeof val === 'object' && val !== null;\n-                }\n-                /** @private */\n-                function isAsyncIterable(val) {\n-                    return typeof Object(val)[Symbol.asyncIterator] === 'function';\n-                }\n-                /** @private */\n-                function isAsyncGenerator(val) {\n-                    return isObject(val) && typeof Object(val)[Symbol.asyncIterator] === 'function' && typeof val.return === 'function'\n-                    // for lazy ones, we only need the return anyway\n-                    // typeof val.throw === 'function' &&\n-                    // typeof val.next === 'function'\n-                    ;\n-                }\n-                /** @private */\n-                function areGraphQLErrors(obj) {\n-                    return Array.isArray(obj) &&\n-                        // must be at least one error\n-                        obj.length > 0 &&\n-                        // error has at least a message\n-                        obj.every(ob => 'message' in ob);\n-                }\n-                /** @private */\n-                function hasOwnProperty(obj, prop) {\n-                    return baseHasOwnProperty.call(obj, prop);\n-                }\n-                /** @private */\n-                function hasOwnObjectProperty(obj, prop) {\n-                    return baseHasOwnProperty.call(obj, prop) && isObject(obj[prop]);\n-                }\n-                /** @private */\n-                function hasOwnArrayProperty(obj, prop) {\n-                    return baseHasOwnProperty.call(obj, prop) && Array.isArray(obj[prop]);\n-                }\n-                /** @private */\n-                function hasOwnStringProperty(obj, prop) {\n-                    return baseHasOwnProperty.call(obj, prop) && typeof obj[prop] === 'string';\n-                }\n-                /**\n-                 * Limits the WebSocket close event reason to not exceed a length of one frame.\n-                 * Reference: https://datatracker.ietf.org/doc/html/rfc6455#section-5.2.\n-                 *\n-                 * @private\n-                 */\n-                function limitCloseReason(reason, whenTooLong) {\n-                    return reason.length < 124 ? reason : whenTooLong;\n-                }\n+                        function arrowBody(type) {\n+                            findFatArrow(cx.stream, cx.state);\n+                            return pass(type == \"{\" ? statement : expression);\n+                        }\n \n-                /***/\n-            }),\n+                        function arrowBodyNoComma(type) {\n+                            findFatArrow(cx.stream, cx.state);\n+                            return pass(type == \"{\" ? statement : expressionNoComma);\n+                        }\n \n-        /***/\n-        \"../../../node_modules/graphql/error/GraphQLError.mjs\":\n-            /*!************************************************************!*\\\n-              !*** ../../../node_modules/graphql/error/GraphQLError.mjs ***!\n-              \\************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                        function maybeTarget(noComma) {\n+                            return function(type) {\n+                                if (type == \".\") return cont(noComma ? targetNoComma : target);\n+                                else if (type == \"variable\" && isTS) return cont(maybeTypeArgs, noComma ? maybeoperatorNoComma : maybeoperatorComma);\n+                                else return pass(noComma ? expressionNoComma : expression);\n+                            };\n+                        }\n \n+                        function target(_, value) {\n+                            if (value == \"target\") {\n+                                cx.marked = \"keyword\";\n+                                return cont(maybeoperatorComma);\n+                            }\n+                        }\n+\n+                        function targetNoComma(_, value) {\n+                            if (value == \"target\") {\n+                                cx.marked = \"keyword\";\n+                                return cont(maybeoperatorNoComma);\n+                            }\n+                        }\n+\n+                        function maybelabel(type) {\n+                            if (type == \":\") return cont(poplex, statement);\n+                            return pass(maybeoperatorComma, expect(\";\"), poplex);\n+                        }\n+\n+                        function property(type) {\n+                            if (type == \"variable\") {\n+                                cx.marked = \"property\";\n+                                return cont();\n+                            }\n+                        }\n+\n+                        function objprop(type, value) {\n+                            if (type == \"async\") {\n+                                cx.marked = \"property\";\n+                                return cont(objprop);\n+                            } else if (type == \"variable\" || cx.style == \"keyword\") {\n+                                cx.marked = \"property\";\n+                                if (value == \"get\" || value == \"set\") return cont(getterSetter);\n+                                var m; // Work around fat-arrow-detection complication for detecting typescript typed arrow params\n+                                if (isTS && cx.state.fatArrowAt == cx.stream.start && (m = cx.stream.match(/^\\s*:\\s*/, false))) cx.state.fatArrowAt = cx.stream.pos + m[0].length;\n+                                return cont(afterprop);\n+                            } else if (type == \"number\" || type == \"string\") {\n+                                cx.marked = jsonldMode ? \"property\" : cx.style + \" property\";\n+                                return cont(afterprop);\n+                            } else if (type == \"jsonld-keyword\") {\n+                                return cont(afterprop);\n+                            } else if (isTS && isModifier(value)) {\n+                                cx.marked = \"keyword\";\n+                                return cont(objprop);\n+                            } else if (type == \"[\") {\n+                                return cont(expression, maybetype, expect(\"]\"), afterprop);\n+                            } else if (type == \"spread\") {\n+                                return cont(expressionNoComma, afterprop);\n+                            } else if (value == \"*\") {\n+                                cx.marked = \"keyword\";\n+                                return cont(objprop);\n+                            } else if (type == \":\") {\n+                                return pass(afterprop);\n+                            }\n+                        }\n+\n+                        function getterSetter(type) {\n+                            if (type != \"variable\") return pass(afterprop);\n+                            cx.marked = \"property\";\n+                            return cont(functiondef);\n+                        }\n+\n+                        function afterprop(type) {\n+                            if (type == \":\") return cont(expressionNoComma);\n+                            if (type == \"(\") return pass(functiondef);\n+                        }\n+\n+                        function commasep(what, end, sep) {\n+                            function proceed(type, value) {\n+                                if (sep ? sep.indexOf(type) > -1 : type == \",\") {\n+                                    var lex = cx.state.lexical;\n+                                    if (lex.info == \"call\") lex.pos = (lex.pos || 0) + 1;\n+                                    return cont(function(type, value) {\n+                                        if (type == end || value == end) return pass();\n+                                        return pass(what);\n+                                    }, proceed);\n+                                }\n+                                if (type == end || value == end) return cont();\n+                                if (sep && sep.indexOf(\";\") > -1) return pass(what);\n+                                return cont(expect(end));\n+                            }\n+                            return function(type, value) {\n+                                if (type == end || value == end) return cont();\n+                                return pass(what, proceed);\n+                            };\n+                        }\n \n+                        function contCommasep(what, end, info) {\n+                            for (var i = 3; i < arguments.length; i++) cx.cc.push(arguments[i]);\n+                            return cont(pushlex(end, info), commasep(what, end), poplex);\n+                        }\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.GraphQLError = void 0;\n-                exports.formatError = formatError;\n-                exports.printError = printError;\n-                var _isObjectLike = __webpack_require__( /*! ../jsutils/isObjectLike.mjs */ \"../../../node_modules/graphql/jsutils/isObjectLike.mjs\");\n-                var _location = __webpack_require__( /*! ../language/location.mjs */ \"../../../node_modules/graphql/language/location.mjs\");\n-                var _printLocation = __webpack_require__( /*! ../language/printLocation.mjs */ \"../../../node_modules/graphql/language/printLocation.mjs\");\n+                        function block(type) {\n+                            if (type == \"}\") return cont();\n+                            return pass(statement, block);\n+                        }\n \n-                function toNormalizedOptions(args) {\n-                    const firstArg = args[0];\n-                    if (firstArg == null || 'kind' in firstArg || 'length' in firstArg) {\n-                        return {\n-                            nodes: firstArg,\n-                            source: args[1],\n-                            positions: args[2],\n-                            path: args[3],\n-                            originalError: args[4],\n-                            extensions: args[5]\n-                        };\n-                    }\n-                    return firstArg;\n-                }\n-                /**\n-                 * A GraphQLError describes an Error found during the parse, validate, or\n-                 * execute phases of performing a GraphQL operation. In addition to a message\n-                 * and stack trace, it also includes information about the locations in a\n-                 * GraphQL document and/or execution result that correspond to the Error.\n-                 */\n+                        function maybetype(type, value) {\n+                            if (isTS) {\n+                                if (type == \":\") return cont(typeexpr);\n+                                if (value == \"?\") return cont(maybetype);\n+                            }\n+                        }\n \n-                class GraphQLError extends Error {\n-                    /**\n-                     * An array of `{ line, column }` locations within the source GraphQL document\n-                     * which correspond to this error.\n-                     *\n-                     * Errors during validation often contain multiple locations, for example to\n-                     * point out two things with the same name. Errors during execution include a\n-                     * single location, the field which produced the error.\n-                     *\n-                     * Enumerable, and appears in the result of JSON.stringify().\n-                     */\n+                        function maybetypeOrIn(type, value) {\n+                            if (isTS && (type == \":\" || value == \"in\")) return cont(typeexpr);\n+                        }\n \n-                    /**\n-                     * An array describing the JSON-path into the execution response which\n-                     * corresponds to this error. Only included for errors during execution.\n-                     *\n-                     * Enumerable, and appears in the result of JSON.stringify().\n-                     */\n+                        function mayberettype(type) {\n+                            if (isTS && type == \":\") {\n+                                if (cx.stream.match(/^\\s*\\w+\\s+is\\b/, false)) return cont(expression, isKW, typeexpr);\n+                                else return cont(typeexpr);\n+                            }\n+                        }\n \n-                    /**\n-                     * An array of GraphQL AST Nodes corresponding to this error.\n-                     */\n+                        function isKW(_, value) {\n+                            if (value == \"is\") {\n+                                cx.marked = \"keyword\";\n+                                return cont();\n+                            }\n+                        }\n \n-                    /**\n-                     * The source GraphQL document for the first location of this error.\n-                     *\n-                     * Note that if this Error represents more than one node, the source may not\n-                     * represent nodes after the first node.\n-                     */\n+                        function typeexpr(type, value) {\n+                            if (value == \"keyof\" || value == \"typeof\" || value == \"infer\" || value == \"readonly\") {\n+                                cx.marked = \"keyword\";\n+                                return cont(value == \"typeof\" ? expressionNoComma : typeexpr);\n+                            }\n+                            if (type == \"variable\" || value == \"void\") {\n+                                cx.marked = \"type\";\n+                                return cont(afterType);\n+                            }\n+                            if (value == \"|\" || value == \"&\") return cont(typeexpr);\n+                            if (type == \"string\" || type == \"number\" || type == \"atom\") return cont(afterType);\n+                            if (type == \"[\") return cont(pushlex(\"]\"), commasep(typeexpr, \"]\", \",\"), poplex, afterType);\n+                            if (type == \"{\") return cont(pushlex(\"}\"), typeprops, poplex, afterType);\n+                            if (type == \"(\") return cont(commasep(typearg, \")\"), maybeReturnType, afterType);\n+                            if (type == \"<\") return cont(commasep(typeexpr, \">\"), typeexpr);\n+                            if (type == \"quasi\") {\n+                                return pass(quasiType, afterType);\n+                            }\n+                        }\n \n-                    /**\n-                     * An array of character offsets within the source GraphQL document\n-                     * which correspond to this error.\n-                     */\n+                        function maybeReturnType(type) {\n+                            if (type == \"=>\") return cont(typeexpr);\n+                        }\n \n-                    /**\n-                     * The original error thrown from a field resolver during execution.\n-                     */\n+                        function typeprops(type) {\n+                            if (type.match(/[\\}\\)\\]]/)) return cont();\n+                            if (type == \",\" || type == \";\") return cont(typeprops);\n+                            return pass(typeprop, typeprops);\n+                        }\n \n-                    /**\n-                     * Extension fields to add to the formatted error.\n-                     */\n+                        function typeprop(type, value) {\n+                            if (type == \"variable\" || cx.style == \"keyword\") {\n+                                cx.marked = \"property\";\n+                                return cont(typeprop);\n+                            } else if (value == \"?\" || type == \"number\" || type == \"string\") {\n+                                return cont(typeprop);\n+                            } else if (type == \":\") {\n+                                return cont(typeexpr);\n+                            } else if (type == \"[\") {\n+                                return cont(expect(\"variable\"), maybetypeOrIn, expect(\"]\"), typeprop);\n+                            } else if (type == \"(\") {\n+                                return pass(functiondecl, typeprop);\n+                            } else if (!type.match(/[;\\}\\)\\],]/)) {\n+                                return cont();\n+                            }\n+                        }\n \n-                    /**\n-                     * @deprecated Please use the `GraphQLErrorOptions` constructor overload instead.\n-                     */\n-                    constructor(message) {\n-                        var _this$nodes, _nodeLocations$, _ref;\n-                        for (var _len = arguments.length, rawArgs = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n-                            rawArgs[_key - 1] = arguments[_key];\n+                        function quasiType(type, value) {\n+                            if (type != \"quasi\") return pass();\n+                            if (value.slice(value.length - 2) != \"${\") return cont(quasiType);\n+                            return cont(typeexpr, continueQuasiType);\n                         }\n-                        const {\n-                            nodes,\n-                            source,\n-                            positions,\n-                            path,\n-                            originalError,\n-                            extensions\n-                        } = toNormalizedOptions(rawArgs);\n-                        super(message);\n-                        this.name = 'GraphQLError';\n-                        this.path = path !== null && path !== void 0 ? path : undefined;\n-                        this.originalError = originalError !== null && originalError !== void 0 ? originalError : undefined; // Compute list of blame nodes.\n \n-                        this.nodes = undefinedIfEmpty(Array.isArray(nodes) ? nodes : nodes ? [nodes] : undefined);\n-                        const nodeLocations = undefinedIfEmpty((_this$nodes = this.nodes) === null || _this$nodes === void 0 ? void 0 : _this$nodes.map(node => node.loc).filter(loc => loc != null)); // Compute locations in the source for the given nodes/positions.\n+                        function continueQuasiType(type) {\n+                            if (type == \"}\") {\n+                                cx.marked = \"string-2\";\n+                                cx.state.tokenize = tokenQuasi;\n+                                return cont(quasiType);\n+                            }\n+                        }\n \n-                        this.source = source !== null && source !== void 0 ? source : nodeLocations === null || nodeLocations === void 0 ? void 0 : (_nodeLocations$ = nodeLocations[0]) === null || _nodeLocations$ === void 0 ? void 0 : _nodeLocations$.source;\n-                        this.positions = positions !== null && positions !== void 0 ? positions : nodeLocations === null || nodeLocations === void 0 ? void 0 : nodeLocations.map(loc => loc.start);\n-                        this.locations = positions && source ? positions.map(pos => (0, _location.getLocation)(source, pos)) : nodeLocations === null || nodeLocations === void 0 ? void 0 : nodeLocations.map(loc => (0, _location.getLocation)(loc.source, loc.start));\n-                        const originalExtensions = (0, _isObjectLike.isObjectLike)(originalError === null || originalError === void 0 ? void 0 : originalError.extensions) ? originalError === null || originalError === void 0 ? void 0 : originalError.extensions : undefined;\n-                        this.extensions = (_ref = extensions !== null && extensions !== void 0 ? extensions : originalExtensions) !== null && _ref !== void 0 ? _ref : Object.create(null); // Only properties prescribed by the spec should be enumerable.\n-                        // Keep the rest as non-enumerable.\n+                        function typearg(type, value) {\n+                            if (type == \"variable\" && cx.stream.match(/^\\s*[?:]/, false) || value == \"?\") return cont(typearg);\n+                            if (type == \":\") return cont(typeexpr);\n+                            if (type == \"spread\") return cont(typearg);\n+                            return pass(typeexpr);\n+                        }\n \n-                        Object.defineProperties(this, {\n-                            message: {\n-                                writable: true,\n-                                enumerable: true\n-                            },\n-                            name: {\n-                                enumerable: false\n-                            },\n-                            nodes: {\n-                                enumerable: false\n-                            },\n-                            source: {\n-                                enumerable: false\n-                            },\n-                            positions: {\n-                                enumerable: false\n-                            },\n-                            originalError: {\n-                                enumerable: false\n+                        function afterType(type, value) {\n+                            if (value == \"<\") return cont(pushlex(\">\"), commasep(typeexpr, \">\"), poplex, afterType);\n+                            if (value == \"|\" || type == \".\" || value == \"&\") return cont(typeexpr);\n+                            if (type == \"[\") return cont(typeexpr, expect(\"]\"), afterType);\n+                            if (value == \"extends\" || value == \"implements\") {\n+                                cx.marked = \"keyword\";\n+                                return cont(typeexpr);\n                             }\n-                        }); // Include (non-enumerable) stack trace.\n+                            if (value == \"?\") return cont(typeexpr, expect(\":\"), typeexpr);\n+                        }\n \n-                        /* c8 ignore start */\n-                        // FIXME: https://github.com/graphql/graphql-js/issues/2317\n+                        function maybeTypeArgs(_, value) {\n+                            if (value == \"<\") return cont(pushlex(\">\"), commasep(typeexpr, \">\"), poplex, afterType);\n+                        }\n \n-                        if (originalError !== null && originalError !== void 0 && originalError.stack) {\n-                            Object.defineProperty(this, 'stack', {\n-                                value: originalError.stack,\n-                                writable: true,\n-                                configurable: true\n-                            });\n-                        } else if (Error.captureStackTrace) {\n-                            Error.captureStackTrace(this, GraphQLError);\n-                        } else {\n-                            Object.defineProperty(this, 'stack', {\n-                                value: Error().stack,\n-                                writable: true,\n-                                configurable: true\n-                            });\n+                        function typeparam() {\n+                            return pass(typeexpr, maybeTypeDefault);\n                         }\n-                        /* c8 ignore stop */\n-                    }\n \n-                    get[Symbol.toStringTag]() {\n-                        return 'GraphQLError';\n-                    }\n-                    toString() {\n-                        let output = this.message;\n-                        if (this.nodes) {\n-                            for (const node of this.nodes) {\n-                                if (node.loc) {\n-                                    output += '\\n\\n' + (0, _printLocation.printLocation)(node.loc);\n-                                }\n+                        function maybeTypeDefault(_, value) {\n+                            if (value == \"=\") return cont(typeexpr);\n+                        }\n+\n+                        function vardef(_, value) {\n+                            if (value == \"enum\") {\n+                                cx.marked = \"keyword\";\n+                                return cont(enumdef);\n                             }\n-                        } else if (this.source && this.locations) {\n-                            for (const location of this.locations) {\n-                                output += '\\n\\n' + (0, _printLocation.printSourceLocation)(this.source, location);\n+                            return pass(pattern, maybetype, maybeAssign, vardefCont);\n+                        }\n+\n+                        function pattern(type, value) {\n+                            if (isTS && isModifier(value)) {\n+                                cx.marked = \"keyword\";\n+                                return cont(pattern);\n                             }\n+                            if (type == \"variable\") {\n+                                register(value);\n+                                return cont();\n+                            }\n+                            if (type == \"spread\") return cont(pattern);\n+                            if (type == \"[\") return contCommasep(eltpattern, \"]\");\n+                            if (type == \"{\") return contCommasep(proppattern, \"}\");\n                         }\n-                        return output;\n-                    }\n-                    toJSON() {\n-                        const formattedError = {\n-                            message: this.message\n-                        };\n-                        if (this.locations != null) {\n-                            formattedError.locations = this.locations;\n+\n+                        function proppattern(type, value) {\n+                            if (type == \"variable\" && !cx.stream.match(/^\\s*:/, false)) {\n+                                register(value);\n+                                return cont(maybeAssign);\n+                            }\n+                            if (type == \"variable\") cx.marked = \"property\";\n+                            if (type == \"spread\") return cont(pattern);\n+                            if (type == \"}\") return pass();\n+                            if (type == \"[\") return cont(expression, expect(']'), expect(':'), proppattern);\n+                            return cont(expect(\":\"), pattern, maybeAssign);\n                         }\n-                        if (this.path != null) {\n-                            formattedError.path = this.path;\n+\n+                        function eltpattern() {\n+                            return pass(pattern, maybeAssign);\n                         }\n-                        if (this.extensions != null && Object.keys(this.extensions).length > 0) {\n-                            formattedError.extensions = this.extensions;\n+\n+                        function maybeAssign(_type, value) {\n+                            if (value == \"=\") return cont(expressionNoComma);\n                         }\n-                        return formattedError;\n-                    }\n-                }\n-                exports.GraphQLError = GraphQLError;\n \n-                function undefinedIfEmpty(array) {\n-                    return array === undefined || array.length === 0 ? undefined : array;\n-                }\n-                /**\n-                 * See: https://spec.graphql.org/draft/#sec-Errors\n-                 */\n+                        function vardefCont(type) {\n+                            if (type == \",\") return cont(vardef);\n+                        }\n \n-                /**\n-                 * Prints a GraphQLError to a string, representing useful location information\n-                 * about the error's position in the source.\n-                 *\n-                 * @deprecated Please use `error.toString` instead. Will be removed in v17\n-                 */\n-                function printError(error) {\n-                    return error.toString();\n-                }\n-                /**\n-                 * Given a GraphQLError, format it according to the rules described by the\n-                 * Response Format, Errors section of the GraphQL Specification.\n-                 *\n-                 * @deprecated Please use `error.toJSON` instead. Will be removed in v17\n-                 */\n+                        function maybeelse(type, value) {\n+                            if (type == \"keyword b\" && value == \"else\") return cont(pushlex(\"form\", \"else\"), statement, poplex);\n+                        }\n \n-                function formatError(error) {\n-                    return error.toJSON();\n-                }\n+                        function forspec(type, value) {\n+                            if (value == \"await\") return cont(forspec);\n+                            if (type == \"(\") return cont(pushlex(\")\"), forspec1, poplex);\n+                        }\n \n-                /***/\n-            }),\n+                        function forspec1(type) {\n+                            if (type == \"var\") return cont(vardef, forspec2);\n+                            if (type == \"variable\") return cont(forspec2);\n+                            return pass(forspec2);\n+                        }\n \n-        /***/\n-        \"../../../node_modules/graphql/error/index.mjs\":\n-            /*!*****************************************************!*\\\n-              !*** ../../../node_modules/graphql/error/index.mjs ***!\n-              \\*****************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                        function forspec2(type, value) {\n+                            if (type == \")\") return cont();\n+                            if (type == \";\") return cont(forspec2);\n+                            if (value == \"in\" || value == \"of\") {\n+                                cx.marked = \"keyword\";\n+                                return cont(expression, forspec2);\n+                            }\n+                            return pass(expression, forspec2);\n+                        }\n \n+                        function functiondef(type, value) {\n+                            if (value == \"*\") {\n+                                cx.marked = \"keyword\";\n+                                return cont(functiondef);\n+                            }\n+                            if (type == \"variable\") {\n+                                register(value);\n+                                return cont(functiondef);\n+                            }\n+                            if (type == \"(\") return cont(pushcontext, pushlex(\")\"), commasep(funarg, \")\"), poplex, mayberettype, statement, popcontext);\n+                            if (isTS && value == \"<\") return cont(pushlex(\">\"), commasep(typeparam, \">\"), poplex, functiondef);\n+                        }\n \n+                        function functiondecl(type, value) {\n+                            if (value == \"*\") {\n+                                cx.marked = \"keyword\";\n+                                return cont(functiondecl);\n+                            }\n+                            if (type == \"variable\") {\n+                                register(value);\n+                                return cont(functiondecl);\n+                            }\n+                            if (type == \"(\") return cont(pushcontext, pushlex(\")\"), commasep(funarg, \")\"), poplex, mayberettype, popcontext);\n+                            if (isTS && value == \"<\") return cont(pushlex(\">\"), commasep(typeparam, \">\"), poplex, functiondecl);\n+                        }\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                Object.defineProperty(exports, \"GraphQLError\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _GraphQLError.GraphQLError;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"formatError\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _GraphQLError.formatError;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"locatedError\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _locatedError.locatedError;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"printError\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _GraphQLError.printError;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"syntaxError\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _syntaxError.syntaxError;\n-                    }\n-                }));\n-                var _GraphQLError = __webpack_require__( /*! ./GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n-                var _syntaxError = __webpack_require__( /*! ./syntaxError.mjs */ \"../../../node_modules/graphql/error/syntaxError.mjs\");\n-                var _locatedError = __webpack_require__( /*! ./locatedError.mjs */ \"../../../node_modules/graphql/error/locatedError.mjs\");\n+                        function typename(type, value) {\n+                            if (type == \"keyword\" || type == \"variable\") {\n+                                cx.marked = \"type\";\n+                                return cont(typename);\n+                            } else if (value == \"<\") {\n+                                return cont(pushlex(\">\"), commasep(typeparam, \">\"), poplex);\n+                            }\n+                        }\n \n-                /***/\n-            }),\n+                        function funarg(type, value) {\n+                            if (value == \"@\") cont(expression, funarg);\n+                            if (type == \"spread\") return cont(funarg);\n+                            if (isTS && isModifier(value)) {\n+                                cx.marked = \"keyword\";\n+                                return cont(funarg);\n+                            }\n+                            if (isTS && type == \"this\") return cont(maybetype, maybeAssign);\n+                            return pass(pattern, maybetype, maybeAssign);\n+                        }\n \n-        /***/\n-        \"../../../node_modules/graphql/error/locatedError.mjs\":\n-            /*!************************************************************!*\\\n-              !*** ../../../node_modules/graphql/error/locatedError.mjs ***!\n-              \\************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                        function classExpression(type, value) {\n+                            // Class expressions may have an optional name.\n+                            if (type == \"variable\") return className(type, value);\n+                            return classNameAfter(type, value);\n+                        }\n \n+                        function className(type, value) {\n+                            if (type == \"variable\") {\n+                                register(value);\n+                                return cont(classNameAfter);\n+                            }\n+                        }\n \n+                        function classNameAfter(type, value) {\n+                            if (value == \"<\") return cont(pushlex(\">\"), commasep(typeparam, \">\"), poplex, classNameAfter);\n+                            if (value == \"extends\" || value == \"implements\" || isTS && type == \",\") {\n+                                if (value == \"implements\") cx.marked = \"keyword\";\n+                                return cont(isTS ? typeexpr : expression, classNameAfter);\n+                            }\n+                            if (type == \"{\") return cont(pushlex(\"}\"), classBody, poplex);\n+                        }\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.locatedError = locatedError;\n-                var _toError = __webpack_require__( /*! ../jsutils/toError.mjs */ \"../../../node_modules/graphql/jsutils/toError.mjs\");\n-                var _GraphQLError = __webpack_require__( /*! ./GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n-                /**\n-                 * Given an arbitrary value, presumably thrown while attempting to execute a\n-                 * GraphQL operation, produce a new GraphQLError aware of the location in the\n-                 * document responsible for the original Error.\n-                 */\n+                        function classBody(type, value) {\n+                            if (type == \"async\" || type == \"variable\" && (value == \"static\" || value == \"get\" || value == \"set\" || isTS && isModifier(value)) && cx.stream.match(/^\\s+[\\w$\\xa1-\\uffff]/, false)) {\n+                                cx.marked = \"keyword\";\n+                                return cont(classBody);\n+                            }\n+                            if (type == \"variable\" || cx.style == \"keyword\") {\n+                                cx.marked = \"property\";\n+                                return cont(classfield, classBody);\n+                            }\n+                            if (type == \"number\" || type == \"string\") return cont(classfield, classBody);\n+                            if (type == \"[\") return cont(expression, maybetype, expect(\"]\"), classfield, classBody);\n+                            if (value == \"*\") {\n+                                cx.marked = \"keyword\";\n+                                return cont(classBody);\n+                            }\n+                            if (isTS && type == \"(\") return pass(functiondecl, classBody);\n+                            if (type == \";\" || type == \",\") return cont(classBody);\n+                            if (type == \"}\") return cont();\n+                            if (value == \"@\") return cont(expression, classBody);\n+                        }\n \n-                function locatedError(rawOriginalError, nodes, path) {\n-                    var _nodes;\n-                    const originalError = (0, _toError.toError)(rawOriginalError); // Note: this uses a brand-check to support GraphQL errors originating from other contexts.\n+                        function classfield(type, value) {\n+                            if (value == \"!\") return cont(classfield);\n+                            if (value == \"?\") return cont(classfield);\n+                            if (type == \":\") return cont(typeexpr, maybeAssign);\n+                            if (value == \"=\") return cont(expressionNoComma);\n+                            var context = cx.state.lexical.prev,\n+                                isInterface = context && context.info == \"interface\";\n+                            return pass(isInterface ? functiondecl : functiondef);\n+                        }\n \n-                    if (isLocatedGraphQLError(originalError)) {\n-                        return originalError;\n-                    }\n-                    return new _GraphQLError.GraphQLError(originalError.message, {\n-                        nodes: (_nodes = originalError.nodes) !== null && _nodes !== void 0 ? _nodes : nodes,\n-                        source: originalError.source,\n-                        positions: originalError.positions,\n-                        path,\n-                        originalError\n-                    });\n-                }\n+                        function afterExport(type, value) {\n+                            if (value == \"*\") {\n+                                cx.marked = \"keyword\";\n+                                return cont(maybeFrom, expect(\";\"));\n+                            }\n+                            if (value == \"default\") {\n+                                cx.marked = \"keyword\";\n+                                return cont(expression, expect(\";\"));\n+                            }\n+                            if (type == \"{\") return cont(commasep(exportField, \"}\"), maybeFrom, expect(\";\"));\n+                            return pass(statement);\n+                        }\n \n-                function isLocatedGraphQLError(error) {\n-                    return Array.isArray(error.path);\n-                }\n+                        function exportField(type, value) {\n+                            if (value == \"as\") {\n+                                cx.marked = \"keyword\";\n+                                return cont(expect(\"variable\"));\n+                            }\n+                            if (type == \"variable\") return pass(expressionNoComma, exportField);\n+                        }\n \n-                /***/\n-            }),\n+                        function afterImport(type) {\n+                            if (type == \"string\") return cont();\n+                            if (type == \"(\") return pass(expression);\n+                            if (type == \".\") return pass(maybeoperatorComma);\n+                            return pass(importSpec, maybeMoreImports, maybeFrom);\n+                        }\n \n-        /***/\n-        \"../../../node_modules/graphql/error/syntaxError.mjs\":\n-            /*!***********************************************************!*\\\n-              !*** ../../../node_modules/graphql/error/syntaxError.mjs ***!\n-              \\***********************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                        function importSpec(type, value) {\n+                            if (type == \"{\") return contCommasep(importSpec, \"}\");\n+                            if (type == \"variable\") register(value);\n+                            if (value == \"*\") cx.marked = \"keyword\";\n+                            return cont(maybeAs);\n+                        }\n \n+                        function maybeMoreImports(type) {\n+                            if (type == \",\") return cont(importSpec, maybeMoreImports);\n+                        }\n \n+                        function maybeAs(_type, value) {\n+                            if (value == \"as\") {\n+                                cx.marked = \"keyword\";\n+                                return cont(importSpec);\n+                            }\n+                        }\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.syntaxError = syntaxError;\n-                var _GraphQLError = __webpack_require__( /*! ./GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n-                /**\n-                 * Produces a GraphQLError representing a syntax error, containing useful\n-                 * descriptive information about the syntax error's position in the source.\n-                 */\n+                        function maybeFrom(_type, value) {\n+                            if (value == \"from\") {\n+                                cx.marked = \"keyword\";\n+                                return cont(expression);\n+                            }\n+                        }\n \n-                function syntaxError(source, position, description) {\n-                    return new _GraphQLError.GraphQLError(`Syntax Error: ${description}`, {\n-                        source,\n-                        positions: [position]\n+                        function arrayLiteral(type) {\n+                            if (type == \"]\") return cont();\n+                            return pass(commasep(expressionNoComma, \"]\"));\n+                        }\n+\n+                        function enumdef() {\n+                            return pass(pushlex(\"form\"), pattern, expect(\"{\"), pushlex(\"}\"), commasep(enummember, \"}\"), poplex, poplex);\n+                        }\n+\n+                        function enummember() {\n+                            return pass(pattern, maybeAssign);\n+                        }\n+\n+                        function isContinuedStatement(state, textAfter) {\n+                            return state.lastType == \"operator\" || state.lastType == \",\" || isOperatorChar.test(textAfter.charAt(0)) || /[,.]/.test(textAfter.charAt(0));\n+                        }\n+\n+                        function expressionAllowed(stream, state, backUp) {\n+                            return state.tokenize == tokenBase && /^(?:operator|sof|keyword [bcd]|case|new|export|default|spread|[\\[{}\\(,;:]|=>)$/.test(state.lastType) || state.lastType == \"quasi\" && /\\{\\s*$/.test(stream.string.slice(0, stream.pos - (backUp || 0)));\n+                        }\n+\n+                        // Interface\n+\n+                        return {\n+                            startState: function(basecolumn) {\n+                                var state = {\n+                                    tokenize: tokenBase,\n+                                    lastType: \"sof\",\n+                                    cc: [],\n+                                    lexical: new JSLexical((basecolumn || 0) - indentUnit, 0, \"block\", false),\n+                                    localVars: parserConfig.localVars,\n+                                    context: parserConfig.localVars && new Context(null, null, false),\n+                                    indented: basecolumn || 0\n+                                };\n+                                if (parserConfig.globalVars && typeof parserConfig.globalVars == \"object\") state.globalVars = parserConfig.globalVars;\n+                                return state;\n+                            },\n+                            token: function(stream, state) {\n+                                if (stream.sol()) {\n+                                    if (!state.lexical.hasOwnProperty(\"align\")) state.lexical.align = false;\n+                                    state.indented = stream.indentation();\n+                                    findFatArrow(stream, state);\n+                                }\n+                                if (state.tokenize != tokenComment && stream.eatSpace()) return null;\n+                                var style = state.tokenize(stream, state);\n+                                if (type == \"comment\") return style;\n+                                state.lastType = type == \"operator\" && (content == \"++\" || content == \"--\") ? \"incdec\" : type;\n+                                return parseJS(state, style, type, content, stream);\n+                            },\n+                            indent: function(state, textAfter) {\n+                                if (state.tokenize == tokenComment || state.tokenize == tokenQuasi) return CodeMirror.Pass;\n+                                if (state.tokenize != tokenBase) return 0;\n+                                var firstChar = textAfter && textAfter.charAt(0),\n+                                    lexical = state.lexical,\n+                                    top;\n+                                // Kludge to prevent 'maybelse' from blocking lexical scope pops\n+                                if (!/^\\s*else\\b/.test(textAfter))\n+                                    for (var i = state.cc.length - 1; i >= 0; --i) {\n+                                        var c = state.cc[i];\n+                                        if (c == poplex) lexical = lexical.prev;\n+                                        else if (c != maybeelse && c != popcontext) break;\n+                                    }\n+                                while ((lexical.type == \"stat\" || lexical.type == \"form\") && (firstChar == \"}\" || (top = state.cc[state.cc.length - 1]) && (top == maybeoperatorComma || top == maybeoperatorNoComma) && !/^[,\\.=+\\-*:?[\\(]/.test(textAfter))) lexical = lexical.prev;\n+                                if (statementIndent && lexical.type == \")\" && lexical.prev.type == \"stat\") lexical = lexical.prev;\n+                                var type = lexical.type,\n+                                    closing = firstChar == type;\n+                                if (type == \"vardef\") return lexical.indented + (state.lastType == \"operator\" || state.lastType == \",\" ? lexical.info.length + 1 : 0);\n+                                else if (type == \"form\" && firstChar == \"{\") return lexical.indented;\n+                                else if (type == \"form\") return lexical.indented + indentUnit;\n+                                else if (type == \"stat\") return lexical.indented + (isContinuedStatement(state, textAfter) ? statementIndent || indentUnit : 0);\n+                                else if (lexical.info == \"switch\" && !closing && parserConfig.doubleIndentSwitch != false) return lexical.indented + (/^(?:case|default)\\b/.test(textAfter) ? indentUnit : 2 * indentUnit);\n+                                else if (lexical.align) return lexical.column + (closing ? 0 : 1);\n+                                else return lexical.indented + (closing ? 0 : indentUnit);\n+                            },\n+                            electricInput: /^\\s*(?:case .*?:|default:|\\{|\\})$/,\n+                            blockCommentStart: jsonMode ? null : \"/*\",\n+                            blockCommentEnd: jsonMode ? null : \"*/\",\n+                            blockCommentContinue: jsonMode ? null : \" * \",\n+                            lineComment: jsonMode ? null : \"//\",\n+                            fold: \"brace\",\n+                            closeBrackets: \"()[]{}''\\\"\\\"``\",\n+                            helperType: jsonMode ? \"json\" : \"javascript\",\n+                            jsonldMode: jsonldMode,\n+                            jsonMode: jsonMode,\n+                            expressionAllowed: expressionAllowed,\n+                            skipExpression: function(state) {\n+                                parseJS(state, \"atom\", \"atom\", \"true\", new CodeMirror.StringStream(\"\", 2, null));\n+                            }\n+                        };\n                     });\n-                }\n+                    CodeMirror.registerHelper(\"wordChars\", \"javascript\", /[\\w$]/);\n+                    CodeMirror.defineMIME(\"text/javascript\", \"javascript\");\n+                    CodeMirror.defineMIME(\"text/ecmascript\", \"javascript\");\n+                    CodeMirror.defineMIME(\"application/javascript\", \"javascript\");\n+                    CodeMirror.defineMIME(\"application/x-javascript\", \"javascript\");\n+                    CodeMirror.defineMIME(\"application/ecmascript\", \"javascript\");\n+                    CodeMirror.defineMIME(\"application/json\", {\n+                        name: \"javascript\",\n+                        json: true\n+                    });\n+                    CodeMirror.defineMIME(\"application/x-json\", {\n+                        name: \"javascript\",\n+                        json: true\n+                    });\n+                    CodeMirror.defineMIME(\"application/manifest+json\", {\n+                        name: \"javascript\",\n+                        json: true\n+                    });\n+                    CodeMirror.defineMIME(\"application/ld+json\", {\n+                        name: \"javascript\",\n+                        jsonld: true\n+                    });\n+                    CodeMirror.defineMIME(\"text/typescript\", {\n+                        name: \"javascript\",\n+                        typescript: true\n+                    });\n+                    CodeMirror.defineMIME(\"application/typescript\", {\n+                        name: \"javascript\",\n+                        typescript: true\n+                    });\n+                });\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/graphql/execution/collectFields.mjs\":\n-            /*!*****************************************************************!*\\\n-              !*** ../../../node_modules/graphql/execution/collectFields.mjs ***!\n-              \\*****************************************************************/\n+        \"../../../node_modules/copy-to-clipboard/index.js\":\n+            /*!********************************************************!*\\\n+              !*** ../../../node_modules/copy-to-clipboard/index.js ***!\n+              \\********************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+            (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.collectFields = collectFields;\n-                exports.collectSubfields = collectSubfields;\n-                var _kinds = __webpack_require__( /*! ../language/kinds.mjs */ \"../../../node_modules/graphql/language/kinds.mjs\");\n-                var _definition = __webpack_require__( /*! ../type/definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n-                var _directives = __webpack_require__( /*! ../type/directives.mjs */ \"../../../node_modules/graphql/type/directives.mjs\");\n-                var _typeFromAST = __webpack_require__( /*! ../utilities/typeFromAST.mjs */ \"../../../node_modules/graphql/utilities/typeFromAST.mjs\");\n-                var _values = __webpack_require__( /*! ./values.mjs */ \"../../../node_modules/graphql/execution/values.mjs\");\n-                /**\n-                 * Given a selectionSet, collects all of the fields and returns them.\n-                 *\n-                 * CollectFields requires the \"runtime type\" of an object. For a field that\n-                 * returns an Interface or Union type, the \"runtime type\" will be the actual\n-                 * object type returned by that field.\n-                 *\n-                 * @internal\n-                 */\n+                var deselectCurrent = __webpack_require__( /*! toggle-selection */ \"../../../node_modules/toggle-selection/index.js\");\n+                var clipboardToIE11Formatting = {\n+                    \"text/plain\": \"Text\",\n+                    \"text/html\": \"Url\",\n+                    \"default\": \"Text\"\n+                };\n+                var defaultMessage = \"Copy to clipboard: #{key}, Enter\";\n \n-                function collectFields(schema, fragments, variableValues, runtimeType, selectionSet) {\n-                    const fields = new Map();\n-                    collectFieldsImpl(schema, fragments, variableValues, runtimeType, selectionSet, fields, new Set());\n-                    return fields;\n+                function format(message) {\n+                    var copyKey = (/mac os x/i.test(navigator.userAgent) ? \"\u2318\" : \"Ctrl\") + \"+C\";\n+                    return message.replace(/#{\\s*key\\s*}/g, copyKey);\n                 }\n-                /**\n-                 * Given an array of field nodes, collects all of the subfields of the passed\n-                 * in fields, and returns them at the end.\n-                 *\n-                 * CollectSubFields requires the \"return type\" of an object. For a field that\n-                 * returns an Interface or Union type, the \"return type\" will be the actual\n-                 * object type returned by that field.\n-                 *\n-                 * @internal\n-                 */\n \n-                function collectSubfields(schema, fragments, variableValues, returnType, fieldNodes) {\n-                    const subFieldNodes = new Map();\n-                    const visitedFragmentNames = new Set();\n-                    for (const node of fieldNodes) {\n-                        if (node.selectionSet) {\n-                            collectFieldsImpl(schema, fragments, variableValues, returnType, node.selectionSet, subFieldNodes, visitedFragmentNames);\n-                        }\n+                function copy(text, options) {\n+                    var debug,\n+                        message,\n+                        reselectPrevious,\n+                        range,\n+                        selection,\n+                        mark,\n+                        success = false;\n+                    if (!options) {\n+                        options = {};\n                     }\n-                    return subFieldNodes;\n-                }\n-\n-                function collectFieldsImpl(schema, fragments, variableValues, runtimeType, selectionSet, fields, visitedFragmentNames) {\n-                    for (const selection of selectionSet.selections) {\n-                        switch (selection.kind) {\n-                            case _kinds.Kind.FIELD: {\n-                                if (!shouldIncludeNode(variableValues, selection)) {\n-                                    continue;\n-                                }\n-                                const name = getFieldEntryKey(selection);\n-                                const fieldList = fields.get(name);\n-                                if (fieldList !== undefined) {\n-                                    fieldList.push(selection);\n+                    debug = options.debug || false;\n+                    try {\n+                        reselectPrevious = deselectCurrent();\n+                        range = document.createRange();\n+                        selection = document.getSelection();\n+                        mark = document.createElement(\"span\");\n+                        mark.textContent = text;\n+                        // avoid screen readers from reading out loud the text\n+                        mark.ariaHidden = \"true\";\n+                        // reset user styles for span element\n+                        mark.style.all = \"unset\";\n+                        // prevents scrolling to the end of the page\n+                        mark.style.position = \"fixed\";\n+                        mark.style.top = 0;\n+                        mark.style.clip = \"rect(0, 0, 0, 0)\";\n+                        // used to preserve spaces and line breaks\n+                        mark.style.whiteSpace = \"pre\";\n+                        // do not inherit user-select (it may be `none`)\n+                        mark.style.webkitUserSelect = \"text\";\n+                        mark.style.MozUserSelect = \"text\";\n+                        mark.style.msUserSelect = \"text\";\n+                        mark.style.userSelect = \"text\";\n+                        mark.addEventListener(\"copy\", function(e) {\n+                            e.stopPropagation();\n+                            if (options.format) {\n+                                e.preventDefault();\n+                                if (typeof e.clipboardData === \"undefined\") {\n+                                    // IE 11\n+                                    debug && console.warn(\"unable to use e.clipboardData\");\n+                                    debug && console.warn(\"trying IE specific stuff\");\n+                                    window.clipboardData.clearData();\n+                                    var format = clipboardToIE11Formatting[options.format] || clipboardToIE11Formatting[\"default\"];\n+                                    window.clipboardData.setData(format, text);\n                                 } else {\n-                                    fields.set(name, [selection]);\n+                                    // all other browsers\n+                                    e.clipboardData.clearData();\n+                                    e.clipboardData.setData(options.format, text);\n                                 }\n-                                break;\n                             }\n-                            case _kinds.Kind.INLINE_FRAGMENT: {\n-                                if (!shouldIncludeNode(variableValues, selection) || !doesFragmentConditionMatch(schema, selection, runtimeType)) {\n-                                    continue;\n-                                }\n-                                collectFieldsImpl(schema, fragments, variableValues, runtimeType, selection.selectionSet, fields, visitedFragmentNames);\n-                                break;\n+                            if (options.onCopy) {\n+                                e.preventDefault();\n+                                options.onCopy(e.clipboardData);\n                             }\n-                            case _kinds.Kind.FRAGMENT_SPREAD: {\n-                                const fragName = selection.name.value;\n-                                if (visitedFragmentNames.has(fragName) || !shouldIncludeNode(variableValues, selection)) {\n-                                    continue;\n-                                }\n-                                visitedFragmentNames.add(fragName);\n-                                const fragment = fragments[fragName];\n-                                if (!fragment || !doesFragmentConditionMatch(schema, fragment, runtimeType)) {\n-                                    continue;\n-                                }\n-                                collectFieldsImpl(schema, fragments, variableValues, runtimeType, fragment.selectionSet, fields, visitedFragmentNames);\n-                                break;\n+                        });\n+                        document.body.appendChild(mark);\n+                        range.selectNodeContents(mark);\n+                        selection.addRange(range);\n+                        var successful = document.execCommand(\"copy\");\n+                        if (!successful) {\n+                            throw new Error(\"copy command was unsuccessful\");\n+                        }\n+                        success = true;\n+                    } catch (err) {\n+                        debug && console.error(\"unable to copy using execCommand: \", err);\n+                        debug && console.warn(\"trying IE specific stuff\");\n+                        try {\n+                            window.clipboardData.setData(options.format || \"text\", text);\n+                            options.onCopy && options.onCopy(window.clipboardData);\n+                            success = true;\n+                        } catch (err) {\n+                            debug && console.error(\"unable to copy using clipboardData: \", err);\n+                            debug && console.error(\"falling back to prompt\");\n+                            message = format(\"message\" in options ? options.message : defaultMessage);\n+                            window.prompt(message, text);\n+                        }\n+                    } finally {\n+                        if (selection) {\n+                            if (typeof selection.removeRange == \"function\") {\n+                                selection.removeRange(range);\n+                            } else {\n+                                selection.removeAllRanges();\n                             }\n                         }\n+                        if (mark) {\n+                            document.body.removeChild(mark);\n+                        }\n+                        reselectPrevious();\n                     }\n+                    return success;\n                 }\n-                /**\n-                 * Determines if a field should be included based on the `@include` and `@skip`\n-                 * directives, where `@skip` has higher precedence than `@include`.\n-                 */\n-\n-                function shouldIncludeNode(variableValues, node) {\n-                    const skip = (0, _values.getDirectiveValues)(_directives.GraphQLSkipDirective, node, variableValues);\n-                    if ((skip === null || skip === void 0 ? void 0 : skip.if) === true) {\n-                        return false;\n-                    }\n-                    const include = (0, _values.getDirectiveValues)(_directives.GraphQLIncludeDirective, node, variableValues);\n-                    if ((include === null || include === void 0 ? void 0 : include.if) === false) {\n-                        return false;\n-                    }\n-                    return true;\n-                }\n-                /**\n-                 * Determines if a fragment is applicable to the given type.\n-                 */\n-\n-                function doesFragmentConditionMatch(schema, fragment, type) {\n-                    const typeConditionNode = fragment.typeCondition;\n-                    if (!typeConditionNode) {\n-                        return true;\n-                    }\n-                    const conditionalType = (0, _typeFromAST.typeFromAST)(schema, typeConditionNode);\n-                    if (conditionalType === type) {\n-                        return true;\n-                    }\n-                    if ((0, _definition.isAbstractType)(conditionalType)) {\n-                        return schema.isSubType(conditionalType, type);\n-                    }\n-                    return false;\n-                }\n-                /**\n-                 * Implements the logic to compute the key of a given field's entry\n-                 */\n-\n-                function getFieldEntryKey(node) {\n-                    return node.alias ? node.alias.value : node.name.value;\n-                }\n+                module.exports = copy;\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/graphql/execution/execute.mjs\":\n+        \"../../../node_modules/detect-node-es/esm/browser.js\":\n             /*!***********************************************************!*\\\n-              !*** ../../../node_modules/graphql/execution/execute.mjs ***!\n+              !*** ../../../node_modules/detect-node-es/esm/browser.js ***!\n               \\***********************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+            (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports.assertValidExecutionArguments = assertValidExecutionArguments;\n-                exports.buildExecutionContext = buildExecutionContext;\n-                exports.buildResolveInfo = buildResolveInfo;\n-                exports.defaultTypeResolver = exports.defaultFieldResolver = void 0;\n-                exports.execute = execute;\n-                exports.executeSync = executeSync;\n-                exports.getFieldDef = getFieldDef;\n-                var _devAssert = __webpack_require__( /*! ../jsutils/devAssert.mjs */ \"../../../node_modules/graphql/jsutils/devAssert.mjs\");\n-                var _inspect = __webpack_require__( /*! ../jsutils/inspect.mjs */ \"../../../node_modules/graphql/jsutils/inspect.mjs\");\n-                var _invariant = __webpack_require__( /*! ../jsutils/invariant.mjs */ \"../../../node_modules/graphql/jsutils/invariant.mjs\");\n-                var _isIterableObject = __webpack_require__( /*! ../jsutils/isIterableObject.mjs */ \"../../../node_modules/graphql/jsutils/isIterableObject.mjs\");\n-                var _isObjectLike = __webpack_require__( /*! ../jsutils/isObjectLike.mjs */ \"../../../node_modules/graphql/jsutils/isObjectLike.mjs\");\n-                var _isPromise = __webpack_require__( /*! ../jsutils/isPromise.mjs */ \"../../../node_modules/graphql/jsutils/isPromise.mjs\");\n-                var _memoize = __webpack_require__( /*! ../jsutils/memoize3.mjs */ \"../../../node_modules/graphql/jsutils/memoize3.mjs\");\n-                var _Path = __webpack_require__( /*! ../jsutils/Path.mjs */ \"../../../node_modules/graphql/jsutils/Path.mjs\");\n-                var _promiseForObject = __webpack_require__( /*! ../jsutils/promiseForObject.mjs */ \"../../../node_modules/graphql/jsutils/promiseForObject.mjs\");\n-                var _promiseReduce = __webpack_require__( /*! ../jsutils/promiseReduce.mjs */ \"../../../node_modules/graphql/jsutils/promiseReduce.mjs\");\n-                var _GraphQLError = __webpack_require__( /*! ../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n-                var _locatedError = __webpack_require__( /*! ../error/locatedError.mjs */ \"../../../node_modules/graphql/error/locatedError.mjs\");\n-                var _ast = __webpack_require__( /*! ../language/ast.mjs */ \"../../../node_modules/graphql/language/ast.mjs\");\n-                var _kinds = __webpack_require__( /*! ../language/kinds.mjs */ \"../../../node_modules/graphql/language/kinds.mjs\");\n-                var _definition = __webpack_require__( /*! ../type/definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n-                var _introspection = __webpack_require__( /*! ../type/introspection.mjs */ \"../../../node_modules/graphql/type/introspection.mjs\");\n-                var _validate = __webpack_require__( /*! ../type/validate.mjs */ \"../../../node_modules/graphql/type/validate.mjs\");\n-                var _collectFields = __webpack_require__( /*! ./collectFields.mjs */ \"../../../node_modules/graphql/execution/collectFields.mjs\");\n-                var _values = __webpack_require__( /*! ./values.mjs */ \"../../../node_modules/graphql/execution/values.mjs\");\n-                /**\n-                 * A memoized collection of relevant subfields with regard to the return\n-                 * type. Memoizing ensures the subfields are not repeatedly calculated, which\n-                 * saves overhead when resolving lists of values.\n-                 */\n-\n-                const collectSubfields = (0, _memoize.memoize3)((exeContext, returnType, fieldNodes) => (0, _collectFields.collectSubfields)(exeContext.schema, exeContext.fragments, exeContext.variableValues, returnType, fieldNodes));\n-                /**\n-                 * Terminology\n-                 *\n-                 * \"Definitions\" are the generic name for top-level statements in the document.\n-                 * Examples of this include:\n-                 * 1) Operations (such as a query)\n-                 * 2) Fragments\n-                 *\n-                 * \"Operations\" are a generic name for requests in the document.\n-                 * Examples of this include:\n-                 * 1) query,\n-                 * 2) mutation\n-                 *\n-                 * \"Selections\" are the definitions that can appear legally and at\n-                 * single level of the query. These include:\n-                 * 1) field references e.g `a`\n-                 * 2) fragment \"spreads\" e.g. `...c`\n-                 * 3) inline fragment \"spreads\" e.g. `...on Type { a }`\n-                 */\n+                exports.isNode = void 0;\n+                const isNode = exports.isNode = false;\n \n-                /**\n-                 * Data that must be available at all points during query execution.\n-                 *\n-                 * Namely, schema of the type system that is currently executing,\n-                 * and the fragments defined in the query document\n-                 */\n+                /***/\n+            }),\n \n-                /**\n-                 * Implements the \"Executing requests\" section of the GraphQL specification.\n-                 *\n-                 * Returns either a synchronous ExecutionResult (if all encountered resolvers\n-                 * are synchronous), or a Promise of an ExecutionResult that will eventually be\n-                 * resolved and never rejected.\n-                 *\n-                 * If the arguments to this function do not result in a legal execution context,\n-                 * a GraphQLError will be thrown immediately explaining the invalid input.\n-                 */\n-                function execute(args) {\n-                    // Temporary for v15 to v16 migration. Remove in v17\n-                    arguments.length < 2 || (0, _devAssert.devAssert)(false, 'graphql@16 dropped long-deprecated support for positional arguments, please pass an object instead.');\n-                    const {\n-                        schema,\n-                        document,\n-                        variableValues,\n-                        rootValue\n-                    } = args; // If arguments are missing or incorrect, throw an error.\n+        /***/\n+        \"../../../node_modules/entities/lib/decode.js\":\n+            /*!****************************************************!*\\\n+              !*** ../../../node_modules/entities/lib/decode.js ***!\n+              \\****************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                    assertValidExecutionArguments(schema, document, variableValues); // If a valid execution context cannot be created due to incorrect arguments,\n-                    // a \"Response\" with only errors is returned.\n+                \"use strict\";\n \n-                    const exeContext = buildExecutionContext(args); // Return early errors if execution context failed.\n \n-                    if (!('schema' in exeContext)) {\n-                        return {\n-                            errors: exeContext\n+                var __createBinding = void 0 && (void 0).__createBinding || (Object.create ? function(o, m, k, k2) {\n+                    if (k2 === undefined) k2 = k;\n+                    var desc = Object.getOwnPropertyDescriptor(m, k);\n+                    if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n+                        desc = {\n+                            enumerable: true,\n+                            get: function() {\n+                                return m[k];\n+                            }\n                         };\n-                    } // Return a Promise that will eventually resolve to the data described by\n-                    // The \"Response\" section of the GraphQL specification.\n-                    //\n-                    // If errors are encountered while executing a GraphQL field, only that\n-                    // field and its descendants will be omitted, and sibling fields will still\n-                    // be executed. An execution which encounters errors will still result in a\n-                    // resolved Promise.\n-                    //\n-                    // Errors from sub-fields of a NonNull type may propagate to the top level,\n-                    // at which point we still log the error and null the parent field, which\n-                    // in this case is the entire response.\n-\n-                    try {\n-                        const {\n-                            operation\n-                        } = exeContext;\n-                        const result = executeOperation(exeContext, operation, rootValue);\n-                        if ((0, _isPromise.isPromise)(result)) {\n-                            return result.then(data => buildResponse(data, exeContext.errors), error => {\n-                                exeContext.errors.push(error);\n-                                return buildResponse(null, exeContext.errors);\n-                            });\n-                        }\n-                        return buildResponse(result, exeContext.errors);\n-                    } catch (error) {\n-                        exeContext.errors.push(error);\n-                        return buildResponse(null, exeContext.errors);\n-                    }\n-                }\n-                /**\n-                 * Also implements the \"Executing requests\" section of the GraphQL specification.\n-                 * However, it guarantees to complete synchronously (or throw an error) assuming\n-                 * that all field resolvers are also synchronous.\n-                 */\n-\n-                function executeSync(args) {\n-                    const result = execute(args); // Assert that the execution was synchronous.\n-\n-                    if ((0, _isPromise.isPromise)(result)) {\n-                        throw new Error('GraphQL execution failed to complete synchronously.');\n                     }\n+                    Object.defineProperty(o, k2, desc);\n+                } : function(o, m, k, k2) {\n+                    if (k2 === undefined) k2 = k;\n+                    o[k2] = m[k];\n+                });\n+                var __setModuleDefault = void 0 && (void 0).__setModuleDefault || (Object.create ? function(o, v) {\n+                    Object.defineProperty(o, \"default\", {\n+                        enumerable: true,\n+                        value: v\n+                    });\n+                } : function(o, v) {\n+                    o[\"default\"] = v;\n+                });\n+                var __importStar = void 0 && (void 0).__importStar || function(mod) {\n+                    if (mod && mod.__esModule) return mod;\n+                    var result = {};\n+                    if (mod != null)\n+                        for (var k in mod)\n+                            if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n+                    __setModuleDefault(result, mod);\n                     return result;\n-                }\n-                /**\n-                 * Given a completed execution context and data, build the `{ errors, data }`\n-                 * response defined by the \"Response\" section of the GraphQL specification.\n-                 */\n-\n-                function buildResponse(data, errors) {\n-                    return errors.length === 0 ? {\n-                        data\n-                    } : {\n-                        errors,\n-                        data\n+                };\n+                var __importDefault = void 0 && (void 0).__importDefault || function(mod) {\n+                    return mod && mod.__esModule ? mod : {\n+                        \"default\": mod\n                     };\n-                }\n-                /**\n-                 * Essential assertions before executing to provide developer feedback for\n-                 * improper use of the GraphQL library.\n-                 *\n-                 * @internal\n-                 */\n-\n-                function assertValidExecutionArguments(schema, document, rawVariableValues) {\n-                    document || (0, _devAssert.devAssert)(false, 'Must provide document.'); // If the schema used for execution is invalid, throw an error.\n-\n-                    (0, _validate.assertValidSchema)(schema); // Variables, if provided, must be an object.\n-\n-                    rawVariableValues == null || (0, _isObjectLike.isObjectLike)(rawVariableValues) || (0, _devAssert.devAssert)(false, 'Variables must be provided as an Object where each property is a variable value. Perhaps look to see if an unparsed JSON string was provided.');\n-                }\n-                /**\n-                 * Constructs a ExecutionContext object from the arguments passed to\n-                 * execute, which we will pass throughout the other execution methods.\n-                 *\n-                 * Throws a GraphQLError if a valid execution context cannot be created.\n-                 *\n-                 * @internal\n-                 */\n-\n-                function buildExecutionContext(args) {\n-                    var _definition$name, _operation$variableDe;\n-                    const {\n-                        schema,\n-                        document,\n-                        rootValue,\n-                        contextValue,\n-                        variableValues: rawVariableValues,\n-                        operationName,\n-                        fieldResolver,\n-                        typeResolver,\n-                        subscribeFieldResolver\n-                    } = args;\n-                    let operation;\n-                    const fragments = Object.create(null);\n-                    for (const definition of document.definitions) {\n-                        switch (definition.kind) {\n-                            case _kinds.Kind.OPERATION_DEFINITION:\n-                                if (operationName == null) {\n-                                    if (operation !== undefined) {\n-                                        return [new _GraphQLError.GraphQLError('Must provide operation name if query contains multiple operations.')];\n-                                    }\n-                                    operation = definition;\n-                                } else if (((_definition$name = definition.name) === null || _definition$name === void 0 ? void 0 : _definition$name.value) === operationName) {\n-                                    operation = definition;\n-                                }\n-                                break;\n-                            case _kinds.Kind.FRAGMENT_DEFINITION:\n-                                fragments[definition.name.value] = definition;\n-                                break;\n-                            default: // ignore non-executable definitions\n-                        }\n+                };\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.decodeXML = exports.decodeHTMLStrict = exports.decodeHTMLAttribute = exports.decodeHTML = exports.determineBranch = exports.EntityDecoder = exports.DecodingMode = exports.BinTrieFlags = exports.fromCodePoint = exports.replaceCodePoint = exports.decodeCodePoint = exports.xmlDecodeTree = exports.htmlDecodeTree = void 0;\n+                var decode_data_html_js_1 = __importDefault(__webpack_require__( /*! ./generated/decode-data-html.js */ \"../../../node_modules/entities/lib/generated/decode-data-html.js\"));\n+                exports.htmlDecodeTree = decode_data_html_js_1.default;\n+                var decode_data_xml_js_1 = __importDefault(__webpack_require__( /*! ./generated/decode-data-xml.js */ \"../../../node_modules/entities/lib/generated/decode-data-xml.js\"));\n+                exports.xmlDecodeTree = decode_data_xml_js_1.default;\n+                var decode_codepoint_js_1 = __importStar(__webpack_require__( /*! ./decode_codepoint.js */ \"../../../node_modules/entities/lib/decode_codepoint.js\"));\n+                exports.decodeCodePoint = decode_codepoint_js_1.default;\n+                var decode_codepoint_js_2 = __webpack_require__( /*! ./decode_codepoint.js */ \"../../../node_modules/entities/lib/decode_codepoint.js\");\n+                Object.defineProperty(exports, \"replaceCodePoint\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return decode_codepoint_js_2.replaceCodePoint;\n                     }\n-\n-                    if (!operation) {\n-                        if (operationName != null) {\n-                            return [new _GraphQLError.GraphQLError(`Unknown operation named \"${operationName}\".`)];\n-                        }\n-                        return [new _GraphQLError.GraphQLError('Must provide an operation.')];\n-                    } // FIXME: https://github.com/graphql/graphql-js/issues/2203\n-\n-                    /* c8 ignore next */\n-\n-                    const variableDefinitions = (_operation$variableDe = operation.variableDefinitions) !== null && _operation$variableDe !== void 0 ? _operation$variableDe : [];\n-                    const coercedVariableValues = (0, _values.getVariableValues)(schema, variableDefinitions, rawVariableValues !== null && rawVariableValues !== void 0 ? rawVariableValues : {}, {\n-                        maxErrors: 50\n-                    });\n-                    if (coercedVariableValues.errors) {\n-                        return coercedVariableValues.errors;\n+                }));\n+                Object.defineProperty(exports, \"fromCodePoint\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return decode_codepoint_js_2.fromCodePoint;\n                     }\n-                    return {\n-                        schema,\n-                        fragments,\n-                        rootValue,\n-                        contextValue,\n-                        operation,\n-                        variableValues: coercedVariableValues.coerced,\n-                        fieldResolver: fieldResolver !== null && fieldResolver !== void 0 ? fieldResolver : defaultFieldResolver,\n-                        typeResolver: typeResolver !== null && typeResolver !== void 0 ? typeResolver : defaultTypeResolver,\n-                        subscribeFieldResolver: subscribeFieldResolver !== null && subscribeFieldResolver !== void 0 ? subscribeFieldResolver : defaultFieldResolver,\n-                        errors: []\n-                    };\n-                }\n-                /**\n-                 * Implements the \"Executing operations\" section of the spec.\n-                 */\n+                }));\n+                var CharCodes;\n+                (function(CharCodes) {\n+                    CharCodes[CharCodes[\"NUM\"] = 35] = \"NUM\";\n+                    CharCodes[CharCodes[\"SEMI\"] = 59] = \"SEMI\";\n+                    CharCodes[CharCodes[\"EQUALS\"] = 61] = \"EQUALS\";\n+                    CharCodes[CharCodes[\"ZERO\"] = 48] = \"ZERO\";\n+                    CharCodes[CharCodes[\"NINE\"] = 57] = \"NINE\";\n+                    CharCodes[CharCodes[\"LOWER_A\"] = 97] = \"LOWER_A\";\n+                    CharCodes[CharCodes[\"LOWER_F\"] = 102] = \"LOWER_F\";\n+                    CharCodes[CharCodes[\"LOWER_X\"] = 120] = \"LOWER_X\";\n+                    CharCodes[CharCodes[\"LOWER_Z\"] = 122] = \"LOWER_Z\";\n+                    CharCodes[CharCodes[\"UPPER_A\"] = 65] = \"UPPER_A\";\n+                    CharCodes[CharCodes[\"UPPER_F\"] = 70] = \"UPPER_F\";\n+                    CharCodes[CharCodes[\"UPPER_Z\"] = 90] = \"UPPER_Z\";\n+                })(CharCodes || (CharCodes = {}));\n+                /** Bit that needs to be set to convert an upper case ASCII character to lower case */\n+                var TO_LOWER_BIT = 32;\n+                var BinTrieFlags;\n+                (function(BinTrieFlags) {\n+                    BinTrieFlags[BinTrieFlags[\"VALUE_LENGTH\"] = 49152] = \"VALUE_LENGTH\";\n+                    BinTrieFlags[BinTrieFlags[\"BRANCH_LENGTH\"] = 16256] = \"BRANCH_LENGTH\";\n+                    BinTrieFlags[BinTrieFlags[\"JUMP_TABLE\"] = 127] = \"JUMP_TABLE\";\n+                })(BinTrieFlags = exports.BinTrieFlags || (exports.BinTrieFlags = {}));\n \n-                function executeOperation(exeContext, operation, rootValue) {\n-                    const rootType = exeContext.schema.getRootType(operation.operation);\n-                    if (rootType == null) {\n-                        throw new _GraphQLError.GraphQLError(`Schema is not configured to execute ${operation.operation} operation.`, {\n-                            nodes: operation\n-                        });\n-                    }\n-                    const rootFields = (0, _collectFields.collectFields)(exeContext.schema, exeContext.fragments, exeContext.variableValues, rootType, operation.selectionSet);\n-                    const path = undefined;\n-                    switch (operation.operation) {\n-                        case _ast.OperationTypeNode.QUERY:\n-                            return executeFields(exeContext, rootType, rootValue, path, rootFields);\n-                        case _ast.OperationTypeNode.MUTATION:\n-                            return executeFieldsSerially(exeContext, rootType, rootValue, path, rootFields);\n-                        case _ast.OperationTypeNode.SUBSCRIPTION:\n-                            // TODO: deprecate `subscribe` and move all logic here\n-                            // Temporary solution until we finish merging execute and subscribe together\n-                            return executeFields(exeContext, rootType, rootValue, path, rootFields);\n-                    }\n+                function isNumber(code) {\n+                    return code >= CharCodes.ZERO && code <= CharCodes.NINE;\n                 }\n-                /**\n-                 * Implements the \"Executing selection sets\" section of the spec\n-                 * for fields that must be executed serially.\n-                 */\n \n-                function executeFieldsSerially(exeContext, parentType, sourceValue, path, fields) {\n-                    return (0, _promiseReduce.promiseReduce)(fields.entries(), (results, _ref) => {\n-                        let [responseName, fieldNodes] = _ref;\n-                        const fieldPath = (0, _Path.addPath)(path, responseName, parentType.name);\n-                        const result = executeField(exeContext, parentType, sourceValue, fieldNodes, fieldPath);\n-                        if (result === undefined) {\n-                            return results;\n-                        }\n-                        if ((0, _isPromise.isPromise)(result)) {\n-                            return result.then(resolvedResult => {\n-                                results[responseName] = resolvedResult;\n-                                return results;\n-                            });\n-                        }\n-                        results[responseName] = result;\n-                        return results;\n-                    }, Object.create(null));\n+                function isHexadecimalCharacter(code) {\n+                    return code >= CharCodes.UPPER_A && code <= CharCodes.UPPER_F || code >= CharCodes.LOWER_A && code <= CharCodes.LOWER_F;\n                 }\n-                /**\n-                 * Implements the \"Executing selection sets\" section of the spec\n-                 * for fields that may be executed in parallel.\n-                 */\n-\n-                function executeFields(exeContext, parentType, sourceValue, path, fields) {\n-                    const results = Object.create(null);\n-                    let containsPromise = false;\n-                    try {\n-                        for (const [responseName, fieldNodes] of fields.entries()) {\n-                            const fieldPath = (0, _Path.addPath)(path, responseName, parentType.name);\n-                            const result = executeField(exeContext, parentType, sourceValue, fieldNodes, fieldPath);\n-                            if (result !== undefined) {\n-                                results[responseName] = result;\n-                                if ((0, _isPromise.isPromise)(result)) {\n-                                    containsPromise = true;\n-                                }\n-                            }\n-                        }\n-                    } catch (error) {\n-                        if (containsPromise) {\n-                            // Ensure that any promises returned by other fields are handled, as they may also reject.\n-                            return (0, _promiseForObject.promiseForObject)(results).finally(() => {\n-                                throw error;\n-                            });\n-                        }\n-                        throw error;\n-                    } // If there are no promises, we can just return the object\n-\n-                    if (!containsPromise) {\n-                        return results;\n-                    } // Otherwise, results is a map from field name to the result of resolving that\n-                    // field, which is possibly a promise. Return a promise that will return this\n-                    // same map, but with any promises replaced with the values they resolved to.\n \n-                    return (0, _promiseForObject.promiseForObject)(results);\n+                function isAsciiAlphaNumeric(code) {\n+                    return code >= CharCodes.UPPER_A && code <= CharCodes.UPPER_Z || code >= CharCodes.LOWER_A && code <= CharCodes.LOWER_Z || isNumber(code);\n                 }\n                 /**\n-                 * Implements the \"Executing fields\" section of the spec\n-                 * In particular, this function figures out the value that the field returns by\n-                 * calling its resolve function, then calls completeValue to complete promises,\n-                 * serialize scalars, or execute the sub-selection-set for objects.\n+                 * Checks if the given character is a valid end character for an entity in an attribute.\n+                 *\n+                 * Attribute values that aren't terminated properly aren't parsed, and shouldn't lead to a parser error.\n+                 * See the example in https://html.spec.whatwg.org/multipage/parsing.html#named-character-reference-state\n                  */\n-\n-                function executeField(exeContext, parentType, source, fieldNodes, path) {\n-                    var _fieldDef$resolve;\n-                    const fieldDef = getFieldDef(exeContext.schema, parentType, fieldNodes[0]);\n-                    if (!fieldDef) {\n-                        return;\n-                    }\n-                    const returnType = fieldDef.type;\n-                    const resolveFn = (_fieldDef$resolve = fieldDef.resolve) !== null && _fieldDef$resolve !== void 0 ? _fieldDef$resolve : exeContext.fieldResolver;\n-                    const info = buildResolveInfo(exeContext, fieldDef, fieldNodes, parentType, path); // Get the resolve function, regardless of if its result is normal or abrupt (error).\n-\n-                    try {\n-                        // Build a JS object of arguments from the field.arguments AST, using the\n-                        // variables scope to fulfill any variable references.\n-                        // TODO: find a way to memoize, in case this field is within a List type.\n-                        const args = (0, _values.getArgumentValues)(fieldDef, fieldNodes[0], exeContext.variableValues); // The resolve function's optional third argument is a context value that\n-                        // is provided to every resolve function within an execution. It is commonly\n-                        // used to represent an authenticated user, or request-specific caches.\n-\n-                        const contextValue = exeContext.contextValue;\n-                        const result = resolveFn(source, args, contextValue, info);\n-                        let completed;\n-                        if ((0, _isPromise.isPromise)(result)) {\n-                            completed = result.then(resolved => completeValue(exeContext, returnType, fieldNodes, info, path, resolved));\n-                        } else {\n-                            completed = completeValue(exeContext, returnType, fieldNodes, info, path, result);\n-                        }\n-                        if ((0, _isPromise.isPromise)(completed)) {\n-                            // Note: we don't rely on a `catch` method, but we do expect \"thenable\"\n-                            // to take a second callback for the error case.\n-                            return completed.then(undefined, rawError => {\n-                                const error = (0, _locatedError.locatedError)(rawError, fieldNodes, (0, _Path.pathToArray)(path));\n-                                return handleFieldError(error, returnType, exeContext);\n-                            });\n-                        }\n-                        return completed;\n-                    } catch (rawError) {\n-                        const error = (0, _locatedError.locatedError)(rawError, fieldNodes, (0, _Path.pathToArray)(path));\n-                        return handleFieldError(error, returnType, exeContext);\n-                    }\n+                function isEntityInAttributeInvalidEnd(code) {\n+                    return code === CharCodes.EQUALS || isAsciiAlphaNumeric(code);\n                 }\n+                var EntityDecoderState;\n+                (function(EntityDecoderState) {\n+                    EntityDecoderState[EntityDecoderState[\"EntityStart\"] = 0] = \"EntityStart\";\n+                    EntityDecoderState[EntityDecoderState[\"NumericStart\"] = 1] = \"NumericStart\";\n+                    EntityDecoderState[EntityDecoderState[\"NumericDecimal\"] = 2] = \"NumericDecimal\";\n+                    EntityDecoderState[EntityDecoderState[\"NumericHex\"] = 3] = \"NumericHex\";\n+                    EntityDecoderState[EntityDecoderState[\"NamedEntity\"] = 4] = \"NamedEntity\";\n+                })(EntityDecoderState || (EntityDecoderState = {}));\n+                var DecodingMode;\n+                (function(DecodingMode) {\n+                    /** Entities in text nodes that can end with any character. */\n+                    DecodingMode[DecodingMode[\"Legacy\"] = 0] = \"Legacy\";\n+                    /** Only allow entities terminated with a semicolon. */\n+                    DecodingMode[DecodingMode[\"Strict\"] = 1] = \"Strict\";\n+                    /** Entities in attributes have limitations on ending characters. */\n+                    DecodingMode[DecodingMode[\"Attribute\"] = 2] = \"Attribute\";\n+                })(DecodingMode = exports.DecodingMode || (exports.DecodingMode = {}));\n                 /**\n-                 * @internal\n+                 * Token decoder with support of writing partial entities.\n                  */\n-\n-                function buildResolveInfo(exeContext, fieldDef, fieldNodes, parentType, path) {\n-                    // The resolve function's optional fourth argument is a collection of\n-                    // information about the current execution state.\n-                    return {\n-                        fieldName: fieldDef.name,\n-                        fieldNodes,\n-                        returnType: fieldDef.type,\n-                        parentType,\n-                        path,\n-                        schema: exeContext.schema,\n-                        fragments: exeContext.fragments,\n-                        rootValue: exeContext.rootValue,\n-                        operation: exeContext.operation,\n-                        variableValues: exeContext.variableValues\n+                var EntityDecoder = /** @class */ function() {\n+                    function EntityDecoder( /** The tree used to decode entities. */\n+                        decodeTree,\n+                        /**\n+                         * The function that is called when a codepoint is decoded.\n+                         *\n+                         * For multi-byte named entities, this will be called multiple times,\n+                         * with the second codepoint, and the same `consumed` value.\n+                         *\n+                         * @param codepoint The decoded codepoint.\n+                         * @param consumed The number of bytes consumed by the decoder.\n+                         */\n+                        emitCodePoint, /** An object that is used to produce errors. */\n+                        errors) {\n+                        this.decodeTree = decodeTree;\n+                        this.emitCodePoint = emitCodePoint;\n+                        this.errors = errors;\n+                        /** The current state of the decoder. */\n+                        this.state = EntityDecoderState.EntityStart;\n+                        /** Characters that were consumed while parsing an entity. */\n+                        this.consumed = 1;\n+                        /**\n+                         * The result of the entity.\n+                         *\n+                         * Either the result index of a numeric entity, or the codepoint of a\n+                         * numeric entity.\n+                         */\n+                        this.result = 0;\n+                        /** The current index in the decode tree. */\n+                        this.treeIndex = 0;\n+                        /** The number of characters that were consumed in excess. */\n+                        this.excess = 1;\n+                        /** The mode in which the decoder is operating. */\n+                        this.decodeMode = DecodingMode.Strict;\n+                    }\n+                    /** Resets the instance to make it reusable. */\n+                    EntityDecoder.prototype.startEntity = function(decodeMode) {\n+                        this.decodeMode = decodeMode;\n+                        this.state = EntityDecoderState.EntityStart;\n+                        this.result = 0;\n+                        this.treeIndex = 0;\n+                        this.excess = 1;\n+                        this.consumed = 1;\n                     };\n-                }\n-\n-                function handleFieldError(error, returnType, exeContext) {\n-                    // If the field type is non-nullable, then it is resolved without any\n-                    // protection from errors, however it still properly locates the error.\n-                    if ((0, _definition.isNonNullType)(returnType)) {\n-                        throw error;\n-                    } // Otherwise, error protection is applied, logging the error and resolving\n-                    // a null value for this field if one is encountered.\n-\n-                    exeContext.errors.push(error);\n-                    return null;\n-                }\n-                /**\n-                 * Implements the instructions for completeValue as defined in the\n-                 * \"Value Completion\" section of the spec.\n-                 *\n-                 * If the field type is Non-Null, then this recursively completes the value\n-                 * for the inner type. It throws a field error if that completion returns null,\n-                 * as per the \"Nullability\" section of the spec.\n-                 *\n-                 * If the field type is a List, then this recursively completes the value\n-                 * for the inner type on each item in the list.\n-                 *\n-                 * If the field type is a Scalar or Enum, ensures the completed value is a legal\n-                 * value of the type by calling the `serialize` method of GraphQL type\n-                 * definition.\n-                 *\n-                 * If the field is an abstract type, determine the runtime type of the value\n-                 * and then complete based on that type\n-                 *\n-                 * Otherwise, the field type expects a sub-selection set, and will complete the\n-                 * value by executing all sub-selections.\n-                 */\n-\n-                function completeValue(exeContext, returnType, fieldNodes, info, path, result) {\n-                    // If result is an Error, throw a located error.\n-                    if (result instanceof Error) {\n-                        throw result;\n-                    } // If field type is NonNull, complete for inner type, and throw field error\n-                    // if result is null.\n-\n-                    if ((0, _definition.isNonNullType)(returnType)) {\n-                        const completed = completeValue(exeContext, returnType.ofType, fieldNodes, info, path, result);\n-                        if (completed === null) {\n-                            throw new Error(`Cannot return null for non-nullable field ${info.parentType.name}.${info.fieldName}.`);\n+                    /**\n+                     * Write an entity to the decoder. This can be called multiple times with partial entities.\n+                     * If the entity is incomplete, the decoder will return -1.\n+                     *\n+                     * Mirrors the implementation of `getDecoder`, but with the ability to stop decoding if the\n+                     * entity is incomplete, and resume when the next string is written.\n+                     *\n+                     * @param string The string containing the entity (or a continuation of the entity).\n+                     * @param offset The offset at which the entity begins. Should be 0 if this is not the first call.\n+                     * @returns The number of characters that were consumed, or -1 if the entity is incomplete.\n+                     */\n+                    EntityDecoder.prototype.write = function(str, offset) {\n+                        switch (this.state) {\n+                            case EntityDecoderState.EntityStart: {\n+                                if (str.charCodeAt(offset) === CharCodes.NUM) {\n+                                    this.state = EntityDecoderState.NumericStart;\n+                                    this.consumed += 1;\n+                                    return this.stateNumericStart(str, offset + 1);\n+                                }\n+                                this.state = EntityDecoderState.NamedEntity;\n+                                return this.stateNamedEntity(str, offset);\n+                            }\n+                            case EntityDecoderState.NumericStart: {\n+                                return this.stateNumericStart(str, offset);\n+                            }\n+                            case EntityDecoderState.NumericDecimal: {\n+                                return this.stateNumericDecimal(str, offset);\n+                            }\n+                            case EntityDecoderState.NumericHex: {\n+                                return this.stateNumericHex(str, offset);\n+                            }\n+                            case EntityDecoderState.NamedEntity: {\n+                                return this.stateNamedEntity(str, offset);\n+                            }\n                         }\n-                        return completed;\n-                    } // If result value is null or undefined then return null.\n-\n-                    if (result == null) {\n-                        return null;\n-                    } // If field type is List, complete each item in the list with the inner type\n-\n-                    if ((0, _definition.isListType)(returnType)) {\n-                        return completeListValue(exeContext, returnType, fieldNodes, info, path, result);\n-                    } // If field type is a leaf type, Scalar or Enum, serialize to a valid value,\n-                    // returning null if serialization is not possible.\n-\n-                    if ((0, _definition.isLeafType)(returnType)) {\n-                        return completeLeafValue(returnType, result);\n-                    } // If field type is an abstract type, Interface or Union, determine the\n-                    // runtime Object type and complete for that type.\n-\n-                    if ((0, _definition.isAbstractType)(returnType)) {\n-                        return completeAbstractValue(exeContext, returnType, fieldNodes, info, path, result);\n-                    } // If field type is Object, execute and complete all sub-selections.\n-\n-                    if ((0, _definition.isObjectType)(returnType)) {\n-                        return completeObjectValue(exeContext, returnType, fieldNodes, info, path, result);\n-                    }\n-                    /* c8 ignore next 6 */\n-                    // Not reachable, all possible output types have been considered.\n-\n-                    false || (0, _invariant.invariant)(false, 'Cannot complete value of unexpected output type: ' + (0, _inspect.inspect)(returnType));\n-                }\n-                /**\n-                 * Complete a list value by completing each item in the list with the\n-                 * inner type\n-                 */\n-\n-                function completeListValue(exeContext, returnType, fieldNodes, info, path, result) {\n-                    if (!(0, _isIterableObject.isIterableObject)(result)) {\n-                        throw new _GraphQLError.GraphQLError(`Expected Iterable, but did not find one for field \"${info.parentType.name}.${info.fieldName}\".`);\n-                    } // This is specified as a simple map, however we're optimizing the path\n-                    // where the list contains no Promises by avoiding creating another Promise.\n-\n-                    const itemType = returnType.ofType;\n-                    let containsPromise = false;\n-                    const completedResults = Array.from(result, (item, index) => {\n-                        // No need to modify the info object containing the path,\n-                        // since from here on it is not ever accessed by resolver functions.\n-                        const itemPath = (0, _Path.addPath)(path, index, undefined);\n-                        try {\n-                            let completedItem;\n-                            if ((0, _isPromise.isPromise)(item)) {\n-                                completedItem = item.then(resolved => completeValue(exeContext, itemType, fieldNodes, info, itemPath, resolved));\n+                    };\n+                    /**\n+                     * Switches between the numeric decimal and hexadecimal states.\n+                     *\n+                     * Equivalent to the `Numeric character reference state` in the HTML spec.\n+                     *\n+                     * @param str The string containing the entity (or a continuation of the entity).\n+                     * @param offset The current offset.\n+                     * @returns The number of characters that were consumed, or -1 if the entity is incomplete.\n+                     */\n+                    EntityDecoder.prototype.stateNumericStart = function(str, offset) {\n+                        if (offset >= str.length) {\n+                            return -1;\n+                        }\n+                        if ((str.charCodeAt(offset) | TO_LOWER_BIT) === CharCodes.LOWER_X) {\n+                            this.state = EntityDecoderState.NumericHex;\n+                            this.consumed += 1;\n+                            return this.stateNumericHex(str, offset + 1);\n+                        }\n+                        this.state = EntityDecoderState.NumericDecimal;\n+                        return this.stateNumericDecimal(str, offset);\n+                    };\n+                    EntityDecoder.prototype.addToNumericResult = function(str, start, end, base) {\n+                        if (start !== end) {\n+                            var digitCount = end - start;\n+                            this.result = this.result * Math.pow(base, digitCount) + parseInt(str.substr(start, digitCount), base);\n+                            this.consumed += digitCount;\n+                        }\n+                    };\n+                    /**\n+                     * Parses a hexadecimal numeric entity.\n+                     *\n+                     * Equivalent to the `Hexademical character reference state` in the HTML spec.\n+                     *\n+                     * @param str The string containing the entity (or a continuation of the entity).\n+                     * @param offset The current offset.\n+                     * @returns The number of characters that were consumed, or -1 if the entity is incomplete.\n+                     */\n+                    EntityDecoder.prototype.stateNumericHex = function(str, offset) {\n+                        var startIdx = offset;\n+                        while (offset < str.length) {\n+                            var char = str.charCodeAt(offset);\n+                            if (isNumber(char) || isHexadecimalCharacter(char)) {\n+                                offset += 1;\n                             } else {\n-                                completedItem = completeValue(exeContext, itemType, fieldNodes, info, itemPath, item);\n+                                this.addToNumericResult(str, startIdx, offset, 16);\n+                                return this.emitNumericEntity(char, 3);\n                             }\n-                            if ((0, _isPromise.isPromise)(completedItem)) {\n-                                containsPromise = true; // Note: we don't rely on a `catch` method, but we do expect \"thenable\"\n-                                // to take a second callback for the error case.\n-\n-                                return completedItem.then(undefined, rawError => {\n-                                    const error = (0, _locatedError.locatedError)(rawError, fieldNodes, (0, _Path.pathToArray)(itemPath));\n-                                    return handleFieldError(error, itemType, exeContext);\n-                                });\n+                        }\n+                        this.addToNumericResult(str, startIdx, offset, 16);\n+                        return -1;\n+                    };\n+                    /**\n+                     * Parses a decimal numeric entity.\n+                     *\n+                     * Equivalent to the `Decimal character reference state` in the HTML spec.\n+                     *\n+                     * @param str The string containing the entity (or a continuation of the entity).\n+                     * @param offset The current offset.\n+                     * @returns The number of characters that were consumed, or -1 if the entity is incomplete.\n+                     */\n+                    EntityDecoder.prototype.stateNumericDecimal = function(str, offset) {\n+                        var startIdx = offset;\n+                        while (offset < str.length) {\n+                            var char = str.charCodeAt(offset);\n+                            if (isNumber(char)) {\n+                                offset += 1;\n+                            } else {\n+                                this.addToNumericResult(str, startIdx, offset, 10);\n+                                return this.emitNumericEntity(char, 2);\n                             }\n-                            return completedItem;\n-                        } catch (rawError) {\n-                            const error = (0, _locatedError.locatedError)(rawError, fieldNodes, (0, _Path.pathToArray)(itemPath));\n-                            return handleFieldError(error, itemType, exeContext);\n                         }\n-                    });\n-                    return containsPromise ? Promise.all(completedResults) : completedResults;\n-                }\n+                        this.addToNumericResult(str, startIdx, offset, 10);\n+                        return -1;\n+                    };\n+                    /**\n+                     * Validate and emit a numeric entity.\n+                     *\n+                     * Implements the logic from the `Hexademical character reference start\n+                     * state` and `Numeric character reference end state` in the HTML spec.\n+                     *\n+                     * @param lastCp The last code point of the entity. Used to see if the\n+                     *               entity was terminated with a semicolon.\n+                     * @param expectedLength The minimum number of characters that should be\n+                     *                       consumed. Used to validate that at least one digit\n+                     *                       was consumed.\n+                     * @returns The number of characters that were consumed.\n+                     */\n+                    EntityDecoder.prototype.emitNumericEntity = function(lastCp, expectedLength) {\n+                        var _a;\n+                        // Ensure we consumed at least one digit.\n+                        if (this.consumed <= expectedLength) {\n+                            (_a = this.errors) === null || _a === void 0 ? void 0 : _a.absenceOfDigitsInNumericCharacterReference(this.consumed);\n+                            return 0;\n+                        }\n+                        // Figure out if this is a legit end of the entity\n+                        if (lastCp === CharCodes.SEMI) {\n+                            this.consumed += 1;\n+                        } else if (this.decodeMode === DecodingMode.Strict) {\n+                            return 0;\n+                        }\n+                        this.emitCodePoint((0, decode_codepoint_js_1.replaceCodePoint)(this.result), this.consumed);\n+                        if (this.errors) {\n+                            if (lastCp !== CharCodes.SEMI) {\n+                                this.errors.missingSemicolonAfterCharacterReference();\n+                            }\n+                            this.errors.validateNumericCharacterReference(this.result);\n+                        }\n+                        return this.consumed;\n+                    };\n+                    /**\n+                     * Parses a named entity.\n+                     *\n+                     * Equivalent to the `Named character reference state` in the HTML spec.\n+                     *\n+                     * @param str The string containing the entity (or a continuation of the entity).\n+                     * @param offset The current offset.\n+                     * @returns The number of characters that were consumed, or -1 if the entity is incomplete.\n+                     */\n+                    EntityDecoder.prototype.stateNamedEntity = function(str, offset) {\n+                        var decodeTree = this.decodeTree;\n+                        var current = decodeTree[this.treeIndex];\n+                        // The mask is the number of bytes of the value, including the current byte.\n+                        var valueLength = (current & BinTrieFlags.VALUE_LENGTH) >> 14;\n+                        for (; offset < str.length; offset++, this.excess++) {\n+                            var char = str.charCodeAt(offset);\n+                            this.treeIndex = determineBranch(decodeTree, current, this.treeIndex + Math.max(1, valueLength), char);\n+                            if (this.treeIndex < 0) {\n+                                return this.result === 0 ||\n+                                    // If we are parsing an attribute\n+                                    this.decodeMode === DecodingMode.Attribute && (\n+                                        // We shouldn't have consumed any characters after the entity,\n+                                        valueLength === 0 ||\n+                                        // And there should be no invalid characters.\n+                                        isEntityInAttributeInvalidEnd(char)) ? 0 : this.emitNotTerminatedNamedEntity();\n+                            }\n+                            current = decodeTree[this.treeIndex];\n+                            valueLength = (current & BinTrieFlags.VALUE_LENGTH) >> 14;\n+                            // If the branch is a value, store it and continue\n+                            if (valueLength !== 0) {\n+                                // If the entity is terminated by a semicolon, we are done.\n+                                if (char === CharCodes.SEMI) {\n+                                    return this.emitNamedEntityData(this.treeIndex, valueLength, this.consumed + this.excess);\n+                                }\n+                                // If we encounter a non-terminated (legacy) entity while parsing strictly, then ignore it.\n+                                if (this.decodeMode !== DecodingMode.Strict) {\n+                                    this.result = this.treeIndex;\n+                                    this.consumed += this.excess;\n+                                    this.excess = 0;\n+                                }\n+                            }\n+                        }\n+                        return -1;\n+                    };\n+                    /**\n+                     * Emit a named entity that was not terminated with a semicolon.\n+                     *\n+                     * @returns The number of characters consumed.\n+                     */\n+                    EntityDecoder.prototype.emitNotTerminatedNamedEntity = function() {\n+                        var _a;\n+                        var _b = this,\n+                            result = _b.result,\n+                            decodeTree = _b.decodeTree;\n+                        var valueLength = (decodeTree[result] & BinTrieFlags.VALUE_LENGTH) >> 14;\n+                        this.emitNamedEntityData(result, valueLength, this.consumed);\n+                        (_a = this.errors) === null || _a === void 0 ? void 0 : _a.missingSemicolonAfterCharacterReference();\n+                        return this.consumed;\n+                    };\n+                    /**\n+                     * Emit a named entity.\n+                     *\n+                     * @param result The index of the entity in the decode tree.\n+                     * @param valueLength The number of bytes in the entity.\n+                     * @param consumed The number of characters consumed.\n+                     *\n+                     * @returns The number of characters consumed.\n+                     */\n+                    EntityDecoder.prototype.emitNamedEntityData = function(result, valueLength, consumed) {\n+                        var decodeTree = this.decodeTree;\n+                        this.emitCodePoint(valueLength === 1 ? decodeTree[result] & ~BinTrieFlags.VALUE_LENGTH : decodeTree[result + 1], consumed);\n+                        if (valueLength === 3) {\n+                            // For multi-byte values, we need to emit the second byte.\n+                            this.emitCodePoint(decodeTree[result + 2], consumed);\n+                        }\n+                        return consumed;\n+                    };\n+                    /**\n+                     * Signal to the parser that the end of the input was reached.\n+                     *\n+                     * Remaining data will be emitted and relevant errors will be produced.\n+                     *\n+                     * @returns The number of characters consumed.\n+                     */\n+                    EntityDecoder.prototype.end = function() {\n+                        var _a;\n+                        switch (this.state) {\n+                            case EntityDecoderState.NamedEntity: {\n+                                // Emit a named entity if we have one.\n+                                return this.result !== 0 && (this.decodeMode !== DecodingMode.Attribute || this.result === this.treeIndex) ? this.emitNotTerminatedNamedEntity() : 0;\n+                            }\n+                            // Otherwise, emit a numeric entity if we have one.\n+                            case EntityDecoderState.NumericDecimal: {\n+                                return this.emitNumericEntity(0, 2);\n+                            }\n+                            case EntityDecoderState.NumericHex: {\n+                                return this.emitNumericEntity(0, 3);\n+                            }\n+                            case EntityDecoderState.NumericStart: {\n+                                (_a = this.errors) === null || _a === void 0 ? void 0 : _a.absenceOfDigitsInNumericCharacterReference(this.consumed);\n+                                return 0;\n+                            }\n+                            case EntityDecoderState.EntityStart: {\n+                                // Return 0 if we have no entity.\n+                                return 0;\n+                            }\n+                        }\n+                    };\n+                    return EntityDecoder;\n+                }();\n+                exports.EntityDecoder = EntityDecoder;\n                 /**\n-                 * Complete a Scalar or Enum by serializing to a valid value, returning\n-                 * null if serialization is not possible.\n+                 * Creates a function that decodes entities in a string.\n+                 *\n+                 * @param decodeTree The decode tree.\n+                 * @returns A function that decodes entities in a string.\n                  */\n-\n-                function completeLeafValue(returnType, result) {\n-                    const serializedResult = returnType.serialize(result);\n-                    if (serializedResult == null) {\n-                        throw new Error(`Expected \\`${(0, _inspect.inspect)(returnType)}.serialize(${(0, _inspect.inspect)(result)})\\` to ` + `return non-nullable value, returned: ${(0, _inspect.inspect)(serializedResult)}`);\n-                    }\n-                    return serializedResult;\n+                function getDecoder(decodeTree) {\n+                    var ret = \"\";\n+                    var decoder = new EntityDecoder(decodeTree, function(str) {\n+                        return ret += (0, decode_codepoint_js_1.fromCodePoint)(str);\n+                    });\n+                    return function decodeWithTrie(str, decodeMode) {\n+                        var lastIndex = 0;\n+                        var offset = 0;\n+                        while ((offset = str.indexOf(\"&\", offset)) >= 0) {\n+                            ret += str.slice(lastIndex, offset);\n+                            decoder.startEntity(decodeMode);\n+                            var len = decoder.write(str,\n+                                // Skip the \"&\"\n+                                offset + 1);\n+                            if (len < 0) {\n+                                lastIndex = offset + decoder.end();\n+                                break;\n+                            }\n+                            lastIndex = offset + len;\n+                            // If `len` is 0, skip the current `&` and continue.\n+                            offset = len === 0 ? lastIndex + 1 : lastIndex;\n+                        }\n+                        var result = ret + str.slice(lastIndex);\n+                        // Make sure we don't keep a reference to the final string.\n+                        ret = \"\";\n+                        return result;\n+                    };\n                 }\n                 /**\n-                 * Complete a value of an abstract type by determining the runtime object type\n-                 * of that value, then complete the value for that type.\n+                 * Determines the branch of the current node that is taken given the current\n+                 * character. This function is used to traverse the trie.\n+                 *\n+                 * @param decodeTree The trie.\n+                 * @param current The current node.\n+                 * @param nodeIdx The index right after the current node and its value.\n+                 * @param char The current character.\n+                 * @returns The index of the next node, or -1 if no branch is taken.\n                  */\n-\n-                function completeAbstractValue(exeContext, returnType, fieldNodes, info, path, result) {\n-                    var _returnType$resolveTy;\n-                    const resolveTypeFn = (_returnType$resolveTy = returnType.resolveType) !== null && _returnType$resolveTy !== void 0 ? _returnType$resolveTy : exeContext.typeResolver;\n-                    const contextValue = exeContext.contextValue;\n-                    const runtimeType = resolveTypeFn(result, contextValue, info, returnType);\n-                    if ((0, _isPromise.isPromise)(runtimeType)) {\n-                        return runtimeType.then(resolvedRuntimeType => completeObjectValue(exeContext, ensureValidRuntimeType(resolvedRuntimeType, exeContext, returnType, fieldNodes, info, result), fieldNodes, info, path, result));\n-                    }\n-                    return completeObjectValue(exeContext, ensureValidRuntimeType(runtimeType, exeContext, returnType, fieldNodes, info, result), fieldNodes, info, path, result);\n-                }\n-\n-                function ensureValidRuntimeType(runtimeTypeName, exeContext, returnType, fieldNodes, info, result) {\n-                    if (runtimeTypeName == null) {\n-                        throw new _GraphQLError.GraphQLError(`Abstract type \"${returnType.name}\" must resolve to an Object type at runtime for field \"${info.parentType.name}.${info.fieldName}\". Either the \"${returnType.name}\" type should provide a \"resolveType\" function or each possible type should provide an \"isTypeOf\" function.`, fieldNodes);\n-                    } // releases before 16.0.0 supported returning `GraphQLObjectType` from `resolveType`\n-                    // TODO: remove in 17.0.0 release\n-\n-                    if ((0, _definition.isObjectType)(runtimeTypeName)) {\n-                        throw new _GraphQLError.GraphQLError('Support for returning GraphQLObjectType from resolveType was removed in graphql-js@16.0.0 please return type name instead.');\n-                    }\n-                    if (typeof runtimeTypeName !== 'string') {\n-                        throw new _GraphQLError.GraphQLError(`Abstract type \"${returnType.name}\" must resolve to an Object type at runtime for field \"${info.parentType.name}.${info.fieldName}\" with ` + `value ${(0, _inspect.inspect)(result)}, received \"${(0, _inspect.inspect)(runtimeTypeName)}\".`);\n-                    }\n-                    const runtimeType = exeContext.schema.getType(runtimeTypeName);\n-                    if (runtimeType == null) {\n-                        throw new _GraphQLError.GraphQLError(`Abstract type \"${returnType.name}\" was resolved to a type \"${runtimeTypeName}\" that does not exist inside the schema.`, {\n-                            nodes: fieldNodes\n-                        });\n+                function determineBranch(decodeTree, current, nodeIdx, char) {\n+                    var branchCount = (current & BinTrieFlags.BRANCH_LENGTH) >> 7;\n+                    var jumpOffset = current & BinTrieFlags.JUMP_TABLE;\n+                    // Case 1: Single branch encoded in jump offset\n+                    if (branchCount === 0) {\n+                        return jumpOffset !== 0 && char === jumpOffset ? nodeIdx : -1;\n                     }\n-                    if (!(0, _definition.isObjectType)(runtimeType)) {\n-                        throw new _GraphQLError.GraphQLError(`Abstract type \"${returnType.name}\" was resolved to a non-object type \"${runtimeTypeName}\".`, {\n-                            nodes: fieldNodes\n-                        });\n+                    // Case 2: Multiple branches encoded in jump table\n+                    if (jumpOffset) {\n+                        var value = char - jumpOffset;\n+                        return value < 0 || value >= branchCount ? -1 : decodeTree[nodeIdx + value] - 1;\n                     }\n-                    if (!exeContext.schema.isSubType(returnType, runtimeType)) {\n-                        throw new _GraphQLError.GraphQLError(`Runtime Object type \"${runtimeType.name}\" is not a possible type for \"${returnType.name}\".`, {\n-                            nodes: fieldNodes\n-                        });\n+                    // Case 3: Multiple branches encoded in dictionary\n+                    // Binary search for the character.\n+                    var lo = nodeIdx;\n+                    var hi = lo + branchCount - 1;\n+                    while (lo <= hi) {\n+                        var mid = lo + hi >>> 1;\n+                        var midVal = decodeTree[mid];\n+                        if (midVal < char) {\n+                            lo = mid + 1;\n+                        } else if (midVal > char) {\n+                            hi = mid - 1;\n+                        } else {\n+                            return decodeTree[mid + branchCount];\n+                        }\n                     }\n-                    return runtimeType;\n+                    return -1;\n                 }\n+                exports.determineBranch = determineBranch;\n+                var htmlDecoder = getDecoder(decode_data_html_js_1.default);\n+                var xmlDecoder = getDecoder(decode_data_xml_js_1.default);\n                 /**\n-                 * Complete an Object value by executing all sub-selections.\n+                 * Decodes an HTML string.\n+                 *\n+                 * @param str The string to decode.\n+                 * @param mode The decoding mode.\n+                 * @returns The decoded string.\n                  */\n-\n-                function completeObjectValue(exeContext, returnType, fieldNodes, info, path, result) {\n-                    // Collect sub-fields to execute to complete this value.\n-                    const subFieldNodes = collectSubfields(exeContext, returnType, fieldNodes); // If there is an isTypeOf predicate function, call it with the\n-                    // current result. If isTypeOf returns false, then raise an error rather\n-                    // than continuing execution.\n-\n-                    if (returnType.isTypeOf) {\n-                        const isTypeOf = returnType.isTypeOf(result, exeContext.contextValue, info);\n-                        if ((0, _isPromise.isPromise)(isTypeOf)) {\n-                            return isTypeOf.then(resolvedIsTypeOf => {\n-                                if (!resolvedIsTypeOf) {\n-                                    throw invalidReturnTypeError(returnType, result, fieldNodes);\n-                                }\n-                                return executeFields(exeContext, returnType, result, path, subFieldNodes);\n-                            });\n-                        }\n-                        if (!isTypeOf) {\n-                            throw invalidReturnTypeError(returnType, result, fieldNodes);\n-                        }\n+                function decodeHTML(str, mode) {\n+                    if (mode === void 0) {\n+                        mode = DecodingMode.Legacy;\n                     }\n-                    return executeFields(exeContext, returnType, result, path, subFieldNodes);\n-                }\n-\n-                function invalidReturnTypeError(returnType, result, fieldNodes) {\n-                    return new _GraphQLError.GraphQLError(`Expected value of type \"${returnType.name}\" but got: ${(0, _inspect.inspect)(result)}.`, {\n-                        nodes: fieldNodes\n-                    });\n+                    return htmlDecoder(str, mode);\n                 }\n+                exports.decodeHTML = decodeHTML;\n                 /**\n-                 * If a resolveType function is not given, then a default resolve behavior is\n-                 * used which attempts two strategies:\n-                 *\n-                 * First, See if the provided value has a `__typename` field defined, if so, use\n-                 * that value as name of the resolved type.\n+                 * Decodes an HTML string in an attribute.\n                  *\n-                 * Otherwise, test each possible type for the abstract type by calling\n-                 * isTypeOf for the object being coerced, returning the first type that matches.\n+                 * @param str The string to decode.\n+                 * @returns The decoded string.\n                  */\n-\n-                const defaultTypeResolver = function(value, contextValue, info, abstractType) {\n-                    // First, look for `__typename`.\n-                    if ((0, _isObjectLike.isObjectLike)(value) && typeof value.__typename === 'string') {\n-                        return value.__typename;\n-                    } // Otherwise, test each possible type.\n-\n-                    const possibleTypes = info.schema.getPossibleTypes(abstractType);\n-                    const promisedIsTypeOfResults = [];\n-                    for (let i = 0; i < possibleTypes.length; i++) {\n-                        const type = possibleTypes[i];\n-                        if (type.isTypeOf) {\n-                            const isTypeOfResult = type.isTypeOf(value, contextValue, info);\n-                            if ((0, _isPromise.isPromise)(isTypeOfResult)) {\n-                                promisedIsTypeOfResults[i] = isTypeOfResult;\n-                            } else if (isTypeOfResult) {\n-                                return type.name;\n-                            }\n-                        }\n-                    }\n-                    if (promisedIsTypeOfResults.length) {\n-                        return Promise.all(promisedIsTypeOfResults).then(isTypeOfResults => {\n-                            for (let i = 0; i < isTypeOfResults.length; i++) {\n-                                if (isTypeOfResults[i]) {\n-                                    return possibleTypes[i].name;\n-                                }\n-                            }\n-                        });\n-                    }\n-                };\n+                function decodeHTMLAttribute(str) {\n+                    return htmlDecoder(str, DecodingMode.Attribute);\n+                }\n+                exports.decodeHTMLAttribute = decodeHTMLAttribute;\n                 /**\n-                 * If a resolve function is not given, then a default resolve behavior is used\n-                 * which takes the property of the source object of the same name as the field\n-                 * and returns it as the result, or if it's a function, returns the result\n-                 * of calling that function while passing along args and context value.\n+                 * Decodes an HTML string, requiring all entities to be terminated by a semicolon.\n+                 *\n+                 * @param str The string to decode.\n+                 * @returns The decoded string.\n                  */\n-                exports.defaultTypeResolver = defaultTypeResolver;\n-                const defaultFieldResolver = function(source, args, contextValue, info) {\n-                    // ensure source is a value for which property access is acceptable.\n-                    if ((0, _isObjectLike.isObjectLike)(source) || typeof source === 'function') {\n-                        const property = source[info.fieldName];\n-                        if (typeof property === 'function') {\n-                            return source[info.fieldName](args, contextValue, info);\n-                        }\n-                        return property;\n-                    }\n-                };\n+                function decodeHTMLStrict(str) {\n+                    return htmlDecoder(str, DecodingMode.Strict);\n+                }\n+                exports.decodeHTMLStrict = decodeHTMLStrict;\n                 /**\n-                 * This method looks up the field on the given type definition.\n-                 * It has special casing for the three introspection fields,\n-                 * __schema, __type and __typename. __typename is special because\n-                 * it can always be queried as a field, even in situations where no\n-                 * other fields are allowed, like on a Union. __schema and __type\n-                 * could get automatically added to the query type, but that would\n-                 * require mutating type definitions, which would cause issues.\n+                 * Decodes an XML string, requiring all entities to be terminated by a semicolon.\n                  *\n-                 * @internal\n+                 * @param str The string to decode.\n+                 * @returns The decoded string.\n                  */\n-                exports.defaultFieldResolver = defaultFieldResolver;\n-\n-                function getFieldDef(schema, parentType, fieldNode) {\n-                    const fieldName = fieldNode.name.value;\n-                    if (fieldName === _introspection.SchemaMetaFieldDef.name && schema.getQueryType() === parentType) {\n-                        return _introspection.SchemaMetaFieldDef;\n-                    } else if (fieldName === _introspection.TypeMetaFieldDef.name && schema.getQueryType() === parentType) {\n-                        return _introspection.TypeMetaFieldDef;\n-                    } else if (fieldName === _introspection.TypeNameMetaFieldDef.name) {\n-                        return _introspection.TypeNameMetaFieldDef;\n-                    }\n-                    return parentType.getFields()[fieldName];\n+                function decodeXML(str) {\n+                    return xmlDecoder(str, DecodingMode.Strict);\n                 }\n+                exports.decodeXML = decodeXML;\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/graphql/execution/index.mjs\":\n-            /*!*********************************************************!*\\\n-              !*** ../../../node_modules/graphql/execution/index.mjs ***!\n-              \\*********************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                Object.defineProperty(exports, \"createSourceEventStream\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _subscribe.createSourceEventStream;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"defaultFieldResolver\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _execute.defaultFieldResolver;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"defaultTypeResolver\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _execute.defaultTypeResolver;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"execute\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _execute.execute;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"executeSync\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _execute.executeSync;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"getArgumentValues\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _values.getArgumentValues;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"getDirectiveValues\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _values.getDirectiveValues;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"getVariableValues\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _values.getVariableValues;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"responsePathAsArray\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _Path.pathToArray;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"subscribe\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _subscribe.subscribe;\n-                    }\n-                }));\n-                var _Path = __webpack_require__( /*! ../jsutils/Path.mjs */ \"../../../node_modules/graphql/jsutils/Path.mjs\");\n-                var _execute = __webpack_require__( /*! ./execute.mjs */ \"../../../node_modules/graphql/execution/execute.mjs\");\n-                var _subscribe = __webpack_require__( /*! ./subscribe.mjs */ \"../../../node_modules/graphql/execution/subscribe.mjs\");\n-                var _values = __webpack_require__( /*! ./values.mjs */ \"../../../node_modules/graphql/execution/values.mjs\");\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/graphql/execution/mapAsyncIterator.mjs\":\n-            /*!********************************************************************!*\\\n-              !*** ../../../node_modules/graphql/execution/mapAsyncIterator.mjs ***!\n-              \\********************************************************************/\n+        \"../../../node_modules/entities/lib/decode_codepoint.js\":\n+            /*!**************************************************************!*\\\n+              !*** ../../../node_modules/entities/lib/decode_codepoint.js ***!\n+              \\**************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n+                // Adapted from https://github.com/mathiasbynens/he/blob/36afe179392226cf1b6ccdb16ebbb7a5a844d93a/src/he.js#L106-L134\n+                var _a;\n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports.mapAsyncIterator = mapAsyncIterator;\n+                exports.replaceCodePoint = exports.fromCodePoint = void 0;\n+                var decodeMap = new Map([\n+                    [0, 65533],\n+                    // C1 Unicode control character reference replacements\n+                    [128, 8364],\n+                    [130, 8218],\n+                    [131, 402],\n+                    [132, 8222],\n+                    [133, 8230],\n+                    [134, 8224],\n+                    [135, 8225],\n+                    [136, 710],\n+                    [137, 8240],\n+                    [138, 352],\n+                    [139, 8249],\n+                    [140, 338],\n+                    [142, 381],\n+                    [145, 8216],\n+                    [146, 8217],\n+                    [147, 8220],\n+                    [148, 8221],\n+                    [149, 8226],\n+                    [150, 8211],\n+                    [151, 8212],\n+                    [152, 732],\n+                    [153, 8482],\n+                    [154, 353],\n+                    [155, 8250],\n+                    [156, 339],\n+                    [158, 382],\n+                    [159, 376]\n+                ]);\n                 /**\n-                 * Given an AsyncIterable and a callback function, return an AsyncIterator\n-                 * which produces values mapped via calling the callback function.\n+                 * Polyfill for `String.fromCodePoint`. It is used to create a string from a Unicode code point.\n                  */\n-                function mapAsyncIterator(iterable, callback) {\n-                    const iterator = iterable[Symbol.asyncIterator]();\n-                    async function mapResult(result) {\n-                        if (result.done) {\n-                            return result;\n-                        }\n-                        try {\n-                            return {\n-                                value: await callback(result.value),\n-                                done: false\n-                            };\n-                        } catch (error) {\n-                            /* c8 ignore start */\n-                            // FIXME: add test case\n-                            if (typeof iterator.return === 'function') {\n-                                try {\n-                                    await iterator.return();\n-                                } catch (_e) {\n-                                    /* ignore error */\n-                                }\n-                            }\n-                            throw error;\n-                            /* c8 ignore stop */\n-                        }\n-                    }\n-\n-                    return {\n-                        async next() {\n-                            return mapResult(await iterator.next());\n-                        },\n-                        async return () {\n-                            // If iterator.return() does not exist, then type R must be undefined.\n-                            return typeof iterator.return === 'function' ? mapResult(await iterator.return()) : {\n-                                value: undefined,\n-                                done: true\n-                            };\n-                        },\n-                        async throw (error) {\n-                            if (typeof iterator.throw === 'function') {\n-                                return mapResult(await iterator.throw(error));\n-                            }\n-                            throw error;\n-                        },\n-                        [Symbol.asyncIterator]() {\n-                            return this;\n+                exports.fromCodePoint =\n+                    // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition, node/no-unsupported-features/es-builtins\n+                    (_a = String.fromCodePoint) !== null && _a !== void 0 ? _a : function(codePoint) {\n+                        var output = \"\";\n+                        if (codePoint > 0xffff) {\n+                            codePoint -= 0x10000;\n+                            output += String.fromCharCode(codePoint >>> 10 & 0x3ff | 0xd800);\n+                            codePoint = 0xdc00 | codePoint & 0x3ff;\n                         }\n+                        output += String.fromCharCode(codePoint);\n+                        return output;\n                     };\n+                /**\n+                 * Replace the given code point with a replacement character if it is a\n+                 * surrogate or is outside the valid range. Otherwise return the code\n+                 * point unchanged.\n+                 */\n+                function replaceCodePoint(codePoint) {\n+                    var _a;\n+                    if (codePoint >= 0xd800 && codePoint <= 0xdfff || codePoint > 0x10ffff) {\n+                        return 0xfffd;\n+                    }\n+                    return (_a = decodeMap.get(codePoint)) !== null && _a !== void 0 ? _a : codePoint;\n+                }\n+                exports.replaceCodePoint = replaceCodePoint;\n+                /**\n+                 * Replace the code point if relevant, then convert it to a string.\n+                 *\n+                 * @deprecated Use `fromCodePoint(replaceCodePoint(codePoint))` instead.\n+                 * @param codePoint The code point to decode.\n+                 * @returns The decoded code point.\n+                 */\n+                function decodeCodePoint(codePoint) {\n+                    return (0, exports.fromCodePoint)(replaceCodePoint(codePoint));\n                 }\n+                exports[\"default\"] = decodeCodePoint;\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/graphql/execution/subscribe.mjs\":\n-            /*!*************************************************************!*\\\n-              !*** ../../../node_modules/graphql/execution/subscribe.mjs ***!\n-              \\*************************************************************/\n+        \"../../../node_modules/entities/lib/encode.js\":\n+            /*!****************************************************!*\\\n+              !*** ../../../node_modules/entities/lib/encode.js ***!\n+              \\****************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n+                var __importDefault = void 0 && (void 0).__importDefault || function(mod) {\n+                    return mod && mod.__esModule ? mod : {\n+                        \"default\": mod\n+                    };\n+                };\n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports.createSourceEventStream = createSourceEventStream;\n-                exports.subscribe = subscribe;\n-                var _devAssert = __webpack_require__( /*! ../jsutils/devAssert.mjs */ \"../../../node_modules/graphql/jsutils/devAssert.mjs\");\n-                var _inspect = __webpack_require__( /*! ../jsutils/inspect.mjs */ \"../../../node_modules/graphql/jsutils/inspect.mjs\");\n-                var _isAsyncIterable = __webpack_require__( /*! ../jsutils/isAsyncIterable.mjs */ \"../../../node_modules/graphql/jsutils/isAsyncIterable.mjs\");\n-                var _Path = __webpack_require__( /*! ../jsutils/Path.mjs */ \"../../../node_modules/graphql/jsutils/Path.mjs\");\n-                var _GraphQLError = __webpack_require__( /*! ../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n-                var _locatedError = __webpack_require__( /*! ../error/locatedError.mjs */ \"../../../node_modules/graphql/error/locatedError.mjs\");\n-                var _collectFields = __webpack_require__( /*! ./collectFields.mjs */ \"../../../node_modules/graphql/execution/collectFields.mjs\");\n-                var _execute = __webpack_require__( /*! ./execute.mjs */ \"../../../node_modules/graphql/execution/execute.mjs\");\n-                var _mapAsyncIterator = __webpack_require__( /*! ./mapAsyncIterator.mjs */ \"../../../node_modules/graphql/execution/mapAsyncIterator.mjs\");\n-                var _values = __webpack_require__( /*! ./values.mjs */ \"../../../node_modules/graphql/execution/values.mjs\");\n+                exports.encodeNonAsciiHTML = exports.encodeHTML = void 0;\n+                var encode_html_js_1 = __importDefault(__webpack_require__( /*! ./generated/encode-html.js */ \"../../../node_modules/entities/lib/generated/encode-html.js\"));\n+                var escape_js_1 = __webpack_require__( /*! ./escape.js */ \"../../../node_modules/entities/lib/escape.js\");\n+                var htmlReplacer = /[\\t\\n!-,./:-@[-`\\f{-}$\\x80-\\uFFFF]/g;\n                 /**\n-                 * Implements the \"Subscribe\" algorithm described in the GraphQL specification.\n-                 *\n-                 * Returns a Promise which resolves to either an AsyncIterator (if successful)\n-                 * or an ExecutionResult (error). The promise will be rejected if the schema or\n-                 * other arguments to this function are invalid, or if the resolved event stream\n-                 * is not an async iterable.\n-                 *\n-                 * If the client-provided arguments to this function do not result in a\n-                 * compliant subscription, a GraphQL Response (ExecutionResult) with\n-                 * descriptive errors and no data will be returned.\n-                 *\n-                 * If the source stream could not be created due to faulty subscription\n-                 * resolver logic or underlying systems, the promise will resolve to a single\n-                 * ExecutionResult containing `errors` and no `data`.\n+                 * Encodes all characters in the input using HTML entities. This includes\n+                 * characters that are valid ASCII characters in HTML documents, such as `#`.\n                  *\n-                 * If the operation succeeded, the promise resolves to an AsyncIterator, which\n-                 * yields a stream of ExecutionResults representing the response stream.\n+                 * To get a more compact output, consider using the `encodeNonAsciiHTML`\n+                 * function, which will only encode characters that are not valid in HTML\n+                 * documents, as well as non-ASCII characters.\n                  *\n-                 * Accepts either an object with named arguments, or individual arguments.\n+                 * If a character has no equivalent entity, a numeric hexadecimal reference\n+                 * (eg. `&#xfc;`) will be used.\n                  */\n-\n-                async function subscribe(args) {\n-                    // Temporary for v15 to v16 migration. Remove in v17\n-                    arguments.length < 2 || (0, _devAssert.devAssert)(false, 'graphql@16 dropped long-deprecated support for positional arguments, please pass an object instead.');\n-                    const resultOrStream = await createSourceEventStream(args);\n-                    if (!(0, _isAsyncIterable.isAsyncIterable)(resultOrStream)) {\n-                        return resultOrStream;\n-                    } // For each payload yielded from a subscription, map it over the normal\n-                    // GraphQL `execute` function, with `payload` as the rootValue.\n-                    // This implements the \"MapSourceToResponseEvent\" algorithm described in\n-                    // the GraphQL specification. The `execute` function provides the\n-                    // \"ExecuteSubscriptionEvent\" algorithm, as it is nearly identical to the\n-                    // \"ExecuteQuery\" algorithm, for which `execute` is also used.\n-\n-                    const mapSourceToResponse = payload => (0, _execute.execute)({\n-                        ...args,\n-                        rootValue: payload\n-                    }); // Map every source value to a ExecutionResult value as described above.\n-\n-                    return (0, _mapAsyncIterator.mapAsyncIterator)(resultOrStream, mapSourceToResponse);\n-                }\n-\n-                function toNormalizedArgs(args) {\n-                    const firstArg = args[0];\n-                    if (firstArg && 'document' in firstArg) {\n-                        return firstArg;\n-                    }\n-                    return {\n-                        schema: firstArg,\n-                        // FIXME: when underlying TS bug fixed, see https://github.com/microsoft/TypeScript/issues/31613\n-                        document: args[1],\n-                        rootValue: args[2],\n-                        contextValue: args[3],\n-                        variableValues: args[4],\n-                        operationName: args[5],\n-                        subscribeFieldResolver: args[6]\n-                    };\n+                function encodeHTML(data) {\n+                    return encodeHTMLTrieRe(htmlReplacer, data);\n                 }\n+                exports.encodeHTML = encodeHTML;\n                 /**\n-                 * Implements the \"CreateSourceEventStream\" algorithm described in the\n-                 * GraphQL specification, resolving the subscription source event stream.\n-                 *\n-                 * Returns a Promise which resolves to either an AsyncIterable (if successful)\n-                 * or an ExecutionResult (error). The promise will be rejected if the schema or\n-                 * other arguments to this function are invalid, or if the resolved event stream\n-                 * is not an async iterable.\n-                 *\n-                 * If the client-provided arguments to this function do not result in a\n-                 * compliant subscription, a GraphQL Response (ExecutionResult) with\n-                 * descriptive errors and no data will be returned.\n-                 *\n-                 * If the the source stream could not be created due to faulty subscription\n-                 * resolver logic or underlying systems, the promise will resolve to a single\n-                 * ExecutionResult containing `errors` and no `data`.\n-                 *\n-                 * If the operation succeeded, the promise resolves to the AsyncIterable for the\n-                 * event stream returned by the resolver.\n-                 *\n-                 * A Source Event Stream represents a sequence of events, each of which triggers\n-                 * a GraphQL execution for that event.\n+                 * Encodes all non-ASCII characters, as well as characters not valid in HTML\n+                 * documents using HTML entities. This function will not encode characters that\n+                 * are valid in HTML documents, such as `#`.\n                  *\n-                 * This may be useful when hosting the stateful subscription service in a\n-                 * different process or machine than the stateless GraphQL execution engine,\n-                 * or otherwise separating these two steps. For more on this, see the\n-                 * \"Supporting Subscriptions at Scale\" information in the GraphQL specification.\n+                 * If a character has no equivalent entity, a numeric hexadecimal reference\n+                 * (eg. `&#xfc;`) will be used.\n                  */\n-\n-                async function createSourceEventStream() {\n-                    for (var _len = arguments.length, rawArgs = new Array(_len), _key = 0; _key < _len; _key++) {\n-                        rawArgs[_key] = arguments[_key];\n-                    }\n-                    const args = toNormalizedArgs(rawArgs);\n-                    const {\n-                        schema,\n-                        document,\n-                        variableValues\n-                    } = args; // If arguments are missing or incorrectly typed, this is an internal\n-                    // developer mistake which should throw an early error.\n-\n-                    (0, _execute.assertValidExecutionArguments)(schema, document, variableValues); // If a valid execution context cannot be created due to incorrect arguments,\n-                    // a \"Response\" with only errors is returned.\n-\n-                    const exeContext = (0, _execute.buildExecutionContext)(args); // Return early errors if execution context failed.\n-\n-                    if (!('schema' in exeContext)) {\n-                        return {\n-                            errors: exeContext\n-                        };\n-                    }\n-                    try {\n-                        const eventStream = await executeSubscription(exeContext); // Assert field returned an event stream, otherwise yield an error.\n-\n-                        if (!(0, _isAsyncIterable.isAsyncIterable)(eventStream)) {\n-                            throw new Error('Subscription field must return Async Iterable. ' + `Received: ${(0, _inspect.inspect)(eventStream)}.`);\n-                        }\n-                        return eventStream;\n-                    } catch (error) {\n-                        // If it GraphQLError, report it as an ExecutionResult, containing only errors and no data.\n-                        // Otherwise treat the error as a system-class error and re-throw it.\n-                        if (error instanceof _GraphQLError.GraphQLError) {\n-                            return {\n-                                errors: [error]\n-                            };\n-                        }\n-                        throw error;\n-                    }\n+                function encodeNonAsciiHTML(data) {\n+                    return encodeHTMLTrieRe(escape_js_1.xmlReplacer, data);\n                 }\n-                async function executeSubscription(exeContext) {\n-                    const {\n-                        schema,\n-                        fragments,\n-                        operation,\n-                        variableValues,\n-                        rootValue\n-                    } = exeContext;\n-                    const rootType = schema.getSubscriptionType();\n-                    if (rootType == null) {\n-                        throw new _GraphQLError.GraphQLError('Schema is not configured to execute subscription operation.', {\n-                            nodes: operation\n-                        });\n-                    }\n-                    const rootFields = (0, _collectFields.collectFields)(schema, fragments, variableValues, rootType, operation.selectionSet);\n-                    const [responseName, fieldNodes] = [...rootFields.entries()][0];\n-                    const fieldDef = (0, _execute.getFieldDef)(schema, rootType, fieldNodes[0]);\n-                    if (!fieldDef) {\n-                        const fieldName = fieldNodes[0].name.value;\n-                        throw new _GraphQLError.GraphQLError(`The subscription field \"${fieldName}\" is not defined.`, {\n-                            nodes: fieldNodes\n-                        });\n-                    }\n-                    const path = (0, _Path.addPath)(undefined, responseName, rootType.name);\n-                    const info = (0, _execute.buildResolveInfo)(exeContext, fieldDef, fieldNodes, rootType, path);\n-                    try {\n-                        var _fieldDef$subscribe;\n-\n-                        // Implements the \"ResolveFieldEventStream\" algorithm from GraphQL specification.\n-                        // It differs from \"ResolveFieldValue\" due to providing a different `resolveFn`.\n-                        // Build a JS object of arguments from the field.arguments AST, using the\n-                        // variables scope to fulfill any variable references.\n-                        const args = (0, _values.getArgumentValues)(fieldDef, fieldNodes[0], variableValues); // The resolve function's optional third argument is a context value that\n-                        // is provided to every resolve function within an execution. It is commonly\n-                        // used to represent an authenticated user, or request-specific caches.\n-\n-                        const contextValue = exeContext.contextValue; // Call the `subscribe()` resolver or the default resolver to produce an\n-                        // AsyncIterable yielding raw payloads.\n+                exports.encodeNonAsciiHTML = encodeNonAsciiHTML;\n \n-                        const resolveFn = (_fieldDef$subscribe = fieldDef.subscribe) !== null && _fieldDef$subscribe !== void 0 ? _fieldDef$subscribe : exeContext.subscribeFieldResolver;\n-                        const eventStream = await resolveFn(rootValue, args, contextValue, info);\n-                        if (eventStream instanceof Error) {\n-                            throw eventStream;\n+                function encodeHTMLTrieRe(regExp, str) {\n+                    var ret = \"\";\n+                    var lastIdx = 0;\n+                    var match;\n+                    while ((match = regExp.exec(str)) !== null) {\n+                        var i = match.index;\n+                        ret += str.substring(lastIdx, i);\n+                        var char = str.charCodeAt(i);\n+                        var next = encode_html_js_1.default.get(char);\n+                        if (typeof next === \"object\") {\n+                            // We are in a branch. Try to match the next char.\n+                            if (i + 1 < str.length) {\n+                                var nextChar = str.charCodeAt(i + 1);\n+                                var value = typeof next.n === \"number\" ? next.n === nextChar ? next.o : undefined : next.n.get(nextChar);\n+                                if (value !== undefined) {\n+                                    ret += value;\n+                                    lastIdx = regExp.lastIndex += 1;\n+                                    continue;\n+                                }\n+                            }\n+                            next = next.v;\n+                        }\n+                        // We might have a tree node without a value; skip and use a numeric entity.\n+                        if (next !== undefined) {\n+                            ret += next;\n+                            lastIdx = i + 1;\n+                        } else {\n+                            var cp = (0, escape_js_1.getCodePoint)(str, i);\n+                            ret += \"&#x\".concat(cp.toString(16), \";\");\n+                            // Increase by 1 if we have a surrogate pair\n+                            lastIdx = regExp.lastIndex += Number(cp !== char);\n                         }\n-                        return eventStream;\n-                    } catch (error) {\n-                        throw (0, _locatedError.locatedError)(error, fieldNodes, (0, _Path.pathToArray)(path));\n                     }\n+                    return ret + str.substr(lastIdx);\n                 }\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/graphql/execution/values.mjs\":\n-            /*!**********************************************************!*\\\n-              !*** ../../../node_modules/graphql/execution/values.mjs ***!\n-              \\**********************************************************/\n+        \"../../../node_modules/entities/lib/escape.js\":\n+            /*!****************************************************!*\\\n+              !*** ../../../node_modules/entities/lib/escape.js ***!\n+              \\****************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+            (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports.getArgumentValues = getArgumentValues;\n-                exports.getDirectiveValues = getDirectiveValues;\n-                exports.getVariableValues = getVariableValues;\n-                var _inspect = __webpack_require__( /*! ../jsutils/inspect.mjs */ \"../../../node_modules/graphql/jsutils/inspect.mjs\");\n-                var _keyMap = __webpack_require__( /*! ../jsutils/keyMap.mjs */ \"../../../node_modules/graphql/jsutils/keyMap.mjs\");\n-                var _printPathArray = __webpack_require__( /*! ../jsutils/printPathArray.mjs */ \"../../../node_modules/graphql/jsutils/printPathArray.mjs\");\n-                var _GraphQLError = __webpack_require__( /*! ../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n-                var _kinds = __webpack_require__( /*! ../language/kinds.mjs */ \"../../../node_modules/graphql/language/kinds.mjs\");\n-                var _printer = __webpack_require__( /*! ../language/printer.mjs */ \"../../../node_modules/graphql/language/printer.mjs\");\n-                var _definition = __webpack_require__( /*! ../type/definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n-                var _coerceInputValue = __webpack_require__( /*! ../utilities/coerceInputValue.mjs */ \"../../../node_modules/graphql/utilities/coerceInputValue.mjs\");\n-                var _typeFromAST = __webpack_require__( /*! ../utilities/typeFromAST.mjs */ \"../../../node_modules/graphql/utilities/typeFromAST.mjs\");\n-                var _valueFromAST = __webpack_require__( /*! ../utilities/valueFromAST.mjs */ \"../../../node_modules/graphql/utilities/valueFromAST.mjs\");\n+                exports.escapeText = exports.escapeAttribute = exports.escapeUTF8 = exports.escape = exports.encodeXML = exports.getCodePoint = exports.xmlReplacer = void 0;\n+                exports.xmlReplacer = /[\"&'<>$\\x80-\\uFFFF]/g;\n+                var xmlCodeMap = new Map([\n+                    [34, \"&quot;\"],\n+                    [38, \"&amp;\"],\n+                    [39, \"&apos;\"],\n+                    [60, \"&lt;\"],\n+                    [62, \"&gt;\"]\n+                ]);\n+                // For compatibility with node < 4, we wrap `codePointAt`\n+                exports.getCodePoint =\n+                    // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n+                    String.prototype.codePointAt != null ? function(str, index) {\n+                        return str.codePointAt(index);\n+                    } :\n+                    // http://mathiasbynens.be/notes/javascript-encoding#surrogate-formulae\n+                    function(c, index) {\n+                        return (c.charCodeAt(index) & 0xfc00) === 0xd800 ? (c.charCodeAt(index) - 0xd800) * 0x400 + c.charCodeAt(index + 1) - 0xdc00 + 0x10000 : c.charCodeAt(index);\n+                    };\n                 /**\n-                 * Prepares an object map of variableValues of the correct type based on the\n-                 * provided variable definitions and arbitrary input. If the input cannot be\n-                 * parsed to match the variable definitions, a GraphQLError will be thrown.\n+                 * Encodes all non-ASCII characters, as well as characters not valid in XML\n+                 * documents using XML entities.\n                  *\n-                 * Note: The returned value is a plain Object with a prototype, since it is\n-                 * exposed to user code. Care should be taken to not pull values from the\n-                 * Object prototype.\n+                 * If a character has no equivalent entity, a\n+                 * numeric hexadecimal reference (eg. `&#xfc;`) will be used.\n                  */\n-                function getVariableValues(schema, varDefNodes, inputs, options) {\n-                    const errors = [];\n-                    const maxErrors = options === null || options === void 0 ? void 0 : options.maxErrors;\n-                    try {\n-                        const coerced = coerceVariableValues(schema, varDefNodes, inputs, error => {\n-                            if (maxErrors != null && errors.length >= maxErrors) {\n-                                throw new _GraphQLError.GraphQLError('Too many errors processing variables, error limit reached. Execution aborted.');\n-                            }\n-                            errors.push(error);\n-                        });\n-                        if (errors.length === 0) {\n-                            return {\n-                                coerced\n-                            };\n-                        }\n-                    } catch (error) {\n-                        errors.push(error);\n-                    }\n-                    return {\n-                        errors\n-                    };\n-                }\n-\n-                function coerceVariableValues(schema, varDefNodes, inputs, onError) {\n-                    const coercedValues = {};\n-                    for (const varDefNode of varDefNodes) {\n-                        const varName = varDefNode.variable.name.value;\n-                        const varType = (0, _typeFromAST.typeFromAST)(schema, varDefNode.type);\n-                        if (!(0, _definition.isInputType)(varType)) {\n-                            // Must use input types for variables. This should be caught during\n-                            // validation, however is checked again here for safety.\n-                            const varTypeStr = (0, _printer.print)(varDefNode.type);\n-                            onError(new _GraphQLError.GraphQLError(`Variable \"$${varName}\" expected value of type \"${varTypeStr}\" which cannot be used as an input type.`, {\n-                                nodes: varDefNode.type\n-                            }));\n-                            continue;\n-                        }\n-                        if (!hasOwnProperty(inputs, varName)) {\n-                            if (varDefNode.defaultValue) {\n-                                coercedValues[varName] = (0, _valueFromAST.valueFromAST)(varDefNode.defaultValue, varType);\n-                            } else if ((0, _definition.isNonNullType)(varType)) {\n-                                const varTypeStr = (0, _inspect.inspect)(varType);\n-                                onError(new _GraphQLError.GraphQLError(`Variable \"$${varName}\" of required type \"${varTypeStr}\" was not provided.`, {\n-                                    nodes: varDefNode\n-                                }));\n-                            }\n-                            continue;\n-                        }\n-                        const value = inputs[varName];\n-                        if (value === null && (0, _definition.isNonNullType)(varType)) {\n-                            const varTypeStr = (0, _inspect.inspect)(varType);\n-                            onError(new _GraphQLError.GraphQLError(`Variable \"$${varName}\" of non-null type \"${varTypeStr}\" must not be null.`, {\n-                                nodes: varDefNode\n-                            }));\n-                            continue;\n+                function encodeXML(str) {\n+                    var ret = \"\";\n+                    var lastIdx = 0;\n+                    var match;\n+                    while ((match = exports.xmlReplacer.exec(str)) !== null) {\n+                        var i = match.index;\n+                        var char = str.charCodeAt(i);\n+                        var next = xmlCodeMap.get(char);\n+                        if (next !== undefined) {\n+                            ret += str.substring(lastIdx, i) + next;\n+                            lastIdx = i + 1;\n+                        } else {\n+                            ret += \"\".concat(str.substring(lastIdx, i), \"&#x\").concat((0, exports.getCodePoint)(str, i).toString(16), \";\");\n+                            // Increase by 1 if we have a surrogate pair\n+                            lastIdx = exports.xmlReplacer.lastIndex += Number((char & 0xfc00) === 0xd800);\n                         }\n-                        coercedValues[varName] = (0, _coerceInputValue.coerceInputValue)(value, varType, (path, invalidValue, error) => {\n-                            let prefix = `Variable \"$${varName}\" got invalid value ` + (0, _inspect.inspect)(invalidValue);\n-                            if (path.length > 0) {\n-                                prefix += ` at \"${varName}${(0, _printPathArray.printPathArray)(path)}\"`;\n-                            }\n-                            onError(new _GraphQLError.GraphQLError(prefix + '; ' + error.message, {\n-                                nodes: varDefNode,\n-                                originalError: error\n-                            }));\n-                        });\n                     }\n-                    return coercedValues;\n+                    return ret + str.substr(lastIdx);\n                 }\n+                exports.encodeXML = encodeXML;\n                 /**\n-                 * Prepares an object map of argument values given a list of argument\n-                 * definitions and list of argument AST nodes.\n+                 * Encodes all non-ASCII characters, as well as characters not valid in XML\n+                 * documents using numeric hexadecimal reference (eg. `&#xfc;`).\n                  *\n-                 * Note: The returned value is a plain Object with a prototype, since it is\n-                 * exposed to user code. Care should be taken to not pull values from the\n-                 * Object prototype.\n+                 * Have a look at `escapeUTF8` if you want a more concise output at the expense\n+                 * of reduced transportability.\n+                 *\n+                 * @param data String to escape.\n                  */\n-\n-                function getArgumentValues(def, node, variableValues) {\n-                    var _node$arguments;\n-                    const coercedValues = {}; // FIXME: https://github.com/graphql/graphql-js/issues/2203\n-\n-                    /* c8 ignore next */\n-\n-                    const argumentNodes = (_node$arguments = node.arguments) !== null && _node$arguments !== void 0 ? _node$arguments : [];\n-                    const argNodeMap = (0, _keyMap.keyMap)(argumentNodes, arg => arg.name.value);\n-                    for (const argDef of def.args) {\n-                        const name = argDef.name;\n-                        const argType = argDef.type;\n-                        const argumentNode = argNodeMap[name];\n-                        if (!argumentNode) {\n-                            if (argDef.defaultValue !== undefined) {\n-                                coercedValues[name] = argDef.defaultValue;\n-                            } else if ((0, _definition.isNonNullType)(argType)) {\n-                                throw new _GraphQLError.GraphQLError(`Argument \"${name}\" of required type \"${(0, _inspect.inspect)(argType)}\" ` + 'was not provided.', {\n-                                    nodes: node\n-                                });\n-                            }\n-                            continue;\n-                        }\n-                        const valueNode = argumentNode.value;\n-                        let isNull = valueNode.kind === _kinds.Kind.NULL;\n-                        if (valueNode.kind === _kinds.Kind.VARIABLE) {\n-                            const variableName = valueNode.name.value;\n-                            if (variableValues == null || !hasOwnProperty(variableValues, variableName)) {\n-                                if (argDef.defaultValue !== undefined) {\n-                                    coercedValues[name] = argDef.defaultValue;\n-                                } else if ((0, _definition.isNonNullType)(argType)) {\n-                                    throw new _GraphQLError.GraphQLError(`Argument \"${name}\" of required type \"${(0, _inspect.inspect)(argType)}\" ` + `was provided the variable \"$${variableName}\" which was not provided a runtime value.`, {\n-                                        nodes: valueNode\n-                                    });\n-                                }\n-                                continue;\n+                exports.escape = encodeXML;\n+                /**\n+                 * Creates a function that escapes all characters matched by the given regular\n+                 * expression using the given map of characters to escape to their entities.\n+                 *\n+                 * @param regex Regular expression to match characters to escape.\n+                 * @param map Map of characters to escape to their entities.\n+                 *\n+                 * @returns Function that escapes all characters matched by the given regular\n+                 * expression using the given map of characters to escape to their entities.\n+                 */\n+                function getEscaper(regex, map) {\n+                    return function escape(data) {\n+                        var match;\n+                        var lastIdx = 0;\n+                        var result = \"\";\n+                        while (match = regex.exec(data)) {\n+                            if (lastIdx !== match.index) {\n+                                result += data.substring(lastIdx, match.index);\n                             }\n-                            isNull = variableValues[variableName] == null;\n-                        }\n-                        if (isNull && (0, _definition.isNonNullType)(argType)) {\n-                            throw new _GraphQLError.GraphQLError(`Argument \"${name}\" of non-null type \"${(0, _inspect.inspect)(argType)}\" ` + 'must not be null.', {\n-                                nodes: valueNode\n-                            });\n-                        }\n-                        const coercedValue = (0, _valueFromAST.valueFromAST)(valueNode, argType, variableValues);\n-                        if (coercedValue === undefined) {\n-                            // Note: ValuesOfCorrectTypeRule validation should catch this before\n-                            // execution. This is a runtime check to ensure execution does not\n-                            // continue with an invalid argument value.\n-                            throw new _GraphQLError.GraphQLError(`Argument \"${name}\" has invalid value ${(0, _printer.print)(valueNode)}.`, {\n-                                nodes: valueNode\n-                            });\n+                            // We know that this character will be in the map.\n+                            result += map.get(match[0].charCodeAt(0));\n+                            // Every match will be of length 1\n+                            lastIdx = match.index + 1;\n                         }\n-                        coercedValues[name] = coercedValue;\n-                    }\n-                    return coercedValues;\n+                        return result + data.substring(lastIdx);\n+                    };\n                 }\n                 /**\n-                 * Prepares an object map of argument values given a directive definition\n-                 * and a AST node which may contain directives. Optionally also accepts a map\n-                 * of variable values.\n+                 * Encodes all characters not valid in XML documents using XML entities.\n                  *\n-                 * If the directive does not exist on the node, returns undefined.\n+                 * Note that the output will be character-set dependent.\n                  *\n-                 * Note: The returned value is a plain Object with a prototype, since it is\n-                 * exposed to user code. Care should be taken to not pull values from the\n-                 * Object prototype.\n+                 * @param data String to escape.\n                  */\n-\n-                function getDirectiveValues(directiveDef, node, variableValues) {\n-                    var _node$directives;\n-                    const directiveNode = (_node$directives = node.directives) === null || _node$directives === void 0 ? void 0 : _node$directives.find(directive => directive.name.value === directiveDef.name);\n-                    if (directiveNode) {\n-                        return getArgumentValues(directiveDef, directiveNode, variableValues);\n-                    }\n-                }\n-\n-                function hasOwnProperty(obj, prop) {\n-                    return Object.prototype.hasOwnProperty.call(obj, prop);\n-                }\n+                exports.escapeUTF8 = getEscaper(/[&<>'\"]/g, xmlCodeMap);\n+                /**\n+                 * Encodes all characters that have to be escaped in HTML attributes,\n+                 * following {@link https://html.spec.whatwg.org/multipage/parsing.html#escapingString}.\n+                 *\n+                 * @param data String to escape.\n+                 */\n+                exports.escapeAttribute = getEscaper(/[\"&\\u00A0]/g, new Map([\n+                    [34, \"&quot;\"],\n+                    [38, \"&amp;\"],\n+                    [160, \"&nbsp;\"]\n+                ]));\n+                /**\n+                 * Encodes all characters that have to be escaped in HTML text,\n+                 * following {@link https://html.spec.whatwg.org/multipage/parsing.html#escapingString}.\n+                 *\n+                 * @param data String to escape.\n+                 */\n+                exports.escapeText = getEscaper(/[&<>\\u00A0]/g, new Map([\n+                    [38, \"&amp;\"],\n+                    [60, \"&lt;\"],\n+                    [62, \"&gt;\"],\n+                    [160, \"&nbsp;\"]\n+                ]));\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/graphql/graphql.mjs\":\n-            /*!*************************************************!*\\\n-              !*** ../../../node_modules/graphql/graphql.mjs ***!\n-              \\*************************************************/\n+        \"../../../node_modules/entities/lib/generated/decode-data-html.js\":\n+            /*!************************************************************************!*\\\n+              !*** ../../../node_modules/entities/lib/generated/decode-data-html.js ***!\n+              \\************************************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+            (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n+                // Generated using scripts/write-decode-map.ts\n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports.graphql = graphql;\n-                exports.graphqlSync = graphqlSync;\n-                var _devAssert = __webpack_require__( /*! ./jsutils/devAssert.mjs */ \"../../../node_modules/graphql/jsutils/devAssert.mjs\");\n-                var _isPromise = __webpack_require__( /*! ./jsutils/isPromise.mjs */ \"../../../node_modules/graphql/jsutils/isPromise.mjs\");\n-                var _parser = __webpack_require__( /*! ./language/parser.mjs */ \"../../../node_modules/graphql/language/parser.mjs\");\n-                var _validate = __webpack_require__( /*! ./type/validate.mjs */ \"../../../node_modules/graphql/type/validate.mjs\");\n-                var _validate2 = __webpack_require__( /*! ./validation/validate.mjs */ \"../../../node_modules/graphql/validation/validate.mjs\");\n-                var _execute = __webpack_require__( /*! ./execution/execute.mjs */ \"../../../node_modules/graphql/execution/execute.mjs\");\n-                /**\n-                 * This is the primary entry point function for fulfilling GraphQL operations\n-                 * by parsing, validating, and executing a GraphQL document along side a\n-                 * GraphQL schema.\n-                 *\n-                 * More sophisticated GraphQL servers, such as those which persist queries,\n-                 * may wish to separate the validation and execution phases to a static time\n-                 * tooling step, and a server runtime step.\n-                 *\n-                 * Accepts either an object with named arguments, or individual arguments:\n-                 *\n-                 * schema:\n-                 *    The GraphQL type system to use when validating and executing a query.\n-                 * source:\n-                 *    A GraphQL language formatted string representing the requested operation.\n-                 * rootValue:\n-                 *    The value provided as the first argument to resolver functions on the top\n-                 *    level type (e.g. the query object type).\n-                 * contextValue:\n-                 *    The context value is provided as an argument to resolver functions after\n-                 *    field arguments. It is used to pass shared information useful at any point\n-                 *    during executing this query, for example the currently logged in user and\n-                 *    connections to databases or other services.\n-                 * variableValues:\n-                 *    A mapping of variable name to runtime value to use for all variables\n-                 *    defined in the requestString.\n-                 * operationName:\n-                 *    The name of the operation to use if requestString contains multiple\n-                 *    possible operations. Can be omitted if requestString contains only\n-                 *    one operation.\n-                 * fieldResolver:\n-                 *    A resolver function to use when one is not provided by the schema.\n-                 *    If not provided, the default field resolver is used (which looks for a\n-                 *    value or method on the source value with the field's name).\n-                 * typeResolver:\n-                 *    A type resolver function to use when none is provided by the schema.\n-                 *    If not provided, the default type resolver is used (which looks for a\n-                 *    `__typename` field or alternatively calls the `isTypeOf` method).\n-                 */\n+                exports[\"default\"] = new Uint16Array(\n+                    // prettier-ignore\n+                    \"\\u1d41<\\xd5\\u0131\\u028a\\u049d\\u057b\\u05d0\\u0675\\u06de\\u07a2\\u07d6\\u080f\\u0a4a\\u0a91\\u0da1\\u0e6d\\u0f09\\u0f26\\u10ca\\u1228\\u12e1\\u1415\\u149d\\u14c3\\u14df\\u1525\\0\\0\\0\\0\\0\\0\\u156b\\u16cd\\u198d\\u1c12\\u1ddd\\u1f7e\\u2060\\u21b0\\u228d\\u23c0\\u23fb\\u2442\\u2824\\u2912\\u2d08\\u2e48\\u2fce\\u3016\\u32ba\\u3639\\u37ac\\u38fe\\u3a28\\u3a71\\u3ae0\\u3b2e\\u0800EMabcfglmnoprstu\\\\bfms\\x7f\\x84\\x8b\\x90\\x95\\x98\\xa6\\xb3\\xb9\\xc8\\xcflig\\u803b\\xc6\\u40c6P\\u803b&\\u4026cute\\u803b\\xc1\\u40c1reve;\\u4102\\u0100iyx}rc\\u803b\\xc2\\u40c2;\\u4410r;\\uc000\\ud835\\udd04rave\\u803b\\xc0\\u40c0pha;\\u4391acr;\\u4100d;\\u6a53\\u0100gp\\x9d\\xa1on;\\u4104f;\\uc000\\ud835\\udd38plyFunction;\\u6061ing\\u803b\\xc5\\u40c5\\u0100cs\\xbe\\xc3r;\\uc000\\ud835\\udc9cign;\\u6254ilde\\u803b\\xc3\\u40c3ml\\u803b\\xc4\\u40c4\\u0400aceforsu\\xe5\\xfb\\xfe\\u0117\\u011c\\u0122\\u0127\\u012a\\u0100cr\\xea\\xf2kslash;\\u6216\\u0176\\xf6\\xf8;\\u6ae7ed;\\u6306y;\\u4411\\u0180crt\\u0105\\u010b\\u0114ause;\\u6235noullis;\\u612ca;\\u4392r;\\uc000\\ud835\\udd05pf;\\uc000\\ud835\\udd39eve;\\u42d8c\\xf2\\u0113mpeq;\\u624e\\u0700HOacdefhilorsu\\u014d\\u0151\\u0156\\u0180\\u019e\\u01a2\\u01b5\\u01b7\\u01ba\\u01dc\\u0215\\u0273\\u0278\\u027ecy;\\u4427PY\\u803b\\xa9\\u40a9\\u0180cpy\\u015d\\u0162\\u017aute;\\u4106\\u0100;i\\u0167\\u0168\\u62d2talDifferentialD;\\u6145leys;\\u612d\\u0200aeio\\u0189\\u018e\\u0194\\u0198ron;\\u410cdil\\u803b\\xc7\\u40c7rc;\\u4108nint;\\u6230ot;\\u410a\\u0100dn\\u01a7\\u01adilla;\\u40b8terDot;\\u40b7\\xf2\\u017fi;\\u43a7rcle\\u0200DMPT\\u01c7\\u01cb\\u01d1\\u01d6ot;\\u6299inus;\\u6296lus;\\u6295imes;\\u6297o\\u0100cs\\u01e2\\u01f8kwiseContourIntegral;\\u6232eCurly\\u0100DQ\\u0203\\u020foubleQuote;\\u601duote;\\u6019\\u0200lnpu\\u021e\\u0228\\u0247\\u0255on\\u0100;e\\u0225\\u0226\\u6237;\\u6a74\\u0180git\\u022f\\u0236\\u023aruent;\\u6261nt;\\u622fourIntegral;\\u622e\\u0100fr\\u024c\\u024e;\\u6102oduct;\\u6210nterClockwiseContourIntegral;\\u6233oss;\\u6a2fcr;\\uc000\\ud835\\udc9ep\\u0100;C\\u0284\\u0285\\u62d3ap;\\u624d\\u0580DJSZacefios\\u02a0\\u02ac\\u02b0\\u02b4\\u02b8\\u02cb\\u02d7\\u02e1\\u02e6\\u0333\\u048d\\u0100;o\\u0179\\u02a5trahd;\\u6911cy;\\u4402cy;\\u4405cy;\\u440f\\u0180grs\\u02bf\\u02c4\\u02c7ger;\\u6021r;\\u61a1hv;\\u6ae4\\u0100ay\\u02d0\\u02d5ron;\\u410e;\\u4414l\\u0100;t\\u02dd\\u02de\\u6207a;\\u4394r;\\uc000\\ud835\\udd07\\u0100af\\u02eb\\u0327\\u0100cm\\u02f0\\u0322ritical\\u0200ADGT\\u0300\\u0306\\u0316\\u031ccute;\\u40b4o\\u0174\\u030b\\u030d;\\u42d9bleAcute;\\u42ddrave;\\u4060ilde;\\u42dcond;\\u62c4ferentialD;\\u6146\\u0470\\u033d\\0\\0\\0\\u0342\\u0354\\0\\u0405f;\\uc000\\ud835\\udd3b\\u0180;DE\\u0348\\u0349\\u034d\\u40a8ot;\\u60dcqual;\\u6250ble\\u0300CDLRUV\\u0363\\u0372\\u0382\\u03cf\\u03e2\\u03f8ontourIntegra\\xec\\u0239o\\u0274\\u0379\\0\\0\\u037b\\xbb\\u0349nArrow;\\u61d3\\u0100eo\\u0387\\u03a4ft\\u0180ART\\u0390\\u0396\\u03a1rrow;\\u61d0ightArrow;\\u61d4e\\xe5\\u02cang\\u0100LR\\u03ab\\u03c4eft\\u0100AR\\u03b3\\u03b9rrow;\\u67f8ightArrow;\\u67faightArrow;\\u67f9ight\\u0100AT\\u03d8\\u03derrow;\\u61d2ee;\\u62a8p\\u0241\\u03e9\\0\\0\\u03efrrow;\\u61d1ownArrow;\\u61d5erticalBar;\\u6225n\\u0300ABLRTa\\u0412\\u042a\\u0430\\u045e\\u047f\\u037crrow\\u0180;BU\\u041d\\u041e\\u0422\\u6193ar;\\u6913pArrow;\\u61f5reve;\\u4311eft\\u02d2\\u043a\\0\\u0446\\0\\u0450ightVector;\\u6950eeVector;\\u695eector\\u0100;B\\u0459\\u045a\\u61bdar;\\u6956ight\\u01d4\\u0467\\0\\u0471eeVector;\\u695fector\\u0100;B\\u047a\\u047b\\u61c1ar;\\u6957ee\\u0100;A\\u0486\\u0487\\u62a4rrow;\\u61a7\\u0100ct\\u0492\\u0497r;\\uc000\\ud835\\udc9frok;\\u4110\\u0800NTacdfglmopqstux\\u04bd\\u04c0\\u04c4\\u04cb\\u04de\\u04e2\\u04e7\\u04ee\\u04f5\\u0521\\u052f\\u0536\\u0552\\u055d\\u0560\\u0565G;\\u414aH\\u803b\\xd0\\u40d0cute\\u803b\\xc9\\u40c9\\u0180aiy\\u04d2\\u04d7\\u04dcron;\\u411arc\\u803b\\xca\\u40ca;\\u442dot;\\u4116r;\\uc000\\ud835\\udd08rave\\u803b\\xc8\\u40c8ement;\\u6208\\u0100ap\\u04fa\\u04fecr;\\u4112ty\\u0253\\u0506\\0\\0\\u0512mallSquare;\\u65fberySmallSquare;\\u65ab\\u0100gp\\u0526\\u052aon;\\u4118f;\\uc000\\ud835\\udd3csilon;\\u4395u\\u0100ai\\u053c\\u0549l\\u0100;T\\u0542\\u0543\\u6a75ilde;\\u6242librium;\\u61cc\\u0100ci\\u0557\\u055ar;\\u6130m;\\u6a73a;\\u4397ml\\u803b\\xcb\\u40cb\\u0100ip\\u056a\\u056fsts;\\u6203onentialE;\\u6147\\u0280cfios\\u0585\\u0588\\u058d\\u05b2\\u05ccy;\\u4424r;\\uc000\\ud835\\udd09lled\\u0253\\u0597\\0\\0\\u05a3mallSquare;\\u65fcerySmallSquare;\\u65aa\\u0370\\u05ba\\0\\u05bf\\0\\0\\u05c4f;\\uc000\\ud835\\udd3dAll;\\u6200riertrf;\\u6131c\\xf2\\u05cb\\u0600JTabcdfgorst\\u05e8\\u05ec\\u05ef\\u05fa\\u0600\\u0612\\u0616\\u061b\\u061d\\u0623\\u066c\\u0672cy;\\u4403\\u803b>\\u403emma\\u0100;d\\u05f7\\u05f8\\u4393;\\u43dcreve;\\u411e\\u0180eiy\\u0607\\u060c\\u0610dil;\\u4122rc;\\u411c;\\u4413ot;\\u4120r;\\uc000\\ud835\\udd0a;\\u62d9pf;\\uc000\\ud835\\udd3eeater\\u0300EFGLST\\u0635\\u0644\\u064e\\u0656\\u065b\\u0666qual\\u0100;L\\u063e\\u063f\\u6265ess;\\u62dbullEqual;\\u6267reater;\\u6aa2ess;\\u6277lantEqual;\\u6a7eilde;\\u6273cr;\\uc000\\ud835\\udca2;\\u626b\\u0400Aacfiosu\\u0685\\u068b\\u0696\\u069b\\u069e\\u06aa\\u06be\\u06caRDcy;\\u442a\\u0100ct\\u0690\\u0694ek;\\u42c7;\\u405eirc;\\u4124r;\\u610clbertSpace;\\u610b\\u01f0\\u06af\\0\\u06b2f;\\u610dizontalLine;\\u6500\\u0100ct\\u06c3\\u06c5\\xf2\\u06a9rok;\\u4126mp\\u0144\\u06d0\\u06d8ownHum\\xf0\\u012fqual;\\u624f\\u0700EJOacdfgmnostu\\u06fa\\u06fe\\u0703\\u0707\\u070e\\u071a\\u071e\\u0721\\u0728\\u0744\\u0778\\u078b\\u078f\\u0795cy;\\u4415lig;\\u4132cy;\\u4401cute\\u803b\\xcd\\u40cd\\u0100iy\\u0713\\u0718rc\\u803b\\xce\\u40ce;\\u4418ot;\\u4130r;\\u6111rave\\u803b\\xcc\\u40cc\\u0180;ap\\u0720\\u072f\\u073f\\u0100cg\\u0734\\u0737r;\\u412ainaryI;\\u6148lie\\xf3\\u03dd\\u01f4\\u0749\\0\\u0762\\u0100;e\\u074d\\u074e\\u622c\\u0100gr\\u0753\\u0758ral;\\u622bsection;\\u62c2isible\\u0100CT\\u076c\\u0772omma;\\u6063imes;\\u6062\\u0180gpt\\u077f\\u0783\\u0788on;\\u412ef;\\uc000\\ud835\\udd40a;\\u4399cr;\\u6110ilde;\\u4128\\u01eb\\u079a\\0\\u079ecy;\\u4406l\\u803b\\xcf\\u40cf\\u0280cfosu\\u07ac\\u07b7\\u07bc\\u07c2\\u07d0\\u0100iy\\u07b1\\u07b5rc;\\u4134;\\u4419r;\\uc000\\ud835\\udd0dpf;\\uc000\\ud835\\udd41\\u01e3\\u07c7\\0\\u07ccr;\\uc000\\ud835\\udca5rcy;\\u4408kcy;\\u4404\\u0380HJacfos\\u07e4\\u07e8\\u07ec\\u07f1\\u07fd\\u0802\\u0808cy;\\u4425cy;\\u440cppa;\\u439a\\u0100ey\\u07f6\\u07fbdil;\\u4136;\\u441ar;\\uc000\\ud835\\udd0epf;\\uc000\\ud835\\udd42cr;\\uc000\\ud835\\udca6\\u0580JTaceflmost\\u0825\\u0829\\u082c\\u0850\\u0863\\u09b3\\u09b8\\u09c7\\u09cd\\u0a37\\u0a47cy;\\u4409\\u803b<\\u403c\\u0280cmnpr\\u0837\\u083c\\u0841\\u0844\\u084dute;\\u4139bda;\\u439bg;\\u67ealacetrf;\\u6112r;\\u619e\\u0180aey\\u0857\\u085c\\u0861ron;\\u413ddil;\\u413b;\\u441b\\u0100fs\\u0868\\u0970t\\u0500ACDFRTUVar\\u087e\\u08a9\\u08b1\\u08e0\\u08e6\\u08fc\\u092f\\u095b\\u0390\\u096a\\u0100nr\\u0883\\u088fgleBracket;\\u67e8row\\u0180;BR\\u0899\\u089a\\u089e\\u6190ar;\\u61e4ightArrow;\\u61c6eiling;\\u6308o\\u01f5\\u08b7\\0\\u08c3bleBracket;\\u67e6n\\u01d4\\u08c8\\0\\u08d2eeVector;\\u6961ector\\u0100;B\\u08db\\u08dc\\u61c3ar;\\u6959loor;\\u630aight\\u0100AV\\u08ef\\u08f5rrow;\\u6194ector;\\u694e\\u0100er\\u0901\\u0917e\\u0180;AV\\u0909\\u090a\\u0910\\u62a3rrow;\\u61a4ector;\\u695aiangle\\u0180;BE\\u0924\\u0925\\u0929\\u62b2ar;\\u69cfqual;\\u62b4p\\u0180DTV\\u0937\\u0942\\u094cownVector;\\u6951eeVector;\\u6960ector\\u0100;B\\u0956\\u0957\\u61bfar;\\u6958ector\\u0100;B\\u0965\\u0966\\u61bcar;\\u6952ight\\xe1\\u039cs\\u0300EFGLST\\u097e\\u098b\\u0995\\u099d\\u09a2\\u09adqualGreater;\\u62daullEqual;\\u6266reater;\\u6276ess;\\u6aa1lantEqual;\\u6a7dilde;\\u6272r;\\uc000\\ud835\\udd0f\\u0100;e\\u09bd\\u09be\\u62d8ftarrow;\\u61daidot;\\u413f\\u0180npw\\u09d4\\u0a16\\u0a1bg\\u0200LRlr\\u09de\\u09f7\\u0a02\\u0a10eft\\u0100AR\\u09e6\\u09ecrrow;\\u67f5ightArrow;\\u67f7ightArrow;\\u67f6eft\\u0100ar\\u03b3\\u0a0aight\\xe1\\u03bfight\\xe1\\u03caf;\\uc000\\ud835\\udd43er\\u0100LR\\u0a22\\u0a2ceftArrow;\\u6199ightArrow;\\u6198\\u0180cht\\u0a3e\\u0a40\\u0a42\\xf2\\u084c;\\u61b0rok;\\u4141;\\u626a\\u0400acefiosu\\u0a5a\\u0a5d\\u0a60\\u0a77\\u0a7c\\u0a85\\u0a8b\\u0a8ep;\\u6905y;\\u441c\\u0100dl\\u0a65\\u0a6fiumSpace;\\u605flintrf;\\u6133r;\\uc000\\ud835\\udd10nusPlus;\\u6213pf;\\uc000\\ud835\\udd44c\\xf2\\u0a76;\\u439c\\u0480Jacefostu\\u0aa3\\u0aa7\\u0aad\\u0ac0\\u0b14\\u0b19\\u0d91\\u0d97\\u0d9ecy;\\u440acute;\\u4143\\u0180aey\\u0ab4\\u0ab9\\u0aberon;\\u4147dil;\\u4145;\\u441d\\u0180gsw\\u0ac7\\u0af0\\u0b0eative\\u0180MTV\\u0ad3\\u0adf\\u0ae8ediumSpace;\\u600bhi\\u0100cn\\u0ae6\\u0ad8\\xeb\\u0ad9eryThi\\xee\\u0ad9ted\\u0100GL\\u0af8\\u0b06reaterGreate\\xf2\\u0673essLes\\xf3\\u0a48Line;\\u400ar;\\uc000\\ud835\\udd11\\u0200Bnpt\\u0b22\\u0b28\\u0b37\\u0b3areak;\\u6060BreakingSpace;\\u40a0f;\\u6115\\u0680;CDEGHLNPRSTV\\u0b55\\u0b56\\u0b6a\\u0b7c\\u0ba1\\u0beb\\u0c04\\u0c5e\\u0c84\\u0ca6\\u0cd8\\u0d61\\u0d85\\u6aec\\u0100ou\\u0b5b\\u0b64ngruent;\\u6262pCap;\\u626doubleVerticalBar;\\u6226\\u0180lqx\\u0b83\\u0b8a\\u0b9bement;\\u6209ual\\u0100;T\\u0b92\\u0b93\\u6260ilde;\\uc000\\u2242\\u0338ists;\\u6204reater\\u0380;EFGLST\\u0bb6\\u0bb7\\u0bbd\\u0bc9\\u0bd3\\u0bd8\\u0be5\\u626fqual;\\u6271ullEqual;\\uc000\\u2267\\u0338reater;\\uc000\\u226b\\u0338ess;\\u6279lantEqual;\\uc000\\u2a7e\\u0338ilde;\\u6275ump\\u0144\\u0bf2\\u0bfdownHump;\\uc000\\u224e\\u0338qual;\\uc000\\u224f\\u0338e\\u0100fs\\u0c0a\\u0c27tTriangle\\u0180;BE\\u0c1a\\u0c1b\\u0c21\\u62eaar;\\uc000\\u29cf\\u0338qual;\\u62ecs\\u0300;EGLST\\u0c35\\u0c36\\u0c3c\\u0c44\\u0c4b\\u0c58\\u626equal;\\u6270reater;\\u6278ess;\\uc000\\u226a\\u0338lantEqual;\\uc000\\u2a7d\\u0338ilde;\\u6274ested\\u0100GL\\u0c68\\u0c79reaterGreater;\\uc000\\u2aa2\\u0338essLess;\\uc000\\u2aa1\\u0338recedes\\u0180;ES\\u0c92\\u0c93\\u0c9b\\u6280qual;\\uc000\\u2aaf\\u0338lantEqual;\\u62e0\\u0100ei\\u0cab\\u0cb9verseElement;\\u620cghtTriangle\\u0180;BE\\u0ccb\\u0ccc\\u0cd2\\u62ebar;\\uc000\\u29d0\\u0338qual;\\u62ed\\u0100qu\\u0cdd\\u0d0cuareSu\\u0100bp\\u0ce8\\u0cf9set\\u0100;E\\u0cf0\\u0cf3\\uc000\\u228f\\u0338qual;\\u62e2erset\\u0100;E\\u0d03\\u0d06\\uc000\\u2290\\u0338qual;\\u62e3\\u0180bcp\\u0d13\\u0d24\\u0d4eset\\u0100;E\\u0d1b\\u0d1e\\uc000\\u2282\\u20d2qual;\\u6288ceeds\\u0200;EST\\u0d32\\u0d33\\u0d3b\\u0d46\\u6281qual;\\uc000\\u2ab0\\u0338lantEqual;\\u62e1ilde;\\uc000\\u227f\\u0338erset\\u0100;E\\u0d58\\u0d5b\\uc000\\u2283\\u20d2qual;\\u6289ilde\\u0200;EFT\\u0d6e\\u0d6f\\u0d75\\u0d7f\\u6241qual;\\u6244ullEqual;\\u6247ilde;\\u6249erticalBar;\\u6224cr;\\uc000\\ud835\\udca9ilde\\u803b\\xd1\\u40d1;\\u439d\\u0700Eacdfgmoprstuv\\u0dbd\\u0dc2\\u0dc9\\u0dd5\\u0ddb\\u0de0\\u0de7\\u0dfc\\u0e02\\u0e20\\u0e22\\u0e32\\u0e3f\\u0e44lig;\\u4152cute\\u803b\\xd3\\u40d3\\u0100iy\\u0dce\\u0dd3rc\\u803b\\xd4\\u40d4;\\u441eblac;\\u4150r;\\uc000\\ud835\\udd12rave\\u803b\\xd2\\u40d2\\u0180aei\\u0dee\\u0df2\\u0df6cr;\\u414cga;\\u43a9cron;\\u439fpf;\\uc000\\ud835\\udd46enCurly\\u0100DQ\\u0e0e\\u0e1aoubleQuote;\\u601cuote;\\u6018;\\u6a54\\u0100cl\\u0e27\\u0e2cr;\\uc000\\ud835\\udcaaash\\u803b\\xd8\\u40d8i\\u016c\\u0e37\\u0e3cde\\u803b\\xd5\\u40d5es;\\u6a37ml\\u803b\\xd6\\u40d6er\\u0100BP\\u0e4b\\u0e60\\u0100ar\\u0e50\\u0e53r;\\u603eac\\u0100ek\\u0e5a\\u0e5c;\\u63deet;\\u63b4arenthesis;\\u63dc\\u0480acfhilors\\u0e7f\\u0e87\\u0e8a\\u0e8f\\u0e92\\u0e94\\u0e9d\\u0eb0\\u0efcrtialD;\\u6202y;\\u441fr;\\uc000\\ud835\\udd13i;\\u43a6;\\u43a0usMinus;\\u40b1\\u0100ip\\u0ea2\\u0eadncareplan\\xe5\\u069df;\\u6119\\u0200;eio\\u0eb9\\u0eba\\u0ee0\\u0ee4\\u6abbcedes\\u0200;EST\\u0ec8\\u0ec9\\u0ecf\\u0eda\\u627aqual;\\u6aaflantEqual;\\u627cilde;\\u627eme;\\u6033\\u0100dp\\u0ee9\\u0eeeuct;\\u620fortion\\u0100;a\\u0225\\u0ef9l;\\u621d\\u0100ci\\u0f01\\u0f06r;\\uc000\\ud835\\udcab;\\u43a8\\u0200Ufos\\u0f11\\u0f16\\u0f1b\\u0f1fOT\\u803b\\\"\\u4022r;\\uc000\\ud835\\udd14pf;\\u611acr;\\uc000\\ud835\\udcac\\u0600BEacefhiorsu\\u0f3e\\u0f43\\u0f47\\u0f60\\u0f73\\u0fa7\\u0faa\\u0fad\\u1096\\u10a9\\u10b4\\u10bearr;\\u6910G\\u803b\\xae\\u40ae\\u0180cnr\\u0f4e\\u0f53\\u0f56ute;\\u4154g;\\u67ebr\\u0100;t\\u0f5c\\u0f5d\\u61a0l;\\u6916\\u0180aey\\u0f67\\u0f6c\\u0f71ron;\\u4158dil;\\u4156;\\u4420\\u0100;v\\u0f78\\u0f79\\u611cerse\\u0100EU\\u0f82\\u0f99\\u0100lq\\u0f87\\u0f8eement;\\u620builibrium;\\u61cbpEquilibrium;\\u696fr\\xbb\\u0f79o;\\u43a1ght\\u0400ACDFTUVa\\u0fc1\\u0feb\\u0ff3\\u1022\\u1028\\u105b\\u1087\\u03d8\\u0100nr\\u0fc6\\u0fd2gleBracket;\\u67e9row\\u0180;BL\\u0fdc\\u0fdd\\u0fe1\\u6192ar;\\u61e5eftArrow;\\u61c4eiling;\\u6309o\\u01f5\\u0ff9\\0\\u1005bleBracket;\\u67e7n\\u01d4\\u100a\\0\\u1014eeVector;\\u695dector\\u0100;B\\u101d\\u101e\\u61c2ar;\\u6955loor;\\u630b\\u0100er\\u102d\\u1043e\\u0180;AV\\u1035\\u1036\\u103c\\u62a2rrow;\\u61a6ector;\\u695biangle\\u0180;BE\\u1050\\u1051\\u1055\\u62b3ar;\\u69d0qual;\\u62b5p\\u0180DTV\\u1063\\u106e\\u1078ownVector;\\u694feeVector;\\u695cector\\u0100;B\\u1082\\u1083\\u61bear;\\u6954ector\\u0100;B\\u1091\\u1092\\u61c0ar;\\u6953\\u0100pu\\u109b\\u109ef;\\u611dndImplies;\\u6970ightarrow;\\u61db\\u0100ch\\u10b9\\u10bcr;\\u611b;\\u61b1leDelayed;\\u69f4\\u0680HOacfhimoqstu\\u10e4\\u10f1\\u10f7\\u10fd\\u1119\\u111e\\u1151\\u1156\\u1161\\u1167\\u11b5\\u11bb\\u11bf\\u0100Cc\\u10e9\\u10eeHcy;\\u4429y;\\u4428FTcy;\\u442ccute;\\u415a\\u0280;aeiy\\u1108\\u1109\\u110e\\u1113\\u1117\\u6abcron;\\u4160dil;\\u415erc;\\u415c;\\u4421r;\\uc000\\ud835\\udd16ort\\u0200DLRU\\u112a\\u1134\\u113e\\u1149ownArrow\\xbb\\u041eeftArrow\\xbb\\u089aightArrow\\xbb\\u0fddpArrow;\\u6191gma;\\u43a3allCircle;\\u6218pf;\\uc000\\ud835\\udd4a\\u0272\\u116d\\0\\0\\u1170t;\\u621aare\\u0200;ISU\\u117b\\u117c\\u1189\\u11af\\u65a1ntersection;\\u6293u\\u0100bp\\u118f\\u119eset\\u0100;E\\u1197\\u1198\\u628fqual;\\u6291erset\\u0100;E\\u11a8\\u11a9\\u6290qual;\\u6292nion;\\u6294cr;\\uc000\\ud835\\udcaear;\\u62c6\\u0200bcmp\\u11c8\\u11db\\u1209\\u120b\\u0100;s\\u11cd\\u11ce\\u62d0et\\u0100;E\\u11cd\\u11d5qual;\\u6286\\u0100ch\\u11e0\\u1205eeds\\u0200;EST\\u11ed\\u11ee\\u11f4\\u11ff\\u627bqual;\\u6ab0lantEqual;\\u627dilde;\\u627fTh\\xe1\\u0f8c;\\u6211\\u0180;es\\u1212\\u1213\\u1223\\u62d1rset\\u0100;E\\u121c\\u121d\\u6283qual;\\u6287et\\xbb\\u1213\\u0580HRSacfhiors\\u123e\\u1244\\u1249\\u1255\\u125e\\u1271\\u1276\\u129f\\u12c2\\u12c8\\u12d1ORN\\u803b\\xde\\u40deADE;\\u6122\\u0100Hc\\u124e\\u1252cy;\\u440by;\\u4426\\u0100bu\\u125a\\u125c;\\u4009;\\u43a4\\u0180aey\\u1265\\u126a\\u126fron;\\u4164dil;\\u4162;\\u4422r;\\uc000\\ud835\\udd17\\u0100ei\\u127b\\u1289\\u01f2\\u1280\\0\\u1287efore;\\u6234a;\\u4398\\u0100cn\\u128e\\u1298kSpace;\\uc000\\u205f\\u200aSpace;\\u6009lde\\u0200;EFT\\u12ab\\u12ac\\u12b2\\u12bc\\u623cqual;\\u6243ullEqual;\\u6245ilde;\\u6248pf;\\uc000\\ud835\\udd4bipleDot;\\u60db\\u0100ct\\u12d6\\u12dbr;\\uc000\\ud835\\udcafrok;\\u4166\\u0ae1\\u12f7\\u130e\\u131a\\u1326\\0\\u132c\\u1331\\0\\0\\0\\0\\0\\u1338\\u133d\\u1377\\u1385\\0\\u13ff\\u1404\\u140a\\u1410\\u0100cr\\u12fb\\u1301ute\\u803b\\xda\\u40dar\\u0100;o\\u1307\\u1308\\u619fcir;\\u6949r\\u01e3\\u1313\\0\\u1316y;\\u440eve;\\u416c\\u0100iy\\u131e\\u1323rc\\u803b\\xdb\\u40db;\\u4423blac;\\u4170r;\\uc000\\ud835\\udd18rave\\u803b\\xd9\\u40d9acr;\\u416a\\u0100di\\u1341\\u1369er\\u0100BP\\u1348\\u135d\\u0100ar\\u134d\\u1350r;\\u405fac\\u0100ek\\u1357\\u1359;\\u63dfet;\\u63b5arenthesis;\\u63ddon\\u0100;P\\u1370\\u1371\\u62c3lus;\\u628e\\u0100gp\\u137b\\u137fon;\\u4172f;\\uc000\\ud835\\udd4c\\u0400ADETadps\\u1395\\u13ae\\u13b8\\u13c4\\u03e8\\u13d2\\u13d7\\u13f3rrow\\u0180;BD\\u1150\\u13a0\\u13a4ar;\\u6912ownArrow;\\u61c5ownArrow;\\u6195quilibrium;\\u696eee\\u0100;A\\u13cb\\u13cc\\u62a5rrow;\\u61a5own\\xe1\\u03f3er\\u0100LR\\u13de\\u13e8eftArrow;\\u6196ightArrow;\\u6197i\\u0100;l\\u13f9\\u13fa\\u43d2on;\\u43a5ing;\\u416ecr;\\uc000\\ud835\\udcb0ilde;\\u4168ml\\u803b\\xdc\\u40dc\\u0480Dbcdefosv\\u1427\\u142c\\u1430\\u1433\\u143e\\u1485\\u148a\\u1490\\u1496ash;\\u62abar;\\u6aeby;\\u4412ash\\u0100;l\\u143b\\u143c\\u62a9;\\u6ae6\\u0100er\\u1443\\u1445;\\u62c1\\u0180bty\\u144c\\u1450\\u147aar;\\u6016\\u0100;i\\u144f\\u1455cal\\u0200BLST\\u1461\\u1465\\u146a\\u1474ar;\\u6223ine;\\u407ceparator;\\u6758ilde;\\u6240ThinSpace;\\u600ar;\\uc000\\ud835\\udd19pf;\\uc000\\ud835\\udd4dcr;\\uc000\\ud835\\udcb1dash;\\u62aa\\u0280cefos\\u14a7\\u14ac\\u14b1\\u14b6\\u14bcirc;\\u4174dge;\\u62c0r;\\uc000\\ud835\\udd1apf;\\uc000\\ud835\\udd4ecr;\\uc000\\ud835\\udcb2\\u0200fios\\u14cb\\u14d0\\u14d2\\u14d8r;\\uc000\\ud835\\udd1b;\\u439epf;\\uc000\\ud835\\udd4fcr;\\uc000\\ud835\\udcb3\\u0480AIUacfosu\\u14f1\\u14f5\\u14f9\\u14fd\\u1504\\u150f\\u1514\\u151a\\u1520cy;\\u442fcy;\\u4407cy;\\u442ecute\\u803b\\xdd\\u40dd\\u0100iy\\u1509\\u150drc;\\u4176;\\u442br;\\uc000\\ud835\\udd1cpf;\\uc000\\ud835\\udd50cr;\\uc000\\ud835\\udcb4ml;\\u4178\\u0400Hacdefos\\u1535\\u1539\\u153f\\u154b\\u154f\\u155d\\u1560\\u1564cy;\\u4416cute;\\u4179\\u0100ay\\u1544\\u1549ron;\\u417d;\\u4417ot;\\u417b\\u01f2\\u1554\\0\\u155boWidt\\xe8\\u0ad9a;\\u4396r;\\u6128pf;\\u6124cr;\\uc000\\ud835\\udcb5\\u0be1\\u1583\\u158a\\u1590\\0\\u15b0\\u15b6\\u15bf\\0\\0\\0\\0\\u15c6\\u15db\\u15eb\\u165f\\u166d\\0\\u1695\\u169b\\u16b2\\u16b9\\0\\u16becute\\u803b\\xe1\\u40e1reve;\\u4103\\u0300;Ediuy\\u159c\\u159d\\u15a1\\u15a3\\u15a8\\u15ad\\u623e;\\uc000\\u223e\\u0333;\\u623frc\\u803b\\xe2\\u40e2te\\u80bb\\xb4\\u0306;\\u4430lig\\u803b\\xe6\\u40e6\\u0100;r\\xb2\\u15ba;\\uc000\\ud835\\udd1erave\\u803b\\xe0\\u40e0\\u0100ep\\u15ca\\u15d6\\u0100fp\\u15cf\\u15d4sym;\\u6135\\xe8\\u15d3ha;\\u43b1\\u0100ap\\u15dfc\\u0100cl\\u15e4\\u15e7r;\\u4101g;\\u6a3f\\u0264\\u15f0\\0\\0\\u160a\\u0280;adsv\\u15fa\\u15fb\\u15ff\\u1601\\u1607\\u6227nd;\\u6a55;\\u6a5clope;\\u6a58;\\u6a5a\\u0380;elmrsz\\u1618\\u1619\\u161b\\u161e\\u163f\\u164f\\u1659\\u6220;\\u69a4e\\xbb\\u1619sd\\u0100;a\\u1625\\u1626\\u6221\\u0461\\u1630\\u1632\\u1634\\u1636\\u1638\\u163a\\u163c\\u163e;\\u69a8;\\u69a9;\\u69aa;\\u69ab;\\u69ac;\\u69ad;\\u69ae;\\u69aft\\u0100;v\\u1645\\u1646\\u621fb\\u0100;d\\u164c\\u164d\\u62be;\\u699d\\u0100pt\\u1654\\u1657h;\\u6222\\xbb\\xb9arr;\\u637c\\u0100gp\\u1663\\u1667on;\\u4105f;\\uc000\\ud835\\udd52\\u0380;Eaeiop\\u12c1\\u167b\\u167d\\u1682\\u1684\\u1687\\u168a;\\u6a70cir;\\u6a6f;\\u624ad;\\u624bs;\\u4027rox\\u0100;e\\u12c1\\u1692\\xf1\\u1683ing\\u803b\\xe5\\u40e5\\u0180cty\\u16a1\\u16a6\\u16a8r;\\uc000\\ud835\\udcb6;\\u402amp\\u0100;e\\u12c1\\u16af\\xf1\\u0288ilde\\u803b\\xe3\\u40e3ml\\u803b\\xe4\\u40e4\\u0100ci\\u16c2\\u16c8onin\\xf4\\u0272nt;\\u6a11\\u0800Nabcdefiklnoprsu\\u16ed\\u16f1\\u1730\\u173c\\u1743\\u1748\\u1778\\u177d\\u17e0\\u17e6\\u1839\\u1850\\u170d\\u193d\\u1948\\u1970ot;\\u6aed\\u0100cr\\u16f6\\u171ek\\u0200ceps\\u1700\\u1705\\u170d\\u1713ong;\\u624cpsilon;\\u43f6rime;\\u6035im\\u0100;e\\u171a\\u171b\\u623dq;\\u62cd\\u0176\\u1722\\u1726ee;\\u62bded\\u0100;g\\u172c\\u172d\\u6305e\\xbb\\u172drk\\u0100;t\\u135c\\u1737brk;\\u63b6\\u0100oy\\u1701\\u1741;\\u4431quo;\\u601e\\u0280cmprt\\u1753\\u175b\\u1761\\u1764\\u1768aus\\u0100;e\\u010a\\u0109ptyv;\\u69b0s\\xe9\\u170cno\\xf5\\u0113\\u0180ahw\\u176f\\u1771\\u1773;\\u43b2;\\u6136een;\\u626cr;\\uc000\\ud835\\udd1fg\\u0380costuvw\\u178d\\u179d\\u17b3\\u17c1\\u17d5\\u17db\\u17de\\u0180aiu\\u1794\\u1796\\u179a\\xf0\\u0760rc;\\u65efp\\xbb\\u1371\\u0180dpt\\u17a4\\u17a8\\u17adot;\\u6a00lus;\\u6a01imes;\\u6a02\\u0271\\u17b9\\0\\0\\u17becup;\\u6a06ar;\\u6605riangle\\u0100du\\u17cd\\u17d2own;\\u65bdp;\\u65b3plus;\\u6a04e\\xe5\\u1444\\xe5\\u14adarow;\\u690d\\u0180ako\\u17ed\\u1826\\u1835\\u0100cn\\u17f2\\u1823k\\u0180lst\\u17fa\\u05ab\\u1802ozenge;\\u69ebriangle\\u0200;dlr\\u1812\\u1813\\u1818\\u181d\\u65b4own;\\u65beeft;\\u65c2ight;\\u65b8k;\\u6423\\u01b1\\u182b\\0\\u1833\\u01b2\\u182f\\0\\u1831;\\u6592;\\u65914;\\u6593ck;\\u6588\\u0100eo\\u183e\\u184d\\u0100;q\\u1843\\u1846\\uc000=\\u20e5uiv;\\uc000\\u2261\\u20e5t;\\u6310\\u0200ptwx\\u1859\\u185e\\u1867\\u186cf;\\uc000\\ud835\\udd53\\u0100;t\\u13cb\\u1863om\\xbb\\u13cctie;\\u62c8\\u0600DHUVbdhmptuv\\u1885\\u1896\\u18aa\\u18bb\\u18d7\\u18db\\u18ec\\u18ff\\u1905\\u190a\\u1910\\u1921\\u0200LRlr\\u188e\\u1890\\u1892\\u1894;\\u6557;\\u6554;\\u6556;\\u6553\\u0280;DUdu\\u18a1\\u18a2\\u18a4\\u18a6\\u18a8\\u6550;\\u6566;\\u6569;\\u6564;\\u6567\\u0200LRlr\\u18b3\\u18b5\\u18b7\\u18b9;\\u655d;\\u655a;\\u655c;\\u6559\\u0380;HLRhlr\\u18ca\\u18cb\\u18cd\\u18cf\\u18d1\\u18d3\\u18d5\\u6551;\\u656c;\\u6563;\\u6560;\\u656b;\\u6562;\\u655fox;\\u69c9\\u0200LRlr\\u18e4\\u18e6\\u18e8\\u18ea;\\u6555;\\u6552;\\u6510;\\u650c\\u0280;DUdu\\u06bd\\u18f7\\u18f9\\u18fb\\u18fd;\\u6565;\\u6568;\\u652c;\\u6534inus;\\u629flus;\\u629eimes;\\u62a0\\u0200LRlr\\u1919\\u191b\\u191d\\u191f;\\u655b;\\u6558;\\u6518;\\u6514\\u0380;HLRhlr\\u1930\\u1931\\u1933\\u1935\\u1937\\u1939\\u193b\\u6502;\\u656a;\\u6561;\\u655e;\\u653c;\\u6524;\\u651c\\u0100ev\\u0123\\u1942bar\\u803b\\xa6\\u40a6\\u0200ceio\\u1951\\u1956\\u195a\\u1960r;\\uc000\\ud835\\udcb7mi;\\u604fm\\u0100;e\\u171a\\u171cl\\u0180;bh\\u1968\\u1969\\u196b\\u405c;\\u69c5sub;\\u67c8\\u016c\\u1974\\u197el\\u0100;e\\u1979\\u197a\\u6022t\\xbb\\u197ap\\u0180;Ee\\u012f\\u1985\\u1987;\\u6aae\\u0100;q\\u06dc\\u06db\\u0ce1\\u19a7\\0\\u19e8\\u1a11\\u1a15\\u1a32\\0\\u1a37\\u1a50\\0\\0\\u1ab4\\0\\0\\u1ac1\\0\\0\\u1b21\\u1b2e\\u1b4d\\u1b52\\0\\u1bfd\\0\\u1c0c\\u0180cpr\\u19ad\\u19b2\\u19ddute;\\u4107\\u0300;abcds\\u19bf\\u19c0\\u19c4\\u19ca\\u19d5\\u19d9\\u6229nd;\\u6a44rcup;\\u6a49\\u0100au\\u19cf\\u19d2p;\\u6a4bp;\\u6a47ot;\\u6a40;\\uc000\\u2229\\ufe00\\u0100eo\\u19e2\\u19e5t;\\u6041\\xee\\u0693\\u0200aeiu\\u19f0\\u19fb\\u1a01\\u1a05\\u01f0\\u19f5\\0\\u19f8s;\\u6a4don;\\u410ddil\\u803b\\xe7\\u40e7rc;\\u4109ps\\u0100;s\\u1a0c\\u1a0d\\u6a4cm;\\u6a50ot;\\u410b\\u0180dmn\\u1a1b\\u1a20\\u1a26il\\u80bb\\xb8\\u01adptyv;\\u69b2t\\u8100\\xa2;e\\u1a2d\\u1a2e\\u40a2r\\xe4\\u01b2r;\\uc000\\ud835\\udd20\\u0180cei\\u1a3d\\u1a40\\u1a4dy;\\u4447ck\\u0100;m\\u1a47\\u1a48\\u6713ark\\xbb\\u1a48;\\u43c7r\\u0380;Ecefms\\u1a5f\\u1a60\\u1a62\\u1a6b\\u1aa4\\u1aaa\\u1aae\\u65cb;\\u69c3\\u0180;el\\u1a69\\u1a6a\\u1a6d\\u42c6q;\\u6257e\\u0261\\u1a74\\0\\0\\u1a88rrow\\u0100lr\\u1a7c\\u1a81eft;\\u61baight;\\u61bb\\u0280RSacd\\u1a92\\u1a94\\u1a96\\u1a9a\\u1a9f\\xbb\\u0f47;\\u64c8st;\\u629birc;\\u629aash;\\u629dnint;\\u6a10id;\\u6aefcir;\\u69c2ubs\\u0100;u\\u1abb\\u1abc\\u6663it\\xbb\\u1abc\\u02ec\\u1ac7\\u1ad4\\u1afa\\0\\u1b0aon\\u0100;e\\u1acd\\u1ace\\u403a\\u0100;q\\xc7\\xc6\\u026d\\u1ad9\\0\\0\\u1ae2a\\u0100;t\\u1ade\\u1adf\\u402c;\\u4040\\u0180;fl\\u1ae8\\u1ae9\\u1aeb\\u6201\\xee\\u1160e\\u0100mx\\u1af1\\u1af6ent\\xbb\\u1ae9e\\xf3\\u024d\\u01e7\\u1afe\\0\\u1b07\\u0100;d\\u12bb\\u1b02ot;\\u6a6dn\\xf4\\u0246\\u0180fry\\u1b10\\u1b14\\u1b17;\\uc000\\ud835\\udd54o\\xe4\\u0254\\u8100\\xa9;s\\u0155\\u1b1dr;\\u6117\\u0100ao\\u1b25\\u1b29rr;\\u61b5ss;\\u6717\\u0100cu\\u1b32\\u1b37r;\\uc000\\ud835\\udcb8\\u0100bp\\u1b3c\\u1b44\\u0100;e\\u1b41\\u1b42\\u6acf;\\u6ad1\\u0100;e\\u1b49\\u1b4a\\u6ad0;\\u6ad2dot;\\u62ef\\u0380delprvw\\u1b60\\u1b6c\\u1b77\\u1b82\\u1bac\\u1bd4\\u1bf9arr\\u0100lr\\u1b68\\u1b6a;\\u6938;\\u6935\\u0270\\u1b72\\0\\0\\u1b75r;\\u62dec;\\u62dfarr\\u0100;p\\u1b7f\\u1b80\\u61b6;\\u693d\\u0300;bcdos\\u1b8f\\u1b90\\u1b96\\u1ba1\\u1ba5\\u1ba8\\u622arcap;\\u6a48\\u0100au\\u1b9b\\u1b9ep;\\u6a46p;\\u6a4aot;\\u628dr;\\u6a45;\\uc000\\u222a\\ufe00\\u0200alrv\\u1bb5\\u1bbf\\u1bde\\u1be3rr\\u0100;m\\u1bbc\\u1bbd\\u61b7;\\u693cy\\u0180evw\\u1bc7\\u1bd4\\u1bd8q\\u0270\\u1bce\\0\\0\\u1bd2re\\xe3\\u1b73u\\xe3\\u1b75ee;\\u62ceedge;\\u62cfen\\u803b\\xa4\\u40a4earrow\\u0100lr\\u1bee\\u1bf3eft\\xbb\\u1b80ight\\xbb\\u1bbde\\xe4\\u1bdd\\u0100ci\\u1c01\\u1c07onin\\xf4\\u01f7nt;\\u6231lcty;\\u632d\\u0980AHabcdefhijlorstuwz\\u1c38\\u1c3b\\u1c3f\\u1c5d\\u1c69\\u1c75\\u1c8a\\u1c9e\\u1cac\\u1cb7\\u1cfb\\u1cff\\u1d0d\\u1d7b\\u1d91\\u1dab\\u1dbb\\u1dc6\\u1dcdr\\xf2\\u0381ar;\\u6965\\u0200glrs\\u1c48\\u1c4d\\u1c52\\u1c54ger;\\u6020eth;\\u6138\\xf2\\u1133h\\u0100;v\\u1c5a\\u1c5b\\u6010\\xbb\\u090a\\u016b\\u1c61\\u1c67arow;\\u690fa\\xe3\\u0315\\u0100ay\\u1c6e\\u1c73ron;\\u410f;\\u4434\\u0180;ao\\u0332\\u1c7c\\u1c84\\u0100gr\\u02bf\\u1c81r;\\u61catseq;\\u6a77\\u0180glm\\u1c91\\u1c94\\u1c98\\u803b\\xb0\\u40b0ta;\\u43b4ptyv;\\u69b1\\u0100ir\\u1ca3\\u1ca8sht;\\u697f;\\uc000\\ud835\\udd21ar\\u0100lr\\u1cb3\\u1cb5\\xbb\\u08dc\\xbb\\u101e\\u0280aegsv\\u1cc2\\u0378\\u1cd6\\u1cdc\\u1ce0m\\u0180;os\\u0326\\u1cca\\u1cd4nd\\u0100;s\\u0326\\u1cd1uit;\\u6666amma;\\u43ddin;\\u62f2\\u0180;io\\u1ce7\\u1ce8\\u1cf8\\u40f7de\\u8100\\xf7;o\\u1ce7\\u1cf0ntimes;\\u62c7n\\xf8\\u1cf7cy;\\u4452c\\u026f\\u1d06\\0\\0\\u1d0arn;\\u631eop;\\u630d\\u0280lptuw\\u1d18\\u1d1d\\u1d22\\u1d49\\u1d55lar;\\u4024f;\\uc000\\ud835\\udd55\\u0280;emps\\u030b\\u1d2d\\u1d37\\u1d3d\\u1d42q\\u0100;d\\u0352\\u1d33ot;\\u6251inus;\\u6238lus;\\u6214quare;\\u62a1blebarwedg\\xe5\\xfan\\u0180adh\\u112e\\u1d5d\\u1d67ownarrow\\xf3\\u1c83arpoon\\u0100lr\\u1d72\\u1d76ef\\xf4\\u1cb4igh\\xf4\\u1cb6\\u0162\\u1d7f\\u1d85karo\\xf7\\u0f42\\u026f\\u1d8a\\0\\0\\u1d8ern;\\u631fop;\\u630c\\u0180cot\\u1d98\\u1da3\\u1da6\\u0100ry\\u1d9d\\u1da1;\\uc000\\ud835\\udcb9;\\u4455l;\\u69f6rok;\\u4111\\u0100dr\\u1db0\\u1db4ot;\\u62f1i\\u0100;f\\u1dba\\u1816\\u65bf\\u0100ah\\u1dc0\\u1dc3r\\xf2\\u0429a\\xf2\\u0fa6angle;\\u69a6\\u0100ci\\u1dd2\\u1dd5y;\\u445fgrarr;\\u67ff\\u0900Dacdefglmnopqrstux\\u1e01\\u1e09\\u1e19\\u1e38\\u0578\\u1e3c\\u1e49\\u1e61\\u1e7e\\u1ea5\\u1eaf\\u1ebd\\u1ee1\\u1f2a\\u1f37\\u1f44\\u1f4e\\u1f5a\\u0100Do\\u1e06\\u1d34o\\xf4\\u1c89\\u0100cs\\u1e0e\\u1e14ute\\u803b\\xe9\\u40e9ter;\\u6a6e\\u0200aioy\\u1e22\\u1e27\\u1e31\\u1e36ron;\\u411br\\u0100;c\\u1e2d\\u1e2e\\u6256\\u803b\\xea\\u40ealon;\\u6255;\\u444dot;\\u4117\\u0100Dr\\u1e41\\u1e45ot;\\u6252;\\uc000\\ud835\\udd22\\u0180;rs\\u1e50\\u1e51\\u1e57\\u6a9aave\\u803b\\xe8\\u40e8\\u0100;d\\u1e5c\\u1e5d\\u6a96ot;\\u6a98\\u0200;ils\\u1e6a\\u1e6b\\u1e72\\u1e74\\u6a99nters;\\u63e7;\\u6113\\u0100;d\\u1e79\\u1e7a\\u6a95ot;\\u6a97\\u0180aps\\u1e85\\u1e89\\u1e97cr;\\u4113ty\\u0180;sv\\u1e92\\u1e93\\u1e95\\u6205et\\xbb\\u1e93p\\u01001;\\u1e9d\\u1ea4\\u0133\\u1ea1\\u1ea3;\\u6004;\\u6005\\u6003\\u0100gs\\u1eaa\\u1eac;\\u414bp;\\u6002\\u0100gp\\u1eb4\\u1eb8on;\\u4119f;\\uc000\\ud835\\udd56\\u0180als\\u1ec4\\u1ece\\u1ed2r\\u0100;s\\u1eca\\u1ecb\\u62d5l;\\u69e3us;\\u6a71i\\u0180;lv\\u1eda\\u1edb\\u1edf\\u43b5on\\xbb\\u1edb;\\u43f5\\u0200csuv\\u1eea\\u1ef3\\u1f0b\\u1f23\\u0100io\\u1eef\\u1e31rc\\xbb\\u1e2e\\u0269\\u1ef9\\0\\0\\u1efb\\xed\\u0548ant\\u0100gl\\u1f02\\u1f06tr\\xbb\\u1e5dess\\xbb\\u1e7a\\u0180aei\\u1f12\\u1f16\\u1f1als;\\u403dst;\\u625fv\\u0100;D\\u0235\\u1f20D;\\u6a78parsl;\\u69e5\\u0100Da\\u1f2f\\u1f33ot;\\u6253rr;\\u6971\\u0180cdi\\u1f3e\\u1f41\\u1ef8r;\\u612fo\\xf4\\u0352\\u0100ah\\u1f49\\u1f4b;\\u43b7\\u803b\\xf0\\u40f0\\u0100mr\\u1f53\\u1f57l\\u803b\\xeb\\u40ebo;\\u60ac\\u0180cip\\u1f61\\u1f64\\u1f67l;\\u4021s\\xf4\\u056e\\u0100eo\\u1f6c\\u1f74ctatio\\xee\\u0559nential\\xe5\\u0579\\u09e1\\u1f92\\0\\u1f9e\\0\\u1fa1\\u1fa7\\0\\0\\u1fc6\\u1fcc\\0\\u1fd3\\0\\u1fe6\\u1fea\\u2000\\0\\u2008\\u205allingdotse\\xf1\\u1e44y;\\u4444male;\\u6640\\u0180ilr\\u1fad\\u1fb3\\u1fc1lig;\\u8000\\ufb03\\u0269\\u1fb9\\0\\0\\u1fbdg;\\u8000\\ufb00ig;\\u8000\\ufb04;\\uc000\\ud835\\udd23lig;\\u8000\\ufb01lig;\\uc000fj\\u0180alt\\u1fd9\\u1fdc\\u1fe1t;\\u666dig;\\u8000\\ufb02ns;\\u65b1of;\\u4192\\u01f0\\u1fee\\0\\u1ff3f;\\uc000\\ud835\\udd57\\u0100ak\\u05bf\\u1ff7\\u0100;v\\u1ffc\\u1ffd\\u62d4;\\u6ad9artint;\\u6a0d\\u0100ao\\u200c\\u2055\\u0100cs\\u2011\\u2052\\u03b1\\u201a\\u2030\\u2038\\u2045\\u2048\\0\\u2050\\u03b2\\u2022\\u2025\\u2027\\u202a\\u202c\\0\\u202e\\u803b\\xbd\\u40bd;\\u6153\\u803b\\xbc\\u40bc;\\u6155;\\u6159;\\u615b\\u01b3\\u2034\\0\\u2036;\\u6154;\\u6156\\u02b4\\u203e\\u2041\\0\\0\\u2043\\u803b\\xbe\\u40be;\\u6157;\\u615c5;\\u6158\\u01b6\\u204c\\0\\u204e;\\u615a;\\u615d8;\\u615el;\\u6044wn;\\u6322cr;\\uc000\\ud835\\udcbb\\u0880Eabcdefgijlnorstv\\u2082\\u2089\\u209f\\u20a5\\u20b0\\u20b4\\u20f0\\u20f5\\u20fa\\u20ff\\u2103\\u2112\\u2138\\u0317\\u213e\\u2152\\u219e\\u0100;l\\u064d\\u2087;\\u6a8c\\u0180cmp\\u2090\\u2095\\u209dute;\\u41f5ma\\u0100;d\\u209c\\u1cda\\u43b3;\\u6a86reve;\\u411f\\u0100iy\\u20aa\\u20aerc;\\u411d;\\u4433ot;\\u4121\\u0200;lqs\\u063e\\u0642\\u20bd\\u20c9\\u0180;qs\\u063e\\u064c\\u20c4lan\\xf4\\u0665\\u0200;cdl\\u0665\\u20d2\\u20d5\\u20e5c;\\u6aa9ot\\u0100;o\\u20dc\\u20dd\\u6a80\\u0100;l\\u20e2\\u20e3\\u6a82;\\u6a84\\u0100;e\\u20ea\\u20ed\\uc000\\u22db\\ufe00s;\\u6a94r;\\uc000\\ud835\\udd24\\u0100;g\\u0673\\u061bmel;\\u6137cy;\\u4453\\u0200;Eaj\\u065a\\u210c\\u210e\\u2110;\\u6a92;\\u6aa5;\\u6aa4\\u0200Eaes\\u211b\\u211d\\u2129\\u2134;\\u6269p\\u0100;p\\u2123\\u2124\\u6a8arox\\xbb\\u2124\\u0100;q\\u212e\\u212f\\u6a88\\u0100;q\\u212e\\u211bim;\\u62e7pf;\\uc000\\ud835\\udd58\\u0100ci\\u2143\\u2146r;\\u610am\\u0180;el\\u066b\\u214e\\u2150;\\u6a8e;\\u6a90\\u8300>;cdlqr\\u05ee\\u2160\\u216a\\u216e\\u2173\\u2179\\u0100ci\\u2165\\u2167;\\u6aa7r;\\u6a7aot;\\u62d7Par;\\u6995uest;\\u6a7c\\u0280adels\\u2184\\u216a\\u2190\\u0656\\u219b\\u01f0\\u2189\\0\\u218epro\\xf8\\u209er;\\u6978q\\u0100lq\\u063f\\u2196les\\xf3\\u2088i\\xed\\u066b\\u0100en\\u21a3\\u21adrtneqq;\\uc000\\u2269\\ufe00\\xc5\\u21aa\\u0500Aabcefkosy\\u21c4\\u21c7\\u21f1\\u21f5\\u21fa\\u2218\\u221d\\u222f\\u2268\\u227dr\\xf2\\u03a0\\u0200ilmr\\u21d0\\u21d4\\u21d7\\u21dbrs\\xf0\\u1484f\\xbb\\u2024il\\xf4\\u06a9\\u0100dr\\u21e0\\u21e4cy;\\u444a\\u0180;cw\\u08f4\\u21eb\\u21efir;\\u6948;\\u61adar;\\u610firc;\\u4125\\u0180alr\\u2201\\u220e\\u2213rts\\u0100;u\\u2209\\u220a\\u6665it\\xbb\\u220alip;\\u6026con;\\u62b9r;\\uc000\\ud835\\udd25s\\u0100ew\\u2223\\u2229arow;\\u6925arow;\\u6926\\u0280amopr\\u223a\\u223e\\u2243\\u225e\\u2263rr;\\u61fftht;\\u623bk\\u0100lr\\u2249\\u2253eftarrow;\\u61a9ightarrow;\\u61aaf;\\uc000\\ud835\\udd59bar;\\u6015\\u0180clt\\u226f\\u2274\\u2278r;\\uc000\\ud835\\udcbdas\\xe8\\u21f4rok;\\u4127\\u0100bp\\u2282\\u2287ull;\\u6043hen\\xbb\\u1c5b\\u0ae1\\u22a3\\0\\u22aa\\0\\u22b8\\u22c5\\u22ce\\0\\u22d5\\u22f3\\0\\0\\u22f8\\u2322\\u2367\\u2362\\u237f\\0\\u2386\\u23aa\\u23b4cute\\u803b\\xed\\u40ed\\u0180;iy\\u0771\\u22b0\\u22b5rc\\u803b\\xee\\u40ee;\\u4438\\u0100cx\\u22bc\\u22bfy;\\u4435cl\\u803b\\xa1\\u40a1\\u0100fr\\u039f\\u22c9;\\uc000\\ud835\\udd26rave\\u803b\\xec\\u40ec\\u0200;ino\\u073e\\u22dd\\u22e9\\u22ee\\u0100in\\u22e2\\u22e6nt;\\u6a0ct;\\u622dfin;\\u69dcta;\\u6129lig;\\u4133\\u0180aop\\u22fe\\u231a\\u231d\\u0180cgt\\u2305\\u2308\\u2317r;\\u412b\\u0180elp\\u071f\\u230f\\u2313in\\xe5\\u078ear\\xf4\\u0720h;\\u4131f;\\u62b7ed;\\u41b5\\u0280;cfot\\u04f4\\u232c\\u2331\\u233d\\u2341are;\\u6105in\\u0100;t\\u2338\\u2339\\u621eie;\\u69dddo\\xf4\\u2319\\u0280;celp\\u0757\\u234c\\u2350\\u235b\\u2361al;\\u62ba\\u0100gr\\u2355\\u2359er\\xf3\\u1563\\xe3\\u234darhk;\\u6a17rod;\\u6a3c\\u0200cgpt\\u236f\\u2372\\u2376\\u237by;\\u4451on;\\u412ff;\\uc000\\ud835\\udd5aa;\\u43b9uest\\u803b\\xbf\\u40bf\\u0100ci\\u238a\\u238fr;\\uc000\\ud835\\udcben\\u0280;Edsv\\u04f4\\u239b\\u239d\\u23a1\\u04f3;\\u62f9ot;\\u62f5\\u0100;v\\u23a6\\u23a7\\u62f4;\\u62f3\\u0100;i\\u0777\\u23aelde;\\u4129\\u01eb\\u23b8\\0\\u23bccy;\\u4456l\\u803b\\xef\\u40ef\\u0300cfmosu\\u23cc\\u23d7\\u23dc\\u23e1\\u23e7\\u23f5\\u0100iy\\u23d1\\u23d5rc;\\u4135;\\u4439r;\\uc000\\ud835\\udd27ath;\\u4237pf;\\uc000\\ud835\\udd5b\\u01e3\\u23ec\\0\\u23f1r;\\uc000\\ud835\\udcbfrcy;\\u4458kcy;\\u4454\\u0400acfghjos\\u240b\\u2416\\u2422\\u2427\\u242d\\u2431\\u2435\\u243bppa\\u0100;v\\u2413\\u2414\\u43ba;\\u43f0\\u0100ey\\u241b\\u2420dil;\\u4137;\\u443ar;\\uc000\\ud835\\udd28reen;\\u4138cy;\\u4445cy;\\u445cpf;\\uc000\\ud835\\udd5ccr;\\uc000\\ud835\\udcc0\\u0b80ABEHabcdefghjlmnoprstuv\\u2470\\u2481\\u2486\\u248d\\u2491\\u250e\\u253d\\u255a\\u2580\\u264e\\u265e\\u2665\\u2679\\u267d\\u269a\\u26b2\\u26d8\\u275d\\u2768\\u278b\\u27c0\\u2801\\u2812\\u0180art\\u2477\\u247a\\u247cr\\xf2\\u09c6\\xf2\\u0395ail;\\u691barr;\\u690e\\u0100;g\\u0994\\u248b;\\u6a8bar;\\u6962\\u0963\\u24a5\\0\\u24aa\\0\\u24b1\\0\\0\\0\\0\\0\\u24b5\\u24ba\\0\\u24c6\\u24c8\\u24cd\\0\\u24f9ute;\\u413amptyv;\\u69b4ra\\xee\\u084cbda;\\u43bbg\\u0180;dl\\u088e\\u24c1\\u24c3;\\u6991\\xe5\\u088e;\\u6a85uo\\u803b\\xab\\u40abr\\u0400;bfhlpst\\u0899\\u24de\\u24e6\\u24e9\\u24eb\\u24ee\\u24f1\\u24f5\\u0100;f\\u089d\\u24e3s;\\u691fs;\\u691d\\xeb\\u2252p;\\u61abl;\\u6939im;\\u6973l;\\u61a2\\u0180;ae\\u24ff\\u2500\\u2504\\u6aabil;\\u6919\\u0100;s\\u2509\\u250a\\u6aad;\\uc000\\u2aad\\ufe00\\u0180abr\\u2515\\u2519\\u251drr;\\u690crk;\\u6772\\u0100ak\\u2522\\u252cc\\u0100ek\\u2528\\u252a;\\u407b;\\u405b\\u0100es\\u2531\\u2533;\\u698bl\\u0100du\\u2539\\u253b;\\u698f;\\u698d\\u0200aeuy\\u2546\\u254b\\u2556\\u2558ron;\\u413e\\u0100di\\u2550\\u2554il;\\u413c\\xec\\u08b0\\xe2\\u2529;\\u443b\\u0200cqrs\\u2563\\u2566\\u256d\\u257da;\\u6936uo\\u0100;r\\u0e19\\u1746\\u0100du\\u2572\\u2577har;\\u6967shar;\\u694bh;\\u61b2\\u0280;fgqs\\u258b\\u258c\\u0989\\u25f3\\u25ff\\u6264t\\u0280ahlrt\\u2598\\u25a4\\u25b7\\u25c2\\u25e8rrow\\u0100;t\\u0899\\u25a1a\\xe9\\u24f6arpoon\\u0100du\\u25af\\u25b4own\\xbb\\u045ap\\xbb\\u0966eftarrows;\\u61c7ight\\u0180ahs\\u25cd\\u25d6\\u25derrow\\u0100;s\\u08f4\\u08a7arpoon\\xf3\\u0f98quigarro\\xf7\\u21f0hreetimes;\\u62cb\\u0180;qs\\u258b\\u0993\\u25falan\\xf4\\u09ac\\u0280;cdgs\\u09ac\\u260a\\u260d\\u261d\\u2628c;\\u6aa8ot\\u0100;o\\u2614\\u2615\\u6a7f\\u0100;r\\u261a\\u261b\\u6a81;\\u6a83\\u0100;e\\u2622\\u2625\\uc000\\u22da\\ufe00s;\\u6a93\\u0280adegs\\u2633\\u2639\\u263d\\u2649\\u264bppro\\xf8\\u24c6ot;\\u62d6q\\u0100gq\\u2643\\u2645\\xf4\\u0989gt\\xf2\\u248c\\xf4\\u099bi\\xed\\u09b2\\u0180ilr\\u2655\\u08e1\\u265asht;\\u697c;\\uc000\\ud835\\udd29\\u0100;E\\u099c\\u2663;\\u6a91\\u0161\\u2669\\u2676r\\u0100du\\u25b2\\u266e\\u0100;l\\u0965\\u2673;\\u696alk;\\u6584cy;\\u4459\\u0280;acht\\u0a48\\u2688\\u268b\\u2691\\u2696r\\xf2\\u25c1orne\\xf2\\u1d08ard;\\u696bri;\\u65fa\\u0100io\\u269f\\u26a4dot;\\u4140ust\\u0100;a\\u26ac\\u26ad\\u63b0che\\xbb\\u26ad\\u0200Eaes\\u26bb\\u26bd\\u26c9\\u26d4;\\u6268p\\u0100;p\\u26c3\\u26c4\\u6a89rox\\xbb\\u26c4\\u0100;q\\u26ce\\u26cf\\u6a87\\u0100;q\\u26ce\\u26bbim;\\u62e6\\u0400abnoptwz\\u26e9\\u26f4\\u26f7\\u271a\\u272f\\u2741\\u2747\\u2750\\u0100nr\\u26ee\\u26f1g;\\u67ecr;\\u61fdr\\xeb\\u08c1g\\u0180lmr\\u26ff\\u270d\\u2714eft\\u0100ar\\u09e6\\u2707ight\\xe1\\u09f2apsto;\\u67fcight\\xe1\\u09fdparrow\\u0100lr\\u2725\\u2729ef\\xf4\\u24edight;\\u61ac\\u0180afl\\u2736\\u2739\\u273dr;\\u6985;\\uc000\\ud835\\udd5dus;\\u6a2dimes;\\u6a34\\u0161\\u274b\\u274fst;\\u6217\\xe1\\u134e\\u0180;ef\\u2757\\u2758\\u1800\\u65cange\\xbb\\u2758ar\\u0100;l\\u2764\\u2765\\u4028t;\\u6993\\u0280achmt\\u2773\\u2776\\u277c\\u2785\\u2787r\\xf2\\u08a8orne\\xf2\\u1d8car\\u0100;d\\u0f98\\u2783;\\u696d;\\u600eri;\\u62bf\\u0300achiqt\\u2798\\u279d\\u0a40\\u27a2\\u27ae\\u27bbquo;\\u6039r;\\uc000\\ud835\\udcc1m\\u0180;eg\\u09b2\\u27aa\\u27ac;\\u6a8d;\\u6a8f\\u0100bu\\u252a\\u27b3o\\u0100;r\\u0e1f\\u27b9;\\u601arok;\\u4142\\u8400<;cdhilqr\\u082b\\u27d2\\u2639\\u27dc\\u27e0\\u27e5\\u27ea\\u27f0\\u0100ci\\u27d7\\u27d9;\\u6aa6r;\\u6a79re\\xe5\\u25f2mes;\\u62c9arr;\\u6976uest;\\u6a7b\\u0100Pi\\u27f5\\u27f9ar;\\u6996\\u0180;ef\\u2800\\u092d\\u181b\\u65c3r\\u0100du\\u2807\\u280dshar;\\u694ahar;\\u6966\\u0100en\\u2817\\u2821rtneqq;\\uc000\\u2268\\ufe00\\xc5\\u281e\\u0700Dacdefhilnopsu\\u2840\\u2845\\u2882\\u288e\\u2893\\u28a0\\u28a5\\u28a8\\u28da\\u28e2\\u28e4\\u0a83\\u28f3\\u2902Dot;\\u623a\\u0200clpr\\u284e\\u2852\\u2863\\u287dr\\u803b\\xaf\\u40af\\u0100et\\u2857\\u2859;\\u6642\\u0100;e\\u285e\\u285f\\u6720se\\xbb\\u285f\\u0100;s\\u103b\\u2868to\\u0200;dlu\\u103b\\u2873\\u2877\\u287bow\\xee\\u048cef\\xf4\\u090f\\xf0\\u13d1ker;\\u65ae\\u0100oy\\u2887\\u288cmma;\\u6a29;\\u443cash;\\u6014asuredangle\\xbb\\u1626r;\\uc000\\ud835\\udd2ao;\\u6127\\u0180cdn\\u28af\\u28b4\\u28c9ro\\u803b\\xb5\\u40b5\\u0200;acd\\u1464\\u28bd\\u28c0\\u28c4s\\xf4\\u16a7ir;\\u6af0ot\\u80bb\\xb7\\u01b5us\\u0180;bd\\u28d2\\u1903\\u28d3\\u6212\\u0100;u\\u1d3c\\u28d8;\\u6a2a\\u0163\\u28de\\u28e1p;\\u6adb\\xf2\\u2212\\xf0\\u0a81\\u0100dp\\u28e9\\u28eeels;\\u62a7f;\\uc000\\ud835\\udd5e\\u0100ct\\u28f8\\u28fdr;\\uc000\\ud835\\udcc2pos\\xbb\\u159d\\u0180;lm\\u2909\\u290a\\u290d\\u43bctimap;\\u62b8\\u0c00GLRVabcdefghijlmoprstuvw\\u2942\\u2953\\u297e\\u2989\\u2998\\u29da\\u29e9\\u2a15\\u2a1a\\u2a58\\u2a5d\\u2a83\\u2a95\\u2aa4\\u2aa8\\u2b04\\u2b07\\u2b44\\u2b7f\\u2bae\\u2c34\\u2c67\\u2c7c\\u2ce9\\u0100gt\\u2947\\u294b;\\uc000\\u22d9\\u0338\\u0100;v\\u2950\\u0bcf\\uc000\\u226b\\u20d2\\u0180elt\\u295a\\u2972\\u2976ft\\u0100ar\\u2961\\u2967rrow;\\u61cdightarrow;\\u61ce;\\uc000\\u22d8\\u0338\\u0100;v\\u297b\\u0c47\\uc000\\u226a\\u20d2ightarrow;\\u61cf\\u0100Dd\\u298e\\u2993ash;\\u62afash;\\u62ae\\u0280bcnpt\\u29a3\\u29a7\\u29ac\\u29b1\\u29ccla\\xbb\\u02deute;\\u4144g;\\uc000\\u2220\\u20d2\\u0280;Eiop\\u0d84\\u29bc\\u29c0\\u29c5\\u29c8;\\uc000\\u2a70\\u0338d;\\uc000\\u224b\\u0338s;\\u4149ro\\xf8\\u0d84ur\\u0100;a\\u29d3\\u29d4\\u666el\\u0100;s\\u29d3\\u0b38\\u01f3\\u29df\\0\\u29e3p\\u80bb\\xa0\\u0b37mp\\u0100;e\\u0bf9\\u0c00\\u0280aeouy\\u29f4\\u29fe\\u2a03\\u2a10\\u2a13\\u01f0\\u29f9\\0\\u29fb;\\u6a43on;\\u4148dil;\\u4146ng\\u0100;d\\u0d7e\\u2a0aot;\\uc000\\u2a6d\\u0338p;\\u6a42;\\u443dash;\\u6013\\u0380;Aadqsx\\u0b92\\u2a29\\u2a2d\\u2a3b\\u2a41\\u2a45\\u2a50rr;\\u61d7r\\u0100hr\\u2a33\\u2a36k;\\u6924\\u0100;o\\u13f2\\u13f0ot;\\uc000\\u2250\\u0338ui\\xf6\\u0b63\\u0100ei\\u2a4a\\u2a4ear;\\u6928\\xed\\u0b98ist\\u0100;s\\u0ba0\\u0b9fr;\\uc000\\ud835\\udd2b\\u0200Eest\\u0bc5\\u2a66\\u2a79\\u2a7c\\u0180;qs\\u0bbc\\u2a6d\\u0be1\\u0180;qs\\u0bbc\\u0bc5\\u2a74lan\\xf4\\u0be2i\\xed\\u0bea\\u0100;r\\u0bb6\\u2a81\\xbb\\u0bb7\\u0180Aap\\u2a8a\\u2a8d\\u2a91r\\xf2\\u2971rr;\\u61aear;\\u6af2\\u0180;sv\\u0f8d\\u2a9c\\u0f8c\\u0100;d\\u2aa1\\u2aa2\\u62fc;\\u62facy;\\u445a\\u0380AEadest\\u2ab7\\u2aba\\u2abe\\u2ac2\\u2ac5\\u2af6\\u2af9r\\xf2\\u2966;\\uc000\\u2266\\u0338rr;\\u619ar;\\u6025\\u0200;fqs\\u0c3b\\u2ace\\u2ae3\\u2aeft\\u0100ar\\u2ad4\\u2ad9rro\\xf7\\u2ac1ightarro\\xf7\\u2a90\\u0180;qs\\u0c3b\\u2aba\\u2aealan\\xf4\\u0c55\\u0100;s\\u0c55\\u2af4\\xbb\\u0c36i\\xed\\u0c5d\\u0100;r\\u0c35\\u2afei\\u0100;e\\u0c1a\\u0c25i\\xe4\\u0d90\\u0100pt\\u2b0c\\u2b11f;\\uc000\\ud835\\udd5f\\u8180\\xac;in\\u2b19\\u2b1a\\u2b36\\u40acn\\u0200;Edv\\u0b89\\u2b24\\u2b28\\u2b2e;\\uc000\\u22f9\\u0338ot;\\uc000\\u22f5\\u0338\\u01e1\\u0b89\\u2b33\\u2b35;\\u62f7;\\u62f6i\\u0100;v\\u0cb8\\u2b3c\\u01e1\\u0cb8\\u2b41\\u2b43;\\u62fe;\\u62fd\\u0180aor\\u2b4b\\u2b63\\u2b69r\\u0200;ast\\u0b7b\\u2b55\\u2b5a\\u2b5flle\\xec\\u0b7bl;\\uc000\\u2afd\\u20e5;\\uc000\\u2202\\u0338lint;\\u6a14\\u0180;ce\\u0c92\\u2b70\\u2b73u\\xe5\\u0ca5\\u0100;c\\u0c98\\u2b78\\u0100;e\\u0c92\\u2b7d\\xf1\\u0c98\\u0200Aait\\u2b88\\u2b8b\\u2b9d\\u2ba7r\\xf2\\u2988rr\\u0180;cw\\u2b94\\u2b95\\u2b99\\u619b;\\uc000\\u2933\\u0338;\\uc000\\u219d\\u0338ghtarrow\\xbb\\u2b95ri\\u0100;e\\u0ccb\\u0cd6\\u0380chimpqu\\u2bbd\\u2bcd\\u2bd9\\u2b04\\u0b78\\u2be4\\u2bef\\u0200;cer\\u0d32\\u2bc6\\u0d37\\u2bc9u\\xe5\\u0d45;\\uc000\\ud835\\udcc3ort\\u026d\\u2b05\\0\\0\\u2bd6ar\\xe1\\u2b56m\\u0100;e\\u0d6e\\u2bdf\\u0100;q\\u0d74\\u0d73su\\u0100bp\\u2beb\\u2bed\\xe5\\u0cf8\\xe5\\u0d0b\\u0180bcp\\u2bf6\\u2c11\\u2c19\\u0200;Ees\\u2bff\\u2c00\\u0d22\\u2c04\\u6284;\\uc000\\u2ac5\\u0338et\\u0100;e\\u0d1b\\u2c0bq\\u0100;q\\u0d23\\u2c00c\\u0100;e\\u0d32\\u2c17\\xf1\\u0d38\\u0200;Ees\\u2c22\\u2c23\\u0d5f\\u2c27\\u6285;\\uc000\\u2ac6\\u0338et\\u0100;e\\u0d58\\u2c2eq\\u0100;q\\u0d60\\u2c23\\u0200gilr\\u2c3d\\u2c3f\\u2c45\\u2c47\\xec\\u0bd7lde\\u803b\\xf1\\u40f1\\xe7\\u0c43iangle\\u0100lr\\u2c52\\u2c5ceft\\u0100;e\\u0c1a\\u2c5a\\xf1\\u0c26ight\\u0100;e\\u0ccb\\u2c65\\xf1\\u0cd7\\u0100;m\\u2c6c\\u2c6d\\u43bd\\u0180;es\\u2c74\\u2c75\\u2c79\\u4023ro;\\u6116p;\\u6007\\u0480DHadgilrs\\u2c8f\\u2c94\\u2c99\\u2c9e\\u2ca3\\u2cb0\\u2cb6\\u2cd3\\u2ce3ash;\\u62adarr;\\u6904p;\\uc000\\u224d\\u20d2ash;\\u62ac\\u0100et\\u2ca8\\u2cac;\\uc000\\u2265\\u20d2;\\uc000>\\u20d2nfin;\\u69de\\u0180Aet\\u2cbd\\u2cc1\\u2cc5rr;\\u6902;\\uc000\\u2264\\u20d2\\u0100;r\\u2cca\\u2ccd\\uc000<\\u20d2ie;\\uc000\\u22b4\\u20d2\\u0100At\\u2cd8\\u2cdcrr;\\u6903rie;\\uc000\\u22b5\\u20d2im;\\uc000\\u223c\\u20d2\\u0180Aan\\u2cf0\\u2cf4\\u2d02rr;\\u61d6r\\u0100hr\\u2cfa\\u2cfdk;\\u6923\\u0100;o\\u13e7\\u13e5ear;\\u6927\\u1253\\u1a95\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\0\\u2d2d\\0\\u2d38\\u2d48\\u2d60\\u2d65\\u2d72\\u2d84\\u1b07\\0\\0\\u2d8d\\u2dab\\0\\u2dc8\\u2dce\\0\\u2ddc\\u2e19\\u2e2b\\u2e3e\\u2e43\\u0100cs\\u2d31\\u1a97ute\\u803b\\xf3\\u40f3\\u0100iy\\u2d3c\\u2d45r\\u0100;c\\u1a9e\\u2d42\\u803b\\xf4\\u40f4;\\u443e\\u0280abios\\u1aa0\\u2d52\\u2d57\\u01c8\\u2d5alac;\\u4151v;\\u6a38old;\\u69bclig;\\u4153\\u0100cr\\u2d69\\u2d6dir;\\u69bf;\\uc000\\ud835\\udd2c\\u036f\\u2d79\\0\\0\\u2d7c\\0\\u2d82n;\\u42dbave\\u803b\\xf2\\u40f2;\\u69c1\\u0100bm\\u2d88\\u0df4ar;\\u69b5\\u0200acit\\u2d95\\u2d98\\u2da5\\u2da8r\\xf2\\u1a80\\u0100ir\\u2d9d\\u2da0r;\\u69beoss;\\u69bbn\\xe5\\u0e52;\\u69c0\\u0180aei\\u2db1\\u2db5\\u2db9cr;\\u414dga;\\u43c9\\u0180cdn\\u2dc0\\u2dc5\\u01cdron;\\u43bf;\\u69b6pf;\\uc000\\ud835\\udd60\\u0180ael\\u2dd4\\u2dd7\\u01d2r;\\u69b7rp;\\u69b9\\u0380;adiosv\\u2dea\\u2deb\\u2dee\\u2e08\\u2e0d\\u2e10\\u2e16\\u6228r\\xf2\\u1a86\\u0200;efm\\u2df7\\u2df8\\u2e02\\u2e05\\u6a5dr\\u0100;o\\u2dfe\\u2dff\\u6134f\\xbb\\u2dff\\u803b\\xaa\\u40aa\\u803b\\xba\\u40bagof;\\u62b6r;\\u6a56lope;\\u6a57;\\u6a5b\\u0180clo\\u2e1f\\u2e21\\u2e27\\xf2\\u2e01ash\\u803b\\xf8\\u40f8l;\\u6298i\\u016c\\u2e2f\\u2e34de\\u803b\\xf5\\u40f5es\\u0100;a\\u01db\\u2e3as;\\u6a36ml\\u803b\\xf6\\u40f6bar;\\u633d\\u0ae1\\u2e5e\\0\\u2e7d\\0\\u2e80\\u2e9d\\0\\u2ea2\\u2eb9\\0\\0\\u2ecb\\u0e9c\\0\\u2f13\\0\\0\\u2f2b\\u2fbc\\0\\u2fc8r\\u0200;ast\\u0403\\u2e67\\u2e72\\u0e85\\u8100\\xb6;l\\u2e6d\\u2e6e\\u40b6le\\xec\\u0403\\u0269\\u2e78\\0\\0\\u2e7bm;\\u6af3;\\u6afdy;\\u443fr\\u0280cimpt\\u2e8b\\u2e8f\\u2e93\\u1865\\u2e97nt;\\u4025od;\\u402eil;\\u6030enk;\\u6031r;\\uc000\\ud835\\udd2d\\u0180imo\\u2ea8\\u2eb0\\u2eb4\\u0100;v\\u2ead\\u2eae\\u43c6;\\u43d5ma\\xf4\\u0a76ne;\\u660e\\u0180;tv\\u2ebf\\u2ec0\\u2ec8\\u43c0chfork\\xbb\\u1ffd;\\u43d6\\u0100au\\u2ecf\\u2edfn\\u0100ck\\u2ed5\\u2eddk\\u0100;h\\u21f4\\u2edb;\\u610e\\xf6\\u21f4s\\u0480;abcdemst\\u2ef3\\u2ef4\\u1908\\u2ef9\\u2efd\\u2f04\\u2f06\\u2f0a\\u2f0e\\u402bcir;\\u6a23ir;\\u6a22\\u0100ou\\u1d40\\u2f02;\\u6a25;\\u6a72n\\u80bb\\xb1\\u0e9dim;\\u6a26wo;\\u6a27\\u0180ipu\\u2f19\\u2f20\\u2f25ntint;\\u6a15f;\\uc000\\ud835\\udd61nd\\u803b\\xa3\\u40a3\\u0500;Eaceinosu\\u0ec8\\u2f3f\\u2f41\\u2f44\\u2f47\\u2f81\\u2f89\\u2f92\\u2f7e\\u2fb6;\\u6ab3p;\\u6ab7u\\xe5\\u0ed9\\u0100;c\\u0ece\\u2f4c\\u0300;acens\\u0ec8\\u2f59\\u2f5f\\u2f66\\u2f68\\u2f7eppro\\xf8\\u2f43urlye\\xf1\\u0ed9\\xf1\\u0ece\\u0180aes\\u2f6f\\u2f76\\u2f7approx;\\u6ab9qq;\\u6ab5im;\\u62e8i\\xed\\u0edfme\\u0100;s\\u2f88\\u0eae\\u6032\\u0180Eas\\u2f78\\u2f90\\u2f7a\\xf0\\u2f75\\u0180dfp\\u0eec\\u2f99\\u2faf\\u0180als\\u2fa0\\u2fa5\\u2faalar;\\u632eine;\\u6312urf;\\u6313\\u0100;t\\u0efb\\u2fb4\\xef\\u0efbrel;\\u62b0\\u0100ci\\u2fc0\\u2fc5r;\\uc000\\ud835\\udcc5;\\u43c8ncsp;\\u6008\\u0300fiopsu\\u2fda\\u22e2\\u2fdf\\u2fe5\\u2feb\\u2ff1r;\\uc000\\ud835\\udd2epf;\\uc000\\ud835\\udd62rime;\\u6057cr;\\uc000\\ud835\\udcc6\\u0180aeo\\u2ff8\\u3009\\u3013t\\u0100ei\\u2ffe\\u3005rnion\\xf3\\u06b0nt;\\u6a16st\\u0100;e\\u3010\\u3011\\u403f\\xf1\\u1f19\\xf4\\u0f14\\u0a80ABHabcdefhilmnoprstux\\u3040\\u3051\\u3055\\u3059\\u30e0\\u310e\\u312b\\u3147\\u3162\\u3172\\u318e\\u3206\\u3215\\u3224\\u3229\\u3258\\u326e\\u3272\\u3290\\u32b0\\u32b7\\u0180art\\u3047\\u304a\\u304cr\\xf2\\u10b3\\xf2\\u03ddail;\\u691car\\xf2\\u1c65ar;\\u6964\\u0380cdenqrt\\u3068\\u3075\\u3078\\u307f\\u308f\\u3094\\u30cc\\u0100eu\\u306d\\u3071;\\uc000\\u223d\\u0331te;\\u4155i\\xe3\\u116emptyv;\\u69b3g\\u0200;del\\u0fd1\\u3089\\u308b\\u308d;\\u6992;\\u69a5\\xe5\\u0fd1uo\\u803b\\xbb\\u40bbr\\u0580;abcfhlpstw\\u0fdc\\u30ac\\u30af\\u30b7\\u30b9\\u30bc\\u30be\\u30c0\\u30c3\\u30c7\\u30cap;\\u6975\\u0100;f\\u0fe0\\u30b4s;\\u6920;\\u6933s;\\u691e\\xeb\\u225d\\xf0\\u272el;\\u6945im;\\u6974l;\\u61a3;\\u619d\\u0100ai\\u30d1\\u30d5il;\\u691ao\\u0100;n\\u30db\\u30dc\\u6236al\\xf3\\u0f1e\\u0180abr\\u30e7\\u30ea\\u30eer\\xf2\\u17e5rk;\\u6773\\u0100ak\\u30f3\\u30fdc\\u0100ek\\u30f9\\u30fb;\\u407d;\\u405d\\u0100es\\u3102\\u3104;\\u698cl\\u0100du\\u310a\\u310c;\\u698e;\\u6990\\u0200aeuy\\u3117\\u311c\\u3127\\u3129ron;\\u4159\\u0100di\\u3121\\u3125il;\\u4157\\xec\\u0ff2\\xe2\\u30fa;\\u4440\\u0200clqs\\u3134\\u3137\\u313d\\u3144a;\\u6937dhar;\\u6969uo\\u0100;r\\u020e\\u020dh;\\u61b3\\u0180acg\\u314e\\u315f\\u0f44l\\u0200;ips\\u0f78\\u3158\\u315b\\u109cn\\xe5\\u10bbar\\xf4\\u0fa9t;\\u65ad\\u0180ilr\\u3169\\u1023\\u316esht;\\u697d;\\uc000\\ud835\\udd2f\\u0100ao\\u3177\\u3186r\\u0100du\\u317d\\u317f\\xbb\\u047b\\u0100;l\\u1091\\u3184;\\u696c\\u0100;v\\u318b\\u318c\\u43c1;\\u43f1\\u0180gns\\u3195\\u31f9\\u31fcht\\u0300ahlrst\\u31a4\\u31b0\\u31c2\\u31d8\\u31e4\\u31eerrow\\u0100;t\\u0fdc\\u31ada\\xe9\\u30c8arpoon\\u0100du\\u31bb\\u31bfow\\xee\\u317ep\\xbb\\u1092eft\\u0100ah\\u31ca\\u31d0rrow\\xf3\\u0feaarpoon\\xf3\\u0551ightarrows;\\u61c9quigarro\\xf7\\u30cbhreetimes;\\u62ccg;\\u42daingdotse\\xf1\\u1f32\\u0180ahm\\u320d\\u3210\\u3213r\\xf2\\u0feaa\\xf2\\u0551;\\u600foust\\u0100;a\\u321e\\u321f\\u63b1che\\xbb\\u321fmid;\\u6aee\\u0200abpt\\u3232\\u323d\\u3240\\u3252\\u0100nr\\u3237\\u323ag;\\u67edr;\\u61fer\\xeb\\u1003\\u0180afl\\u3247\\u324a\\u324er;\\u6986;\\uc000\\ud835\\udd63us;\\u6a2eimes;\\u6a35\\u0100ap\\u325d\\u3267r\\u0100;g\\u3263\\u3264\\u4029t;\\u6994olint;\\u6a12ar\\xf2\\u31e3\\u0200achq\\u327b\\u3280\\u10bc\\u3285quo;\\u603ar;\\uc000\\ud835\\udcc7\\u0100bu\\u30fb\\u328ao\\u0100;r\\u0214\\u0213\\u0180hir\\u3297\\u329b\\u32a0re\\xe5\\u31f8mes;\\u62cai\\u0200;efl\\u32aa\\u1059\\u1821\\u32ab\\u65b9tri;\\u69celuhar;\\u6968;\\u611e\\u0d61\\u32d5\\u32db\\u32df\\u332c\\u3338\\u3371\\0\\u337a\\u33a4\\0\\0\\u33ec\\u33f0\\0\\u3428\\u3448\\u345a\\u34ad\\u34b1\\u34ca\\u34f1\\0\\u3616\\0\\0\\u3633cute;\\u415bqu\\xef\\u27ba\\u0500;Eaceinpsy\\u11ed\\u32f3\\u32f5\\u32ff\\u3302\\u330b\\u330f\\u331f\\u3326\\u3329;\\u6ab4\\u01f0\\u32fa\\0\\u32fc;\\u6ab8on;\\u4161u\\xe5\\u11fe\\u0100;d\\u11f3\\u3307il;\\u415frc;\\u415d\\u0180Eas\\u3316\\u3318\\u331b;\\u6ab6p;\\u6abaim;\\u62e9olint;\\u6a13i\\xed\\u1204;\\u4441ot\\u0180;be\\u3334\\u1d47\\u3335\\u62c5;\\u6a66\\u0380Aacmstx\\u3346\\u334a\\u3357\\u335b\\u335e\\u3363\\u336drr;\\u61d8r\\u0100hr\\u3350\\u3352\\xeb\\u2228\\u0100;o\\u0a36\\u0a34t\\u803b\\xa7\\u40a7i;\\u403bwar;\\u6929m\\u0100in\\u3369\\xf0nu\\xf3\\xf1t;\\u6736r\\u0100;o\\u3376\\u2055\\uc000\\ud835\\udd30\\u0200acoy\\u3382\\u3386\\u3391\\u33a0rp;\\u666f\\u0100hy\\u338b\\u338fcy;\\u4449;\\u4448rt\\u026d\\u3399\\0\\0\\u339ci\\xe4\\u1464ara\\xec\\u2e6f\\u803b\\xad\\u40ad\\u0100gm\\u33a8\\u33b4ma\\u0180;fv\\u33b1\\u33b2\\u33b2\\u43c3;\\u43c2\\u0400;deglnpr\\u12ab\\u33c5\\u33c9\\u33ce\\u33d6\\u33de\\u33e1\\u33e6ot;\\u6a6a\\u0100;q\\u12b1\\u12b0\\u0100;E\\u33d3\\u33d4\\u6a9e;\\u6aa0\\u0100;E\\u33db\\u33dc\\u6a9d;\\u6a9fe;\\u6246lus;\\u6a24arr;\\u6972ar\\xf2\\u113d\\u0200aeit\\u33f8\\u3408\\u340f\\u3417\\u0100ls\\u33fd\\u3404lsetm\\xe9\\u336ahp;\\u6a33parsl;\\u69e4\\u0100dl\\u1463\\u3414e;\\u6323\\u0100;e\\u341c\\u341d\\u6aaa\\u0100;s\\u3422\\u3423\\u6aac;\\uc000\\u2aac\\ufe00\\u0180flp\\u342e\\u3433\\u3442tcy;\\u444c\\u0100;b\\u3438\\u3439\\u402f\\u0100;a\\u343e\\u343f\\u69c4r;\\u633ff;\\uc000\\ud835\\udd64a\\u0100dr\\u344d\\u0402es\\u0100;u\\u3454\\u3455\\u6660it\\xbb\\u3455\\u0180csu\\u3460\\u3479\\u349f\\u0100au\\u3465\\u346fp\\u0100;s\\u1188\\u346b;\\uc000\\u2293\\ufe00p\\u0100;s\\u11b4\\u3475;\\uc000\\u2294\\ufe00u\\u0100bp\\u347f\\u348f\\u0180;es\\u1197\\u119c\\u3486et\\u0100;e\\u1197\\u348d\\xf1\\u119d\\u0180;es\\u11a8\\u11ad\\u3496et\\u0100;e\\u11a8\\u349d\\xf1\\u11ae\\u0180;af\\u117b\\u34a6\\u05b0r\\u0165\\u34ab\\u05b1\\xbb\\u117car\\xf2\\u1148\\u0200cemt\\u34b9\\u34be\\u34c2\\u34c5r;\\uc000\\ud835\\udcc8tm\\xee\\xf1i\\xec\\u3415ar\\xe6\\u11be\\u0100ar\\u34ce\\u34d5r\\u0100;f\\u34d4\\u17bf\\u6606\\u0100an\\u34da\\u34edight\\u0100ep\\u34e3\\u34eapsilo\\xee\\u1ee0h\\xe9\\u2eafs\\xbb\\u2852\\u0280bcmnp\\u34fb\\u355e\\u1209\\u358b\\u358e\\u0480;Edemnprs\\u350e\\u350f\\u3511\\u3515\\u351e\\u3523\\u352c\\u3531\\u3536\\u6282;\\u6ac5ot;\\u6abd\\u0100;d\\u11da\\u351aot;\\u6ac3ult;\\u6ac1\\u0100Ee\\u3528\\u352a;\\u6acb;\\u628alus;\\u6abfarr;\\u6979\\u0180eiu\\u353d\\u3552\\u3555t\\u0180;en\\u350e\\u3545\\u354bq\\u0100;q\\u11da\\u350feq\\u0100;q\\u352b\\u3528m;\\u6ac7\\u0100bp\\u355a\\u355c;\\u6ad5;\\u6ad3c\\u0300;acens\\u11ed\\u356c\\u3572\\u3579\\u357b\\u3326ppro\\xf8\\u32faurlye\\xf1\\u11fe\\xf1\\u11f3\\u0180aes\\u3582\\u3588\\u331bppro\\xf8\\u331aq\\xf1\\u3317g;\\u666a\\u0680123;Edehlmnps\\u35a9\\u35ac\\u35af\\u121c\\u35b2\\u35b4\\u35c0\\u35c9\\u35d5\\u35da\\u35df\\u35e8\\u35ed\\u803b\\xb9\\u40b9\\u803b\\xb2\\u40b2\\u803b\\xb3\\u40b3;\\u6ac6\\u0100os\\u35b9\\u35bct;\\u6abeub;\\u6ad8\\u0100;d\\u1222\\u35c5ot;\\u6ac4s\\u0100ou\\u35cf\\u35d2l;\\u67c9b;\\u6ad7arr;\\u697bult;\\u6ac2\\u0100Ee\\u35e4\\u35e6;\\u6acc;\\u628blus;\\u6ac0\\u0180eiu\\u35f4\\u3609\\u360ct\\u0180;en\\u121c\\u35fc\\u3602q\\u0100;q\\u1222\\u35b2eq\\u0100;q\\u35e7\\u35e4m;\\u6ac8\\u0100bp\\u3611\\u3613;\\u6ad4;\\u6ad6\\u0180Aan\\u361c\\u3620\\u362drr;\\u61d9r\\u0100hr\\u3626\\u3628\\xeb\\u222e\\u0100;o\\u0a2b\\u0a29war;\\u692alig\\u803b\\xdf\\u40df\\u0be1\\u3651\\u365d\\u3660\\u12ce\\u3673\\u3679\\0\\u367e\\u36c2\\0\\0\\0\\0\\0\\u36db\\u3703\\0\\u3709\\u376c\\0\\0\\0\\u3787\\u0272\\u3656\\0\\0\\u365bget;\\u6316;\\u43c4r\\xeb\\u0e5f\\u0180aey\\u3666\\u366b\\u3670ron;\\u4165dil;\\u4163;\\u4442lrec;\\u6315r;\\uc000\\ud835\\udd31\\u0200eiko\\u3686\\u369d\\u36b5\\u36bc\\u01f2\\u368b\\0\\u3691e\\u01004f\\u1284\\u1281a\\u0180;sv\\u3698\\u3699\\u369b\\u43b8ym;\\u43d1\\u0100cn\\u36a2\\u36b2k\\u0100as\\u36a8\\u36aeppro\\xf8\\u12c1im\\xbb\\u12acs\\xf0\\u129e\\u0100as\\u36ba\\u36ae\\xf0\\u12c1rn\\u803b\\xfe\\u40fe\\u01ec\\u031f\\u36c6\\u22e7es\\u8180\\xd7;bd\\u36cf\\u36d0\\u36d8\\u40d7\\u0100;a\\u190f\\u36d5r;\\u6a31;\\u6a30\\u0180eps\\u36e1\\u36e3\\u3700\\xe1\\u2a4d\\u0200;bcf\\u0486\\u36ec\\u36f0\\u36f4ot;\\u6336ir;\\u6af1\\u0100;o\\u36f9\\u36fc\\uc000\\ud835\\udd65rk;\\u6ada\\xe1\\u3362rime;\\u6034\\u0180aip\\u370f\\u3712\\u3764d\\xe5\\u1248\\u0380adempst\\u3721\\u374d\\u3740\\u3751\\u3757\\u375c\\u375fngle\\u0280;dlqr\\u3730\\u3731\\u3736\\u3740\\u3742\\u65b5own\\xbb\\u1dbbeft\\u0100;e\\u2800\\u373e\\xf1\\u092e;\\u625cight\\u0100;e\\u32aa\\u374b\\xf1\\u105aot;\\u65ecinus;\\u6a3alus;\\u6a39b;\\u69cdime;\\u6a3bezium;\\u63e2\\u0180cht\\u3772\\u377d\\u3781\\u0100ry\\u3777\\u377b;\\uc000\\ud835\\udcc9;\\u4446cy;\\u445brok;\\u4167\\u0100io\\u378b\\u378ex\\xf4\\u1777head\\u0100lr\\u3797\\u37a0eftarro\\xf7\\u084fightarrow\\xbb\\u0f5d\\u0900AHabcdfghlmoprstuw\\u37d0\\u37d3\\u37d7\\u37e4\\u37f0\\u37fc\\u380e\\u381c\\u3823\\u3834\\u3851\\u385d\\u386b\\u38a9\\u38cc\\u38d2\\u38ea\\u38f6r\\xf2\\u03edar;\\u6963\\u0100cr\\u37dc\\u37e2ute\\u803b\\xfa\\u40fa\\xf2\\u1150r\\u01e3\\u37ea\\0\\u37edy;\\u445eve;\\u416d\\u0100iy\\u37f5\\u37farc\\u803b\\xfb\\u40fb;\\u4443\\u0180abh\\u3803\\u3806\\u380br\\xf2\\u13adlac;\\u4171a\\xf2\\u13c3\\u0100ir\\u3813\\u3818sht;\\u697e;\\uc000\\ud835\\udd32rave\\u803b\\xf9\\u40f9\\u0161\\u3827\\u3831r\\u0100lr\\u382c\\u382e\\xbb\\u0957\\xbb\\u1083lk;\\u6580\\u0100ct\\u3839\\u384d\\u026f\\u383f\\0\\0\\u384arn\\u0100;e\\u3845\\u3846\\u631cr\\xbb\\u3846op;\\u630fri;\\u65f8\\u0100al\\u3856\\u385acr;\\u416b\\u80bb\\xa8\\u0349\\u0100gp\\u3862\\u3866on;\\u4173f;\\uc000\\ud835\\udd66\\u0300adhlsu\\u114b\\u3878\\u387d\\u1372\\u3891\\u38a0own\\xe1\\u13b3arpoon\\u0100lr\\u3888\\u388cef\\xf4\\u382digh\\xf4\\u382fi\\u0180;hl\\u3899\\u389a\\u389c\\u43c5\\xbb\\u13faon\\xbb\\u389aparrows;\\u61c8\\u0180cit\\u38b0\\u38c4\\u38c8\\u026f\\u38b6\\0\\0\\u38c1rn\\u0100;e\\u38bc\\u38bd\\u631dr\\xbb\\u38bdop;\\u630eng;\\u416fri;\\u65f9cr;\\uc000\\ud835\\udcca\\u0180dir\\u38d9\\u38dd\\u38e2ot;\\u62f0lde;\\u4169i\\u0100;f\\u3730\\u38e8\\xbb\\u1813\\u0100am\\u38ef\\u38f2r\\xf2\\u38a8l\\u803b\\xfc\\u40fcangle;\\u69a7\\u0780ABDacdeflnoprsz\\u391c\\u391f\\u3929\\u392d\\u39b5\\u39b8\\u39bd\\u39df\\u39e4\\u39e8\\u39f3\\u39f9\\u39fd\\u3a01\\u3a20r\\xf2\\u03f7ar\\u0100;v\\u3926\\u3927\\u6ae8;\\u6ae9as\\xe8\\u03e1\\u0100nr\\u3932\\u3937grt;\\u699c\\u0380eknprst\\u34e3\\u3946\\u394b\\u3952\\u395d\\u3964\\u3996app\\xe1\\u2415othin\\xe7\\u1e96\\u0180hir\\u34eb\\u2ec8\\u3959op\\xf4\\u2fb5\\u0100;h\\u13b7\\u3962\\xef\\u318d\\u0100iu\\u3969\\u396dgm\\xe1\\u33b3\\u0100bp\\u3972\\u3984setneq\\u0100;q\\u397d\\u3980\\uc000\\u228a\\ufe00;\\uc000\\u2acb\\ufe00setneq\\u0100;q\\u398f\\u3992\\uc000\\u228b\\ufe00;\\uc000\\u2acc\\ufe00\\u0100hr\\u399b\\u399fet\\xe1\\u369ciangle\\u0100lr\\u39aa\\u39afeft\\xbb\\u0925ight\\xbb\\u1051y;\\u4432ash\\xbb\\u1036\\u0180elr\\u39c4\\u39d2\\u39d7\\u0180;be\\u2dea\\u39cb\\u39cfar;\\u62bbq;\\u625alip;\\u62ee\\u0100bt\\u39dc\\u1468a\\xf2\\u1469r;\\uc000\\ud835\\udd33tr\\xe9\\u39aesu\\u0100bp\\u39ef\\u39f1\\xbb\\u0d1c\\xbb\\u0d59pf;\\uc000\\ud835\\udd67ro\\xf0\\u0efbtr\\xe9\\u39b4\\u0100cu\\u3a06\\u3a0br;\\uc000\\ud835\\udccb\\u0100bp\\u3a10\\u3a18n\\u0100Ee\\u3980\\u3a16\\xbb\\u397en\\u0100Ee\\u3992\\u3a1e\\xbb\\u3990igzag;\\u699a\\u0380cefoprs\\u3a36\\u3a3b\\u3a56\\u3a5b\\u3a54\\u3a61\\u3a6airc;\\u4175\\u0100di\\u3a40\\u3a51\\u0100bg\\u3a45\\u3a49ar;\\u6a5fe\\u0100;q\\u15fa\\u3a4f;\\u6259erp;\\u6118r;\\uc000\\ud835\\udd34pf;\\uc000\\ud835\\udd68\\u0100;e\\u1479\\u3a66at\\xe8\\u1479cr;\\uc000\\ud835\\udccc\\u0ae3\\u178e\\u3a87\\0\\u3a8b\\0\\u3a90\\u3a9b\\0\\0\\u3a9d\\u3aa8\\u3aab\\u3aaf\\0\\0\\u3ac3\\u3ace\\0\\u3ad8\\u17dc\\u17dftr\\xe9\\u17d1r;\\uc000\\ud835\\udd35\\u0100Aa\\u3a94\\u3a97r\\xf2\\u03c3r\\xf2\\u09f6;\\u43be\\u0100Aa\\u3aa1\\u3aa4r\\xf2\\u03b8r\\xf2\\u09eba\\xf0\\u2713is;\\u62fb\\u0180dpt\\u17a4\\u3ab5\\u3abe\\u0100fl\\u3aba\\u17a9;\\uc000\\ud835\\udd69im\\xe5\\u17b2\\u0100Aa\\u3ac7\\u3acar\\xf2\\u03cer\\xf2\\u0a01\\u0100cq\\u3ad2\\u17b8r;\\uc000\\ud835\\udccd\\u0100pt\\u17d6\\u3adcr\\xe9\\u17d4\\u0400acefiosu\\u3af0\\u3afd\\u3b08\\u3b0c\\u3b11\\u3b15\\u3b1b\\u3b21c\\u0100uy\\u3af6\\u3afbte\\u803b\\xfd\\u40fd;\\u444f\\u0100iy\\u3b02\\u3b06rc;\\u4177;\\u444bn\\u803b\\xa5\\u40a5r;\\uc000\\ud835\\udd36cy;\\u4457pf;\\uc000\\ud835\\udd6acr;\\uc000\\ud835\\udcce\\u0100cm\\u3b26\\u3b29y;\\u444el\\u803b\\xff\\u40ff\\u0500acdefhiosw\\u3b42\\u3b48\\u3b54\\u3b58\\u3b64\\u3b69\\u3b6d\\u3b74\\u3b7a\\u3b80cute;\\u417a\\u0100ay\\u3b4d\\u3b52ron;\\u417e;\\u4437ot;\\u417c\\u0100et\\u3b5d\\u3b61tr\\xe6\\u155fa;\\u43b6r;\\uc000\\ud835\\udd37cy;\\u4436grarr;\\u61ddpf;\\uc000\\ud835\\udd6bcr;\\uc000\\ud835\\udccf\\u0100jn\\u3b85\\u3b87;\\u600dj;\\u600c\".split(\"\").map(function(c) {\n+                        return c.charCodeAt(0);\n+                    }));\n \n-                function graphql(args) {\n-                    // Always return a Promise for a consistent API.\n-                    return new Promise(resolve => resolve(graphqlImpl(args)));\n-                }\n-                /**\n-                 * The graphqlSync function also fulfills GraphQL operations by parsing,\n-                 * validating, and executing a GraphQL document along side a GraphQL schema.\n-                 * However, it guarantees to complete synchronously (or throw an error) assuming\n-                 * that all field resolvers are also synchronous.\n-                 */\n+                /***/\n+            }),\n \n-                function graphqlSync(args) {\n-                    const result = graphqlImpl(args); // Assert that the execution was synchronous.\n+        /***/\n+        \"../../../node_modules/entities/lib/generated/decode-data-xml.js\":\n+            /*!***********************************************************************!*\\\n+              !*** ../../../node_modules/entities/lib/generated/decode-data-xml.js ***!\n+              \\***********************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports) {\n \n-                    if ((0, _isPromise.isPromise)(result)) {\n-                        throw new Error('GraphQL execution failed to complete synchronously.');\n-                    }\n-                    return result;\n-                }\n+                \"use strict\";\n \n-                function graphqlImpl(args) {\n-                    // Temporary for v15 to v16 migration. Remove in v17\n-                    arguments.length < 2 || (0, _devAssert.devAssert)(false, 'graphql@16 dropped long-deprecated support for positional arguments, please pass an object instead.');\n-                    const {\n-                        schema,\n-                        source,\n-                        rootValue,\n-                        contextValue,\n-                        variableValues,\n-                        operationName,\n-                        fieldResolver,\n-                        typeResolver\n-                    } = args; // Validate Schema\n \n-                    const schemaValidationErrors = (0, _validate.validateSchema)(schema);\n-                    if (schemaValidationErrors.length > 0) {\n-                        return {\n-                            errors: schemaValidationErrors\n-                        };\n-                    } // Parse\n+                // Generated using scripts/write-decode-map.ts\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports[\"default\"] = new Uint16Array(\n+                    // prettier-ignore\n+                    \"\\u0200aglq\\t\\x15\\x18\\x1b\\u026d\\x0f\\0\\0\\x12p;\\u4026os;\\u4027t;\\u403et;\\u403cuot;\\u4022\".split(\"\").map(function(c) {\n+                        return c.charCodeAt(0);\n+                    }));\n \n-                    let document;\n-                    try {\n-                        document = (0, _parser.parse)(source);\n-                    } catch (syntaxError) {\n-                        return {\n-                            errors: [syntaxError]\n-                        };\n-                    } // Validate\n+                /***/\n+            }),\n \n-                    const validationErrors = (0, _validate2.validate)(schema, document);\n-                    if (validationErrors.length > 0) {\n-                        return {\n-                            errors: validationErrors\n-                        };\n-                    } // Execute\n+        /***/\n+        \"../../../node_modules/entities/lib/generated/encode-html.js\":\n+            /*!*******************************************************************!*\\\n+              !*** ../../../node_modules/entities/lib/generated/encode-html.js ***!\n+              \\*******************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports) {\n \n-                    return (0, _execute.execute)({\n-                        schema,\n-                        document,\n-                        rootValue,\n-                        contextValue,\n-                        variableValues,\n-                        operationName,\n-                        fieldResolver,\n-                        typeResolver\n-                    });\n+                \"use strict\";\n+\n+\n+                // Generated using scripts/write-encode-map.ts\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+\n+                function restoreDiff(arr) {\n+                    for (var i = 1; i < arr.length; i++) {\n+                        arr[i][0] += arr[i - 1][0] + 1;\n+                    }\n+                    return arr;\n                 }\n+                // prettier-ignore\n+                exports[\"default\"] = new Map( /* #__PURE__ */ restoreDiff([\n+                    [9, \"&Tab;\"],\n+                    [0, \"&NewLine;\"],\n+                    [22, \"&excl;\"],\n+                    [0, \"&quot;\"],\n+                    [0, \"&num;\"],\n+                    [0, \"&dollar;\"],\n+                    [0, \"&percnt;\"],\n+                    [0, \"&amp;\"],\n+                    [0, \"&apos;\"],\n+                    [0, \"&lpar;\"],\n+                    [0, \"&rpar;\"],\n+                    [0, \"&ast;\"],\n+                    [0, \"&plus;\"],\n+                    [0, \"&comma;\"],\n+                    [1, \"&period;\"],\n+                    [0, \"&sol;\"],\n+                    [10, \"&colon;\"],\n+                    [0, \"&semi;\"],\n+                    [0, {\n+                        v: \"&lt;\",\n+                        n: 8402,\n+                        o: \"&nvlt;\"\n+                    }],\n+                    [0, {\n+                        v: \"&equals;\",\n+                        n: 8421,\n+                        o: \"&bne;\"\n+                    }],\n+                    [0, {\n+                        v: \"&gt;\",\n+                        n: 8402,\n+                        o: \"&nvgt;\"\n+                    }],\n+                    [0, \"&quest;\"],\n+                    [0, \"&commat;\"],\n+                    [26, \"&lbrack;\"],\n+                    [0, \"&bsol;\"],\n+                    [0, \"&rbrack;\"],\n+                    [0, \"&Hat;\"],\n+                    [0, \"&lowbar;\"],\n+                    [0, \"&DiacriticalGrave;\"],\n+                    [5, {\n+                        n: 106,\n+                        o: \"&fjlig;\"\n+                    }],\n+                    [20, \"&lbrace;\"],\n+                    [0, \"&verbar;\"],\n+                    [0, \"&rbrace;\"],\n+                    [34, \"&nbsp;\"],\n+                    [0, \"&iexcl;\"],\n+                    [0, \"&cent;\"],\n+                    [0, \"&pound;\"],\n+                    [0, \"&curren;\"],\n+                    [0, \"&yen;\"],\n+                    [0, \"&brvbar;\"],\n+                    [0, \"&sect;\"],\n+                    [0, \"&die;\"],\n+                    [0, \"&copy;\"],\n+                    [0, \"&ordf;\"],\n+                    [0, \"&laquo;\"],\n+                    [0, \"&not;\"],\n+                    [0, \"&shy;\"],\n+                    [0, \"&circledR;\"],\n+                    [0, \"&macr;\"],\n+                    [0, \"&deg;\"],\n+                    [0, \"&PlusMinus;\"],\n+                    [0, \"&sup2;\"],\n+                    [0, \"&sup3;\"],\n+                    [0, \"&acute;\"],\n+                    [0, \"&micro;\"],\n+                    [0, \"&para;\"],\n+                    [0, \"&centerdot;\"],\n+                    [0, \"&cedil;\"],\n+                    [0, \"&sup1;\"],\n+                    [0, \"&ordm;\"],\n+                    [0, \"&raquo;\"],\n+                    [0, \"&frac14;\"],\n+                    [0, \"&frac12;\"],\n+                    [0, \"&frac34;\"],\n+                    [0, \"&iquest;\"],\n+                    [0, \"&Agrave;\"],\n+                    [0, \"&Aacute;\"],\n+                    [0, \"&Acirc;\"],\n+                    [0, \"&Atilde;\"],\n+                    [0, \"&Auml;\"],\n+                    [0, \"&angst;\"],\n+                    [0, \"&AElig;\"],\n+                    [0, \"&Ccedil;\"],\n+                    [0, \"&Egrave;\"],\n+                    [0, \"&Eacute;\"],\n+                    [0, \"&Ecirc;\"],\n+                    [0, \"&Euml;\"],\n+                    [0, \"&Igrave;\"],\n+                    [0, \"&Iacute;\"],\n+                    [0, \"&Icirc;\"],\n+                    [0, \"&Iuml;\"],\n+                    [0, \"&ETH;\"],\n+                    [0, \"&Ntilde;\"],\n+                    [0, \"&Ograve;\"],\n+                    [0, \"&Oacute;\"],\n+                    [0, \"&Ocirc;\"],\n+                    [0, \"&Otilde;\"],\n+                    [0, \"&Ouml;\"],\n+                    [0, \"&times;\"],\n+                    [0, \"&Oslash;\"],\n+                    [0, \"&Ugrave;\"],\n+                    [0, \"&Uacute;\"],\n+                    [0, \"&Ucirc;\"],\n+                    [0, \"&Uuml;\"],\n+                    [0, \"&Yacute;\"],\n+                    [0, \"&THORN;\"],\n+                    [0, \"&szlig;\"],\n+                    [0, \"&agrave;\"],\n+                    [0, \"&aacute;\"],\n+                    [0, \"&acirc;\"],\n+                    [0, \"&atilde;\"],\n+                    [0, \"&auml;\"],\n+                    [0, \"&aring;\"],\n+                    [0, \"&aelig;\"],\n+                    [0, \"&ccedil;\"],\n+                    [0, \"&egrave;\"],\n+                    [0, \"&eacute;\"],\n+                    [0, \"&ecirc;\"],\n+                    [0, \"&euml;\"],\n+                    [0, \"&igrave;\"],\n+                    [0, \"&iacute;\"],\n+                    [0, \"&icirc;\"],\n+                    [0, \"&iuml;\"],\n+                    [0, \"&eth;\"],\n+                    [0, \"&ntilde;\"],\n+                    [0, \"&ograve;\"],\n+                    [0, \"&oacute;\"],\n+                    [0, \"&ocirc;\"],\n+                    [0, \"&otilde;\"],\n+                    [0, \"&ouml;\"],\n+                    [0, \"&div;\"],\n+                    [0, \"&oslash;\"],\n+                    [0, \"&ugrave;\"],\n+                    [0, \"&uacute;\"],\n+                    [0, \"&ucirc;\"],\n+                    [0, \"&uuml;\"],\n+                    [0, \"&yacute;\"],\n+                    [0, \"&thorn;\"],\n+                    [0, \"&yuml;\"],\n+                    [0, \"&Amacr;\"],\n+                    [0, \"&amacr;\"],\n+                    [0, \"&Abreve;\"],\n+                    [0, \"&abreve;\"],\n+                    [0, \"&Aogon;\"],\n+                    [0, \"&aogon;\"],\n+                    [0, \"&Cacute;\"],\n+                    [0, \"&cacute;\"],\n+                    [0, \"&Ccirc;\"],\n+                    [0, \"&ccirc;\"],\n+                    [0, \"&Cdot;\"],\n+                    [0, \"&cdot;\"],\n+                    [0, \"&Ccaron;\"],\n+                    [0, \"&ccaron;\"],\n+                    [0, \"&Dcaron;\"],\n+                    [0, \"&dcaron;\"],\n+                    [0, \"&Dstrok;\"],\n+                    [0, \"&dstrok;\"],\n+                    [0, \"&Emacr;\"],\n+                    [0, \"&emacr;\"],\n+                    [2, \"&Edot;\"],\n+                    [0, \"&edot;\"],\n+                    [0, \"&Eogon;\"],\n+                    [0, \"&eogon;\"],\n+                    [0, \"&Ecaron;\"],\n+                    [0, \"&ecaron;\"],\n+                    [0, \"&Gcirc;\"],\n+                    [0, \"&gcirc;\"],\n+                    [0, \"&Gbreve;\"],\n+                    [0, \"&gbreve;\"],\n+                    [0, \"&Gdot;\"],\n+                    [0, \"&gdot;\"],\n+                    [0, \"&Gcedil;\"],\n+                    [1, \"&Hcirc;\"],\n+                    [0, \"&hcirc;\"],\n+                    [0, \"&Hstrok;\"],\n+                    [0, \"&hstrok;\"],\n+                    [0, \"&Itilde;\"],\n+                    [0, \"&itilde;\"],\n+                    [0, \"&Imacr;\"],\n+                    [0, \"&imacr;\"],\n+                    [2, \"&Iogon;\"],\n+                    [0, \"&iogon;\"],\n+                    [0, \"&Idot;\"],\n+                    [0, \"&imath;\"],\n+                    [0, \"&IJlig;\"],\n+                    [0, \"&ijlig;\"],\n+                    [0, \"&Jcirc;\"],\n+                    [0, \"&jcirc;\"],\n+                    [0, \"&Kcedil;\"],\n+                    [0, \"&kcedil;\"],\n+                    [0, \"&kgreen;\"],\n+                    [0, \"&Lacute;\"],\n+                    [0, \"&lacute;\"],\n+                    [0, \"&Lcedil;\"],\n+                    [0, \"&lcedil;\"],\n+                    [0, \"&Lcaron;\"],\n+                    [0, \"&lcaron;\"],\n+                    [0, \"&Lmidot;\"],\n+                    [0, \"&lmidot;\"],\n+                    [0, \"&Lstrok;\"],\n+                    [0, \"&lstrok;\"],\n+                    [0, \"&Nacute;\"],\n+                    [0, \"&nacute;\"],\n+                    [0, \"&Ncedil;\"],\n+                    [0, \"&ncedil;\"],\n+                    [0, \"&Ncaron;\"],\n+                    [0, \"&ncaron;\"],\n+                    [0, \"&napos;\"],\n+                    [0, \"&ENG;\"],\n+                    [0, \"&eng;\"],\n+                    [0, \"&Omacr;\"],\n+                    [0, \"&omacr;\"],\n+                    [2, \"&Odblac;\"],\n+                    [0, \"&odblac;\"],\n+                    [0, \"&OElig;\"],\n+                    [0, \"&oelig;\"],\n+                    [0, \"&Racute;\"],\n+                    [0, \"&racute;\"],\n+                    [0, \"&Rcedil;\"],\n+                    [0, \"&rcedil;\"],\n+                    [0, \"&Rcaron;\"],\n+                    [0, \"&rcaron;\"],\n+                    [0, \"&Sacute;\"],\n+                    [0, \"&sacute;\"],\n+                    [0, \"&Scirc;\"],\n+                    [0, \"&scirc;\"],\n+                    [0, \"&Scedil;\"],\n+                    [0, \"&scedil;\"],\n+                    [0, \"&Scaron;\"],\n+                    [0, \"&scaron;\"],\n+                    [0, \"&Tcedil;\"],\n+                    [0, \"&tcedil;\"],\n+                    [0, \"&Tcaron;\"],\n+                    [0, \"&tcaron;\"],\n+                    [0, \"&Tstrok;\"],\n+                    [0, \"&tstrok;\"],\n+                    [0, \"&Utilde;\"],\n+                    [0, \"&utilde;\"],\n+                    [0, \"&Umacr;\"],\n+                    [0, \"&umacr;\"],\n+                    [0, \"&Ubreve;\"],\n+                    [0, \"&ubreve;\"],\n+                    [0, \"&Uring;\"],\n+                    [0, \"&uring;\"],\n+                    [0, \"&Udblac;\"],\n+                    [0, \"&udblac;\"],\n+                    [0, \"&Uogon;\"],\n+                    [0, \"&uogon;\"],\n+                    [0, \"&Wcirc;\"],\n+                    [0, \"&wcirc;\"],\n+                    [0, \"&Ycirc;\"],\n+                    [0, \"&ycirc;\"],\n+                    [0, \"&Yuml;\"],\n+                    [0, \"&Zacute;\"],\n+                    [0, \"&zacute;\"],\n+                    [0, \"&Zdot;\"],\n+                    [0, \"&zdot;\"],\n+                    [0, \"&Zcaron;\"],\n+                    [0, \"&zcaron;\"],\n+                    [19, \"&fnof;\"],\n+                    [34, \"&imped;\"],\n+                    [63, \"&gacute;\"],\n+                    [65, \"&jmath;\"],\n+                    [142, \"&circ;\"],\n+                    [0, \"&caron;\"],\n+                    [16, \"&breve;\"],\n+                    [0, \"&DiacriticalDot;\"],\n+                    [0, \"&ring;\"],\n+                    [0, \"&ogon;\"],\n+                    [0, \"&DiacriticalTilde;\"],\n+                    [0, \"&dblac;\"],\n+                    [51, \"&DownBreve;\"],\n+                    [127, \"&Alpha;\"],\n+                    [0, \"&Beta;\"],\n+                    [0, \"&Gamma;\"],\n+                    [0, \"&Delta;\"],\n+                    [0, \"&Epsilon;\"],\n+                    [0, \"&Zeta;\"],\n+                    [0, \"&Eta;\"],\n+                    [0, \"&Theta;\"],\n+                    [0, \"&Iota;\"],\n+                    [0, \"&Kappa;\"],\n+                    [0, \"&Lambda;\"],\n+                    [0, \"&Mu;\"],\n+                    [0, \"&Nu;\"],\n+                    [0, \"&Xi;\"],\n+                    [0, \"&Omicron;\"],\n+                    [0, \"&Pi;\"],\n+                    [0, \"&Rho;\"],\n+                    [1, \"&Sigma;\"],\n+                    [0, \"&Tau;\"],\n+                    [0, \"&Upsilon;\"],\n+                    [0, \"&Phi;\"],\n+                    [0, \"&Chi;\"],\n+                    [0, \"&Psi;\"],\n+                    [0, \"&ohm;\"],\n+                    [7, \"&alpha;\"],\n+                    [0, \"&beta;\"],\n+                    [0, \"&gamma;\"],\n+                    [0, \"&delta;\"],\n+                    [0, \"&epsi;\"],\n+                    [0, \"&zeta;\"],\n+                    [0, \"&eta;\"],\n+                    [0, \"&theta;\"],\n+                    [0, \"&iota;\"],\n+                    [0, \"&kappa;\"],\n+                    [0, \"&lambda;\"],\n+                    [0, \"&mu;\"],\n+                    [0, \"&nu;\"],\n+                    [0, \"&xi;\"],\n+                    [0, \"&omicron;\"],\n+                    [0, \"&pi;\"],\n+                    [0, \"&rho;\"],\n+                    [0, \"&sigmaf;\"],\n+                    [0, \"&sigma;\"],\n+                    [0, \"&tau;\"],\n+                    [0, \"&upsi;\"],\n+                    [0, \"&phi;\"],\n+                    [0, \"&chi;\"],\n+                    [0, \"&psi;\"],\n+                    [0, \"&omega;\"],\n+                    [7, \"&thetasym;\"],\n+                    [0, \"&Upsi;\"],\n+                    [2, \"&phiv;\"],\n+                    [0, \"&piv;\"],\n+                    [5, \"&Gammad;\"],\n+                    [0, \"&digamma;\"],\n+                    [18, \"&kappav;\"],\n+                    [0, \"&rhov;\"],\n+                    [3, \"&epsiv;\"],\n+                    [0, \"&backepsilon;\"],\n+                    [10, \"&IOcy;\"],\n+                    [0, \"&DJcy;\"],\n+                    [0, \"&GJcy;\"],\n+                    [0, \"&Jukcy;\"],\n+                    [0, \"&DScy;\"],\n+                    [0, \"&Iukcy;\"],\n+                    [0, \"&YIcy;\"],\n+                    [0, \"&Jsercy;\"],\n+                    [0, \"&LJcy;\"],\n+                    [0, \"&NJcy;\"],\n+                    [0, \"&TSHcy;\"],\n+                    [0, \"&KJcy;\"],\n+                    [1, \"&Ubrcy;\"],\n+                    [0, \"&DZcy;\"],\n+                    [0, \"&Acy;\"],\n+                    [0, \"&Bcy;\"],\n+                    [0, \"&Vcy;\"],\n+                    [0, \"&Gcy;\"],\n+                    [0, \"&Dcy;\"],\n+                    [0, \"&IEcy;\"],\n+                    [0, \"&ZHcy;\"],\n+                    [0, \"&Zcy;\"],\n+                    [0, \"&Icy;\"],\n+                    [0, \"&Jcy;\"],\n+                    [0, \"&Kcy;\"],\n+                    [0, \"&Lcy;\"],\n+                    [0, \"&Mcy;\"],\n+                    [0, \"&Ncy;\"],\n+                    [0, \"&Ocy;\"],\n+                    [0, \"&Pcy;\"],\n+                    [0, \"&Rcy;\"],\n+                    [0, \"&Scy;\"],\n+                    [0, \"&Tcy;\"],\n+                    [0, \"&Ucy;\"],\n+                    [0, \"&Fcy;\"],\n+                    [0, \"&KHcy;\"],\n+                    [0, \"&TScy;\"],\n+                    [0, \"&CHcy;\"],\n+                    [0, \"&SHcy;\"],\n+                    [0, \"&SHCHcy;\"],\n+                    [0, \"&HARDcy;\"],\n+                    [0, \"&Ycy;\"],\n+                    [0, \"&SOFTcy;\"],\n+                    [0, \"&Ecy;\"],\n+                    [0, \"&YUcy;\"],\n+                    [0, \"&YAcy;\"],\n+                    [0, \"&acy;\"],\n+                    [0, \"&bcy;\"],\n+                    [0, \"&vcy;\"],\n+                    [0, \"&gcy;\"],\n+                    [0, \"&dcy;\"],\n+                    [0, \"&iecy;\"],\n+                    [0, \"&zhcy;\"],\n+                    [0, \"&zcy;\"],\n+                    [0, \"&icy;\"],\n+                    [0, \"&jcy;\"],\n+                    [0, \"&kcy;\"],\n+                    [0, \"&lcy;\"],\n+                    [0, \"&mcy;\"],\n+                    [0, \"&ncy;\"],\n+                    [0, \"&ocy;\"],\n+                    [0, \"&pcy;\"],\n+                    [0, \"&rcy;\"],\n+                    [0, \"&scy;\"],\n+                    [0, \"&tcy;\"],\n+                    [0, \"&ucy;\"],\n+                    [0, \"&fcy;\"],\n+                    [0, \"&khcy;\"],\n+                    [0, \"&tscy;\"],\n+                    [0, \"&chcy;\"],\n+                    [0, \"&shcy;\"],\n+                    [0, \"&shchcy;\"],\n+                    [0, \"&hardcy;\"],\n+                    [0, \"&ycy;\"],\n+                    [0, \"&softcy;\"],\n+                    [0, \"&ecy;\"],\n+                    [0, \"&yucy;\"],\n+                    [0, \"&yacy;\"],\n+                    [1, \"&iocy;\"],\n+                    [0, \"&djcy;\"],\n+                    [0, \"&gjcy;\"],\n+                    [0, \"&jukcy;\"],\n+                    [0, \"&dscy;\"],\n+                    [0, \"&iukcy;\"],\n+                    [0, \"&yicy;\"],\n+                    [0, \"&jsercy;\"],\n+                    [0, \"&ljcy;\"],\n+                    [0, \"&njcy;\"],\n+                    [0, \"&tshcy;\"],\n+                    [0, \"&kjcy;\"],\n+                    [1, \"&ubrcy;\"],\n+                    [0, \"&dzcy;\"],\n+                    [7074, \"&ensp;\"],\n+                    [0, \"&emsp;\"],\n+                    [0, \"&emsp13;\"],\n+                    [0, \"&emsp14;\"],\n+                    [1, \"&numsp;\"],\n+                    [0, \"&puncsp;\"],\n+                    [0, \"&ThinSpace;\"],\n+                    [0, \"&hairsp;\"],\n+                    [0, \"&NegativeMediumSpace;\"],\n+                    [0, \"&zwnj;\"],\n+                    [0, \"&zwj;\"],\n+                    [0, \"&lrm;\"],\n+                    [0, \"&rlm;\"],\n+                    [0, \"&dash;\"],\n+                    [2, \"&ndash;\"],\n+                    [0, \"&mdash;\"],\n+                    [0, \"&horbar;\"],\n+                    [0, \"&Verbar;\"],\n+                    [1, \"&lsquo;\"],\n+                    [0, \"&CloseCurlyQuote;\"],\n+                    [0, \"&lsquor;\"],\n+                    [1, \"&ldquo;\"],\n+                    [0, \"&CloseCurlyDoubleQuote;\"],\n+                    [0, \"&bdquo;\"],\n+                    [1, \"&dagger;\"],\n+                    [0, \"&Dagger;\"],\n+                    [0, \"&bull;\"],\n+                    [2, \"&nldr;\"],\n+                    [0, \"&hellip;\"],\n+                    [9, \"&permil;\"],\n+                    [0, \"&pertenk;\"],\n+                    [0, \"&prime;\"],\n+                    [0, \"&Prime;\"],\n+                    [0, \"&tprime;\"],\n+                    [0, \"&backprime;\"],\n+                    [3, \"&lsaquo;\"],\n+                    [0, \"&rsaquo;\"],\n+                    [3, \"&oline;\"],\n+                    [2, \"&caret;\"],\n+                    [1, \"&hybull;\"],\n+                    [0, \"&frasl;\"],\n+                    [10, \"&bsemi;\"],\n+                    [7, \"&qprime;\"],\n+                    [7, {\n+                        v: \"&MediumSpace;\",\n+                        n: 8202,\n+                        o: \"&ThickSpace;\"\n+                    }],\n+                    [0, \"&NoBreak;\"],\n+                    [0, \"&af;\"],\n+                    [0, \"&InvisibleTimes;\"],\n+                    [0, \"&ic;\"],\n+                    [72, \"&euro;\"],\n+                    [46, \"&tdot;\"],\n+                    [0, \"&DotDot;\"],\n+                    [37, \"&complexes;\"],\n+                    [2, \"&incare;\"],\n+                    [4, \"&gscr;\"],\n+                    [0, \"&hamilt;\"],\n+                    [0, \"&Hfr;\"],\n+                    [0, \"&Hopf;\"],\n+                    [0, \"&planckh;\"],\n+                    [0, \"&hbar;\"],\n+                    [0, \"&imagline;\"],\n+                    [0, \"&Ifr;\"],\n+                    [0, \"&lagran;\"],\n+                    [0, \"&ell;\"],\n+                    [1, \"&naturals;\"],\n+                    [0, \"&numero;\"],\n+                    [0, \"&copysr;\"],\n+                    [0, \"&weierp;\"],\n+                    [0, \"&Popf;\"],\n+                    [0, \"&Qopf;\"],\n+                    [0, \"&realine;\"],\n+                    [0, \"&real;\"],\n+                    [0, \"&reals;\"],\n+                    [0, \"&rx;\"],\n+                    [3, \"&trade;\"],\n+                    [1, \"&integers;\"],\n+                    [2, \"&mho;\"],\n+                    [0, \"&zeetrf;\"],\n+                    [0, \"&iiota;\"],\n+                    [2, \"&bernou;\"],\n+                    [0, \"&Cayleys;\"],\n+                    [1, \"&escr;\"],\n+                    [0, \"&Escr;\"],\n+                    [0, \"&Fouriertrf;\"],\n+                    [1, \"&Mellintrf;\"],\n+                    [0, \"&order;\"],\n+                    [0, \"&alefsym;\"],\n+                    [0, \"&beth;\"],\n+                    [0, \"&gimel;\"],\n+                    [0, \"&daleth;\"],\n+                    [12, \"&CapitalDifferentialD;\"],\n+                    [0, \"&dd;\"],\n+                    [0, \"&ee;\"],\n+                    [0, \"&ii;\"],\n+                    [10, \"&frac13;\"],\n+                    [0, \"&frac23;\"],\n+                    [0, \"&frac15;\"],\n+                    [0, \"&frac25;\"],\n+                    [0, \"&frac35;\"],\n+                    [0, \"&frac45;\"],\n+                    [0, \"&frac16;\"],\n+                    [0, \"&frac56;\"],\n+                    [0, \"&frac18;\"],\n+                    [0, \"&frac38;\"],\n+                    [0, \"&frac58;\"],\n+                    [0, \"&frac78;\"],\n+                    [49, \"&larr;\"],\n+                    [0, \"&ShortUpArrow;\"],\n+                    [0, \"&rarr;\"],\n+                    [0, \"&darr;\"],\n+                    [0, \"&harr;\"],\n+                    [0, \"&updownarrow;\"],\n+                    [0, \"&nwarr;\"],\n+                    [0, \"&nearr;\"],\n+                    [0, \"&LowerRightArrow;\"],\n+                    [0, \"&LowerLeftArrow;\"],\n+                    [0, \"&nlarr;\"],\n+                    [0, \"&nrarr;\"],\n+                    [1, {\n+                        v: \"&rarrw;\",\n+                        n: 824,\n+                        o: \"&nrarrw;\"\n+                    }],\n+                    [0, \"&Larr;\"],\n+                    [0, \"&Uarr;\"],\n+                    [0, \"&Rarr;\"],\n+                    [0, \"&Darr;\"],\n+                    [0, \"&larrtl;\"],\n+                    [0, \"&rarrtl;\"],\n+                    [0, \"&LeftTeeArrow;\"],\n+                    [0, \"&mapstoup;\"],\n+                    [0, \"&map;\"],\n+                    [0, \"&DownTeeArrow;\"],\n+                    [1, \"&hookleftarrow;\"],\n+                    [0, \"&hookrightarrow;\"],\n+                    [0, \"&larrlp;\"],\n+                    [0, \"&looparrowright;\"],\n+                    [0, \"&harrw;\"],\n+                    [0, \"&nharr;\"],\n+                    [1, \"&lsh;\"],\n+                    [0, \"&rsh;\"],\n+                    [0, \"&ldsh;\"],\n+                    [0, \"&rdsh;\"],\n+                    [1, \"&crarr;\"],\n+                    [0, \"&cularr;\"],\n+                    [0, \"&curarr;\"],\n+                    [2, \"&circlearrowleft;\"],\n+                    [0, \"&circlearrowright;\"],\n+                    [0, \"&leftharpoonup;\"],\n+                    [0, \"&DownLeftVector;\"],\n+                    [0, \"&RightUpVector;\"],\n+                    [0, \"&LeftUpVector;\"],\n+                    [0, \"&rharu;\"],\n+                    [0, \"&DownRightVector;\"],\n+                    [0, \"&dharr;\"],\n+                    [0, \"&dharl;\"],\n+                    [0, \"&RightArrowLeftArrow;\"],\n+                    [0, \"&udarr;\"],\n+                    [0, \"&LeftArrowRightArrow;\"],\n+                    [0, \"&leftleftarrows;\"],\n+                    [0, \"&upuparrows;\"],\n+                    [0, \"&rightrightarrows;\"],\n+                    [0, \"&ddarr;\"],\n+                    [0, \"&leftrightharpoons;\"],\n+                    [0, \"&Equilibrium;\"],\n+                    [0, \"&nlArr;\"],\n+                    [0, \"&nhArr;\"],\n+                    [0, \"&nrArr;\"],\n+                    [0, \"&DoubleLeftArrow;\"],\n+                    [0, \"&DoubleUpArrow;\"],\n+                    [0, \"&DoubleRightArrow;\"],\n+                    [0, \"&dArr;\"],\n+                    [0, \"&DoubleLeftRightArrow;\"],\n+                    [0, \"&DoubleUpDownArrow;\"],\n+                    [0, \"&nwArr;\"],\n+                    [0, \"&neArr;\"],\n+                    [0, \"&seArr;\"],\n+                    [0, \"&swArr;\"],\n+                    [0, \"&lAarr;\"],\n+                    [0, \"&rAarr;\"],\n+                    [1, \"&zigrarr;\"],\n+                    [6, \"&larrb;\"],\n+                    [0, \"&rarrb;\"],\n+                    [15, \"&DownArrowUpArrow;\"],\n+                    [7, \"&loarr;\"],\n+                    [0, \"&roarr;\"],\n+                    [0, \"&hoarr;\"],\n+                    [0, \"&forall;\"],\n+                    [0, \"&comp;\"],\n+                    [0, {\n+                        v: \"&part;\",\n+                        n: 824,\n+                        o: \"&npart;\"\n+                    }],\n+                    [0, \"&exist;\"],\n+                    [0, \"&nexist;\"],\n+                    [0, \"&empty;\"],\n+                    [1, \"&Del;\"],\n+                    [0, \"&Element;\"],\n+                    [0, \"&NotElement;\"],\n+                    [1, \"&ni;\"],\n+                    [0, \"&notni;\"],\n+                    [2, \"&prod;\"],\n+                    [0, \"&coprod;\"],\n+                    [0, \"&sum;\"],\n+                    [0, \"&minus;\"],\n+                    [0, \"&MinusPlus;\"],\n+                    [0, \"&dotplus;\"],\n+                    [1, \"&Backslash;\"],\n+                    [0, \"&lowast;\"],\n+                    [0, \"&compfn;\"],\n+                    [1, \"&radic;\"],\n+                    [2, \"&prop;\"],\n+                    [0, \"&infin;\"],\n+                    [0, \"&angrt;\"],\n+                    [0, {\n+                        v: \"&ang;\",\n+                        n: 8402,\n+                        o: \"&nang;\"\n+                    }],\n+                    [0, \"&angmsd;\"],\n+                    [0, \"&angsph;\"],\n+                    [0, \"&mid;\"],\n+                    [0, \"&nmid;\"],\n+                    [0, \"&DoubleVerticalBar;\"],\n+                    [0, \"&NotDoubleVerticalBar;\"],\n+                    [0, \"&and;\"],\n+                    [0, \"&or;\"],\n+                    [0, {\n+                        v: \"&cap;\",\n+                        n: 65024,\n+                        o: \"&caps;\"\n+                    }],\n+                    [0, {\n+                        v: \"&cup;\",\n+                        n: 65024,\n+                        o: \"&cups;\"\n+                    }],\n+                    [0, \"&int;\"],\n+                    [0, \"&Int;\"],\n+                    [0, \"&iiint;\"],\n+                    [0, \"&conint;\"],\n+                    [0, \"&Conint;\"],\n+                    [0, \"&Cconint;\"],\n+                    [0, \"&cwint;\"],\n+                    [0, \"&ClockwiseContourIntegral;\"],\n+                    [0, \"&awconint;\"],\n+                    [0, \"&there4;\"],\n+                    [0, \"&becaus;\"],\n+                    [0, \"&ratio;\"],\n+                    [0, \"&Colon;\"],\n+                    [0, \"&dotminus;\"],\n+                    [1, \"&mDDot;\"],\n+                    [0, \"&homtht;\"],\n+                    [0, {\n+                        v: \"&sim;\",\n+                        n: 8402,\n+                        o: \"&nvsim;\"\n+                    }],\n+                    [0, {\n+                        v: \"&backsim;\",\n+                        n: 817,\n+                        o: \"&race;\"\n+                    }],\n+                    [0, {\n+                        v: \"&ac;\",\n+                        n: 819,\n+                        o: \"&acE;\"\n+                    }],\n+                    [0, \"&acd;\"],\n+                    [0, \"&VerticalTilde;\"],\n+                    [0, \"&NotTilde;\"],\n+                    [0, {\n+                        v: \"&eqsim;\",\n+                        n: 824,\n+                        o: \"&nesim;\"\n+                    }],\n+                    [0, \"&sime;\"],\n+                    [0, \"&NotTildeEqual;\"],\n+                    [0, \"&cong;\"],\n+                    [0, \"&simne;\"],\n+                    [0, \"&ncong;\"],\n+                    [0, \"&ap;\"],\n+                    [0, \"&nap;\"],\n+                    [0, \"&ape;\"],\n+                    [0, {\n+                        v: \"&apid;\",\n+                        n: 824,\n+                        o: \"&napid;\"\n+                    }],\n+                    [0, \"&backcong;\"],\n+                    [0, {\n+                        v: \"&asympeq;\",\n+                        n: 8402,\n+                        o: \"&nvap;\"\n+                    }],\n+                    [0, {\n+                        v: \"&bump;\",\n+                        n: 824,\n+                        o: \"&nbump;\"\n+                    }],\n+                    [0, {\n+                        v: \"&bumpe;\",\n+                        n: 824,\n+                        o: \"&nbumpe;\"\n+                    }],\n+                    [0, {\n+                        v: \"&doteq;\",\n+                        n: 824,\n+                        o: \"&nedot;\"\n+                    }],\n+                    [0, \"&doteqdot;\"],\n+                    [0, \"&efDot;\"],\n+                    [0, \"&erDot;\"],\n+                    [0, \"&Assign;\"],\n+                    [0, \"&ecolon;\"],\n+                    [0, \"&ecir;\"],\n+                    [0, \"&circeq;\"],\n+                    [1, \"&wedgeq;\"],\n+                    [0, \"&veeeq;\"],\n+                    [1, \"&triangleq;\"],\n+                    [2, \"&equest;\"],\n+                    [0, \"&ne;\"],\n+                    [0, {\n+                        v: \"&Congruent;\",\n+                        n: 8421,\n+                        o: \"&bnequiv;\"\n+                    }],\n+                    [0, \"&nequiv;\"],\n+                    [1, {\n+                        v: \"&le;\",\n+                        n: 8402,\n+                        o: \"&nvle;\"\n+                    }],\n+                    [0, {\n+                        v: \"&ge;\",\n+                        n: 8402,\n+                        o: \"&nvge;\"\n+                    }],\n+                    [0, {\n+                        v: \"&lE;\",\n+                        n: 824,\n+                        o: \"&nlE;\"\n+                    }],\n+                    [0, {\n+                        v: \"&gE;\",\n+                        n: 824,\n+                        o: \"&ngE;\"\n+                    }],\n+                    [0, {\n+                        v: \"&lnE;\",\n+                        n: 65024,\n+                        o: \"&lvertneqq;\"\n+                    }],\n+                    [0, {\n+                        v: \"&gnE;\",\n+                        n: 65024,\n+                        o: \"&gvertneqq;\"\n+                    }],\n+                    [0, {\n+                        v: \"&ll;\",\n+                        n: new Map( /* #__PURE__ */ restoreDiff([\n+                            [824, \"&nLtv;\"],\n+                            [7577, \"&nLt;\"]\n+                        ]))\n+                    }],\n+                    [0, {\n+                        v: \"&gg;\",\n+                        n: new Map( /* #__PURE__ */ restoreDiff([\n+                            [824, \"&nGtv;\"],\n+                            [7577, \"&nGt;\"]\n+                        ]))\n+                    }],\n+                    [0, \"&between;\"],\n+                    [0, \"&NotCupCap;\"],\n+                    [0, \"&nless;\"],\n+                    [0, \"&ngt;\"],\n+                    [0, \"&nle;\"],\n+                    [0, \"&nge;\"],\n+                    [0, \"&lesssim;\"],\n+                    [0, \"&GreaterTilde;\"],\n+                    [0, \"&nlsim;\"],\n+                    [0, \"&ngsim;\"],\n+                    [0, \"&LessGreater;\"],\n+                    [0, \"&gl;\"],\n+                    [0, \"&NotLessGreater;\"],\n+                    [0, \"&NotGreaterLess;\"],\n+                    [0, \"&pr;\"],\n+                    [0, \"&sc;\"],\n+                    [0, \"&prcue;\"],\n+                    [0, \"&sccue;\"],\n+                    [0, \"&PrecedesTilde;\"],\n+                    [0, {\n+                        v: \"&scsim;\",\n+                        n: 824,\n+                        o: \"&NotSucceedsTilde;\"\n+                    }],\n+                    [0, \"&NotPrecedes;\"],\n+                    [0, \"&NotSucceeds;\"],\n+                    [0, {\n+                        v: \"&sub;\",\n+                        n: 8402,\n+                        o: \"&NotSubset;\"\n+                    }],\n+                    [0, {\n+                        v: \"&sup;\",\n+                        n: 8402,\n+                        o: \"&NotSuperset;\"\n+                    }],\n+                    [0, \"&nsub;\"],\n+                    [0, \"&nsup;\"],\n+                    [0, \"&sube;\"],\n+                    [0, \"&supe;\"],\n+                    [0, \"&NotSubsetEqual;\"],\n+                    [0, \"&NotSupersetEqual;\"],\n+                    [0, {\n+                        v: \"&subne;\",\n+                        n: 65024,\n+                        o: \"&varsubsetneq;\"\n+                    }],\n+                    [0, {\n+                        v: \"&supne;\",\n+                        n: 65024,\n+                        o: \"&varsupsetneq;\"\n+                    }],\n+                    [1, \"&cupdot;\"],\n+                    [0, \"&UnionPlus;\"],\n+                    [0, {\n+                        v: \"&sqsub;\",\n+                        n: 824,\n+                        o: \"&NotSquareSubset;\"\n+                    }],\n+                    [0, {\n+                        v: \"&sqsup;\",\n+                        n: 824,\n+                        o: \"&NotSquareSuperset;\"\n+                    }],\n+                    [0, \"&sqsube;\"],\n+                    [0, \"&sqsupe;\"],\n+                    [0, {\n+                        v: \"&sqcap;\",\n+                        n: 65024,\n+                        o: \"&sqcaps;\"\n+                    }],\n+                    [0, {\n+                        v: \"&sqcup;\",\n+                        n: 65024,\n+                        o: \"&sqcups;\"\n+                    }],\n+                    [0, \"&CirclePlus;\"],\n+                    [0, \"&CircleMinus;\"],\n+                    [0, \"&CircleTimes;\"],\n+                    [0, \"&osol;\"],\n+                    [0, \"&CircleDot;\"],\n+                    [0, \"&circledcirc;\"],\n+                    [0, \"&circledast;\"],\n+                    [1, \"&circleddash;\"],\n+                    [0, \"&boxplus;\"],\n+                    [0, \"&boxminus;\"],\n+                    [0, \"&boxtimes;\"],\n+                    [0, \"&dotsquare;\"],\n+                    [0, \"&RightTee;\"],\n+                    [0, \"&dashv;\"],\n+                    [0, \"&DownTee;\"],\n+                    [0, \"&bot;\"],\n+                    [1, \"&models;\"],\n+                    [0, \"&DoubleRightTee;\"],\n+                    [0, \"&Vdash;\"],\n+                    [0, \"&Vvdash;\"],\n+                    [0, \"&VDash;\"],\n+                    [0, \"&nvdash;\"],\n+                    [0, \"&nvDash;\"],\n+                    [0, \"&nVdash;\"],\n+                    [0, \"&nVDash;\"],\n+                    [0, \"&prurel;\"],\n+                    [1, \"&LeftTriangle;\"],\n+                    [0, \"&RightTriangle;\"],\n+                    [0, {\n+                        v: \"&LeftTriangleEqual;\",\n+                        n: 8402,\n+                        o: \"&nvltrie;\"\n+                    }],\n+                    [0, {\n+                        v: \"&RightTriangleEqual;\",\n+                        n: 8402,\n+                        o: \"&nvrtrie;\"\n+                    }],\n+                    [0, \"&origof;\"],\n+                    [0, \"&imof;\"],\n+                    [0, \"&multimap;\"],\n+                    [0, \"&hercon;\"],\n+                    [0, \"&intcal;\"],\n+                    [0, \"&veebar;\"],\n+                    [1, \"&barvee;\"],\n+                    [0, \"&angrtvb;\"],\n+                    [0, \"&lrtri;\"],\n+                    [0, \"&bigwedge;\"],\n+                    [0, \"&bigvee;\"],\n+                    [0, \"&bigcap;\"],\n+                    [0, \"&bigcup;\"],\n+                    [0, \"&diam;\"],\n+                    [0, \"&sdot;\"],\n+                    [0, \"&sstarf;\"],\n+                    [0, \"&divideontimes;\"],\n+                    [0, \"&bowtie;\"],\n+                    [0, \"&ltimes;\"],\n+                    [0, \"&rtimes;\"],\n+                    [0, \"&leftthreetimes;\"],\n+                    [0, \"&rightthreetimes;\"],\n+                    [0, \"&backsimeq;\"],\n+                    [0, \"&curlyvee;\"],\n+                    [0, \"&curlywedge;\"],\n+                    [0, \"&Sub;\"],\n+                    [0, \"&Sup;\"],\n+                    [0, \"&Cap;\"],\n+                    [0, \"&Cup;\"],\n+                    [0, \"&fork;\"],\n+                    [0, \"&epar;\"],\n+                    [0, \"&lessdot;\"],\n+                    [0, \"&gtdot;\"],\n+                    [0, {\n+                        v: \"&Ll;\",\n+                        n: 824,\n+                        o: \"&nLl;\"\n+                    }],\n+                    [0, {\n+                        v: \"&Gg;\",\n+                        n: 824,\n+                        o: \"&nGg;\"\n+                    }],\n+                    [0, {\n+                        v: \"&leg;\",\n+                        n: 65024,\n+                        o: \"&lesg;\"\n+                    }],\n+                    [0, {\n+                        v: \"&gel;\",\n+                        n: 65024,\n+                        o: \"&gesl;\"\n+                    }],\n+                    [2, \"&cuepr;\"],\n+                    [0, \"&cuesc;\"],\n+                    [0, \"&NotPrecedesSlantEqual;\"],\n+                    [0, \"&NotSucceedsSlantEqual;\"],\n+                    [0, \"&NotSquareSubsetEqual;\"],\n+                    [0, \"&NotSquareSupersetEqual;\"],\n+                    [2, \"&lnsim;\"],\n+                    [0, \"&gnsim;\"],\n+                    [0, \"&precnsim;\"],\n+                    [0, \"&scnsim;\"],\n+                    [0, \"&nltri;\"],\n+                    [0, \"&NotRightTriangle;\"],\n+                    [0, \"&nltrie;\"],\n+                    [0, \"&NotRightTriangleEqual;\"],\n+                    [0, \"&vellip;\"],\n+                    [0, \"&ctdot;\"],\n+                    [0, \"&utdot;\"],\n+                    [0, \"&dtdot;\"],\n+                    [0, \"&disin;\"],\n+                    [0, \"&isinsv;\"],\n+                    [0, \"&isins;\"],\n+                    [0, {\n+                        v: \"&isindot;\",\n+                        n: 824,\n+                        o: \"&notindot;\"\n+                    }],\n+                    [0, \"&notinvc;\"],\n+                    [0, \"&notinvb;\"],\n+                    [1, {\n+                        v: \"&isinE;\",\n+                        n: 824,\n+                        o: \"&notinE;\"\n+                    }],\n+                    [0, \"&nisd;\"],\n+                    [0, \"&xnis;\"],\n+                    [0, \"&nis;\"],\n+                    [0, \"&notnivc;\"],\n+                    [0, \"&notnivb;\"],\n+                    [6, \"&barwed;\"],\n+                    [0, \"&Barwed;\"],\n+                    [1, \"&lceil;\"],\n+                    [0, \"&rceil;\"],\n+                    [0, \"&LeftFloor;\"],\n+                    [0, \"&rfloor;\"],\n+                    [0, \"&drcrop;\"],\n+                    [0, \"&dlcrop;\"],\n+                    [0, \"&urcrop;\"],\n+                    [0, \"&ulcrop;\"],\n+                    [0, \"&bnot;\"],\n+                    [1, \"&profline;\"],\n+                    [0, \"&profsurf;\"],\n+                    [1, \"&telrec;\"],\n+                    [0, \"&target;\"],\n+                    [5, \"&ulcorn;\"],\n+                    [0, \"&urcorn;\"],\n+                    [0, \"&dlcorn;\"],\n+                    [0, \"&drcorn;\"],\n+                    [2, \"&frown;\"],\n+                    [0, \"&smile;\"],\n+                    [9, \"&cylcty;\"],\n+                    [0, \"&profalar;\"],\n+                    [7, \"&topbot;\"],\n+                    [6, \"&ovbar;\"],\n+                    [1, \"&solbar;\"],\n+                    [60, \"&angzarr;\"],\n+                    [51, \"&lmoustache;\"],\n+                    [0, \"&rmoustache;\"],\n+                    [2, \"&OverBracket;\"],\n+                    [0, \"&bbrk;\"],\n+                    [0, \"&bbrktbrk;\"],\n+                    [37, \"&OverParenthesis;\"],\n+                    [0, \"&UnderParenthesis;\"],\n+                    [0, \"&OverBrace;\"],\n+                    [0, \"&UnderBrace;\"],\n+                    [2, \"&trpezium;\"],\n+                    [4, \"&elinters;\"],\n+                    [59, \"&blank;\"],\n+                    [164, \"&circledS;\"],\n+                    [55, \"&boxh;\"],\n+                    [1, \"&boxv;\"],\n+                    [9, \"&boxdr;\"],\n+                    [3, \"&boxdl;\"],\n+                    [3, \"&boxur;\"],\n+                    [3, \"&boxul;\"],\n+                    [3, \"&boxvr;\"],\n+                    [7, \"&boxvl;\"],\n+                    [7, \"&boxhd;\"],\n+                    [7, \"&boxhu;\"],\n+                    [7, \"&boxvh;\"],\n+                    [19, \"&boxH;\"],\n+                    [0, \"&boxV;\"],\n+                    [0, \"&boxdR;\"],\n+                    [0, \"&boxDr;\"],\n+                    [0, \"&boxDR;\"],\n+                    [0, \"&boxdL;\"],\n+                    [0, \"&boxDl;\"],\n+                    [0, \"&boxDL;\"],\n+                    [0, \"&boxuR;\"],\n+                    [0, \"&boxUr;\"],\n+                    [0, \"&boxUR;\"],\n+                    [0, \"&boxuL;\"],\n+                    [0, \"&boxUl;\"],\n+                    [0, \"&boxUL;\"],\n+                    [0, \"&boxvR;\"],\n+                    [0, \"&boxVr;\"],\n+                    [0, \"&boxVR;\"],\n+                    [0, \"&boxvL;\"],\n+                    [0, \"&boxVl;\"],\n+                    [0, \"&boxVL;\"],\n+                    [0, \"&boxHd;\"],\n+                    [0, \"&boxhD;\"],\n+                    [0, \"&boxHD;\"],\n+                    [0, \"&boxHu;\"],\n+                    [0, \"&boxhU;\"],\n+                    [0, \"&boxHU;\"],\n+                    [0, \"&boxvH;\"],\n+                    [0, \"&boxVh;\"],\n+                    [0, \"&boxVH;\"],\n+                    [19, \"&uhblk;\"],\n+                    [3, \"&lhblk;\"],\n+                    [3, \"&block;\"],\n+                    [8, \"&blk14;\"],\n+                    [0, \"&blk12;\"],\n+                    [0, \"&blk34;\"],\n+                    [13, \"&square;\"],\n+                    [8, \"&blacksquare;\"],\n+                    [0, \"&EmptyVerySmallSquare;\"],\n+                    [1, \"&rect;\"],\n+                    [0, \"&marker;\"],\n+                    [2, \"&fltns;\"],\n+                    [1, \"&bigtriangleup;\"],\n+                    [0, \"&blacktriangle;\"],\n+                    [0, \"&triangle;\"],\n+                    [2, \"&blacktriangleright;\"],\n+                    [0, \"&rtri;\"],\n+                    [3, \"&bigtriangledown;\"],\n+                    [0, \"&blacktriangledown;\"],\n+                    [0, \"&dtri;\"],\n+                    [2, \"&blacktriangleleft;\"],\n+                    [0, \"&ltri;\"],\n+                    [6, \"&loz;\"],\n+                    [0, \"&cir;\"],\n+                    [32, \"&tridot;\"],\n+                    [2, \"&bigcirc;\"],\n+                    [8, \"&ultri;\"],\n+                    [0, \"&urtri;\"],\n+                    [0, \"&lltri;\"],\n+                    [0, \"&EmptySmallSquare;\"],\n+                    [0, \"&FilledSmallSquare;\"],\n+                    [8, \"&bigstar;\"],\n+                    [0, \"&star;\"],\n+                    [7, \"&phone;\"],\n+                    [49, \"&female;\"],\n+                    [1, \"&male;\"],\n+                    [29, \"&spades;\"],\n+                    [2, \"&clubs;\"],\n+                    [1, \"&hearts;\"],\n+                    [0, \"&diamondsuit;\"],\n+                    [3, \"&sung;\"],\n+                    [2, \"&flat;\"],\n+                    [0, \"&natural;\"],\n+                    [0, \"&sharp;\"],\n+                    [163, \"&check;\"],\n+                    [3, \"&cross;\"],\n+                    [8, \"&malt;\"],\n+                    [21, \"&sext;\"],\n+                    [33, \"&VerticalSeparator;\"],\n+                    [25, \"&lbbrk;\"],\n+                    [0, \"&rbbrk;\"],\n+                    [84, \"&bsolhsub;\"],\n+                    [0, \"&suphsol;\"],\n+                    [28, \"&LeftDoubleBracket;\"],\n+                    [0, \"&RightDoubleBracket;\"],\n+                    [0, \"&lang;\"],\n+                    [0, \"&rang;\"],\n+                    [0, \"&Lang;\"],\n+                    [0, \"&Rang;\"],\n+                    [0, \"&loang;\"],\n+                    [0, \"&roang;\"],\n+                    [7, \"&longleftarrow;\"],\n+                    [0, \"&longrightarrow;\"],\n+                    [0, \"&longleftrightarrow;\"],\n+                    [0, \"&DoubleLongLeftArrow;\"],\n+                    [0, \"&DoubleLongRightArrow;\"],\n+                    [0, \"&DoubleLongLeftRightArrow;\"],\n+                    [1, \"&longmapsto;\"],\n+                    [2, \"&dzigrarr;\"],\n+                    [258, \"&nvlArr;\"],\n+                    [0, \"&nvrArr;\"],\n+                    [0, \"&nvHarr;\"],\n+                    [0, \"&Map;\"],\n+                    [6, \"&lbarr;\"],\n+                    [0, \"&bkarow;\"],\n+                    [0, \"&lBarr;\"],\n+                    [0, \"&dbkarow;\"],\n+                    [0, \"&drbkarow;\"],\n+                    [0, \"&DDotrahd;\"],\n+                    [0, \"&UpArrowBar;\"],\n+                    [0, \"&DownArrowBar;\"],\n+                    [2, \"&Rarrtl;\"],\n+                    [2, \"&latail;\"],\n+                    [0, \"&ratail;\"],\n+                    [0, \"&lAtail;\"],\n+                    [0, \"&rAtail;\"],\n+                    [0, \"&larrfs;\"],\n+                    [0, \"&rarrfs;\"],\n+                    [0, \"&larrbfs;\"],\n+                    [0, \"&rarrbfs;\"],\n+                    [2, \"&nwarhk;\"],\n+                    [0, \"&nearhk;\"],\n+                    [0, \"&hksearow;\"],\n+                    [0, \"&hkswarow;\"],\n+                    [0, \"&nwnear;\"],\n+                    [0, \"&nesear;\"],\n+                    [0, \"&seswar;\"],\n+                    [0, \"&swnwar;\"],\n+                    [8, {\n+                        v: \"&rarrc;\",\n+                        n: 824,\n+                        o: \"&nrarrc;\"\n+                    }],\n+                    [1, \"&cudarrr;\"],\n+                    [0, \"&ldca;\"],\n+                    [0, \"&rdca;\"],\n+                    [0, \"&cudarrl;\"],\n+                    [0, \"&larrpl;\"],\n+                    [2, \"&curarrm;\"],\n+                    [0, \"&cularrp;\"],\n+                    [7, \"&rarrpl;\"],\n+                    [2, \"&harrcir;\"],\n+                    [0, \"&Uarrocir;\"],\n+                    [0, \"&lurdshar;\"],\n+                    [0, \"&ldrushar;\"],\n+                    [2, \"&LeftRightVector;\"],\n+                    [0, \"&RightUpDownVector;\"],\n+                    [0, \"&DownLeftRightVector;\"],\n+                    [0, \"&LeftUpDownVector;\"],\n+                    [0, \"&LeftVectorBar;\"],\n+                    [0, \"&RightVectorBar;\"],\n+                    [0, \"&RightUpVectorBar;\"],\n+                    [0, \"&RightDownVectorBar;\"],\n+                    [0, \"&DownLeftVectorBar;\"],\n+                    [0, \"&DownRightVectorBar;\"],\n+                    [0, \"&LeftUpVectorBar;\"],\n+                    [0, \"&LeftDownVectorBar;\"],\n+                    [0, \"&LeftTeeVector;\"],\n+                    [0, \"&RightTeeVector;\"],\n+                    [0, \"&RightUpTeeVector;\"],\n+                    [0, \"&RightDownTeeVector;\"],\n+                    [0, \"&DownLeftTeeVector;\"],\n+                    [0, \"&DownRightTeeVector;\"],\n+                    [0, \"&LeftUpTeeVector;\"],\n+                    [0, \"&LeftDownTeeVector;\"],\n+                    [0, \"&lHar;\"],\n+                    [0, \"&uHar;\"],\n+                    [0, \"&rHar;\"],\n+                    [0, \"&dHar;\"],\n+                    [0, \"&luruhar;\"],\n+                    [0, \"&ldrdhar;\"],\n+                    [0, \"&ruluhar;\"],\n+                    [0, \"&rdldhar;\"],\n+                    [0, \"&lharul;\"],\n+                    [0, \"&llhard;\"],\n+                    [0, \"&rharul;\"],\n+                    [0, \"&lrhard;\"],\n+                    [0, \"&udhar;\"],\n+                    [0, \"&duhar;\"],\n+                    [0, \"&RoundImplies;\"],\n+                    [0, \"&erarr;\"],\n+                    [0, \"&simrarr;\"],\n+                    [0, \"&larrsim;\"],\n+                    [0, \"&rarrsim;\"],\n+                    [0, \"&rarrap;\"],\n+                    [0, \"&ltlarr;\"],\n+                    [1, \"&gtrarr;\"],\n+                    [0, \"&subrarr;\"],\n+                    [1, \"&suplarr;\"],\n+                    [0, \"&lfisht;\"],\n+                    [0, \"&rfisht;\"],\n+                    [0, \"&ufisht;\"],\n+                    [0, \"&dfisht;\"],\n+                    [5, \"&lopar;\"],\n+                    [0, \"&ropar;\"],\n+                    [4, \"&lbrke;\"],\n+                    [0, \"&rbrke;\"],\n+                    [0, \"&lbrkslu;\"],\n+                    [0, \"&rbrksld;\"],\n+                    [0, \"&lbrksld;\"],\n+                    [0, \"&rbrkslu;\"],\n+                    [0, \"&langd;\"],\n+                    [0, \"&rangd;\"],\n+                    [0, \"&lparlt;\"],\n+                    [0, \"&rpargt;\"],\n+                    [0, \"&gtlPar;\"],\n+                    [0, \"&ltrPar;\"],\n+                    [3, \"&vzigzag;\"],\n+                    [1, \"&vangrt;\"],\n+                    [0, \"&angrtvbd;\"],\n+                    [6, \"&ange;\"],\n+                    [0, \"&range;\"],\n+                    [0, \"&dwangle;\"],\n+                    [0, \"&uwangle;\"],\n+                    [0, \"&angmsdaa;\"],\n+                    [0, \"&angmsdab;\"],\n+                    [0, \"&angmsdac;\"],\n+                    [0, \"&angmsdad;\"],\n+                    [0, \"&angmsdae;\"],\n+                    [0, \"&angmsdaf;\"],\n+                    [0, \"&angmsdag;\"],\n+                    [0, \"&angmsdah;\"],\n+                    [0, \"&bemptyv;\"],\n+                    [0, \"&demptyv;\"],\n+                    [0, \"&cemptyv;\"],\n+                    [0, \"&raemptyv;\"],\n+                    [0, \"&laemptyv;\"],\n+                    [0, \"&ohbar;\"],\n+                    [0, \"&omid;\"],\n+                    [0, \"&opar;\"],\n+                    [1, \"&operp;\"],\n+                    [1, \"&olcross;\"],\n+                    [0, \"&odsold;\"],\n+                    [1, \"&olcir;\"],\n+                    [0, \"&ofcir;\"],\n+                    [0, \"&olt;\"],\n+                    [0, \"&ogt;\"],\n+                    [0, \"&cirscir;\"],\n+                    [0, \"&cirE;\"],\n+                    [0, \"&solb;\"],\n+                    [0, \"&bsolb;\"],\n+                    [3, \"&boxbox;\"],\n+                    [3, \"&trisb;\"],\n+                    [0, \"&rtriltri;\"],\n+                    [0, {\n+                        v: \"&LeftTriangleBar;\",\n+                        n: 824,\n+                        o: \"&NotLeftTriangleBar;\"\n+                    }],\n+                    [0, {\n+                        v: \"&RightTriangleBar;\",\n+                        n: 824,\n+                        o: \"&NotRightTriangleBar;\"\n+                    }],\n+                    [11, \"&iinfin;\"],\n+                    [0, \"&infintie;\"],\n+                    [0, \"&nvinfin;\"],\n+                    [4, \"&eparsl;\"],\n+                    [0, \"&smeparsl;\"],\n+                    [0, \"&eqvparsl;\"],\n+                    [5, \"&blacklozenge;\"],\n+                    [8, \"&RuleDelayed;\"],\n+                    [1, \"&dsol;\"],\n+                    [9, \"&bigodot;\"],\n+                    [0, \"&bigoplus;\"],\n+                    [0, \"&bigotimes;\"],\n+                    [1, \"&biguplus;\"],\n+                    [1, \"&bigsqcup;\"],\n+                    [5, \"&iiiint;\"],\n+                    [0, \"&fpartint;\"],\n+                    [2, \"&cirfnint;\"],\n+                    [0, \"&awint;\"],\n+                    [0, \"&rppolint;\"],\n+                    [0, \"&scpolint;\"],\n+                    [0, \"&npolint;\"],\n+                    [0, \"&pointint;\"],\n+                    [0, \"&quatint;\"],\n+                    [0, \"&intlarhk;\"],\n+                    [10, \"&pluscir;\"],\n+                    [0, \"&plusacir;\"],\n+                    [0, \"&simplus;\"],\n+                    [0, \"&plusdu;\"],\n+                    [0, \"&plussim;\"],\n+                    [0, \"&plustwo;\"],\n+                    [1, \"&mcomma;\"],\n+                    [0, \"&minusdu;\"],\n+                    [2, \"&loplus;\"],\n+                    [0, \"&roplus;\"],\n+                    [0, \"&Cross;\"],\n+                    [0, \"&timesd;\"],\n+                    [0, \"&timesbar;\"],\n+                    [1, \"&smashp;\"],\n+                    [0, \"&lotimes;\"],\n+                    [0, \"&rotimes;\"],\n+                    [0, \"&otimesas;\"],\n+                    [0, \"&Otimes;\"],\n+                    [0, \"&odiv;\"],\n+                    [0, \"&triplus;\"],\n+                    [0, \"&triminus;\"],\n+                    [0, \"&tritime;\"],\n+                    [0, \"&intprod;\"],\n+                    [2, \"&amalg;\"],\n+                    [0, \"&capdot;\"],\n+                    [1, \"&ncup;\"],\n+                    [0, \"&ncap;\"],\n+                    [0, \"&capand;\"],\n+                    [0, \"&cupor;\"],\n+                    [0, \"&cupcap;\"],\n+                    [0, \"&capcup;\"],\n+                    [0, \"&cupbrcap;\"],\n+                    [0, \"&capbrcup;\"],\n+                    [0, \"&cupcup;\"],\n+                    [0, \"&capcap;\"],\n+                    [0, \"&ccups;\"],\n+                    [0, \"&ccaps;\"],\n+                    [2, \"&ccupssm;\"],\n+                    [2, \"&And;\"],\n+                    [0, \"&Or;\"],\n+                    [0, \"&andand;\"],\n+                    [0, \"&oror;\"],\n+                    [0, \"&orslope;\"],\n+                    [0, \"&andslope;\"],\n+                    [1, \"&andv;\"],\n+                    [0, \"&orv;\"],\n+                    [0, \"&andd;\"],\n+                    [0, \"&ord;\"],\n+                    [1, \"&wedbar;\"],\n+                    [6, \"&sdote;\"],\n+                    [3, \"&simdot;\"],\n+                    [2, {\n+                        v: \"&congdot;\",\n+                        n: 824,\n+                        o: \"&ncongdot;\"\n+                    }],\n+                    [0, \"&easter;\"],\n+                    [0, \"&apacir;\"],\n+                    [0, {\n+                        v: \"&apE;\",\n+                        n: 824,\n+                        o: \"&napE;\"\n+                    }],\n+                    [0, \"&eplus;\"],\n+                    [0, \"&pluse;\"],\n+                    [0, \"&Esim;\"],\n+                    [0, \"&Colone;\"],\n+                    [0, \"&Equal;\"],\n+                    [1, \"&ddotseq;\"],\n+                    [0, \"&equivDD;\"],\n+                    [0, \"&ltcir;\"],\n+                    [0, \"&gtcir;\"],\n+                    [0, \"&ltquest;\"],\n+                    [0, \"&gtquest;\"],\n+                    [0, {\n+                        v: \"&leqslant;\",\n+                        n: 824,\n+                        o: \"&nleqslant;\"\n+                    }],\n+                    [0, {\n+                        v: \"&geqslant;\",\n+                        n: 824,\n+                        o: \"&ngeqslant;\"\n+                    }],\n+                    [0, \"&lesdot;\"],\n+                    [0, \"&gesdot;\"],\n+                    [0, \"&lesdoto;\"],\n+                    [0, \"&gesdoto;\"],\n+                    [0, \"&lesdotor;\"],\n+                    [0, \"&gesdotol;\"],\n+                    [0, \"&lap;\"],\n+                    [0, \"&gap;\"],\n+                    [0, \"&lne;\"],\n+                    [0, \"&gne;\"],\n+                    [0, \"&lnap;\"],\n+                    [0, \"&gnap;\"],\n+                    [0, \"&lEg;\"],\n+                    [0, \"&gEl;\"],\n+                    [0, \"&lsime;\"],\n+                    [0, \"&gsime;\"],\n+                    [0, \"&lsimg;\"],\n+                    [0, \"&gsiml;\"],\n+                    [0, \"&lgE;\"],\n+                    [0, \"&glE;\"],\n+                    [0, \"&lesges;\"],\n+                    [0, \"&gesles;\"],\n+                    [0, \"&els;\"],\n+                    [0, \"&egs;\"],\n+                    [0, \"&elsdot;\"],\n+                    [0, \"&egsdot;\"],\n+                    [0, \"&el;\"],\n+                    [0, \"&eg;\"],\n+                    [2, \"&siml;\"],\n+                    [0, \"&simg;\"],\n+                    [0, \"&simlE;\"],\n+                    [0, \"&simgE;\"],\n+                    [0, {\n+                        v: \"&LessLess;\",\n+                        n: 824,\n+                        o: \"&NotNestedLessLess;\"\n+                    }],\n+                    [0, {\n+                        v: \"&GreaterGreater;\",\n+                        n: 824,\n+                        o: \"&NotNestedGreaterGreater;\"\n+                    }],\n+                    [1, \"&glj;\"],\n+                    [0, \"&gla;\"],\n+                    [0, \"&ltcc;\"],\n+                    [0, \"&gtcc;\"],\n+                    [0, \"&lescc;\"],\n+                    [0, \"&gescc;\"],\n+                    [0, \"&smt;\"],\n+                    [0, \"&lat;\"],\n+                    [0, {\n+                        v: \"&smte;\",\n+                        n: 65024,\n+                        o: \"&smtes;\"\n+                    }],\n+                    [0, {\n+                        v: \"&late;\",\n+                        n: 65024,\n+                        o: \"&lates;\"\n+                    }],\n+                    [0, \"&bumpE;\"],\n+                    [0, {\n+                        v: \"&PrecedesEqual;\",\n+                        n: 824,\n+                        o: \"&NotPrecedesEqual;\"\n+                    }],\n+                    [0, {\n+                        v: \"&sce;\",\n+                        n: 824,\n+                        o: \"&NotSucceedsEqual;\"\n+                    }],\n+                    [2, \"&prE;\"],\n+                    [0, \"&scE;\"],\n+                    [0, \"&precneqq;\"],\n+                    [0, \"&scnE;\"],\n+                    [0, \"&prap;\"],\n+                    [0, \"&scap;\"],\n+                    [0, \"&precnapprox;\"],\n+                    [0, \"&scnap;\"],\n+                    [0, \"&Pr;\"],\n+                    [0, \"&Sc;\"],\n+                    [0, \"&subdot;\"],\n+                    [0, \"&supdot;\"],\n+                    [0, \"&subplus;\"],\n+                    [0, \"&supplus;\"],\n+                    [0, \"&submult;\"],\n+                    [0, \"&supmult;\"],\n+                    [0, \"&subedot;\"],\n+                    [0, \"&supedot;\"],\n+                    [0, {\n+                        v: \"&subE;\",\n+                        n: 824,\n+                        o: \"&nsubE;\"\n+                    }],\n+                    [0, {\n+                        v: \"&supE;\",\n+                        n: 824,\n+                        o: \"&nsupE;\"\n+                    }],\n+                    [0, \"&subsim;\"],\n+                    [0, \"&supsim;\"],\n+                    [2, {\n+                        v: \"&subnE;\",\n+                        n: 65024,\n+                        o: \"&varsubsetneqq;\"\n+                    }],\n+                    [0, {\n+                        v: \"&supnE;\",\n+                        n: 65024,\n+                        o: \"&varsupsetneqq;\"\n+                    }],\n+                    [2, \"&csub;\"],\n+                    [0, \"&csup;\"],\n+                    [0, \"&csube;\"],\n+                    [0, \"&csupe;\"],\n+                    [0, \"&subsup;\"],\n+                    [0, \"&supsub;\"],\n+                    [0, \"&subsub;\"],\n+                    [0, \"&supsup;\"],\n+                    [0, \"&suphsub;\"],\n+                    [0, \"&supdsub;\"],\n+                    [0, \"&forkv;\"],\n+                    [0, \"&topfork;\"],\n+                    [0, \"&mlcp;\"],\n+                    [8, \"&Dashv;\"],\n+                    [1, \"&Vdashl;\"],\n+                    [0, \"&Barv;\"],\n+                    [0, \"&vBar;\"],\n+                    [0, \"&vBarv;\"],\n+                    [1, \"&Vbar;\"],\n+                    [0, \"&Not;\"],\n+                    [0, \"&bNot;\"],\n+                    [0, \"&rnmid;\"],\n+                    [0, \"&cirmid;\"],\n+                    [0, \"&midcir;\"],\n+                    [0, \"&topcir;\"],\n+                    [0, \"&nhpar;\"],\n+                    [0, \"&parsim;\"],\n+                    [9, {\n+                        v: \"&parsl;\",\n+                        n: 8421,\n+                        o: \"&nparsl;\"\n+                    }],\n+                    [44343, {\n+                        n: new Map( /* #__PURE__ */ restoreDiff([\n+                            [56476, \"&Ascr;\"],\n+                            [1, \"&Cscr;\"],\n+                            [0, \"&Dscr;\"],\n+                            [2, \"&Gscr;\"],\n+                            [2, \"&Jscr;\"],\n+                            [0, \"&Kscr;\"],\n+                            [2, \"&Nscr;\"],\n+                            [0, \"&Oscr;\"],\n+                            [0, \"&Pscr;\"],\n+                            [0, \"&Qscr;\"],\n+                            [1, \"&Sscr;\"],\n+                            [0, \"&Tscr;\"],\n+                            [0, \"&Uscr;\"],\n+                            [0, \"&Vscr;\"],\n+                            [0, \"&Wscr;\"],\n+                            [0, \"&Xscr;\"],\n+                            [0, \"&Yscr;\"],\n+                            [0, \"&Zscr;\"],\n+                            [0, \"&ascr;\"],\n+                            [0, \"&bscr;\"],\n+                            [0, \"&cscr;\"],\n+                            [0, \"&dscr;\"],\n+                            [1, \"&fscr;\"],\n+                            [1, \"&hscr;\"],\n+                            [0, \"&iscr;\"],\n+                            [0, \"&jscr;\"],\n+                            [0, \"&kscr;\"],\n+                            [0, \"&lscr;\"],\n+                            [0, \"&mscr;\"],\n+                            [0, \"&nscr;\"],\n+                            [1, \"&pscr;\"],\n+                            [0, \"&qscr;\"],\n+                            [0, \"&rscr;\"],\n+                            [0, \"&sscr;\"],\n+                            [0, \"&tscr;\"],\n+                            [0, \"&uscr;\"],\n+                            [0, \"&vscr;\"],\n+                            [0, \"&wscr;\"],\n+                            [0, \"&xscr;\"],\n+                            [0, \"&yscr;\"],\n+                            [0, \"&zscr;\"],\n+                            [52, \"&Afr;\"],\n+                            [0, \"&Bfr;\"],\n+                            [1, \"&Dfr;\"],\n+                            [0, \"&Efr;\"],\n+                            [0, \"&Ffr;\"],\n+                            [0, \"&Gfr;\"],\n+                            [2, \"&Jfr;\"],\n+                            [0, \"&Kfr;\"],\n+                            [0, \"&Lfr;\"],\n+                            [0, \"&Mfr;\"],\n+                            [0, \"&Nfr;\"],\n+                            [0, \"&Ofr;\"],\n+                            [0, \"&Pfr;\"],\n+                            [0, \"&Qfr;\"],\n+                            [1, \"&Sfr;\"],\n+                            [0, \"&Tfr;\"],\n+                            [0, \"&Ufr;\"],\n+                            [0, \"&Vfr;\"],\n+                            [0, \"&Wfr;\"],\n+                            [0, \"&Xfr;\"],\n+                            [0, \"&Yfr;\"],\n+                            [1, \"&afr;\"],\n+                            [0, \"&bfr;\"],\n+                            [0, \"&cfr;\"],\n+                            [0, \"&dfr;\"],\n+                            [0, \"&efr;\"],\n+                            [0, \"&ffr;\"],\n+                            [0, \"&gfr;\"],\n+                            [0, \"&hfr;\"],\n+                            [0, \"&ifr;\"],\n+                            [0, \"&jfr;\"],\n+                            [0, \"&kfr;\"],\n+                            [0, \"&lfr;\"],\n+                            [0, \"&mfr;\"],\n+                            [0, \"&nfr;\"],\n+                            [0, \"&ofr;\"],\n+                            [0, \"&pfr;\"],\n+                            [0, \"&qfr;\"],\n+                            [0, \"&rfr;\"],\n+                            [0, \"&sfr;\"],\n+                            [0, \"&tfr;\"],\n+                            [0, \"&ufr;\"],\n+                            [0, \"&vfr;\"],\n+                            [0, \"&wfr;\"],\n+                            [0, \"&xfr;\"],\n+                            [0, \"&yfr;\"],\n+                            [0, \"&zfr;\"],\n+                            [0, \"&Aopf;\"],\n+                            [0, \"&Bopf;\"],\n+                            [1, \"&Dopf;\"],\n+                            [0, \"&Eopf;\"],\n+                            [0, \"&Fopf;\"],\n+                            [0, \"&Gopf;\"],\n+                            [1, \"&Iopf;\"],\n+                            [0, \"&Jopf;\"],\n+                            [0, \"&Kopf;\"],\n+                            [0, \"&Lopf;\"],\n+                            [0, \"&Mopf;\"],\n+                            [1, \"&Oopf;\"],\n+                            [3, \"&Sopf;\"],\n+                            [0, \"&Topf;\"],\n+                            [0, \"&Uopf;\"],\n+                            [0, \"&Vopf;\"],\n+                            [0, \"&Wopf;\"],\n+                            [0, \"&Xopf;\"],\n+                            [0, \"&Yopf;\"],\n+                            [1, \"&aopf;\"],\n+                            [0, \"&bopf;\"],\n+                            [0, \"&copf;\"],\n+                            [0, \"&dopf;\"],\n+                            [0, \"&eopf;\"],\n+                            [0, \"&fopf;\"],\n+                            [0, \"&gopf;\"],\n+                            [0, \"&hopf;\"],\n+                            [0, \"&iopf;\"],\n+                            [0, \"&jopf;\"],\n+                            [0, \"&kopf;\"],\n+                            [0, \"&lopf;\"],\n+                            [0, \"&mopf;\"],\n+                            [0, \"&nopf;\"],\n+                            [0, \"&oopf;\"],\n+                            [0, \"&popf;\"],\n+                            [0, \"&qopf;\"],\n+                            [0, \"&ropf;\"],\n+                            [0, \"&sopf;\"],\n+                            [0, \"&topf;\"],\n+                            [0, \"&uopf;\"],\n+                            [0, \"&vopf;\"],\n+                            [0, \"&wopf;\"],\n+                            [0, \"&xopf;\"],\n+                            [0, \"&yopf;\"],\n+                            [0, \"&zopf;\"]\n+                        ]))\n+                    }],\n+                    [8906, \"&fflig;\"],\n+                    [0, \"&filig;\"],\n+                    [0, \"&fllig;\"],\n+                    [0, \"&ffilig;\"],\n+                    [0, \"&ffllig;\"]\n+                ]));\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/graphql/index.mjs\":\n-            /*!***********************************************!*\\\n-              !*** ../../../node_modules/graphql/index.mjs ***!\n-              \\***********************************************/\n+        \"../../../node_modules/entities/lib/index.js\":\n+            /*!***************************************************!*\\\n+              !*** ../../../node_modules/entities/lib/index.js ***!\n+              \\***************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                Object.defineProperty(exports, \"BREAK\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index2.BREAK;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"BreakingChangeType\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index6.BreakingChangeType;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"DEFAULT_DEPRECATION_REASON\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index.DEFAULT_DEPRECATION_REASON;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"DangerousChangeType\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index6.DangerousChangeType;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"DirectiveLocation\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index2.DirectiveLocation;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"ExecutableDefinitionsRule\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index4.ExecutableDefinitionsRule;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"FieldsOnCorrectTypeRule\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index4.FieldsOnCorrectTypeRule;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"FragmentsOnCompositeTypesRule\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index4.FragmentsOnCompositeTypesRule;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"GRAPHQL_MAX_INT\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index.GRAPHQL_MAX_INT;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"GRAPHQL_MIN_INT\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index.GRAPHQL_MIN_INT;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"GraphQLBoolean\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index.GraphQLBoolean;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"GraphQLDeprecatedDirective\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index.GraphQLDeprecatedDirective;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"GraphQLDirective\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index.GraphQLDirective;\n+                exports.decodeXMLStrict = exports.decodeHTML5Strict = exports.decodeHTML4Strict = exports.decodeHTML5 = exports.decodeHTML4 = exports.decodeHTMLAttribute = exports.decodeHTMLStrict = exports.decodeHTML = exports.decodeXML = exports.DecodingMode = exports.EntityDecoder = exports.encodeHTML5 = exports.encodeHTML4 = exports.encodeNonAsciiHTML = exports.encodeHTML = exports.escapeText = exports.escapeAttribute = exports.escapeUTF8 = exports.escape = exports.encodeXML = exports.encode = exports.decodeStrict = exports.decode = exports.EncodingMode = exports.EntityLevel = void 0;\n+                var decode_js_1 = __webpack_require__( /*! ./decode.js */ \"../../../node_modules/entities/lib/decode.js\");\n+                var encode_js_1 = __webpack_require__( /*! ./encode.js */ \"../../../node_modules/entities/lib/encode.js\");\n+                var escape_js_1 = __webpack_require__( /*! ./escape.js */ \"../../../node_modules/entities/lib/escape.js\");\n+                /** The level of entities to support. */\n+                var EntityLevel;\n+                (function(EntityLevel) {\n+                    /** Support only XML entities. */\n+                    EntityLevel[EntityLevel[\"XML\"] = 0] = \"XML\";\n+                    /** Support HTML entities, which are a superset of XML entities. */\n+                    EntityLevel[EntityLevel[\"HTML\"] = 1] = \"HTML\";\n+                })(EntityLevel = exports.EntityLevel || (exports.EntityLevel = {}));\n+                var EncodingMode;\n+                (function(EncodingMode) {\n+                    /**\n+                     * The output is UTF-8 encoded. Only characters that need escaping within\n+                     * XML will be escaped.\n+                     */\n+                    EncodingMode[EncodingMode[\"UTF8\"] = 0] = \"UTF8\";\n+                    /**\n+                     * The output consists only of ASCII characters. Characters that need\n+                     * escaping within HTML, and characters that aren't ASCII characters will\n+                     * be escaped.\n+                     */\n+                    EncodingMode[EncodingMode[\"ASCII\"] = 1] = \"ASCII\";\n+                    /**\n+                     * Encode all characters that have an equivalent entity, as well as all\n+                     * characters that are not ASCII characters.\n+                     */\n+                    EncodingMode[EncodingMode[\"Extensive\"] = 2] = \"Extensive\";\n+                    /**\n+                     * Encode all characters that have to be escaped in HTML attributes,\n+                     * following {@link https://html.spec.whatwg.org/multipage/parsing.html#escapingString}.\n+                     */\n+                    EncodingMode[EncodingMode[\"Attribute\"] = 3] = \"Attribute\";\n+                    /**\n+                     * Encode all characters that have to be escaped in HTML text,\n+                     * following {@link https://html.spec.whatwg.org/multipage/parsing.html#escapingString}.\n+                     */\n+                    EncodingMode[EncodingMode[\"Text\"] = 4] = \"Text\";\n+                })(EncodingMode = exports.EncodingMode || (exports.EncodingMode = {}));\n+                /**\n+                 * Decodes a string with entities.\n+                 *\n+                 * @param data String to decode.\n+                 * @param options Decoding options.\n+                 */\n+                function decode(data, options) {\n+                    if (options === void 0) {\n+                        options = EntityLevel.XML;\n                     }\n-                }));\n-                Object.defineProperty(exports, \"GraphQLEnumType\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index.GraphQLEnumType;\n+                    var level = typeof options === \"number\" ? options : options.level;\n+                    if (level === EntityLevel.HTML) {\n+                        var mode = typeof options === \"object\" ? options.mode : undefined;\n+                        return (0, decode_js_1.decodeHTML)(data, mode);\n                     }\n-                }));\n-                Object.defineProperty(exports, \"GraphQLError\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index5.GraphQLError;\n+                    return (0, decode_js_1.decodeXML)(data);\n+                }\n+                exports.decode = decode;\n+                /**\n+                 * Decodes a string with entities. Does not allow missing trailing semicolons for entities.\n+                 *\n+                 * @param data String to decode.\n+                 * @param options Decoding options.\n+                 * @deprecated Use `decode` with the `mode` set to `Strict`.\n+                 */\n+                function decodeStrict(data, options) {\n+                    var _a;\n+                    if (options === void 0) {\n+                        options = EntityLevel.XML;\n                     }\n-                }));\n-                Object.defineProperty(exports, \"GraphQLFloat\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index.GraphQLFloat;\n+                    var opts = typeof options === \"number\" ? {\n+                        level: options\n+                    } : options;\n+                    (_a = opts.mode) !== null && _a !== void 0 ? _a : opts.mode = decode_js_1.DecodingMode.Strict;\n+                    return decode(data, opts);\n+                }\n+                exports.decodeStrict = decodeStrict;\n+                /**\n+                 * Encodes a string with entities.\n+                 *\n+                 * @param data String to encode.\n+                 * @param options Encoding options.\n+                 */\n+                function encode(data, options) {\n+                    if (options === void 0) {\n+                        options = EntityLevel.XML;\n                     }\n-                }));\n-                Object.defineProperty(exports, \"GraphQLID\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index.GraphQLID;\n+                    var opts = typeof options === \"number\" ? {\n+                        level: options\n+                    } : options;\n+                    // Mode `UTF8` just escapes XML entities\n+                    if (opts.mode === EncodingMode.UTF8) return (0, escape_js_1.escapeUTF8)(data);\n+                    if (opts.mode === EncodingMode.Attribute) return (0, escape_js_1.escapeAttribute)(data);\n+                    if (opts.mode === EncodingMode.Text) return (0, escape_js_1.escapeText)(data);\n+                    if (opts.level === EntityLevel.HTML) {\n+                        if (opts.mode === EncodingMode.ASCII) {\n+                            return (0, encode_js_1.encodeNonAsciiHTML)(data);\n+                        }\n+                        return (0, encode_js_1.encodeHTML)(data);\n                     }\n-                }));\n-                Object.defineProperty(exports, \"GraphQLIncludeDirective\", ({\n+                    // ASCII and Extensive are equivalent\n+                    return (0, escape_js_1.encodeXML)(data);\n+                }\n+                exports.encode = encode;\n+                var escape_js_2 = __webpack_require__( /*! ./escape.js */ \"../../../node_modules/entities/lib/escape.js\");\n+                Object.defineProperty(exports, \"encodeXML\", ({\n                     enumerable: true,\n                     get: function() {\n-                        return _index.GraphQLIncludeDirective;\n+                        return escape_js_2.encodeXML;\n                     }\n                 }));\n-                Object.defineProperty(exports, \"GraphQLInputObjectType\", ({\n+                Object.defineProperty(exports, \"escape\", ({\n                     enumerable: true,\n                     get: function() {\n-                        return _index.GraphQLInputObjectType;\n+                        return escape_js_2.escape;\n                     }\n                 }));\n-                Object.defineProperty(exports, \"GraphQLInt\", ({\n+                Object.defineProperty(exports, \"escapeUTF8\", ({\n                     enumerable: true,\n                     get: function() {\n-                        return _index.GraphQLInt;\n+                        return escape_js_2.escapeUTF8;\n                     }\n                 }));\n-                Object.defineProperty(exports, \"GraphQLInterfaceType\", ({\n+                Object.defineProperty(exports, \"escapeAttribute\", ({\n                     enumerable: true,\n                     get: function() {\n-                        return _index.GraphQLInterfaceType;\n+                        return escape_js_2.escapeAttribute;\n                     }\n                 }));\n-                Object.defineProperty(exports, \"GraphQLList\", ({\n+                Object.defineProperty(exports, \"escapeText\", ({\n                     enumerable: true,\n                     get: function() {\n-                        return _index.GraphQLList;\n+                        return escape_js_2.escapeText;\n                     }\n                 }));\n-                Object.defineProperty(exports, \"GraphQLNonNull\", ({\n+                var encode_js_2 = __webpack_require__( /*! ./encode.js */ \"../../../node_modules/entities/lib/encode.js\");\n+                Object.defineProperty(exports, \"encodeHTML\", ({\n                     enumerable: true,\n                     get: function() {\n-                        return _index.GraphQLNonNull;\n+                        return encode_js_2.encodeHTML;\n                     }\n                 }));\n-                Object.defineProperty(exports, \"GraphQLObjectType\", ({\n+                Object.defineProperty(exports, \"encodeNonAsciiHTML\", ({\n                     enumerable: true,\n                     get: function() {\n-                        return _index.GraphQLObjectType;\n+                        return encode_js_2.encodeNonAsciiHTML;\n                     }\n                 }));\n-                Object.defineProperty(exports, \"GraphQLScalarType\", ({\n+                // Legacy aliases (deprecated)\n+                Object.defineProperty(exports, \"encodeHTML4\", ({\n                     enumerable: true,\n                     get: function() {\n-                        return _index.GraphQLScalarType;\n+                        return encode_js_2.encodeHTML;\n                     }\n                 }));\n-                Object.defineProperty(exports, \"GraphQLSchema\", ({\n+                Object.defineProperty(exports, \"encodeHTML5\", ({\n                     enumerable: true,\n                     get: function() {\n-                        return _index.GraphQLSchema;\n+                        return encode_js_2.encodeHTML;\n                     }\n                 }));\n-                Object.defineProperty(exports, \"GraphQLSkipDirective\", ({\n+                var decode_js_2 = __webpack_require__( /*! ./decode.js */ \"../../../node_modules/entities/lib/decode.js\");\n+                Object.defineProperty(exports, \"EntityDecoder\", ({\n                     enumerable: true,\n                     get: function() {\n-                        return _index.GraphQLSkipDirective;\n+                        return decode_js_2.EntityDecoder;\n                     }\n                 }));\n-                Object.defineProperty(exports, \"GraphQLSpecifiedByDirective\", ({\n+                Object.defineProperty(exports, \"DecodingMode\", ({\n                     enumerable: true,\n                     get: function() {\n-                        return _index.GraphQLSpecifiedByDirective;\n+                        return decode_js_2.DecodingMode;\n                     }\n                 }));\n-                Object.defineProperty(exports, \"GraphQLString\", ({\n+                Object.defineProperty(exports, \"decodeXML\", ({\n                     enumerable: true,\n                     get: function() {\n-                        return _index.GraphQLString;\n+                        return decode_js_2.decodeXML;\n                     }\n                 }));\n-                Object.defineProperty(exports, \"GraphQLUnionType\", ({\n+                Object.defineProperty(exports, \"decodeHTML\", ({\n                     enumerable: true,\n                     get: function() {\n-                        return _index.GraphQLUnionType;\n+                        return decode_js_2.decodeHTML;\n                     }\n                 }));\n-                Object.defineProperty(exports, \"Kind\", ({\n+                Object.defineProperty(exports, \"decodeHTMLStrict\", ({\n                     enumerable: true,\n                     get: function() {\n-                        return _index2.Kind;\n+                        return decode_js_2.decodeHTMLStrict;\n                     }\n                 }));\n-                Object.defineProperty(exports, \"KnownArgumentNamesRule\", ({\n+                Object.defineProperty(exports, \"decodeHTMLAttribute\", ({\n                     enumerable: true,\n                     get: function() {\n-                        return _index4.KnownArgumentNamesRule;\n+                        return decode_js_2.decodeHTMLAttribute;\n                     }\n                 }));\n-                Object.defineProperty(exports, \"KnownDirectivesRule\", ({\n+                // Legacy aliases (deprecated)\n+                Object.defineProperty(exports, \"decodeHTML4\", ({\n                     enumerable: true,\n                     get: function() {\n-                        return _index4.KnownDirectivesRule;\n+                        return decode_js_2.decodeHTML;\n                     }\n                 }));\n-                Object.defineProperty(exports, \"KnownFragmentNamesRule\", ({\n+                Object.defineProperty(exports, \"decodeHTML5\", ({\n                     enumerable: true,\n                     get: function() {\n-                        return _index4.KnownFragmentNamesRule;\n+                        return decode_js_2.decodeHTML;\n                     }\n                 }));\n-                Object.defineProperty(exports, \"KnownTypeNamesRule\", ({\n+                Object.defineProperty(exports, \"decodeHTML4Strict\", ({\n                     enumerable: true,\n                     get: function() {\n-                        return _index4.KnownTypeNamesRule;\n+                        return decode_js_2.decodeHTMLStrict;\n                     }\n                 }));\n-                Object.defineProperty(exports, \"Lexer\", ({\n+                Object.defineProperty(exports, \"decodeHTML5Strict\", ({\n                     enumerable: true,\n                     get: function() {\n-                        return _index2.Lexer;\n+                        return decode_js_2.decodeHTMLStrict;\n                     }\n                 }));\n-                Object.defineProperty(exports, \"Location\", ({\n+                Object.defineProperty(exports, \"decodeXMLStrict\", ({\n                     enumerable: true,\n                     get: function() {\n-                        return _index2.Location;\n+                        return decode_js_2.decodeXML;\n                     }\n                 }));\n-                Object.defineProperty(exports, \"LoneAnonymousOperationRule\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index4.LoneAnonymousOperationRule;\n-                    }\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/framer-motion/dist/cjs/index.js\":\n+            /*!*************************************************************!*\\\n+              !*** ../../../node_modules/framer-motion/dist/cjs/index.js ***!\n+              \\*************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n                 }));\n-                Object.defineProperty(exports, \"LoneSchemaDefinitionRule\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index4.LoneSchemaDefinitionRule;\n+                var tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.mjs\");\n+                var React = __webpack_require__( /*! react */ \"react\");\n+                var heyListen = __webpack_require__( /*! hey-listen */ \"../../../node_modules/hey-listen/dist/hey-listen.es.js\");\n+                var styleValueTypes = __webpack_require__( /*! style-value-types */ \"../../../node_modules/style-value-types/dist/valueTypes.cjs.js\");\n+                var popmotion = __webpack_require__( /*! popmotion */ \"../../../node_modules/popmotion/dist/popmotion.cjs.js\");\n+                var sync = __webpack_require__( /*! framesync */ \"../../../node_modules/framesync/dist/framesync.cjs.js\");\n+                var dom = __webpack_require__( /*! @motionone/dom */ \"../../../node_modules/@motionone/dom/dist/index.es.js\");\n+\n+                function _interopDefaultLegacy(e) {\n+                    return e && typeof e === 'object' && 'default' in e ? e : {\n+                        'default': e\n+                    };\n+                }\n+\n+                function _interopNamespace(e) {\n+                    if (e && e.__esModule) return e;\n+                    var n = Object.create(null);\n+                    if (e) {\n+                        Object.keys(e).forEach(function(k) {\n+                            if (k !== 'default') {\n+                                var d = Object.getOwnPropertyDescriptor(e, k);\n+                                Object.defineProperty(n, k, d.get ? d : {\n+                                    enumerable: true,\n+                                    get: function() {\n+                                        return e[k];\n+                                    }\n+                                });\n+                            }\n+                        });\n                     }\n-                }));\n-                Object.defineProperty(exports, \"NoDeprecatedCustomRule\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index4.NoDeprecatedCustomRule;\n+                    n[\"default\"] = e;\n+                    return Object.freeze(n);\n+                }\n+                var React__namespace = /*#__PURE__*/ _interopNamespace(React);\n+                var React__default = /*#__PURE__*/ _interopDefaultLegacy(React);\n+                var sync__default = /*#__PURE__*/ _interopDefaultLegacy(sync);\n+\n+                /**\n+                 * Browser-safe usage of process\n+                 */\n+                var defaultEnvironment = \"production\";\n+                var env = typeof process === \"undefined\" || process.env === undefined ? defaultEnvironment : \"development\" || 0;\n+                var createDefinition = function(propNames) {\n+                    return {\n+                        isEnabled: function(props) {\n+                            return propNames.some(function(name) {\n+                                return !!props[name];\n+                            });\n+                        }\n+                    };\n+                };\n+                var featureDefinitions = {\n+                    measureLayout: createDefinition([\"layout\", \"layoutId\", \"drag\"]),\n+                    animation: createDefinition([\"animate\", \"exit\", \"variants\", \"whileHover\", \"whileTap\", \"whileFocus\", \"whileDrag\", \"whileInView\"]),\n+                    exit: createDefinition([\"exit\"]),\n+                    drag: createDefinition([\"drag\", \"dragControls\"]),\n+                    focus: createDefinition([\"whileFocus\"]),\n+                    hover: createDefinition([\"whileHover\", \"onHoverStart\", \"onHoverEnd\"]),\n+                    tap: createDefinition([\"whileTap\", \"onTap\", \"onTapStart\", \"onTapCancel\"]),\n+                    pan: createDefinition([\"onPan\", \"onPanStart\", \"onPanSessionStart\", \"onPanEnd\"]),\n+                    inView: createDefinition([\"whileInView\", \"onViewportEnter\", \"onViewportLeave\"])\n+                };\n+\n+                function loadFeatures(features) {\n+                    for (var key in features) {\n+                        if (features[key] === null) continue;\n+                        if (key === \"projectionNodeConstructor\") {\n+                            featureDefinitions.projectionNodeConstructor = features[key];\n+                        } else {\n+                            featureDefinitions[key].Component = features[key];\n+                        }\n                     }\n-                }));\n-                Object.defineProperty(exports, \"NoFragmentCyclesRule\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index4.NoFragmentCyclesRule;\n+                }\n+                var LazyContext = React.createContext({\n+                    strict: false\n+                });\n+                var featureNames = Object.keys(featureDefinitions);\n+                var numFeatures = featureNames.length;\n+                /**\n+                 * Load features via renderless components based on the provided MotionProps.\n+                 */\n+                function useFeatures(props, visualElement, preloadedFeatures) {\n+                    var features = [];\n+                    var lazyContext = React.useContext(LazyContext);\n+                    if (!visualElement) return null;\n+                    /**\n+                     * If we're in development mode, check to make sure we're not rendering a motion component\n+                     * as a child of LazyMotion, as this will break the file-size benefits of using it.\n+                     */\n+                    if (env !== \"production\" && preloadedFeatures && lazyContext.strict) {\n+                        heyListen.invariant(false, \"You have rendered a `motion` component within a `LazyMotion` component. This will break tree shaking. Import and render a `m` component instead.\");\n                     }\n-                }));\n-                Object.defineProperty(exports, \"NoSchemaIntrospectionCustomRule\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index4.NoSchemaIntrospectionCustomRule;\n+                    for (var i = 0; i < numFeatures; i++) {\n+                        var name_1 = featureNames[i];\n+                        var _a = featureDefinitions[name_1],\n+                            isEnabled = _a.isEnabled,\n+                            Component = _a.Component;\n+                        /**\n+                         * It might be possible in the future to use this moment to\n+                         * dynamically request functionality. In initial tests this\n+                         * was producing a lot of duplication amongst bundles.\n+                         */\n+                        if (isEnabled(props) && Component) {\n+                            features.push(React__namespace.createElement(Component, tslib.__assign({\n+                                key: name_1\n+                            }, props, {\n+                                visualElement: visualElement\n+                            })));\n+                        }\n                     }\n-                }));\n-                Object.defineProperty(exports, \"NoUndefinedVariablesRule\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index4.NoUndefinedVariablesRule;\n+                    return features;\n+                }\n+\n+                /**\n+                 * @public\n+                 */\n+                var MotionConfigContext = React.createContext({\n+                    transformPagePoint: function(p) {\n+                        return p;\n+                    },\n+                    isStatic: false,\n+                    reducedMotion: \"never\"\n+                });\n+                var MotionContext = React.createContext({});\n+\n+                function useVisualElementContext() {\n+                    return React.useContext(MotionContext).visualElement;\n+                }\n+\n+                /**\n+                 * @public\n+                 */\n+                var PresenceContext = React.createContext(null);\n+                var isBrowser = typeof document !== \"undefined\";\n+                var useIsomorphicLayoutEffect = isBrowser ? React.useLayoutEffect : React.useEffect;\n+\n+                // Does this device prefer reduced motion? Returns `null` server-side.\n+                var prefersReducedMotion = {\n+                    current: null\n+                };\n+                var hasDetected = false;\n+\n+                function initPrefersReducedMotion() {\n+                    hasDetected = true;\n+                    if (!isBrowser) return;\n+                    if (window.matchMedia) {\n+                        var motionMediaQuery_1 = window.matchMedia(\"(prefers-reduced-motion)\");\n+                        var setReducedMotionPreferences = function() {\n+                            return prefersReducedMotion.current = motionMediaQuery_1.matches;\n+                        };\n+                        motionMediaQuery_1.addListener(setReducedMotionPreferences);\n+                        setReducedMotionPreferences();\n+                    } else {\n+                        prefersReducedMotion.current = false;\n                     }\n-                }));\n-                Object.defineProperty(exports, \"NoUnusedFragmentsRule\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index4.NoUnusedFragmentsRule;\n+                }\n+                /**\n+                 * A hook that returns `true` if we should be using reduced motion based on the current device's Reduced Motion setting.\n+                 *\n+                 * This can be used to implement changes to your UI based on Reduced Motion. For instance, replacing motion-sickness inducing\n+                 * `x`/`y` animations with `opacity`, disabling the autoplay of background videos, or turning off parallax motion.\n+                 *\n+                 * It will actively respond to changes and re-render your components with the latest setting.\n+                 *\n+                 * ```jsx\n+                 * export function Sidebar({ isOpen }) {\n+                 *   const shouldReduceMotion = useReducedMotion()\n+                 *   const closedX = shouldReduceMotion ? 0 : \"-100%\"\n+                 *\n+                 *   return (\n+                 *     <motion.div animate={{\n+                 *       opacity: isOpen ? 1 : 0,\n+                 *       x: isOpen ? 0 : closedX\n+                 *     }} />\n+                 *   )\n+                 * }\n+                 * ```\n+                 *\n+                 * @return boolean\n+                 *\n+                 * @public\n+                 */\n+                function useReducedMotion() {\n+                    /**\n+                     * Lazy initialisation of prefersReducedMotion\n+                     */\n+                    !hasDetected && initPrefersReducedMotion();\n+                    var _a = tslib.__read(React.useState(prefersReducedMotion.current), 1),\n+                        shouldReduceMotion = _a[0];\n+                    /**\n+                     * TODO See if people miss automatically updating shouldReduceMotion setting\n+                     */\n+                    return shouldReduceMotion;\n+                }\n+\n+                function useReducedMotionConfig() {\n+                    var reducedMotionPreference = useReducedMotion();\n+                    var reducedMotion = React.useContext(MotionConfigContext).reducedMotion;\n+                    if (reducedMotion === \"never\") {\n+                        return false;\n+                    } else if (reducedMotion === \"always\") {\n+                        return true;\n+                    } else {\n+                        return reducedMotionPreference;\n                     }\n-                }));\n-                Object.defineProperty(exports, \"NoUnusedVariablesRule\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index4.NoUnusedVariablesRule;\n+                }\n+\n+                function useVisualElement(Component, visualState, props, createVisualElement) {\n+                    var lazyContext = React.useContext(LazyContext);\n+                    var parent = useVisualElementContext();\n+                    var presenceContext = React.useContext(PresenceContext);\n+                    var shouldReduceMotion = useReducedMotionConfig();\n+                    var visualElementRef = React.useRef(undefined);\n+                    /**\n+                     * If we haven't preloaded a renderer, check to see if we have one lazy-loaded\n+                     */\n+                    if (!createVisualElement) createVisualElement = lazyContext.renderer;\n+                    if (!visualElementRef.current && createVisualElement) {\n+                        visualElementRef.current = createVisualElement(Component, {\n+                            visualState: visualState,\n+                            parent: parent,\n+                            props: props,\n+                            presenceId: presenceContext === null || presenceContext === void 0 ? void 0 : presenceContext.id,\n+                            blockInitialAnimation: (presenceContext === null || presenceContext === void 0 ? void 0 : presenceContext.initial) === false,\n+                            shouldReduceMotion: shouldReduceMotion\n+                        });\n                     }\n-                }));\n-                Object.defineProperty(exports, \"OperationTypeNode\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index2.OperationTypeNode;\n+                    var visualElement = visualElementRef.current;\n+                    useIsomorphicLayoutEffect(function() {\n+                        visualElement === null || visualElement === void 0 ? void 0 : visualElement.syncRender();\n+                    });\n+                    React.useEffect(function() {\n+                        var _a;\n+                        (_a = visualElement === null || visualElement === void 0 ? void 0 : visualElement.animationState) === null || _a === void 0 ? void 0 : _a.animateChanges();\n+                    });\n+                    useIsomorphicLayoutEffect(function() {\n+                        return function() {\n+                            return visualElement === null || visualElement === void 0 ? void 0 : visualElement.notifyUnmount();\n+                        };\n+                    }, []);\n+                    return visualElement;\n+                }\n+\n+                function isRefObject(ref) {\n+                    return typeof ref === \"object\" && Object.prototype.hasOwnProperty.call(ref, \"current\");\n+                }\n+\n+                /**\n+                 * Creates a ref function that, when called, hydrates the provided\n+                 * external ref and VisualElement.\n+                 */\n+                function useMotionRef(visualState, visualElement, externalRef) {\n+                    return React.useCallback(function(instance) {\n+                            var _a;\n+                            instance && ((_a = visualState.mount) === null || _a === void 0 ? void 0 : _a.call(visualState, instance));\n+                            if (visualElement) {\n+                                instance ? visualElement.mount(instance) : visualElement.unmount();\n+                            }\n+                            if (externalRef) {\n+                                if (typeof externalRef === \"function\") {\n+                                    externalRef(instance);\n+                                } else if (isRefObject(externalRef)) {\n+                                    externalRef.current = instance;\n+                                }\n+                            }\n+                        },\n+                        /**\n+                         * Only pass a new ref callback to React if we've received a visual element\n+                         * factory. Otherwise we'll be mounting/remounting every time externalRef\n+                         * or other dependencies change.\n+                         */\n+                        [visualElement]);\n+                }\n+\n+                /**\n+                 * Decides if the supplied variable is an array of variant labels\n+                 */\n+                function isVariantLabels(v) {\n+                    return Array.isArray(v);\n+                }\n+                /**\n+                 * Decides if the supplied variable is variant label\n+                 */\n+                function isVariantLabel(v) {\n+                    return typeof v === \"string\" || isVariantLabels(v);\n+                }\n+                /**\n+                 * Creates an object containing the latest state of every MotionValue on a VisualElement\n+                 */\n+                function getCurrent(visualElement) {\n+                    var current = {};\n+                    visualElement.forEachValue(function(value, key) {\n+                        return current[key] = value.get();\n+                    });\n+                    return current;\n+                }\n+                /**\n+                 * Creates an object containing the latest velocity of every MotionValue on a VisualElement\n+                 */\n+                function getVelocity$1(visualElement) {\n+                    var velocity = {};\n+                    visualElement.forEachValue(function(value, key) {\n+                        return velocity[key] = value.getVelocity();\n+                    });\n+                    return velocity;\n+                }\n+\n+                function resolveVariantFromProps(props, definition, custom, currentValues, currentVelocity) {\n+                    var _a;\n+                    if (currentValues === void 0) {\n+                        currentValues = {};\n                     }\n-                }));\n-                Object.defineProperty(exports, \"OverlappingFieldsCanBeMergedRule\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index4.OverlappingFieldsCanBeMergedRule;\n+                    if (currentVelocity === void 0) {\n+                        currentVelocity = {};\n                     }\n-                }));\n-                Object.defineProperty(exports, \"PossibleFragmentSpreadsRule\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index4.PossibleFragmentSpreadsRule;\n+                    /**\n+                     * If the variant definition is a function, resolve.\n+                     */\n+                    if (typeof definition === \"function\") {\n+                        definition = definition(custom !== null && custom !== void 0 ? custom : props.custom, currentValues, currentVelocity);\n                     }\n-                }));\n-                Object.defineProperty(exports, \"PossibleTypeExtensionsRule\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index4.PossibleTypeExtensionsRule;\n+                    /**\n+                     * If the variant definition is a variant label, or\n+                     * the function returned a variant label, resolve.\n+                     */\n+                    if (typeof definition === \"string\") {\n+                        definition = (_a = props.variants) === null || _a === void 0 ? void 0 : _a[definition];\n                     }\n-                }));\n-                Object.defineProperty(exports, \"ProvidedRequiredArgumentsRule\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index4.ProvidedRequiredArgumentsRule;\n+                    /**\n+                     * At this point we've resolved both functions and variant labels,\n+                     * but the resolved variant label might itself have been a function.\n+                     * If so, resolve. This can only have returned a valid target object.\n+                     */\n+                    if (typeof definition === \"function\") {\n+                        definition = definition(custom !== null && custom !== void 0 ? custom : props.custom, currentValues, currentVelocity);\n                     }\n-                }));\n-                Object.defineProperty(exports, \"ScalarLeafsRule\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index4.ScalarLeafsRule;\n+                    return definition;\n+                }\n+\n+                function resolveVariant(visualElement, definition, custom) {\n+                    var props = visualElement.getProps();\n+                    return resolveVariantFromProps(props, definition, custom !== null && custom !== void 0 ? custom : props.custom, getCurrent(visualElement), getVelocity$1(visualElement));\n+                }\n+\n+                function checkIfControllingVariants(props) {\n+                    var _a;\n+                    return typeof((_a = props.animate) === null || _a === void 0 ? void 0 : _a.start) === \"function\" || isVariantLabel(props.initial) || isVariantLabel(props.animate) || isVariantLabel(props.whileHover) || isVariantLabel(props.whileDrag) || isVariantLabel(props.whileTap) || isVariantLabel(props.whileFocus) || isVariantLabel(props.exit);\n+                }\n+\n+                function checkIfVariantNode(props) {\n+                    return Boolean(checkIfControllingVariants(props) || props.variants);\n+                }\n+\n+                function getCurrentTreeVariants(props, context) {\n+                    if (checkIfControllingVariants(props)) {\n+                        var initial = props.initial,\n+                            animate = props.animate;\n+                        return {\n+                            initial: initial === false || isVariantLabel(initial) ? initial : undefined,\n+                            animate: isVariantLabel(animate) ? animate : undefined\n+                        };\n                     }\n-                }));\n-                Object.defineProperty(exports, \"SchemaMetaFieldDef\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index.SchemaMetaFieldDef;\n+                    return props.inherit !== false ? context : {};\n+                }\n+\n+                function useCreateMotionContext(props) {\n+                    var _a = getCurrentTreeVariants(props, React.useContext(MotionContext)),\n+                        initial = _a.initial,\n+                        animate = _a.animate;\n+                    return React.useMemo(function() {\n+                        return {\n+                            initial: initial,\n+                            animate: animate\n+                        };\n+                    }, [variantLabelsAsDependency(initial), variantLabelsAsDependency(animate)]);\n+                }\n+\n+                function variantLabelsAsDependency(prop) {\n+                    return Array.isArray(prop) ? prop.join(\" \") : prop;\n+                }\n+\n+                /**\n+                 * Creates a constant value over the lifecycle of a component.\n+                 *\n+                 * Even if `useMemo` is provided an empty array as its final argument, it doesn't offer\n+                 * a guarantee that it won't re-run for performance reasons later on. By using `useConstant`\n+                 * you can ensure that initialisers don't execute twice or more.\n+                 */\n+                function useConstant(init) {\n+                    var ref = React.useRef(null);\n+                    if (ref.current === null) {\n+                        ref.current = init();\n                     }\n-                }));\n-                Object.defineProperty(exports, \"SingleFieldSubscriptionsRule\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index4.SingleFieldSubscriptionsRule;\n+                    return ref.current;\n+                }\n+\n+                /**\n+                 * This should only ever be modified on the client otherwise it'll\n+                 * persist through server requests. If we need instanced states we\n+                 * could lazy-init via root.\n+                 */\n+                var globalProjectionState = {\n+                    /**\n+                     * Global flag as to whether the tree has animated since the last time\n+                     * we resized the window\n+                     */\n+                    hasAnimatedSinceResize: true,\n+                    /**\n+                     * We set this to true once, on the first update. Any nodes added to the tree beyond that\n+                     * update will be given a `data-projection-id` attribute.\n+                     */\n+                    hasEverUpdated: false\n+                };\n+                var id$1 = 1;\n+\n+                function useProjectionId() {\n+                    return useConstant(function() {\n+                        if (globalProjectionState.hasEverUpdated) {\n+                            return id$1++;\n+                        }\n+                    });\n+                }\n+                var LayoutGroupContext = React.createContext({});\n+\n+                /**\n+                 * Internal, exported only for usage in Framer\n+                 */\n+                var SwitchLayoutGroupContext = React.createContext({});\n+\n+                function useProjection(projectionId, _a, visualElement, ProjectionNodeConstructor) {\n+                    var _b;\n+                    var layoutId = _a.layoutId,\n+                        layout = _a.layout,\n+                        drag = _a.drag,\n+                        dragConstraints = _a.dragConstraints,\n+                        layoutScroll = _a.layoutScroll;\n+                    var initialPromotionConfig = React.useContext(SwitchLayoutGroupContext);\n+                    if (!ProjectionNodeConstructor || !visualElement || (visualElement === null || visualElement === void 0 ? void 0 : visualElement.projection)) {\n+                        return;\n                     }\n-                }));\n-                Object.defineProperty(exports, \"Source\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _index2.Source;\n+                    visualElement.projection = new ProjectionNodeConstructor(projectionId, visualElement.getLatestValues(), (_b = visualElement.parent) === null || _b === void 0 ? void 0 : _b.projection);\n+                    visualElement.projection.setOptions({\n+                        layoutId: layoutId,\n+                        layout: layout,\n+                        alwaysMeasureLayout: Boolean(drag) || dragConstraints && isRefObject(dragConstraints),\n+                        visualElement: visualElement,\n+                        scheduleRender: function() {\n+                            return visualElement.scheduleRender();\n+                        },\n+                        /**\n+                         * TODO: Update options in an effect. This could be tricky as it'll be too late\n+                         * to update by the time layout animations run.\n+                         * We also need to fix this safeToRemove by linking it up to the one returned by usePresence,\n+                         * ensuring it gets called if there's no potential layout animations.\n+                         *\n+                         */\n+                        animationType: typeof layout === \"string\" ? layout : \"both\",\n+                        initialPromotionConfig: initialPromotionConfig,\n+                        layoutScroll: layoutScroll\n+                    });\n+                }\n+                var VisualElementHandler = /** @class */ function(_super) {\n+                    tslib.__extends(VisualElementHandler, _super);\n+\n+                    function VisualElementHandler() {\n+                        return _super !== null && _super.apply(this, arguments) || this;\n                     }\n-                }));\n-                Object.defineProperty(exports, \"Token\", ({\n+                    /**\n+                     * Update visual element props as soon as we know this update is going to be commited.\n+                     */\n+                    VisualElementHandler.prototype.getSnapshotBeforeUpdate = function() {\n+                        this.updateProps();\n+                        return null;\n+                    };\n+                    VisualElementHandler.prototype.componentDidUpdate = function() {};\n+                    VisualElementHandler.prototype.updateProps = function() {\n+                        var _a = this.props,\n+                            visualElement = _a.visualElement,\n+                            props = _a.props;\n+                        if (visualElement) visualElement.setProps(props);\n+                    };\n+                    VisualElementHandler.prototype.render = function() {\n+                        return this.props.children;\n+                    };\n+                    return VisualElementHandler;\n+                }(React__default[\"default\"].Component);\n+\n+                /**\n+                 * Create a `motion` component.\n+                 *\n+                 * This function accepts a Component argument, which can be either a string (ie \"div\"\n+                 * for `motion.div`), or an actual React component.\n+                 *\n+                 * Alongside this is a config option which provides a way of rendering the provided\n+                 * component \"offline\", or outside the React render cycle.\n+                 */\n+                function createMotionComponent(_a) {\n+                    var preloadedFeatures = _a.preloadedFeatures,\n+                        createVisualElement = _a.createVisualElement,\n+                        projectionNodeConstructor = _a.projectionNodeConstructor,\n+                        useRender = _a.useRender,\n+                        useVisualState = _a.useVisualState,\n+                        Component = _a.Component;\n+                    preloadedFeatures && loadFeatures(preloadedFeatures);\n+\n+                    function MotionComponent(props, externalRef) {\n+                        var layoutId = useLayoutId(props);\n+                        props = tslib.__assign(tslib.__assign({}, props), {\n+                            layoutId: layoutId\n+                        });\n+                        /**\n+                         * If we're rendering in a static environment, we only visually update the component\n+                         * as a result of a React-rerender rather than interactions or animations. This\n+                         * means we don't need to load additional memory structures like VisualElement,\n+                         * or any gesture/animation features.\n+                         */\n+                        var config = React.useContext(MotionConfigContext);\n+                        var features = null;\n+                        var context = useCreateMotionContext(props);\n+                        /**\n+                         * Create a unique projection ID for this component. If a new component is added\n+                         * during a layout animation we'll use this to query the DOM and hydrate its ref early, allowing\n+                         * us to measure it as soon as any layout effect flushes pending layout animations.\n+                         *\n+                         * Performance note: It'd be better not to have to search the DOM for these elements.\n+                         * For newly-entering components it could be enough to only correct treeScale, in which\n+                         * case we could mount in a scale-correction mode. This wouldn't be enough for\n+                         * shared element transitions however. Perhaps for those we could revert to a root node\n+                         * that gets forceRendered and layout animations are triggered on its layout effect.\n+                         */\n+                        var projectionId = config.isStatic ? undefined : useProjectionId();\n+                        /**\n+                         *\n+                         */\n+                        var visualState = useVisualState(props, config.isStatic);\n+                        if (!config.isStatic && isBrowser) {\n+                            /**\n+                             * Create a VisualElement for this component. A VisualElement provides a common\n+                             * interface to renderer-specific APIs (ie DOM/Three.js etc) as well as\n+                             * providing a way of rendering to these APIs outside of the React render loop\n+                             * for more performant animations and interactions\n+                             */\n+                            context.visualElement = useVisualElement(Component, visualState, tslib.__assign(tslib.__assign({}, config), props), createVisualElement);\n+                            useProjection(projectionId, props, context.visualElement, projectionNodeConstructor || featureDefinitions.projectionNodeConstructor);\n+                            /**\n+                             * Load Motion gesture and animation features. These are rendered as renderless\n+                             * components so each feature can optionally make use of React lifecycle methods.\n+                             */\n+                            features = useFeatures(props, context.visualElement, preloadedFeatures);\n+                        }\n+                        /**\n+                         * The mount order and hierarchy is specific to ensure our element ref\n+                         * is hydrated by the time features fire their effects.\n+                         */\n+                        return React__namespace.createElement(VisualElementHandler, {\n+                            visualElement: context.visualElement,\n+                            props: tslib.__assign(tslib.__assign({}, config), props)\n+                        }, features, React__namespace.createElement(MotionContext.Provider, {\n+                            value: context\n+                        }, useRender(Component, props, projectionId, useMotionRef(visualState, context.visualElement, externalRef), visualState, config.isStatic, context.visualElement)));\n+                    }\n+                    return React.forwardRef(MotionComponent);\n+                }\n+\n+                function useLayoutId(_a) {\n+                    var _b;\n+                    var layoutId = _a.layoutId;\n+                    var layoutGroupId = (_b = React.useContext(LayoutGroupContext)) === null || _b === void 0 ? void 0 : _b.id;\n+                    return layoutGroupId && layoutId !== undefined ? layoutGroupId + \"-\" + layoutId : layoutId;\n+                }\n+\n+                /**\n+                 * Convert any React component into a `motion` component. The provided component\n+                 * **must** use `React.forwardRef` to the underlying DOM component you want to animate.\n+                 *\n+                 * ```jsx\n+                 * const Component = React.forwardRef((props, ref) => {\n+                 *   return <div ref={ref} />\n+                 * })\n+                 *\n+                 * const MotionComponent = motion(Component)\n+                 * ```\n+                 *\n+                 * @public\n+                 */\n+                function createMotionProxy(createConfig) {\n+                    function custom(Component, customMotionComponentConfig) {\n+                        if (customMotionComponentConfig === void 0) {\n+                            customMotionComponentConfig = {};\n+                        }\n+                        return createMotionComponent(createConfig(Component, customMotionComponentConfig));\n+                    }\n+                    if (typeof Proxy === \"undefined\") {\n+                        return custom;\n+                    }\n+                    /**\n+                     * A cache of generated `motion` components, e.g `motion.div`, `motion.input` etc.\n+                     * Rather than generating them anew every render.\n+                     */\n+                    var componentCache = new Map();\n+                    return new Proxy(custom, {\n+                        /**\n+                         * Called when `motion` is referenced with a prop: `motion.div`, `motion.input` etc.\n+                         * The prop name is passed through as `key` and we can use that to generate a `motion`\n+                         * DOM component with that name.\n+                         */\n+                        get: function(_target, key) {\n+                            /**\n+                             * If this element doesn't exist in the component cache, create it and cache.\n+                             */\n+                            if (!componentCache.has(key)) {\n+                                componentCache.set(key, custom(key));\n+                            }\n+                            return componentCache.get(key);\n+                        }\n+                    });\n+                }\n+\n+                /**\n+                 * We keep these listed seperately as we use the lowercase tag names as part\n+                 * of the runtime bundle to detect SVG components\n+                 */\n+                var lowercaseSVGElements = [\"animate\", \"circle\", \"defs\", \"desc\", \"ellipse\", \"g\", \"image\", \"line\", \"filter\", \"marker\", \"mask\", \"metadata\", \"path\", \"pattern\", \"polygon\", \"polyline\", \"rect\", \"stop\", \"svg\", \"switch\", \"symbol\", \"text\", \"tspan\", \"use\", \"view\"];\n+\n+                function isSVGComponent(Component) {\n+                    if (\n+                        /**\n+                         * If it's not a string, it's a custom React component. Currently we only support\n+                         * HTML custom React components.\n+                         */\n+                        typeof Component !== \"string\" ||\n+                        /**\n+                         * If it contains a dash, the element is a custom HTML webcomponent.\n+                         */\n+                        Component.includes(\"-\")) {\n+                        return false;\n+                    } else if (\n+                        /**\n+                         * If it's in our list of lowercase SVG tags, it's an SVG component\n+                         */\n+                        lowercaseSVGElements.indexOf(Component) > -1 ||\n+                        /**\n+                         * If it contains a capital letter, it's an SVG component\n+                         */\n+                        /[A-Z]/.test(Component)) {\n+                        return true;\n+                    }\n+                    return false;\n+                }\n+                var scaleCorrectors = {};\n+\n+                function addScaleCorrector(correctors) {\n+                    Object.assign(scaleCorrectors, correctors);\n+                }\n+\n+                /**\n+                 * A list of all transformable axes. We'll use this list to generated a version\n+                 * of each axes for each transform.\n+                 */\n+                var transformAxes = [\"\", \"X\", \"Y\", \"Z\"];\n+                /**\n+                 * An ordered array of each transformable value. By default, transform values\n+                 * will be sorted to this order.\n+                 */\n+                var order = [\"translate\", \"scale\", \"rotate\", \"skew\"];\n+                /**\n+                 * Generate a list of every possible transform key.\n+                 */\n+                var transformProps = [\"transformPerspective\", \"x\", \"y\", \"z\"];\n+                order.forEach(function(operationKey) {\n+                    return transformAxes.forEach(function(axesKey) {\n+                        return transformProps.push(operationKey + axesKey);\n+                    });\n+                });\n+                /**\n+                 * A function to use with Array.sort to sort transform keys by their default order.\n+                 */\n+                function sortTransformProps(a, b) {\n+                    return transformProps.indexOf(a) - transformProps.indexOf(b);\n+                }\n+                /**\n+                 * A quick lookup for transform props.\n+                 */\n+                var transformPropSet = new Set(transformProps);\n+\n+                function isTransformProp(key) {\n+                    return transformPropSet.has(key);\n+                }\n+                /**\n+                 * A quick lookup for transform origin props\n+                 */\n+                var transformOriginProps = new Set([\"originX\", \"originY\", \"originZ\"]);\n+\n+                function isTransformOriginProp(key) {\n+                    return transformOriginProps.has(key);\n+                }\n+\n+                function isForcedMotionValue(key, _a) {\n+                    var layout = _a.layout,\n+                        layoutId = _a.layoutId;\n+                    return isTransformProp(key) || isTransformOriginProp(key) || (layout || layoutId !== undefined) && (!!scaleCorrectors[key] || key === \"opacity\");\n+                }\n+                var isMotionValue = function(value) {\n+                    return Boolean(value !== null && typeof value === \"object\" && value.getVelocity);\n+                };\n+                var translateAlias = {\n+                    x: \"translateX\",\n+                    y: \"translateY\",\n+                    z: \"translateZ\",\n+                    transformPerspective: \"perspective\"\n+                };\n+                /**\n+                 * Build a CSS transform style from individual x/y/scale etc properties.\n+                 *\n+                 * This outputs with a default order of transforms/scales/rotations, this can be customised by\n+                 * providing a transformTemplate function.\n+                 */\n+                function buildTransform(_a, _b, transformIsDefault, transformTemplate) {\n+                    var transform = _a.transform,\n+                        transformKeys = _a.transformKeys;\n+                    var _c = _b.enableHardwareAcceleration,\n+                        enableHardwareAcceleration = _c === void 0 ? true : _c,\n+                        _d = _b.allowTransformNone,\n+                        allowTransformNone = _d === void 0 ? true : _d;\n+                    // The transform string we're going to build into.\n+                    var transformString = \"\";\n+                    // Transform keys into their default order - this will determine the output order.\n+                    transformKeys.sort(sortTransformProps);\n+                    // Track whether the defined transform has a defined z so we don't add a\n+                    // second to enable hardware acceleration\n+                    var transformHasZ = false;\n+                    // Loop over each transform and build them into transformString\n+                    var numTransformKeys = transformKeys.length;\n+                    for (var i = 0; i < numTransformKeys; i++) {\n+                        var key = transformKeys[i];\n+                        transformString += \"\".concat(translateAlias[key] || key, \"(\").concat(transform[key], \") \");\n+                        if (key === \"z\") transformHasZ = true;\n+                    }\n+                    if (!transformHasZ && enableHardwareAcceleration) {\n+                        transformString += \"translateZ(0)\";\n+                    } else {\n+                        transformString = transformString.trim();\n+                    }\n+                    // If we have a custom `transform` template, pass our transform values and\n+                    // generated transformString to that before returning\n+                    if (transformTemplate) {\n+                        transformString = transformTemplate(transform, transformIsDefault ? \"\" : transformString);\n+                    } else if (allowTransformNone && transformIsDefault) {\n+                        transformString = \"none\";\n+                    }\n+                    return transformString;\n+                }\n+                /**\n+                 * Build a transformOrigin style. Uses the same defaults as the browser for\n+                 * undefined origins.\n+                 */\n+                function buildTransformOrigin(_a) {\n+                    var _b = _a.originX,\n+                        originX = _b === void 0 ? \"50%\" : _b,\n+                        _c = _a.originY,\n+                        originY = _c === void 0 ? \"50%\" : _c,\n+                        _d = _a.originZ,\n+                        originZ = _d === void 0 ? 0 : _d;\n+                    return \"\".concat(originX, \" \").concat(originY, \" \").concat(originZ);\n+                }\n+\n+                /**\n+                 * Returns true if the provided key is a CSS variable\n+                 */\n+                function isCSSVariable$1(key) {\n+                    return key.startsWith(\"--\");\n+                }\n+\n+                /**\n+                 * Provided a value and a ValueType, returns the value as that value type.\n+                 */\n+                var getValueAsType = function(value, type) {\n+                    return type && typeof value === \"number\" ? type.transform(value) : value;\n+                };\n+                var int = tslib.__assign(tslib.__assign({}, styleValueTypes.number), {\n+                    transform: Math.round\n+                });\n+                var numberValueTypes = {\n+                    // Border props\n+                    borderWidth: styleValueTypes.px,\n+                    borderTopWidth: styleValueTypes.px,\n+                    borderRightWidth: styleValueTypes.px,\n+                    borderBottomWidth: styleValueTypes.px,\n+                    borderLeftWidth: styleValueTypes.px,\n+                    borderRadius: styleValueTypes.px,\n+                    radius: styleValueTypes.px,\n+                    borderTopLeftRadius: styleValueTypes.px,\n+                    borderTopRightRadius: styleValueTypes.px,\n+                    borderBottomRightRadius: styleValueTypes.px,\n+                    borderBottomLeftRadius: styleValueTypes.px,\n+                    // Positioning props\n+                    width: styleValueTypes.px,\n+                    maxWidth: styleValueTypes.px,\n+                    height: styleValueTypes.px,\n+                    maxHeight: styleValueTypes.px,\n+                    size: styleValueTypes.px,\n+                    top: styleValueTypes.px,\n+                    right: styleValueTypes.px,\n+                    bottom: styleValueTypes.px,\n+                    left: styleValueTypes.px,\n+                    // Spacing props\n+                    padding: styleValueTypes.px,\n+                    paddingTop: styleValueTypes.px,\n+                    paddingRight: styleValueTypes.px,\n+                    paddingBottom: styleValueTypes.px,\n+                    paddingLeft: styleValueTypes.px,\n+                    margin: styleValueTypes.px,\n+                    marginTop: styleValueTypes.px,\n+                    marginRight: styleValueTypes.px,\n+                    marginBottom: styleValueTypes.px,\n+                    marginLeft: styleValueTypes.px,\n+                    // Transform props\n+                    rotate: styleValueTypes.degrees,\n+                    rotateX: styleValueTypes.degrees,\n+                    rotateY: styleValueTypes.degrees,\n+                    rotateZ: styleValueTypes.degrees,\n+                    scale: styleValueTypes.scale,\n+                    scaleX: styleValueTypes.scale,\n+                    scaleY: styleValueTypes.scale,\n+                    scaleZ: styleValueTypes.scale,\n+                    skew: styleValueTypes.degrees,\n+                    skewX: styleValueTypes.degrees,\n+                    skewY: styleValueTypes.degrees,\n+                    distance: styleValueTypes.px,\n+                    translateX: styleValueTypes.px,\n+                    translateY: styleValueTypes.px,\n+                    translateZ: styleValueTypes.px,\n+                    x: styleValueTypes.px,\n+                    y: styleValueTypes.px,\n+                    z: styleValueTypes.px,\n+                    perspective: styleValueTypes.px,\n+                    transformPerspective: styleValueTypes.px,\n+                    opacity: styleValueTypes.alpha,\n+                    originX: styleValueTypes.progressPercentage,\n+                    originY: styleValueTypes.progressPercentage,\n+                    originZ: styleValueTypes.px,\n+                    // Misc\n+                    zIndex: int,\n+                    // SVG\n+                    fillOpacity: styleValueTypes.alpha,\n+                    strokeOpacity: styleValueTypes.alpha,\n+                    numOctaves: int\n+                };\n+\n+                function buildHTMLStyles(state, latestValues, options, transformTemplate) {\n+                    var _a;\n+                    var style = state.style,\n+                        vars = state.vars,\n+                        transform = state.transform,\n+                        transformKeys = state.transformKeys,\n+                        transformOrigin = state.transformOrigin;\n+                    // Empty the transformKeys array. As we're throwing out refs to its items\n+                    // this might not be as cheap as suspected. Maybe using the array as a buffer\n+                    // with a manual incrementation would be better.\n+                    transformKeys.length = 0;\n+                    // Track whether we encounter any transform or transformOrigin values.\n+                    var hasTransform = false;\n+                    var hasTransformOrigin = false;\n+                    // Does the calculated transform essentially equal \"none\"?\n+                    var transformIsNone = true;\n+                    /**\n+                     * Loop over all our latest animated values and decide whether to handle them\n+                     * as a style or CSS variable.\n+                     *\n+                     * Transforms and transform origins are kept seperately for further processing.\n+                     */\n+                    for (var key in latestValues) {\n+                        var value = latestValues[key];\n+                        /**\n+                         * If this is a CSS variable we don't do any further processing.\n+                         */\n+                        if (isCSSVariable$1(key)) {\n+                            vars[key] = value;\n+                            continue;\n+                        }\n+                        // Convert the value to its default value type, ie 0 -> \"0px\"\n+                        var valueType = numberValueTypes[key];\n+                        var valueAsType = getValueAsType(value, valueType);\n+                        if (isTransformProp(key)) {\n+                            // If this is a transform, flag to enable further transform processing\n+                            hasTransform = true;\n+                            transform[key] = valueAsType;\n+                            transformKeys.push(key);\n+                            // If we already know we have a non-default transform, early return\n+                            if (!transformIsNone) continue;\n+                            // Otherwise check to see if this is a default transform\n+                            if (value !== ((_a = valueType.default) !== null && _a !== void 0 ? _a : 0)) transformIsNone = false;\n+                        } else if (isTransformOriginProp(key)) {\n+                            transformOrigin[key] = valueAsType;\n+                            // If this is a transform origin, flag and enable further transform-origin processing\n+                            hasTransformOrigin = true;\n+                        } else {\n+                            style[key] = valueAsType;\n+                        }\n+                    }\n+                    if (hasTransform) {\n+                        style.transform = buildTransform(state, options, transformIsNone, transformTemplate);\n+                    } else if (transformTemplate) {\n+                        style.transform = transformTemplate({}, \"\");\n+                    } else if (!latestValues.transform && style.transform) {\n+                        style.transform = \"none\";\n+                    }\n+                    if (hasTransformOrigin) {\n+                        style.transformOrigin = buildTransformOrigin(transformOrigin);\n+                    }\n+                }\n+                var createHtmlRenderState = function() {\n+                    return {\n+                        style: {},\n+                        transform: {},\n+                        transformKeys: [],\n+                        transformOrigin: {},\n+                        vars: {}\n+                    };\n+                };\n+\n+                function copyRawValuesOnly(target, source, props) {\n+                    for (var key in source) {\n+                        if (!isMotionValue(source[key]) && !isForcedMotionValue(key, props)) {\n+                            target[key] = source[key];\n+                        }\n+                    }\n+                }\n+\n+                function useInitialMotionValues(_a, visualState, isStatic) {\n+                    var transformTemplate = _a.transformTemplate;\n+                    return React.useMemo(function() {\n+                        var state = createHtmlRenderState();\n+                        buildHTMLStyles(state, visualState, {\n+                            enableHardwareAcceleration: !isStatic\n+                        }, transformTemplate);\n+                        var vars = state.vars,\n+                            style = state.style;\n+                        return tslib.__assign(tslib.__assign({}, vars), style);\n+                    }, [visualState]);\n+                }\n+\n+                function useStyle(props, visualState, isStatic) {\n+                    var styleProp = props.style || {};\n+                    var style = {};\n+                    /**\n+                     * Copy non-Motion Values straight into style\n+                     */\n+                    copyRawValuesOnly(style, styleProp, props);\n+                    Object.assign(style, useInitialMotionValues(props, visualState, isStatic));\n+                    if (props.transformValues) {\n+                        style = props.transformValues(style);\n+                    }\n+                    return style;\n+                }\n+\n+                function useHTMLProps(props, visualState, isStatic) {\n+                    // The `any` isn't ideal but it is the type of createElement props argument\n+                    var htmlProps = {};\n+                    var style = useStyle(props, visualState, isStatic);\n+                    if (Boolean(props.drag) && props.dragListener !== false) {\n+                        // Disable the ghost element when a user drags\n+                        htmlProps.draggable = false;\n+                        // Disable text selection\n+                        style.userSelect = style.WebkitUserSelect = style.WebkitTouchCallout = \"none\";\n+                        // Disable scrolling on the draggable direction\n+                        style.touchAction = props.drag === true ? \"none\" : \"pan-\".concat(props.drag === \"x\" ? \"y\" : \"x\");\n+                    }\n+                    htmlProps.style = style;\n+                    return htmlProps;\n+                }\n+\n+                /**\n+                 * A list of all valid MotionProps.\n+                 *\n+                 * @privateRemarks\n+                 * This doesn't throw if a `MotionProp` name is missing - it should.\n+                 */\n+                var validMotionProps = new Set([\"initial\", \"animate\", \"exit\", \"style\", \"variants\", \"transition\", \"transformTemplate\", \"transformValues\", \"custom\", \"inherit\", \"layout\", \"layoutId\", \"layoutDependency\", \"onLayoutAnimationStart\", \"onLayoutAnimationComplete\", \"onLayoutMeasure\", \"onBeforeLayoutMeasure\", \"onAnimationStart\", \"onAnimationComplete\", \"onUpdate\", \"onDragStart\", \"onDrag\", \"onDragEnd\", \"onMeasureDragConstraints\", \"onDirectionLock\", \"onDragTransitionEnd\", \"drag\", \"dragControls\", \"dragListener\", \"dragConstraints\", \"dragDirectionLock\", \"dragSnapToOrigin\", \"_dragX\", \"_dragY\", \"dragElastic\", \"dragMomentum\", \"dragPropagation\", \"dragTransition\", \"whileDrag\", \"onPan\", \"onPanStart\", \"onPanEnd\", \"onPanSessionStart\", \"onTap\", \"onTapStart\", \"onTapCancel\", \"onHoverStart\", \"onHoverEnd\", \"whileFocus\", \"whileTap\", \"whileHover\", \"whileInView\", \"onViewportEnter\", \"onViewportLeave\", \"viewport\", \"layoutScroll\"]);\n+                /**\n+                 * Check whether a prop name is a valid `MotionProp` key.\n+                 *\n+                 * @param key - Name of the property to check\n+                 * @returns `true` is key is a valid `MotionProp`.\n+                 *\n+                 * @public\n+                 */\n+                function isValidMotionProp(key) {\n+                    return validMotionProps.has(key);\n+                }\n+                var shouldForward = function(key) {\n+                    return !isValidMotionProp(key);\n+                };\n+\n+                function loadExternalIsValidProp(isValidProp) {\n+                    if (!isValidProp) return;\n+                    // Explicitly filter our events\n+                    shouldForward = function(key) {\n+                        return key.startsWith(\"on\") ? !isValidMotionProp(key) : isValidProp(key);\n+                    };\n+                }\n+                /**\n+                 * Emotion and Styled Components both allow users to pass through arbitrary props to their components\n+                 * to dynamically generate CSS. They both use the `@emotion/is-prop-valid` package to determine which\n+                 * of these should be passed to the underlying DOM node.\n+                 *\n+                 * However, when styling a Motion component `styled(motion.div)`, both packages pass through *all* props\n+                 * as it's seen as an arbitrary component rather than a DOM node. Motion only allows arbitrary props\n+                 * passed through the `custom` prop so it doesn't *need* the payload or computational overhead of\n+                 * `@emotion/is-prop-valid`, however to fix this problem we need to use it.\n+                 *\n+                 * By making it an optionalDependency we can offer this functionality only in the situations where it's\n+                 * actually required.\n+                 */\n+                try {\n+                    /**\n+                     * We attempt to import this package but require won't be defined in esm environments, in that case\n+                     * isPropValid will have to be provided via `MotionContext`. In a 6.0.0 this should probably be removed\n+                     * in favour of explicit injection.\n+                     */\n+                    loadExternalIsValidProp((__webpack_require__( /*! @emotion/is-prop-valid */ \"../../../node_modules/@emotion/is-prop-valid/dist/is-prop-valid.browser.esm.js\")[\"default\"]));\n+                } catch (_a) {\n+                    // We don't need to actually do anything here - the fallback is the existing `isPropValid`.\n+                }\n+\n+                function filterProps(props, isDom, forwardMotionProps) {\n+                    var filteredProps = {};\n+                    for (var key in props) {\n+                        if (shouldForward(key) || forwardMotionProps === true && isValidMotionProp(key) || !isDom && !isValidMotionProp(key) ||\n+                            // If trying to use native HTML drag events, forward drag listeners\n+                            props[\"draggable\"] && key.startsWith(\"onDrag\")) {\n+                            filteredProps[key] = props[key];\n+                        }\n+                    }\n+                    return filteredProps;\n+                }\n+\n+                function calcOrigin$1(origin, offset, size) {\n+                    return typeof origin === \"string\" ? origin : styleValueTypes.px.transform(offset + size * origin);\n+                }\n+                /**\n+                 * The SVG transform origin defaults are different to CSS and is less intuitive,\n+                 * so we use the measured dimensions of the SVG to reconcile these.\n+                 */\n+                function calcSVGTransformOrigin(dimensions, originX, originY) {\n+                    var pxOriginX = calcOrigin$1(originX, dimensions.x, dimensions.width);\n+                    var pxOriginY = calcOrigin$1(originY, dimensions.y, dimensions.height);\n+                    return \"\".concat(pxOriginX, \" \").concat(pxOriginY);\n+                }\n+                var dashKeys = {\n+                    offset: \"stroke-dashoffset\",\n+                    array: \"stroke-dasharray\"\n+                };\n+                var camelKeys = {\n+                    offset: \"strokeDashoffset\",\n+                    array: \"strokeDasharray\"\n+                };\n+                /**\n+                 * Build SVG path properties. Uses the path's measured length to convert\n+                 * our custom pathLength, pathSpacing and pathOffset into stroke-dashoffset\n+                 * and stroke-dasharray attributes.\n+                 *\n+                 * This function is mutative to reduce per-frame GC.\n+                 */\n+                function buildSVGPath(attrs, length, spacing, offset, useDashCase) {\n+                    if (spacing === void 0) {\n+                        spacing = 1;\n+                    }\n+                    if (offset === void 0) {\n+                        offset = 0;\n+                    }\n+                    if (useDashCase === void 0) {\n+                        useDashCase = true;\n+                    }\n+                    // Normalise path length by setting SVG attribute pathLength to 1\n+                    attrs.pathLength = 1;\n+                    // We use dash case when setting attributes directly to the DOM node and camel case\n+                    // when defining props on a React component.\n+                    var keys = useDashCase ? dashKeys : camelKeys;\n+                    // Build the dash offset\n+                    attrs[keys.offset] = styleValueTypes.px.transform(-offset);\n+                    // Build the dash array\n+                    var pathLength = styleValueTypes.px.transform(length);\n+                    var pathSpacing = styleValueTypes.px.transform(spacing);\n+                    attrs[keys.array] = \"\".concat(pathLength, \" \").concat(pathSpacing);\n+                }\n+\n+                /**\n+                 * Build SVG visual attrbutes, like cx and style.transform\n+                 */\n+                function buildSVGAttrs(state, _a, options, transformTemplate) {\n+                    var attrX = _a.attrX,\n+                        attrY = _a.attrY,\n+                        originX = _a.originX,\n+                        originY = _a.originY,\n+                        pathLength = _a.pathLength,\n+                        _b = _a.pathSpacing,\n+                        pathSpacing = _b === void 0 ? 1 : _b,\n+                        _c = _a.pathOffset,\n+                        pathOffset = _c === void 0 ? 0 : _c,\n+                        // This is object creation, which we try to avoid per-frame.\n+                        latest = tslib.__rest(_a, [\"attrX\", \"attrY\", \"originX\", \"originY\", \"pathLength\", \"pathSpacing\", \"pathOffset\"]);\n+                    buildHTMLStyles(state, latest, options, transformTemplate);\n+                    state.attrs = state.style;\n+                    state.style = {};\n+                    var attrs = state.attrs,\n+                        style = state.style,\n+                        dimensions = state.dimensions;\n+                    /**\n+                     * However, we apply transforms as CSS transforms. So if we detect a transform we take it from attrs\n+                     * and copy it into style.\n+                     */\n+                    if (attrs.transform) {\n+                        if (dimensions) style.transform = attrs.transform;\n+                        delete attrs.transform;\n+                    }\n+                    // Parse transformOrigin\n+                    if (dimensions && (originX !== undefined || originY !== undefined || style.transform)) {\n+                        style.transformOrigin = calcSVGTransformOrigin(dimensions, originX !== undefined ? originX : 0.5, originY !== undefined ? originY : 0.5);\n+                    }\n+                    // Treat x/y not as shortcuts but as actual attributes\n+                    if (attrX !== undefined) attrs.x = attrX;\n+                    if (attrY !== undefined) attrs.y = attrY;\n+                    // Build SVG path if one has been defined\n+                    if (pathLength !== undefined) {\n+                        buildSVGPath(attrs, pathLength, pathSpacing, pathOffset, false);\n+                    }\n+                }\n+                var createSvgRenderState = function() {\n+                    return tslib.__assign(tslib.__assign({}, createHtmlRenderState()), {\n+                        attrs: {}\n+                    });\n+                };\n+\n+                function useSVGProps(props, visualState) {\n+                    var visualProps = React.useMemo(function() {\n+                        var state = createSvgRenderState();\n+                        buildSVGAttrs(state, visualState, {\n+                            enableHardwareAcceleration: false\n+                        }, props.transformTemplate);\n+                        return tslib.__assign(tslib.__assign({}, state.attrs), {\n+                            style: tslib.__assign({}, state.style)\n+                        });\n+                    }, [visualState]);\n+                    if (props.style) {\n+                        var rawStyles = {};\n+                        copyRawValuesOnly(rawStyles, props.style, props);\n+                        visualProps.style = tslib.__assign(tslib.__assign({}, rawStyles), visualProps.style);\n+                    }\n+                    return visualProps;\n+                }\n+\n+                function createUseRender(forwardMotionProps) {\n+                    if (forwardMotionProps === void 0) {\n+                        forwardMotionProps = false;\n+                    }\n+                    var useRender = function(Component, props, projectionId, ref, _a, isStatic) {\n+                        var latestValues = _a.latestValues;\n+                        var useVisualProps = isSVGComponent(Component) ? useSVGProps : useHTMLProps;\n+                        var visualProps = useVisualProps(props, latestValues, isStatic);\n+                        var filteredProps = filterProps(props, typeof Component === \"string\", forwardMotionProps);\n+                        var elementProps = tslib.__assign(tslib.__assign(tslib.__assign({}, filteredProps), visualProps), {\n+                            ref: ref\n+                        });\n+                        if (projectionId) {\n+                            elementProps[\"data-projection-id\"] = projectionId;\n+                        }\n+                        return React.createElement(Component, elementProps);\n+                    };\n+                    return useRender;\n+                }\n+                var CAMEL_CASE_PATTERN = /([a-z])([A-Z])/g;\n+                var REPLACE_TEMPLATE = \"$1-$2\";\n+                /**\n+                 * Convert camelCase to dash-case properties.\n+                 */\n+                var camelToDash = function(str) {\n+                    return str.replace(CAMEL_CASE_PATTERN, REPLACE_TEMPLATE).toLowerCase();\n+                };\n+\n+                function renderHTML(element, _a, styleProp, projection) {\n+                    var style = _a.style,\n+                        vars = _a.vars;\n+                    Object.assign(element.style, style, projection && projection.getProjectionStyles(styleProp));\n+                    // Loop over any CSS variables and assign those.\n+                    for (var key in vars) {\n+                        element.style.setProperty(key, vars[key]);\n+                    }\n+                }\n+\n+                /**\n+                 * A set of attribute names that are always read/written as camel case.\n+                 */\n+                var camelCaseAttributes = new Set([\"baseFrequency\", \"diffuseConstant\", \"kernelMatrix\", \"kernelUnitLength\", \"keySplines\", \"keyTimes\", \"limitingConeAngle\", \"markerHeight\", \"markerWidth\", \"numOctaves\", \"targetX\", \"targetY\", \"surfaceScale\", \"specularConstant\", \"specularExponent\", \"stdDeviation\", \"tableValues\", \"viewBox\", \"gradientTransform\", \"pathLength\"]);\n+\n+                function renderSVG(element, renderState, _styleProp, projection) {\n+                    renderHTML(element, renderState, undefined, projection);\n+                    for (var key in renderState.attrs) {\n+                        element.setAttribute(!camelCaseAttributes.has(key) ? camelToDash(key) : key, renderState.attrs[key]);\n+                    }\n+                }\n+\n+                function scrapeMotionValuesFromProps$1(props) {\n+                    var style = props.style;\n+                    var newValues = {};\n+                    for (var key in style) {\n+                        if (isMotionValue(style[key]) || isForcedMotionValue(key, props)) {\n+                            newValues[key] = style[key];\n+                        }\n+                    }\n+                    return newValues;\n+                }\n+\n+                function scrapeMotionValuesFromProps(props) {\n+                    var newValues = scrapeMotionValuesFromProps$1(props);\n+                    for (var key in props) {\n+                        if (isMotionValue(props[key])) {\n+                            var targetKey = key === \"x\" || key === \"y\" ? \"attr\" + key.toUpperCase() : key;\n+                            newValues[targetKey] = props[key];\n+                        }\n+                    }\n+                    return newValues;\n+                }\n+\n+                function isAnimationControls(v) {\n+                    return typeof v === \"object\" && typeof v.start === \"function\";\n+                }\n+                var isKeyframesTarget = function(v) {\n+                    return Array.isArray(v);\n+                };\n+                var isCustomValue = function(v) {\n+                    return Boolean(v && typeof v === \"object\" && v.mix && v.toValue);\n+                };\n+                var resolveFinalValueInKeyframes = function(v) {\n+                    // TODO maybe throw if v.length - 1 is placeholder token?\n+                    return isKeyframesTarget(v) ? v[v.length - 1] || 0 : v;\n+                };\n+\n+                /**\n+                 * If the provided value is a MotionValue, this returns the actual value, otherwise just the value itself\n+                 *\n+                 * TODO: Remove and move to library\n+                 */\n+                function resolveMotionValue(value) {\n+                    var unwrappedValue = isMotionValue(value) ? value.get() : value;\n+                    return isCustomValue(unwrappedValue) ? unwrappedValue.toValue() : unwrappedValue;\n+                }\n+\n+                function makeState(_a, props, context, presenceContext) {\n+                    var scrapeMotionValuesFromProps = _a.scrapeMotionValuesFromProps,\n+                        createRenderState = _a.createRenderState,\n+                        onMount = _a.onMount;\n+                    var state = {\n+                        latestValues: makeLatestValues(props, context, presenceContext, scrapeMotionValuesFromProps),\n+                        renderState: createRenderState()\n+                    };\n+                    if (onMount) {\n+                        state.mount = function(instance) {\n+                            return onMount(props, instance, state);\n+                        };\n+                    }\n+                    return state;\n+                }\n+                var makeUseVisualState = function(config) {\n+                    return function(props, isStatic) {\n+                        var context = React.useContext(MotionContext);\n+                        var presenceContext = React.useContext(PresenceContext);\n+                        return isStatic ? makeState(config, props, context, presenceContext) : useConstant(function() {\n+                            return makeState(config, props, context, presenceContext);\n+                        });\n+                    };\n+                };\n+\n+                function makeLatestValues(props, context, presenceContext, scrapeMotionValues) {\n+                    var values = {};\n+                    var blockInitialAnimation = (presenceContext === null || presenceContext === void 0 ? void 0 : presenceContext.initial) === false;\n+                    var motionValues = scrapeMotionValues(props);\n+                    for (var key in motionValues) {\n+                        values[key] = resolveMotionValue(motionValues[key]);\n+                    }\n+                    var initial = props.initial,\n+                        animate = props.animate;\n+                    var isControllingVariants = checkIfControllingVariants(props);\n+                    var isVariantNode = checkIfVariantNode(props);\n+                    if (context && isVariantNode && !isControllingVariants && props.inherit !== false) {\n+                        initial !== null && initial !== void 0 ? initial : initial = context.initial;\n+                        animate !== null && animate !== void 0 ? animate : animate = context.animate;\n+                    }\n+                    var initialAnimationIsBlocked = blockInitialAnimation || initial === false;\n+                    var variantToSet = initialAnimationIsBlocked ? animate : initial;\n+                    if (variantToSet && typeof variantToSet !== \"boolean\" && !isAnimationControls(variantToSet)) {\n+                        var list = Array.isArray(variantToSet) ? variantToSet : [variantToSet];\n+                        list.forEach(function(definition) {\n+                            var resolved = resolveVariantFromProps(props, definition);\n+                            if (!resolved) return;\n+                            var transitionEnd = resolved.transitionEnd;\n+                            resolved.transition;\n+                            var target = tslib.__rest(resolved, [\"transitionEnd\", \"transition\"]);\n+                            for (var key in target) {\n+                                var valueTarget = target[key];\n+                                if (Array.isArray(valueTarget)) {\n+                                    /**\n+                                     * Take final keyframe if the initial animation is blocked because\n+                                     * we want to initialise at the end of that blocked animation.\n+                                     */\n+                                    var index = initialAnimationIsBlocked ? valueTarget.length - 1 : 0;\n+                                    valueTarget = valueTarget[index];\n+                                }\n+                                if (valueTarget !== null) {\n+                                    values[key] = valueTarget;\n+                                }\n+                            }\n+                            for (var key in transitionEnd) values[key] = transitionEnd[key];\n+                        });\n+                    }\n+                    return values;\n+                }\n+                var svgMotionConfig = {\n+                    useVisualState: makeUseVisualState({\n+                        scrapeMotionValuesFromProps: scrapeMotionValuesFromProps,\n+                        createRenderState: createSvgRenderState,\n+                        onMount: function(props, instance, _a) {\n+                            var renderState = _a.renderState,\n+                                latestValues = _a.latestValues;\n+                            try {\n+                                renderState.dimensions = typeof instance.getBBox === \"function\" ? instance.getBBox() : instance.getBoundingClientRect();\n+                            } catch (e) {\n+                                // Most likely trying to measure an unrendered element under Firefox\n+                                renderState.dimensions = {\n+                                    x: 0,\n+                                    y: 0,\n+                                    width: 0,\n+                                    height: 0\n+                                };\n+                            }\n+                            buildSVGAttrs(renderState, latestValues, {\n+                                enableHardwareAcceleration: false\n+                            }, props.transformTemplate);\n+                            renderSVG(instance, renderState);\n+                        }\n+                    })\n+                };\n+                var htmlMotionConfig = {\n+                    useVisualState: makeUseVisualState({\n+                        scrapeMotionValuesFromProps: scrapeMotionValuesFromProps$1,\n+                        createRenderState: createHtmlRenderState\n+                    })\n+                };\n+\n+                function createDomMotionConfig(Component, _a, preloadedFeatures, createVisualElement, projectionNodeConstructor) {\n+                    var _b = _a.forwardMotionProps,\n+                        forwardMotionProps = _b === void 0 ? false : _b;\n+                    var baseConfig = isSVGComponent(Component) ? svgMotionConfig : htmlMotionConfig;\n+                    return tslib.__assign(tslib.__assign({}, baseConfig), {\n+                        preloadedFeatures: preloadedFeatures,\n+                        useRender: createUseRender(forwardMotionProps),\n+                        createVisualElement: createVisualElement,\n+                        projectionNodeConstructor: projectionNodeConstructor,\n+                        Component: Component\n+                    });\n+                }\n+                exports.AnimationType = void 0;\n+                (function(AnimationType) {\n+                    AnimationType[\"Animate\"] = \"animate\";\n+                    AnimationType[\"Hover\"] = \"whileHover\";\n+                    AnimationType[\"Tap\"] = \"whileTap\";\n+                    AnimationType[\"Drag\"] = \"whileDrag\";\n+                    AnimationType[\"Focus\"] = \"whileFocus\";\n+                    AnimationType[\"InView\"] = \"whileInView\";\n+                    AnimationType[\"Exit\"] = \"exit\";\n+                })(exports.AnimationType || (exports.AnimationType = {}));\n+\n+                function addDomEvent(target, eventName, handler, options) {\n+                    if (options === void 0) {\n+                        options = {\n+                            passive: true\n+                        };\n+                    }\n+                    target.addEventListener(eventName, handler, options);\n+                    return function() {\n+                        return target.removeEventListener(eventName, handler);\n+                    };\n+                }\n+                /**\n+                 * Attaches an event listener directly to the provided DOM element.\n+                 *\n+                 * Bypassing React's event system can be desirable, for instance when attaching non-passive\n+                 * event handlers.\n+                 *\n+                 * ```jsx\n+                 * const ref = useRef(null)\n+                 *\n+                 * useDomEvent(ref, 'wheel', onWheel, { passive: false })\n+                 *\n+                 * return <div ref={ref} />\n+                 * ```\n+                 *\n+                 * @param ref - React.RefObject that's been provided to the element you want to bind the listener to.\n+                 * @param eventName - Name of the event you want listen for.\n+                 * @param handler - Function to fire when receiving the event.\n+                 * @param options - Options to pass to `Event.addEventListener`.\n+                 *\n+                 * @public\n+                 */\n+                function useDomEvent(ref, eventName, handler, options) {\n+                    React.useEffect(function() {\n+                        var element = ref.current;\n+                        if (handler && element) {\n+                            return addDomEvent(element, eventName, handler, options);\n+                        }\n+                    }, [ref, eventName, handler, options]);\n+                }\n+\n+                /**\n+                 *\n+                 * @param props\n+                 * @param ref\n+                 * @internal\n+                 */\n+                function useFocusGesture(_a) {\n+                    var whileFocus = _a.whileFocus,\n+                        visualElement = _a.visualElement;\n+                    var onFocus = function() {\n+                        var _a;\n+                        (_a = visualElement.animationState) === null || _a === void 0 ? void 0 : _a.setActive(exports.AnimationType.Focus, true);\n+                    };\n+                    var onBlur = function() {\n+                        var _a;\n+                        (_a = visualElement.animationState) === null || _a === void 0 ? void 0 : _a.setActive(exports.AnimationType.Focus, false);\n+                    };\n+                    useDomEvent(visualElement, \"focus\", whileFocus ? onFocus : undefined);\n+                    useDomEvent(visualElement, \"blur\", whileFocus ? onBlur : undefined);\n+                }\n+\n+                function isMouseEvent(event) {\n+                    // PointerEvent inherits from MouseEvent so we can't use a straight instanceof check.\n+                    if (typeof PointerEvent !== \"undefined\" && event instanceof PointerEvent) {\n+                        return !!(event.pointerType === \"mouse\");\n+                    }\n+                    return event instanceof MouseEvent;\n+                }\n+\n+                function isTouchEvent(event) {\n+                    var hasTouches = !!event.touches;\n+                    return hasTouches;\n+                }\n+\n+                /**\n+                 * Filters out events not attached to the primary pointer (currently left mouse button)\n+                 * @param eventHandler\n+                 */\n+                function filterPrimaryPointer(eventHandler) {\n+                    return function(event) {\n+                        var isMouseEvent = event instanceof MouseEvent;\n+                        var isPrimaryPointer = !isMouseEvent || isMouseEvent && event.button === 0;\n+                        if (isPrimaryPointer) {\n+                            eventHandler(event);\n+                        }\n+                    };\n+                }\n+                var defaultPagePoint = {\n+                    pageX: 0,\n+                    pageY: 0\n+                };\n+\n+                function pointFromTouch(e, pointType) {\n+                    if (pointType === void 0) {\n+                        pointType = \"page\";\n+                    }\n+                    var primaryTouch = e.touches[0] || e.changedTouches[0];\n+                    var point = primaryTouch || defaultPagePoint;\n+                    return {\n+                        x: point[pointType + \"X\"],\n+                        y: point[pointType + \"Y\"]\n+                    };\n+                }\n+\n+                function pointFromMouse(point, pointType) {\n+                    if (pointType === void 0) {\n+                        pointType = \"page\";\n+                    }\n+                    return {\n+                        x: point[pointType + \"X\"],\n+                        y: point[pointType + \"Y\"]\n+                    };\n+                }\n+\n+                function extractEventInfo(event, pointType) {\n+                    if (pointType === void 0) {\n+                        pointType = \"page\";\n+                    }\n+                    return {\n+                        point: isTouchEvent(event) ? pointFromTouch(event, pointType) : pointFromMouse(event, pointType)\n+                    };\n+                }\n+                var wrapHandler = function(handler, shouldFilterPrimaryPointer) {\n+                    if (shouldFilterPrimaryPointer === void 0) {\n+                        shouldFilterPrimaryPointer = false;\n+                    }\n+                    var listener = function(event) {\n+                        return handler(event, extractEventInfo(event));\n+                    };\n+                    return shouldFilterPrimaryPointer ? filterPrimaryPointer(listener) : listener;\n+                };\n+\n+                // We check for event support via functions in case they've been mocked by a testing suite.\n+                var supportsPointerEvents = function() {\n+                    return isBrowser && window.onpointerdown === null;\n+                };\n+                var supportsTouchEvents = function() {\n+                    return isBrowser && window.ontouchstart === null;\n+                };\n+                var supportsMouseEvents = function() {\n+                    return isBrowser && window.onmousedown === null;\n+                };\n+                var mouseEventNames = {\n+                    pointerdown: \"mousedown\",\n+                    pointermove: \"mousemove\",\n+                    pointerup: \"mouseup\",\n+                    pointercancel: \"mousecancel\",\n+                    pointerover: \"mouseover\",\n+                    pointerout: \"mouseout\",\n+                    pointerenter: \"mouseenter\",\n+                    pointerleave: \"mouseleave\"\n+                };\n+                var touchEventNames = {\n+                    pointerdown: \"touchstart\",\n+                    pointermove: \"touchmove\",\n+                    pointerup: \"touchend\",\n+                    pointercancel: \"touchcancel\"\n+                };\n+\n+                function getPointerEventName(name) {\n+                    if (supportsPointerEvents()) {\n+                        return name;\n+                    } else if (supportsTouchEvents()) {\n+                        return touchEventNames[name];\n+                    } else if (supportsMouseEvents()) {\n+                        return mouseEventNames[name];\n+                    }\n+                    return name;\n+                }\n+\n+                function addPointerEvent(target, eventName, handler, options) {\n+                    return addDomEvent(target, getPointerEventName(eventName), wrapHandler(handler, eventName === \"pointerdown\"), options);\n+                }\n+\n+                function usePointerEvent(ref, eventName, handler, options) {\n+                    return useDomEvent(ref, getPointerEventName(eventName), handler && wrapHandler(handler, eventName === \"pointerdown\"), options);\n+                }\n+\n+                function createLock(name) {\n+                    var lock = null;\n+                    return function() {\n+                        var openLock = function() {\n+                            lock = null;\n+                        };\n+                        if (lock === null) {\n+                            lock = name;\n+                            return openLock;\n+                        }\n+                        return false;\n+                    };\n+                }\n+                var globalHorizontalLock = createLock(\"dragHorizontal\");\n+                var globalVerticalLock = createLock(\"dragVertical\");\n+\n+                function getGlobalLock(drag) {\n+                    var lock = false;\n+                    if (drag === \"y\") {\n+                        lock = globalVerticalLock();\n+                    } else if (drag === \"x\") {\n+                        lock = globalHorizontalLock();\n+                    } else {\n+                        var openHorizontal_1 = globalHorizontalLock();\n+                        var openVertical_1 = globalVerticalLock();\n+                        if (openHorizontal_1 && openVertical_1) {\n+                            lock = function() {\n+                                openHorizontal_1();\n+                                openVertical_1();\n+                            };\n+                        } else {\n+                            // Release the locks because we don't use them\n+                            if (openHorizontal_1) openHorizontal_1();\n+                            if (openVertical_1) openVertical_1();\n+                        }\n+                    }\n+                    return lock;\n+                }\n+\n+                function isDragActive() {\n+                    // Check the gesture lock - if we get it, it means no drag gesture is active\n+                    // and we can safely fire the tap gesture.\n+                    var openGestureLock = getGlobalLock(true);\n+                    if (!openGestureLock) return true;\n+                    openGestureLock();\n+                    return false;\n+                }\n+\n+                function createHoverEvent(visualElement, isActive, callback) {\n+                    return function(event, info) {\n+                        var _a;\n+                        if (!isMouseEvent(event) || isDragActive()) return;\n+                        /**\n+                         * Ensure we trigger animations before firing event callback\n+                         */\n+                        (_a = visualElement.animationState) === null || _a === void 0 ? void 0 : _a.setActive(exports.AnimationType.Hover, isActive);\n+                        callback === null || callback === void 0 ? void 0 : callback(event, info);\n+                    };\n+                }\n+\n+                function useHoverGesture(_a) {\n+                    var onHoverStart = _a.onHoverStart,\n+                        onHoverEnd = _a.onHoverEnd,\n+                        whileHover = _a.whileHover,\n+                        visualElement = _a.visualElement;\n+                    usePointerEvent(visualElement, \"pointerenter\", onHoverStart || whileHover ? createHoverEvent(visualElement, true, onHoverStart) : undefined, {\n+                        passive: !onHoverStart\n+                    });\n+                    usePointerEvent(visualElement, \"pointerleave\", onHoverEnd || whileHover ? createHoverEvent(visualElement, false, onHoverEnd) : undefined, {\n+                        passive: !onHoverEnd\n+                    });\n+                }\n+\n+                /**\n+                 * Recursively traverse up the tree to check whether the provided child node\n+                 * is the parent or a descendant of it.\n+                 *\n+                 * @param parent - Element to find\n+                 * @param child - Element to test against parent\n+                 */\n+                var isNodeOrChild = function(parent, child) {\n+                    if (!child) {\n+                        return false;\n+                    } else if (parent === child) {\n+                        return true;\n+                    } else {\n+                        return isNodeOrChild(parent, child.parentElement);\n+                    }\n+                };\n+\n+                function useUnmountEffect(callback) {\n+                    return React.useEffect(function() {\n+                        return function() {\n+                            return callback();\n+                        };\n+                    }, []);\n+                }\n+\n+                /**\n+                 * @param handlers -\n+                 * @internal\n+                 */\n+                function useTapGesture(_a) {\n+                    var onTap = _a.onTap,\n+                        onTapStart = _a.onTapStart,\n+                        onTapCancel = _a.onTapCancel,\n+                        whileTap = _a.whileTap,\n+                        visualElement = _a.visualElement;\n+                    var hasPressListeners = onTap || onTapStart || onTapCancel || whileTap;\n+                    var isPressing = React.useRef(false);\n+                    var cancelPointerEndListeners = React.useRef(null);\n+                    /**\n+                     * Only set listener to passive if there are no external listeners.\n+                     */\n+                    var eventOptions = {\n+                        passive: !(onTapStart || onTap || onTapCancel || onPointerDown)\n+                    };\n+\n+                    function removePointerEndListener() {\n+                        var _a;\n+                        (_a = cancelPointerEndListeners.current) === null || _a === void 0 ? void 0 : _a.call(cancelPointerEndListeners);\n+                        cancelPointerEndListeners.current = null;\n+                    }\n+\n+                    function checkPointerEnd() {\n+                        var _a;\n+                        removePointerEndListener();\n+                        isPressing.current = false;\n+                        (_a = visualElement.animationState) === null || _a === void 0 ? void 0 : _a.setActive(exports.AnimationType.Tap, false);\n+                        return !isDragActive();\n+                    }\n+\n+                    function onPointerUp(event, info) {\n+                        if (!checkPointerEnd()) return;\n+                        /**\n+                         * We only count this as a tap gesture if the event.target is the same\n+                         * as, or a child of, this component's element\n+                         */\n+                        !isNodeOrChild(visualElement.getInstance(), event.target) ? onTapCancel === null || onTapCancel === void 0 ? void 0 : onTapCancel(event, info) : onTap === null || onTap === void 0 ? void 0 : onTap(event, info);\n+                    }\n+\n+                    function onPointerCancel(event, info) {\n+                        if (!checkPointerEnd()) return;\n+                        onTapCancel === null || onTapCancel === void 0 ? void 0 : onTapCancel(event, info);\n+                    }\n+\n+                    function onPointerDown(event, info) {\n+                        var _a;\n+                        removePointerEndListener();\n+                        if (isPressing.current) return;\n+                        isPressing.current = true;\n+                        cancelPointerEndListeners.current = popmotion.pipe(addPointerEvent(window, \"pointerup\", onPointerUp, eventOptions), addPointerEvent(window, \"pointercancel\", onPointerCancel, eventOptions));\n+                        /**\n+                         * Ensure we trigger animations before firing event callback\n+                         */\n+                        (_a = visualElement.animationState) === null || _a === void 0 ? void 0 : _a.setActive(exports.AnimationType.Tap, true);\n+                        onTapStart === null || onTapStart === void 0 ? void 0 : onTapStart(event, info);\n+                    }\n+                    usePointerEvent(visualElement, \"pointerdown\", hasPressListeners ? onPointerDown : undefined, eventOptions);\n+                    useUnmountEffect(removePointerEndListener);\n+                }\n+                var warned = new Set();\n+\n+                function warnOnce(condition, message, element) {\n+                    if (condition || warned.has(message)) return;\n+                    console.warn(message);\n+                    if (element) console.warn(element);\n+                    warned.add(message);\n+                }\n+\n+                /**\n+                 * Map an IntersectionHandler callback to an element. We only ever make one handler for one\n+                 * element, so even though these handlers might all be triggered by different\n+                 * observers, we can keep them in the same map.\n+                 */\n+                var observerCallbacks = new WeakMap();\n+                /**\n+                 * Multiple observers can be created for multiple element/document roots. Each with\n+                 * different settings. So here we store dictionaries of observers to each root,\n+                 * using serialised settings (threshold/margin) as lookup keys.\n+                 */\n+                var observers = new WeakMap();\n+                var fireObserverCallback = function(entry) {\n+                    var _a;\n+                    (_a = observerCallbacks.get(entry.target)) === null || _a === void 0 ? void 0 : _a(entry);\n+                };\n+                var fireAllObserverCallbacks = function(entries) {\n+                    entries.forEach(fireObserverCallback);\n+                };\n+\n+                function initIntersectionObserver(_a) {\n+                    var root = _a.root,\n+                        options = tslib.__rest(_a, [\"root\"]);\n+                    var lookupRoot = root || document;\n+                    /**\n+                     * If we don't have an observer lookup map for this root, create one.\n+                     */\n+                    if (!observers.has(lookupRoot)) {\n+                        observers.set(lookupRoot, {});\n+                    }\n+                    var rootObservers = observers.get(lookupRoot);\n+                    var key = JSON.stringify(options);\n+                    /**\n+                     * If we don't have an observer for this combination of root and settings,\n+                     * create one.\n+                     */\n+                    if (!rootObservers[key]) {\n+                        rootObservers[key] = new IntersectionObserver(fireAllObserverCallbacks, tslib.__assign({\n+                            root: root\n+                        }, options));\n+                    }\n+                    return rootObservers[key];\n+                }\n+\n+                function observeIntersection(element, options, callback) {\n+                    var rootInteresectionObserver = initIntersectionObserver(options);\n+                    observerCallbacks.set(element, callback);\n+                    rootInteresectionObserver.observe(element);\n+                    return function() {\n+                        observerCallbacks.delete(element);\n+                        rootInteresectionObserver.unobserve(element);\n+                    };\n+                }\n+\n+                function useViewport(_a) {\n+                    var visualElement = _a.visualElement,\n+                        whileInView = _a.whileInView,\n+                        onViewportEnter = _a.onViewportEnter,\n+                        onViewportLeave = _a.onViewportLeave,\n+                        _b = _a.viewport,\n+                        viewport = _b === void 0 ? {} : _b;\n+                    var state = React.useRef({\n+                        hasEnteredView: false,\n+                        isInView: false\n+                    });\n+                    var shouldObserve = Boolean(whileInView || onViewportEnter || onViewportLeave);\n+                    if (viewport.once && state.current.hasEnteredView) shouldObserve = false;\n+                    var useObserver = typeof IntersectionObserver === \"undefined\" ? useMissingIntersectionObserver : useIntersectionObserver;\n+                    useObserver(shouldObserve, state.current, visualElement, viewport);\n+                }\n+                var thresholdNames = {\n+                    some: 0,\n+                    all: 1\n+                };\n+\n+                function useIntersectionObserver(shouldObserve, state, visualElement, _a) {\n+                    var root = _a.root,\n+                        rootMargin = _a.margin,\n+                        _b = _a.amount,\n+                        amount = _b === void 0 ? \"some\" : _b,\n+                        once = _a.once;\n+                    React.useEffect(function() {\n+                        if (!shouldObserve) return;\n+                        var options = {\n+                            root: root === null || root === void 0 ? void 0 : root.current,\n+                            rootMargin: rootMargin,\n+                            threshold: typeof amount === \"number\" ? amount : thresholdNames[amount]\n+                        };\n+                        var intersectionCallback = function(entry) {\n+                            var _a;\n+                            var isIntersecting = entry.isIntersecting;\n+                            /**\n+                             * If there's been no change in the viewport state, early return.\n+                             */\n+                            if (state.isInView === isIntersecting) return;\n+                            state.isInView = isIntersecting;\n+                            /**\n+                             * Handle hasEnteredView. If this is only meant to run once, and\n+                             * element isn't visible, early return. Otherwise set hasEnteredView to true.\n+                             */\n+                            if (once && !isIntersecting && state.hasEnteredView) {\n+                                return;\n+                            } else if (isIntersecting) {\n+                                state.hasEnteredView = true;\n+                            }\n+                            (_a = visualElement.animationState) === null || _a === void 0 ? void 0 : _a.setActive(exports.AnimationType.InView, isIntersecting);\n+                            /**\n+                             * Use the latest committed props rather than the ones in scope\n+                             * when this observer is created\n+                             */\n+                            var props = visualElement.getProps();\n+                            var callback = isIntersecting ? props.onViewportEnter : props.onViewportLeave;\n+                            callback === null || callback === void 0 ? void 0 : callback(entry);\n+                        };\n+                        return observeIntersection(visualElement.getInstance(), options, intersectionCallback);\n+                    }, [shouldObserve, root, rootMargin, amount]);\n+                }\n+                /**\n+                 * If IntersectionObserver is missing, we activate inView and fire onViewportEnter\n+                 * on mount. This way, the page will be in the state the author expects users\n+                 * to see it in for everyone.\n+                 */\n+                function useMissingIntersectionObserver(shouldObserve, state, visualElement, _a) {\n+                    var _b = _a.fallback,\n+                        fallback = _b === void 0 ? true : _b;\n+                    React.useEffect(function() {\n+                        if (!shouldObserve || !fallback) return;\n+                        if (env !== \"production\") {\n+                            warnOnce(false, \"IntersectionObserver not available on this device. whileInView animations will trigger on mount.\");\n+                        }\n+                        /**\n+                         * Fire this in an rAF because, at this point, the animation state\n+                         * won't have flushed for the first time and there's certain logic in\n+                         * there that behaves differently on the initial animation.\n+                         *\n+                         * This hook should be quite rarely called so setting this in an rAF\n+                         * is preferred to changing the behaviour of the animation state.\n+                         */\n+                        requestAnimationFrame(function() {\n+                            var _a;\n+                            state.hasEnteredView = true;\n+                            var onViewportEnter = visualElement.getProps().onViewportEnter;\n+                            onViewportEnter === null || onViewportEnter === void 0 ? void 0 : onViewportEnter(null);\n+                            (_a = visualElement.animationState) === null || _a === void 0 ? void 0 : _a.setActive(exports.AnimationType.InView, true);\n+                        });\n+                    }, [shouldObserve]);\n+                }\n+                var makeRenderlessComponent = function(hook) {\n+                    return function(props) {\n+                        hook(props);\n+                        return null;\n+                    };\n+                };\n+                var gestureAnimations = {\n+                    inView: makeRenderlessComponent(useViewport),\n+                    tap: makeRenderlessComponent(useTapGesture),\n+                    focus: makeRenderlessComponent(useFocusGesture),\n+                    hover: makeRenderlessComponent(useHoverGesture)\n+                };\n+                var counter = 0;\n+                var incrementId = function() {\n+                    return counter++;\n+                };\n+                var useId = function() {\n+                    return useConstant(incrementId);\n+                };\n+                /**\n+                 * Ideally we'd use the following code to support React 18 optionally.\n+                 * But this fairly fails in Webpack (otherwise treeshaking wouldn't work at all).\n+                 * Need to come up with a different way of figuring this out.\n+                 */\n+                // export const useId = (React as any).useId\n+                //     ? (React as any).useId\n+                //     : () => useConstant(incrementId)\n+\n+                /**\n+                 * When a component is the child of `AnimatePresence`, it can use `usePresence`\n+                 * to access information about whether it's still present in the React tree.\n+                 *\n+                 * ```jsx\n+                 * import { usePresence } from \"framer-motion\"\n+                 *\n+                 * export const Component = () => {\n+                 *   const [isPresent, safeToRemove] = usePresence()\n+                 *\n+                 *   useEffect(() => {\n+                 *     !isPresent && setTimeout(safeToRemove, 1000)\n+                 *   }, [isPresent])\n+                 *\n+                 *   return <div />\n+                 * }\n+                 * ```\n+                 *\n+                 * If `isPresent` is `false`, it means that a component has been removed the tree, but\n+                 * `AnimatePresence` won't really remove it until `safeToRemove` has been called.\n+                 *\n+                 * @public\n+                 */\n+                function usePresence() {\n+                    var context = React.useContext(PresenceContext);\n+                    if (context === null) return [true, null];\n+                    var isPresent = context.isPresent,\n+                        onExitComplete = context.onExitComplete,\n+                        register = context.register;\n+                    // It's safe to call the following hooks conditionally (after an early return) because the context will always\n+                    // either be null or non-null for the lifespan of the component.\n+                    // Replace with useId when released in React\n+                    var id = useId();\n+                    React.useEffect(function() {\n+                        return register(id);\n+                    }, []);\n+                    var safeToRemove = function() {\n+                        return onExitComplete === null || onExitComplete === void 0 ? void 0 : onExitComplete(id);\n+                    };\n+                    return !isPresent && onExitComplete ? [false, safeToRemove] : [true];\n+                }\n+                /**\n+                 * Similar to `usePresence`, except `useIsPresent` simply returns whether or not the component is present.\n+                 * There is no `safeToRemove` function.\n+                 *\n+                 * ```jsx\n+                 * import { useIsPresent } from \"framer-motion\"\n+                 *\n+                 * export const Component = () => {\n+                 *   const isPresent = useIsPresent()\n+                 *\n+                 *   useEffect(() => {\n+                 *     !isPresent && console.log(\"I've been removed!\")\n+                 *   }, [isPresent])\n+                 *\n+                 *   return <div />\n+                 * }\n+                 * ```\n+                 *\n+                 * @public\n+                 */\n+                function useIsPresent() {\n+                    return isPresent(React.useContext(PresenceContext));\n+                }\n+\n+                function isPresent(context) {\n+                    return context === null ? true : context.isPresent;\n+                }\n+\n+                function shallowCompare(next, prev) {\n+                    if (!Array.isArray(prev)) return false;\n+                    var prevLength = prev.length;\n+                    if (prevLength !== next.length) return false;\n+                    for (var i = 0; i < prevLength; i++) {\n+                        if (prev[i] !== next[i]) return false;\n+                    }\n+                    return true;\n+                }\n+\n+                /**\n+                 * Converts seconds to milliseconds\n+                 *\n+                 * @param seconds - Time in seconds.\n+                 * @return milliseconds - Converted time in milliseconds.\n+                 */\n+                var secondsToMilliseconds = function(seconds) {\n+                    return seconds * 1000;\n+                };\n+                var easingLookup = {\n+                    linear: popmotion.linear,\n+                    easeIn: popmotion.easeIn,\n+                    easeInOut: popmotion.easeInOut,\n+                    easeOut: popmotion.easeOut,\n+                    circIn: popmotion.circIn,\n+                    circInOut: popmotion.circInOut,\n+                    circOut: popmotion.circOut,\n+                    backIn: popmotion.backIn,\n+                    backInOut: popmotion.backInOut,\n+                    backOut: popmotion.backOut,\n+                    anticipate: popmotion.anticipate,\n+                    bounceIn: popmotion.bounceIn,\n+                    bounceInOut: popmotion.bounceInOut,\n+                    bounceOut: popmotion.bounceOut\n+                };\n+                var easingDefinitionToFunction = function(definition) {\n+                    if (Array.isArray(definition)) {\n+                        // If cubic bezier definition, create bezier curve\n+                        heyListen.invariant(definition.length === 4, \"Cubic bezier arrays must contain four numerical values.\");\n+                        var _a = tslib.__read(definition, 4),\n+                            x1 = _a[0],\n+                            y1 = _a[1],\n+                            x2 = _a[2],\n+                            y2 = _a[3];\n+                        return popmotion.cubicBezier(x1, y1, x2, y2);\n+                    } else if (typeof definition === \"string\") {\n+                        // Else lookup from table\n+                        heyListen.invariant(easingLookup[definition] !== undefined, \"Invalid easing type '\".concat(definition, \"'\"));\n+                        return easingLookup[definition];\n+                    }\n+                    return definition;\n+                };\n+                var isEasingArray = function(ease) {\n+                    return Array.isArray(ease) && typeof ease[0] !== \"number\";\n+                };\n+\n+                /**\n+                 * Check if a value is animatable. Examples:\n+                 *\n+                 * \u2705: 100, \"100px\", \"#fff\"\n+                 * \u274c: \"block\", \"url(2.jpg)\"\n+                 * @param value\n+                 *\n+                 * @internal\n+                 */\n+                var isAnimatable = function(key, value) {\n+                    // If the list of keys tat might be non-animatable grows, replace with Set\n+                    if (key === \"zIndex\") return false;\n+                    // If it's a number or a keyframes array, we can animate it. We might at some point\n+                    // need to do a deep isAnimatable check of keyframes, or let Popmotion handle this,\n+                    // but for now lets leave it like this for performance reasons\n+                    if (typeof value === \"number\" || Array.isArray(value)) return true;\n+                    if (typeof value === \"string\" &&\n+                        // It's animatable if we have a string\n+                        styleValueTypes.complex.test(value) &&\n+                        // And it contains numbers and/or colors\n+                        !value.startsWith(\"url(\") // Unless it starts with \"url(\"\n+                    ) {\n+                        return true;\n+                    }\n+                    return false;\n+                };\n+                var underDampedSpring = function() {\n+                    return {\n+                        type: \"spring\",\n+                        stiffness: 500,\n+                        damping: 25,\n+                        restSpeed: 10\n+                    };\n+                };\n+                var criticallyDampedSpring = function(to) {\n+                    return {\n+                        type: \"spring\",\n+                        stiffness: 550,\n+                        damping: to === 0 ? 2 * Math.sqrt(550) : 30,\n+                        restSpeed: 10\n+                    };\n+                };\n+                var linearTween = function() {\n+                    return {\n+                        type: \"keyframes\",\n+                        ease: \"linear\",\n+                        duration: 0.3\n+                    };\n+                };\n+                var keyframes = function(values) {\n+                    return {\n+                        type: \"keyframes\",\n+                        duration: 0.8,\n+                        values: values\n+                    };\n+                };\n+                var defaultTransitions = {\n+                    x: underDampedSpring,\n+                    y: underDampedSpring,\n+                    z: underDampedSpring,\n+                    rotate: underDampedSpring,\n+                    rotateX: underDampedSpring,\n+                    rotateY: underDampedSpring,\n+                    rotateZ: underDampedSpring,\n+                    scaleX: criticallyDampedSpring,\n+                    scaleY: criticallyDampedSpring,\n+                    scale: criticallyDampedSpring,\n+                    opacity: linearTween,\n+                    backgroundColor: linearTween,\n+                    color: linearTween,\n+                    default: criticallyDampedSpring\n+                };\n+                var getDefaultTransition = function(valueKey, to) {\n+                    var transitionFactory;\n+                    if (isKeyframesTarget(to)) {\n+                        transitionFactory = keyframes;\n+                    } else {\n+                        transitionFactory = defaultTransitions[valueKey] || defaultTransitions.default;\n+                    }\n+                    return tslib.__assign({\n+                        to: to\n+                    }, transitionFactory(to));\n+                };\n+\n+                /**\n+                 * A map of default value types for common values\n+                 */\n+                var defaultValueTypes = tslib.__assign(tslib.__assign({}, numberValueTypes), {\n+                    // Color props\n+                    color: styleValueTypes.color,\n+                    backgroundColor: styleValueTypes.color,\n+                    outlineColor: styleValueTypes.color,\n+                    fill: styleValueTypes.color,\n+                    stroke: styleValueTypes.color,\n+                    // Border props\n+                    borderColor: styleValueTypes.color,\n+                    borderTopColor: styleValueTypes.color,\n+                    borderRightColor: styleValueTypes.color,\n+                    borderBottomColor: styleValueTypes.color,\n+                    borderLeftColor: styleValueTypes.color,\n+                    filter: styleValueTypes.filter,\n+                    WebkitFilter: styleValueTypes.filter\n+                });\n+                /**\n+                 * Gets the default ValueType for the provided value key\n+                 */\n+                var getDefaultValueType = function(key) {\n+                    return defaultValueTypes[key];\n+                };\n+\n+                function getAnimatableNone(key, value) {\n+                    var _a;\n+                    var defaultValueType = getDefaultValueType(key);\n+                    if (defaultValueType !== styleValueTypes.filter) defaultValueType = styleValueTypes.complex;\n+                    // If value is not recognised as animatable, ie \"none\", create an animatable version origin based on the target\n+                    return (_a = defaultValueType.getAnimatableNone) === null || _a === void 0 ? void 0 : _a.call(defaultValueType, value);\n+                }\n+                var instantAnimationState = {\n+                    current: false\n+                };\n+\n+                /**\n+                 * Decide whether a transition is defined on a given Transition.\n+                 * This filters out orchestration options and returns true\n+                 * if any options are left.\n+                 */\n+                function isTransitionDefined(_a) {\n+                    _a.when;\n+                    _a.delay;\n+                    _a.delayChildren;\n+                    _a.staggerChildren;\n+                    _a.staggerDirection;\n+                    _a.repeat;\n+                    _a.repeatType;\n+                    _a.repeatDelay;\n+                    _a.from;\n+                    var transition = tslib.__rest(_a, [\"when\", \"delay\", \"delayChildren\", \"staggerChildren\", \"staggerDirection\", \"repeat\", \"repeatType\", \"repeatDelay\", \"from\"]);\n+                    return !!Object.keys(transition).length;\n+                }\n+                var legacyRepeatWarning = false;\n+                /**\n+                 * Convert Framer Motion's Transition type into Popmotion-compatible options.\n+                 */\n+                function convertTransitionToAnimationOptions(_a) {\n+                    var ease = _a.ease,\n+                        times = _a.times,\n+                        yoyo = _a.yoyo,\n+                        flip = _a.flip,\n+                        loop = _a.loop,\n+                        transition = tslib.__rest(_a, [\"ease\", \"times\", \"yoyo\", \"flip\", \"loop\"]);\n+                    var options = tslib.__assign({}, transition);\n+                    if (times) options[\"offset\"] = times;\n+                    /**\n+                     * Convert any existing durations from seconds to milliseconds\n+                     */\n+                    if (transition.duration) options[\"duration\"] = secondsToMilliseconds(transition.duration);\n+                    if (transition.repeatDelay) options.repeatDelay = secondsToMilliseconds(transition.repeatDelay);\n+                    /**\n+                     * Map easing names to Popmotion's easing functions\n+                     */\n+                    if (ease) {\n+                        options[\"ease\"] = isEasingArray(ease) ? ease.map(easingDefinitionToFunction) : easingDefinitionToFunction(ease);\n+                    }\n+                    /**\n+                     * Support legacy transition API\n+                     */\n+                    if (transition.type === \"tween\") options.type = \"keyframes\";\n+                    /**\n+                     * TODO: These options are officially removed from the API.\n+                     */\n+                    if (yoyo || loop || flip) {\n+                        heyListen.warning(!legacyRepeatWarning, \"yoyo, loop and flip have been removed from the API. Replace with repeat and repeatType options.\");\n+                        legacyRepeatWarning = true;\n+                        if (yoyo) {\n+                            options.repeatType = \"reverse\";\n+                        } else if (loop) {\n+                            options.repeatType = \"loop\";\n+                        } else if (flip) {\n+                            options.repeatType = \"mirror\";\n+                        }\n+                        options.repeat = loop || yoyo || flip || transition.repeat;\n+                    }\n+                    /**\n+                     * TODO: Popmotion 9 has the ability to automatically detect whether to use\n+                     * a keyframes or spring animation, but does so by detecting velocity and other spring options.\n+                     * It'd be good to introduce a similar thing here.\n+                     */\n+                    if (transition.type !== \"spring\") options.type = \"keyframes\";\n+                    return options;\n+                }\n+                /**\n+                 * Get the delay for a value by checking Transition with decreasing specificity.\n+                 */\n+                function getDelayFromTransition(transition, key) {\n+                    var _a, _b;\n+                    var valueTransition = getValueTransition(transition, key) || {};\n+                    return (_b = (_a = valueTransition.delay) !== null && _a !== void 0 ? _a : transition.delay) !== null && _b !== void 0 ? _b : 0;\n+                }\n+\n+                function hydrateKeyframes(options) {\n+                    if (Array.isArray(options.to) && options.to[0] === null) {\n+                        options.to = tslib.__spreadArray([], tslib.__read(options.to), false);\n+                        options.to[0] = options.from;\n+                    }\n+                    return options;\n+                }\n+\n+                function getPopmotionAnimationOptions(transition, options, key) {\n+                    var _a;\n+                    if (Array.isArray(options.to)) {\n+                        (_a = transition.duration) !== null && _a !== void 0 ? _a : transition.duration = 0.8;\n+                    }\n+                    hydrateKeyframes(options);\n+                    /**\n+                     * Get a default transition if none is determined to be defined.\n+                     */\n+                    if (!isTransitionDefined(transition)) {\n+                        transition = tslib.__assign(tslib.__assign({}, transition), getDefaultTransition(key, options.to));\n+                    }\n+                    return tslib.__assign(tslib.__assign({}, options), convertTransitionToAnimationOptions(transition));\n+                }\n+                /**\n+                 *\n+                 */\n+                function getAnimation(key, value, target, transition, onComplete) {\n+                    var _a;\n+                    var valueTransition = getValueTransition(transition, key);\n+                    var origin = (_a = valueTransition.from) !== null && _a !== void 0 ? _a : value.get();\n+                    var isTargetAnimatable = isAnimatable(key, target);\n+                    if (origin === \"none\" && isTargetAnimatable && typeof target === \"string\") {\n+                        /**\n+                         * If we're trying to animate from \"none\", try and get an animatable version\n+                         * of the target. This could be improved to work both ways.\n+                         */\n+                        origin = getAnimatableNone(key, target);\n+                    } else if (isZero(origin) && typeof target === \"string\") {\n+                        origin = getZeroUnit(target);\n+                    } else if (!Array.isArray(target) && isZero(target) && typeof origin === \"string\") {\n+                        target = getZeroUnit(origin);\n+                    }\n+                    var isOriginAnimatable = isAnimatable(key, origin);\n+                    heyListen.warning(isOriginAnimatable === isTargetAnimatable, \"You are trying to animate \".concat(key, \" from \\\"\").concat(origin, \"\\\" to \\\"\").concat(target, \"\\\". \").concat(origin, \" is not an animatable value - to enable this animation set \").concat(origin, \" to a value animatable to \").concat(target, \" via the `style` property.\"));\n+\n+                    function start() {\n+                        var options = {\n+                            from: origin,\n+                            to: target,\n+                            velocity: value.getVelocity(),\n+                            onComplete: onComplete,\n+                            onUpdate: function(v) {\n+                                return value.set(v);\n+                            }\n+                        };\n+                        return valueTransition.type === \"inertia\" || valueTransition.type === \"decay\" ? popmotion.inertia(tslib.__assign(tslib.__assign({}, options), valueTransition)) : popmotion.animate(tslib.__assign(tslib.__assign({}, getPopmotionAnimationOptions(valueTransition, options, key)), {\n+                            onUpdate: function(v) {\n+                                var _a;\n+                                options.onUpdate(v);\n+                                (_a = valueTransition.onUpdate) === null || _a === void 0 ? void 0 : _a.call(valueTransition, v);\n+                            },\n+                            onComplete: function() {\n+                                var _a;\n+                                options.onComplete();\n+                                (_a = valueTransition.onComplete) === null || _a === void 0 ? void 0 : _a.call(valueTransition);\n+                            }\n+                        }));\n+                    }\n+\n+                    function set() {\n+                        var _a, _b;\n+                        var finalTarget = resolveFinalValueInKeyframes(target);\n+                        value.set(finalTarget);\n+                        onComplete();\n+                        (_a = valueTransition === null || valueTransition === void 0 ? void 0 : valueTransition.onUpdate) === null || _a === void 0 ? void 0 : _a.call(valueTransition, finalTarget);\n+                        (_b = valueTransition === null || valueTransition === void 0 ? void 0 : valueTransition.onComplete) === null || _b === void 0 ? void 0 : _b.call(valueTransition);\n+                        return {\n+                            stop: function() {}\n+                        };\n+                    }\n+                    return !isOriginAnimatable || !isTargetAnimatable || valueTransition.type === false ? set : start;\n+                }\n+\n+                function isZero(value) {\n+                    return value === 0 || typeof value === \"string\" && parseFloat(value) === 0 && value.indexOf(\" \") === -1;\n+                }\n+\n+                function getZeroUnit(potentialUnitType) {\n+                    return typeof potentialUnitType === \"number\" ? 0 : getAnimatableNone(\"\", potentialUnitType);\n+                }\n+\n+                function getValueTransition(transition, key) {\n+                    return transition[key] || transition[\"default\"] || transition;\n+                }\n+                /**\n+                 * Start animation on a MotionValue. This function is an interface between\n+                 * Framer Motion and Popmotion\n+                 */\n+                function startAnimation(key, value, target, transition) {\n+                    if (transition === void 0) {\n+                        transition = {};\n+                    }\n+                    if (instantAnimationState.current) {\n+                        transition = {\n+                            type: false\n+                        };\n+                    }\n+                    return value.start(function(onComplete) {\n+                        var delayTimer;\n+                        var controls;\n+                        var animation = getAnimation(key, value, target, transition, onComplete);\n+                        var delay = getDelayFromTransition(transition, key);\n+                        var start = function() {\n+                            return controls = animation();\n+                        };\n+                        if (delay) {\n+                            delayTimer = window.setTimeout(start, secondsToMilliseconds(delay));\n+                        } else {\n+                            start();\n+                        }\n+                        return function() {\n+                            clearTimeout(delayTimer);\n+                            controls === null || controls === void 0 ? void 0 : controls.stop();\n+                        };\n+                    });\n+                }\n+\n+                /**\n+                 * Check if value is a numerical string, ie a string that is purely a number eg \"100\" or \"-100.1\"\n+                 */\n+                var isNumericalString = function(v) {\n+                    return /^\\-?\\d*\\.?\\d+$/.test(v);\n+                };\n+\n+                /**\n+                 * Check if the value is a zero value string like \"0px\" or \"0%\"\n+                 */\n+                var isZeroValueString = function(v) {\n+                    return /^0[^.\\s]+$/.test(v);\n+                };\n+\n+                function addUniqueItem(arr, item) {\n+                    arr.indexOf(item) === -1 && arr.push(item);\n+                }\n+\n+                function removeItem(arr, item) {\n+                    var index = arr.indexOf(item);\n+                    index > -1 && arr.splice(index, 1);\n+                }\n+                // Adapted from array-move\n+                function moveItem(_a, fromIndex, toIndex) {\n+                    var _b = tslib.__read(_a),\n+                        arr = _b.slice(0);\n+                    var startIndex = fromIndex < 0 ? arr.length + fromIndex : fromIndex;\n+                    if (startIndex >= 0 && startIndex < arr.length) {\n+                        var endIndex = toIndex < 0 ? arr.length + toIndex : toIndex;\n+                        var _c = tslib.__read(arr.splice(fromIndex, 1), 1),\n+                            item = _c[0];\n+                        arr.splice(endIndex, 0, item);\n+                    }\n+                    return arr;\n+                }\n+                var SubscriptionManager = /** @class */ function() {\n+                    function SubscriptionManager() {\n+                        this.subscriptions = [];\n+                    }\n+                    SubscriptionManager.prototype.add = function(handler) {\n+                        var _this = this;\n+                        addUniqueItem(this.subscriptions, handler);\n+                        return function() {\n+                            return removeItem(_this.subscriptions, handler);\n+                        };\n+                    };\n+                    SubscriptionManager.prototype.notify = function(a, b, c) {\n+                        var numSubscriptions = this.subscriptions.length;\n+                        if (!numSubscriptions) return;\n+                        if (numSubscriptions === 1) {\n+                            /**\n+                             * If there's only a single handler we can just call it without invoking a loop.\n+                             */\n+                            this.subscriptions[0](a, b, c);\n+                        } else {\n+                            for (var i = 0; i < numSubscriptions; i++) {\n+                                /**\n+                                 * Check whether the handler exists before firing as it's possible\n+                                 * the subscriptions were modified during this loop running.\n+                                 */\n+                                var handler = this.subscriptions[i];\n+                                handler && handler(a, b, c);\n+                            }\n+                        }\n+                    };\n+                    SubscriptionManager.prototype.getSize = function() {\n+                        return this.subscriptions.length;\n+                    };\n+                    SubscriptionManager.prototype.clear = function() {\n+                        this.subscriptions.length = 0;\n+                    };\n+                    return SubscriptionManager;\n+                }();\n+                var isFloat = function(value) {\n+                    return !isNaN(parseFloat(value));\n+                };\n+                /**\n+                 * `MotionValue` is used to track the state and velocity of motion values.\n+                 *\n+                 * @public\n+                 */\n+                var MotionValue = /** @class */ function() {\n+                    /**\n+                     * @param init - The initiating value\n+                     * @param config - Optional configuration options\n+                     *\n+                     * -  `transformer`: A function to transform incoming values with.\n+                     *\n+                     * @internal\n+                     */\n+                    function MotionValue(init) {\n+                        var _this = this;\n+                        /**\n+                         * This will be replaced by the build step with the latest version number.\n+                         * When MotionValues are provided to motion components, warn if versions are mixed.\n+                         */\n+                        this.version = \"6.5.1\";\n+                        /**\n+                         * Duration, in milliseconds, since last updating frame.\n+                         *\n+                         * @internal\n+                         */\n+                        this.timeDelta = 0;\n+                        /**\n+                         * Timestamp of the last time this `MotionValue` was updated.\n+                         *\n+                         * @internal\n+                         */\n+                        this.lastUpdated = 0;\n+                        /**\n+                         * Functions to notify when the `MotionValue` updates.\n+                         *\n+                         * @internal\n+                         */\n+                        this.updateSubscribers = new SubscriptionManager();\n+                        /**\n+                         * Functions to notify when the velocity updates.\n+                         *\n+                         * @internal\n+                         */\n+                        this.velocityUpdateSubscribers = new SubscriptionManager();\n+                        /**\n+                         * Functions to notify when the `MotionValue` updates and `render` is set to `true`.\n+                         *\n+                         * @internal\n+                         */\n+                        this.renderSubscribers = new SubscriptionManager();\n+                        /**\n+                         * Tracks whether this value can output a velocity. Currently this is only true\n+                         * if the value is numerical, but we might be able to widen the scope here and support\n+                         * other value types.\n+                         *\n+                         * @internal\n+                         */\n+                        this.canTrackVelocity = false;\n+                        this.updateAndNotify = function(v, render) {\n+                            if (render === void 0) {\n+                                render = true;\n+                            }\n+                            _this.prev = _this.current;\n+                            _this.current = v;\n+                            // Update timestamp\n+                            var _a = sync.getFrameData(),\n+                                delta = _a.delta,\n+                                timestamp = _a.timestamp;\n+                            if (_this.lastUpdated !== timestamp) {\n+                                _this.timeDelta = delta;\n+                                _this.lastUpdated = timestamp;\n+                                sync__default[\"default\"].postRender(_this.scheduleVelocityCheck);\n+                            }\n+                            // Update update subscribers\n+                            if (_this.prev !== _this.current) {\n+                                _this.updateSubscribers.notify(_this.current);\n+                            }\n+                            // Update velocity subscribers\n+                            if (_this.velocityUpdateSubscribers.getSize()) {\n+                                _this.velocityUpdateSubscribers.notify(_this.getVelocity());\n+                            }\n+                            // Update render subscribers\n+                            if (render) {\n+                                _this.renderSubscribers.notify(_this.current);\n+                            }\n+                        };\n+                        /**\n+                         * Schedule a velocity check for the next frame.\n+                         *\n+                         * This is an instanced and bound function to prevent generating a new\n+                         * function once per frame.\n+                         *\n+                         * @internal\n+                         */\n+                        this.scheduleVelocityCheck = function() {\n+                            return sync__default[\"default\"].postRender(_this.velocityCheck);\n+                        };\n+                        /**\n+                         * Updates `prev` with `current` if the value hasn't been updated this frame.\n+                         * This ensures velocity calculations return `0`.\n+                         *\n+                         * This is an instanced and bound function to prevent generating a new\n+                         * function once per frame.\n+                         *\n+                         * @internal\n+                         */\n+                        this.velocityCheck = function(_a) {\n+                            var timestamp = _a.timestamp;\n+                            if (timestamp !== _this.lastUpdated) {\n+                                _this.prev = _this.current;\n+                                _this.velocityUpdateSubscribers.notify(_this.getVelocity());\n+                            }\n+                        };\n+                        this.hasAnimated = false;\n+                        this.prev = this.current = init;\n+                        this.canTrackVelocity = isFloat(this.current);\n+                    }\n+                    /**\n+                     * Adds a function that will be notified when the `MotionValue` is updated.\n+                     *\n+                     * It returns a function that, when called, will cancel the subscription.\n+                     *\n+                     * When calling `onChange` inside a React component, it should be wrapped with the\n+                     * `useEffect` hook. As it returns an unsubscribe function, this should be returned\n+                     * from the `useEffect` function to ensure you don't add duplicate subscribers..\n+                     *\n+                     * ```jsx\n+                     * export const MyComponent = () => {\n+                     *   const x = useMotionValue(0)\n+                     *   const y = useMotionValue(0)\n+                     *   const opacity = useMotionValue(1)\n+                     *\n+                     *   useEffect(() => {\n+                     *     function updateOpacity() {\n+                     *       const maxXY = Math.max(x.get(), y.get())\n+                     *       const newOpacity = transform(maxXY, [0, 100], [1, 0])\n+                     *       opacity.set(newOpacity)\n+                     *     }\n+                     *\n+                     *     const unsubscribeX = x.onChange(updateOpacity)\n+                     *     const unsubscribeY = y.onChange(updateOpacity)\n+                     *\n+                     *     return () => {\n+                     *       unsubscribeX()\n+                     *       unsubscribeY()\n+                     *     }\n+                     *   }, [])\n+                     *\n+                     *   return <motion.div style={{ x }} />\n+                     * }\n+                     * ```\n+                     *\n+                     * @privateRemarks\n+                     *\n+                     * We could look into a `useOnChange` hook if the above lifecycle management proves confusing.\n+                     *\n+                     * ```jsx\n+                     * useOnChange(x, () => {})\n+                     * ```\n+                     *\n+                     * @param subscriber - A function that receives the latest value.\n+                     * @returns A function that, when called, will cancel this subscription.\n+                     *\n+                     * @public\n+                     */\n+                    MotionValue.prototype.onChange = function(subscription) {\n+                        return this.updateSubscribers.add(subscription);\n+                    };\n+                    MotionValue.prototype.clearListeners = function() {\n+                        this.updateSubscribers.clear();\n+                    };\n+                    /**\n+                     * Adds a function that will be notified when the `MotionValue` requests a render.\n+                     *\n+                     * @param subscriber - A function that's provided the latest value.\n+                     * @returns A function that, when called, will cancel this subscription.\n+                     *\n+                     * @internal\n+                     */\n+                    MotionValue.prototype.onRenderRequest = function(subscription) {\n+                        // Render immediately\n+                        subscription(this.get());\n+                        return this.renderSubscribers.add(subscription);\n+                    };\n+                    /**\n+                     * Attaches a passive effect to the `MotionValue`.\n+                     *\n+                     * @internal\n+                     */\n+                    MotionValue.prototype.attach = function(passiveEffect) {\n+                        this.passiveEffect = passiveEffect;\n+                    };\n+                    /**\n+                     * Sets the state of the `MotionValue`.\n+                     *\n+                     * @remarks\n+                     *\n+                     * ```jsx\n+                     * const x = useMotionValue(0)\n+                     * x.set(10)\n+                     * ```\n+                     *\n+                     * @param latest - Latest value to set.\n+                     * @param render - Whether to notify render subscribers. Defaults to `true`\n+                     *\n+                     * @public\n+                     */\n+                    MotionValue.prototype.set = function(v, render) {\n+                        if (render === void 0) {\n+                            render = true;\n+                        }\n+                        if (!render || !this.passiveEffect) {\n+                            this.updateAndNotify(v, render);\n+                        } else {\n+                            this.passiveEffect(v, this.updateAndNotify);\n+                        }\n+                    };\n+                    /**\n+                     * Returns the latest state of `MotionValue`\n+                     *\n+                     * @returns - The latest state of `MotionValue`\n+                     *\n+                     * @public\n+                     */\n+                    MotionValue.prototype.get = function() {\n+                        return this.current;\n+                    };\n+                    /**\n+                     * @public\n+                     */\n+                    MotionValue.prototype.getPrevious = function() {\n+                        return this.prev;\n+                    };\n+                    /**\n+                     * Returns the latest velocity of `MotionValue`\n+                     *\n+                     * @returns - The latest velocity of `MotionValue`. Returns `0` if the state is non-numerical.\n+                     *\n+                     * @public\n+                     */\n+                    MotionValue.prototype.getVelocity = function() {\n+                        // This could be isFloat(this.prev) && isFloat(this.current), but that would be wasteful\n+                        return this.canTrackVelocity ?\n+                            // These casts could be avoided if parseFloat would be typed better\n+                            popmotion.velocityPerSecond(parseFloat(this.current) - parseFloat(this.prev), this.timeDelta) : 0;\n+                    };\n+                    /**\n+                     * Registers a new animation to control this `MotionValue`. Only one\n+                     * animation can drive a `MotionValue` at one time.\n+                     *\n+                     * ```jsx\n+                     * value.start()\n+                     * ```\n+                     *\n+                     * @param animation - A function that starts the provided animation\n+                     *\n+                     * @internal\n+                     */\n+                    MotionValue.prototype.start = function(animation) {\n+                        var _this = this;\n+                        this.stop();\n+                        return new Promise(function(resolve) {\n+                            _this.hasAnimated = true;\n+                            _this.stopAnimation = animation(resolve);\n+                        }).then(function() {\n+                            return _this.clearAnimation();\n+                        });\n+                    };\n+                    /**\n+                     * Stop the currently active animation.\n+                     *\n+                     * @public\n+                     */\n+                    MotionValue.prototype.stop = function() {\n+                        if (this.stopAnimation) this.stopAnimation();\n+                        this.clearAnimation();\n+                    };\n+                    /**\n+                     * Returns `true` if this value is currently animating.\n+                     *\n+                     * @public\n+                     */\n+                    MotionValue.prototype.isAnimating = function() {\n+                        return !!this.stopAnimation;\n+                    };\n+                    MotionValue.prototype.clearAnimation = function() {\n+                        this.stopAnimation = null;\n+                    };\n+                    /**\n+                     * Destroy and clean up subscribers to this `MotionValue`.\n+                     *\n+                     * The `MotionValue` hooks like `useMotionValue` and `useTransform` automatically\n+                     * handle the lifecycle of the returned `MotionValue`, so this method is only necessary if you've manually\n+                     * created a `MotionValue` via the `motionValue` function.\n+                     *\n+                     * @public\n+                     */\n+                    MotionValue.prototype.destroy = function() {\n+                        this.updateSubscribers.clear();\n+                        this.renderSubscribers.clear();\n+                        this.stop();\n+                    };\n+                    return MotionValue;\n+                }();\n+\n+                function motionValue(init) {\n+                    return new MotionValue(init);\n+                }\n+\n+                /**\n+                 * Tests a provided value against a ValueType\n+                 */\n+                var testValueType = function(v) {\n+                    return function(type) {\n+                        return type.test(v);\n+                    };\n+                };\n+\n+                /**\n+                 * ValueType for \"auto\"\n+                 */\n+                var auto = {\n+                    test: function(v) {\n+                        return v === \"auto\";\n+                    },\n+                    parse: function(v) {\n+                        return v;\n+                    }\n+                };\n+\n+                /**\n+                 * A list of value types commonly used for dimensions\n+                 */\n+                var dimensionValueTypes = [styleValueTypes.number, styleValueTypes.px, styleValueTypes.percent, styleValueTypes.degrees, styleValueTypes.vw, styleValueTypes.vh, auto];\n+                /**\n+                 * Tests a dimensional value against the list of dimension ValueTypes\n+                 */\n+                var findDimensionValueType = function(v) {\n+                    return dimensionValueTypes.find(testValueType(v));\n+                };\n+\n+                /**\n+                 * A list of all ValueTypes\n+                 */\n+                var valueTypes = tslib.__spreadArray(tslib.__spreadArray([], tslib.__read(dimensionValueTypes), false), [styleValueTypes.color, styleValueTypes.complex], false);\n+                /**\n+                 * Tests a value against the list of ValueTypes\n+                 */\n+                var findValueType = function(v) {\n+                    return valueTypes.find(testValueType(v));\n+                };\n+\n+                /**\n+                 * Set VisualElement's MotionValue, creating a new MotionValue for it if\n+                 * it doesn't exist.\n+                 */\n+                function setMotionValue(visualElement, key, value) {\n+                    if (visualElement.hasValue(key)) {\n+                        visualElement.getValue(key).set(value);\n+                    } else {\n+                        visualElement.addValue(key, motionValue(value));\n+                    }\n+                }\n+\n+                function setTarget(visualElement, definition) {\n+                    var resolved = resolveVariant(visualElement, definition);\n+                    var _a = resolved ? visualElement.makeTargetAnimatable(resolved, false) : {},\n+                        _b = _a.transitionEnd,\n+                        transitionEnd = _b === void 0 ? {} : _b;\n+                    _a.transition;\n+                    var target = tslib.__rest(_a, [\"transitionEnd\", \"transition\"]);\n+                    target = tslib.__assign(tslib.__assign({}, target), transitionEnd);\n+                    for (var key in target) {\n+                        var value = resolveFinalValueInKeyframes(target[key]);\n+                        setMotionValue(visualElement, key, value);\n+                    }\n+                }\n+\n+                function setVariants(visualElement, variantLabels) {\n+                    var reversedLabels = tslib.__spreadArray([], tslib.__read(variantLabels), false).reverse();\n+                    reversedLabels.forEach(function(key) {\n+                        var _a;\n+                        var variant = visualElement.getVariant(key);\n+                        variant && setTarget(visualElement, variant);\n+                        (_a = visualElement.variantChildren) === null || _a === void 0 ? void 0 : _a.forEach(function(child) {\n+                            setVariants(child, variantLabels);\n+                        });\n+                    });\n+                }\n+\n+                function setValues(visualElement, definition) {\n+                    if (Array.isArray(definition)) {\n+                        return setVariants(visualElement, definition);\n+                    } else if (typeof definition === \"string\") {\n+                        return setVariants(visualElement, [definition]);\n+                    } else {\n+                        setTarget(visualElement, definition);\n+                    }\n+                }\n+\n+                function checkTargetForNewValues(visualElement, target, origin) {\n+                    var _a, _b, _c;\n+                    var _d;\n+                    var newValueKeys = Object.keys(target).filter(function(key) {\n+                        return !visualElement.hasValue(key);\n+                    });\n+                    var numNewValues = newValueKeys.length;\n+                    if (!numNewValues) return;\n+                    for (var i = 0; i < numNewValues; i++) {\n+                        var key = newValueKeys[i];\n+                        var targetValue = target[key];\n+                        var value = null;\n+                        /**\n+                         * If the target is a series of keyframes, we can use the first value\n+                         * in the array. If this first value is null, we'll still need to read from the DOM.\n+                         */\n+                        if (Array.isArray(targetValue)) {\n+                            value = targetValue[0];\n+                        }\n+                        /**\n+                         * If the target isn't keyframes, or the first keyframe was null, we need to\n+                         * first check if an origin value was explicitly defined in the transition as \"from\",\n+                         * if not read the value from the DOM. As an absolute fallback, take the defined target value.\n+                         */\n+                        if (value === null) {\n+                            value = (_b = (_a = origin[key]) !== null && _a !== void 0 ? _a : visualElement.readValue(key)) !== null && _b !== void 0 ? _b : target[key];\n+                        }\n+                        /**\n+                         * If value is still undefined or null, ignore it. Preferably this would throw,\n+                         * but this was causing issues in Framer.\n+                         */\n+                        if (value === undefined || value === null) continue;\n+                        if (typeof value === \"string\" && (isNumericalString(value) || isZeroValueString(value))) {\n+                            // If this is a number read as a string, ie \"0\" or \"200\", convert it to a number\n+                            value = parseFloat(value);\n+                        } else if (!findValueType(value) && styleValueTypes.complex.test(targetValue)) {\n+                            value = getAnimatableNone(key, targetValue);\n+                        }\n+                        visualElement.addValue(key, motionValue(value));\n+                        (_c = (_d = origin)[key]) !== null && _c !== void 0 ? _c : _d[key] = value;\n+                        visualElement.setBaseTarget(key, value);\n+                    }\n+                }\n+\n+                function getOriginFromTransition(key, transition) {\n+                    if (!transition) return;\n+                    var valueTransition = transition[key] || transition[\"default\"] || transition;\n+                    return valueTransition.from;\n+                }\n+\n+                function getOrigin(target, transition, visualElement) {\n+                    var _a, _b;\n+                    var origin = {};\n+                    for (var key in target) {\n+                        origin[key] = (_a = getOriginFromTransition(key, transition)) !== null && _a !== void 0 ? _a : (_b = visualElement.getValue(key)) === null || _b === void 0 ? void 0 : _b.get();\n+                    }\n+                    return origin;\n+                }\n+\n+                function animateVisualElement(visualElement, definition, options) {\n+                    if (options === void 0) {\n+                        options = {};\n+                    }\n+                    visualElement.notifyAnimationStart(definition);\n+                    var animation;\n+                    if (Array.isArray(definition)) {\n+                        var animations = definition.map(function(variant) {\n+                            return animateVariant(visualElement, variant, options);\n+                        });\n+                        animation = Promise.all(animations);\n+                    } else if (typeof definition === \"string\") {\n+                        animation = animateVariant(visualElement, definition, options);\n+                    } else {\n+                        var resolvedDefinition = typeof definition === \"function\" ? resolveVariant(visualElement, definition, options.custom) : definition;\n+                        animation = animateTarget(visualElement, resolvedDefinition, options);\n+                    }\n+                    return animation.then(function() {\n+                        return visualElement.notifyAnimationComplete(definition);\n+                    });\n+                }\n+\n+                function animateVariant(visualElement, variant, options) {\n+                    var _a;\n+                    if (options === void 0) {\n+                        options = {};\n+                    }\n+                    var resolved = resolveVariant(visualElement, variant, options.custom);\n+                    var _b = (resolved || {}).transition,\n+                        transition = _b === void 0 ? visualElement.getDefaultTransition() || {} : _b;\n+                    if (options.transitionOverride) {\n+                        transition = options.transitionOverride;\n+                    }\n+                    /**\n+                     * If we have a variant, create a callback that runs it as an animation.\n+                     * Otherwise, we resolve a Promise immediately for a composable no-op.\n+                     */\n+                    var getAnimation = resolved ? function() {\n+                        return animateTarget(visualElement, resolved, options);\n+                    } : function() {\n+                        return Promise.resolve();\n+                    };\n+                    /**\n+                     * If we have children, create a callback that runs all their animations.\n+                     * Otherwise, we resolve a Promise immediately for a composable no-op.\n+                     */\n+                    var getChildAnimations = ((_a = visualElement.variantChildren) === null || _a === void 0 ? void 0 : _a.size) ? function(forwardDelay) {\n+                        if (forwardDelay === void 0) {\n+                            forwardDelay = 0;\n+                        }\n+                        var _a = transition.delayChildren,\n+                            delayChildren = _a === void 0 ? 0 : _a,\n+                            staggerChildren = transition.staggerChildren,\n+                            staggerDirection = transition.staggerDirection;\n+                        return animateChildren(visualElement, variant, delayChildren + forwardDelay, staggerChildren, staggerDirection, options);\n+                    } : function() {\n+                        return Promise.resolve();\n+                    };\n+                    /**\n+                     * If the transition explicitly defines a \"when\" option, we need to resolve either\n+                     * this animation or all children animations before playing the other.\n+                     */\n+                    var when = transition.when;\n+                    if (when) {\n+                        var _c = tslib.__read(when === \"beforeChildren\" ? [getAnimation, getChildAnimations] : [getChildAnimations, getAnimation], 2),\n+                            first = _c[0],\n+                            last = _c[1];\n+                        return first().then(last);\n+                    } else {\n+                        return Promise.all([getAnimation(), getChildAnimations(options.delay)]);\n+                    }\n+                }\n+                /**\n+                 * @internal\n+                 */\n+                function animateTarget(visualElement, definition, _a) {\n+                    var _b;\n+                    var _c = _a === void 0 ? {} : _a,\n+                        _d = _c.delay,\n+                        delay = _d === void 0 ? 0 : _d,\n+                        transitionOverride = _c.transitionOverride,\n+                        type = _c.type;\n+                    var _e = visualElement.makeTargetAnimatable(definition),\n+                        _f = _e.transition,\n+                        transition = _f === void 0 ? visualElement.getDefaultTransition() : _f,\n+                        transitionEnd = _e.transitionEnd,\n+                        target = tslib.__rest(_e, [\"transition\", \"transitionEnd\"]);\n+                    if (transitionOverride) transition = transitionOverride;\n+                    var animations = [];\n+                    var animationTypeState = type && ((_b = visualElement.animationState) === null || _b === void 0 ? void 0 : _b.getState()[type]);\n+                    for (var key in target) {\n+                        var value = visualElement.getValue(key);\n+                        var valueTarget = target[key];\n+                        if (!value || valueTarget === undefined || animationTypeState && shouldBlockAnimation(animationTypeState, key)) {\n+                            continue;\n+                        }\n+                        var valueTransition = tslib.__assign({\n+                            delay: delay\n+                        }, transition);\n+                        /**\n+                         * Make animation instant if this is a transform prop and we should reduce motion.\n+                         */\n+                        if (visualElement.shouldReduceMotion && isTransformProp(key)) {\n+                            valueTransition = tslib.__assign(tslib.__assign({}, valueTransition), {\n+                                type: false,\n+                                delay: 0\n+                            });\n+                        }\n+                        var animation = startAnimation(key, value, valueTarget, valueTransition);\n+                        animations.push(animation);\n+                    }\n+                    return Promise.all(animations).then(function() {\n+                        transitionEnd && setTarget(visualElement, transitionEnd);\n+                    });\n+                }\n+\n+                function animateChildren(visualElement, variant, delayChildren, staggerChildren, staggerDirection, options) {\n+                    if (delayChildren === void 0) {\n+                        delayChildren = 0;\n+                    }\n+                    if (staggerChildren === void 0) {\n+                        staggerChildren = 0;\n+                    }\n+                    if (staggerDirection === void 0) {\n+                        staggerDirection = 1;\n+                    }\n+                    var animations = [];\n+                    var maxStaggerDuration = (visualElement.variantChildren.size - 1) * staggerChildren;\n+                    var generateStaggerDuration = staggerDirection === 1 ? function(i) {\n+                        if (i === void 0) {\n+                            i = 0;\n+                        }\n+                        return i * staggerChildren;\n+                    } : function(i) {\n+                        if (i === void 0) {\n+                            i = 0;\n+                        }\n+                        return maxStaggerDuration - i * staggerChildren;\n+                    };\n+                    Array.from(visualElement.variantChildren).sort(sortByTreeOrder).forEach(function(child, i) {\n+                        animations.push(animateVariant(child, variant, tslib.__assign(tslib.__assign({}, options), {\n+                            delay: delayChildren + generateStaggerDuration(i)\n+                        })).then(function() {\n+                            return child.notifyAnimationComplete(variant);\n+                        }));\n+                    });\n+                    return Promise.all(animations);\n+                }\n+\n+                function stopAnimation(visualElement) {\n+                    visualElement.forEachValue(function(value) {\n+                        return value.stop();\n+                    });\n+                }\n+\n+                function sortByTreeOrder(a, b) {\n+                    return a.sortNodePosition(b);\n+                }\n+                /**\n+                 * Decide whether we should block this animation. Previously, we achieved this\n+                 * just by checking whether the key was listed in protectedKeys, but this\n+                 * posed problems if an animation was triggered by afterChildren and protectedKeys\n+                 * had been set to true in the meantime.\n+                 */\n+                function shouldBlockAnimation(_a, key) {\n+                    var protectedKeys = _a.protectedKeys,\n+                        needsAnimating = _a.needsAnimating;\n+                    var shouldBlock = protectedKeys.hasOwnProperty(key) && needsAnimating[key] !== true;\n+                    needsAnimating[key] = false;\n+                    return shouldBlock;\n+                }\n+                var variantPriorityOrder = [exports.AnimationType.Animate, exports.AnimationType.InView, exports.AnimationType.Focus, exports.AnimationType.Hover, exports.AnimationType.Tap, exports.AnimationType.Drag, exports.AnimationType.Exit];\n+                var reversePriorityOrder = tslib.__spreadArray([], tslib.__read(variantPriorityOrder), false).reverse();\n+                var numAnimationTypes = variantPriorityOrder.length;\n+\n+                function animateList(visualElement) {\n+                    return function(animations) {\n+                        return Promise.all(animations.map(function(_a) {\n+                            var animation = _a.animation,\n+                                options = _a.options;\n+                            return animateVisualElement(visualElement, animation, options);\n+                        }));\n+                    };\n+                }\n+\n+                function createAnimationState(visualElement) {\n+                    var animate = animateList(visualElement);\n+                    var state = createState();\n+                    var allAnimatedKeys = {};\n+                    var isInitialRender = true;\n+                    /**\n+                     * This function will be used to reduce the animation definitions for\n+                     * each active animation type into an object of resolved values for it.\n+                     */\n+                    var buildResolvedTypeValues = function(acc, definition) {\n+                        var resolved = resolveVariant(visualElement, definition);\n+                        if (resolved) {\n+                            resolved.transition;\n+                            var transitionEnd = resolved.transitionEnd,\n+                                target = tslib.__rest(resolved, [\"transition\", \"transitionEnd\"]);\n+                            acc = tslib.__assign(tslib.__assign(tslib.__assign({}, acc), target), transitionEnd);\n+                        }\n+                        return acc;\n+                    };\n+\n+                    function isAnimated(key) {\n+                        return allAnimatedKeys[key] !== undefined;\n+                    }\n+                    /**\n+                     * This just allows us to inject mocked animation functions\n+                     * @internal\n+                     */\n+                    function setAnimateFunction(makeAnimator) {\n+                        animate = makeAnimator(visualElement);\n+                    }\n+                    /**\n+                     * When we receive new props, we need to:\n+                     * 1. Create a list of protected keys for each type. This is a directory of\n+                     *    value keys that are currently being \"handled\" by types of a higher priority\n+                     *    so that whenever an animation is played of a given type, these values are\n+                     *    protected from being animated.\n+                     * 2. Determine if an animation type needs animating.\n+                     * 3. Determine if any values have been removed from a type and figure out\n+                     *    what to animate those to.\n+                     */\n+                    function animateChanges(options, changedActiveType) {\n+                        var _a;\n+                        var props = visualElement.getProps();\n+                        var context = visualElement.getVariantContext(true) || {};\n+                        /**\n+                         * A list of animations that we'll build into as we iterate through the animation\n+                         * types. This will get executed at the end of the function.\n+                         */\n+                        var animations = [];\n+                        /**\n+                         * Keep track of which values have been removed. Then, as we hit lower priority\n+                         * animation types, we can check if they contain removed values and animate to that.\n+                         */\n+                        var removedKeys = new Set();\n+                        /**\n+                         * A dictionary of all encountered keys. This is an object to let us build into and\n+                         * copy it without iteration. Each time we hit an animation type we set its protected\n+                         * keys - the keys its not allowed to animate - to the latest version of this object.\n+                         */\n+                        var encounteredKeys = {};\n+                        /**\n+                         * If a variant has been removed at a given index, and this component is controlling\n+                         * variant animations, we want to ensure lower-priority variants are forced to animate.\n+                         */\n+                        var removedVariantIndex = Infinity;\n+                        var _loop_1 = function(i) {\n+                            var type = reversePriorityOrder[i];\n+                            var typeState = state[type];\n+                            var prop = (_a = props[type]) !== null && _a !== void 0 ? _a : context[type];\n+                            var propIsVariant = isVariantLabel(prop);\n+                            /**\n+                             * If this type has *just* changed isActive status, set activeDelta\n+                             * to that status. Otherwise set to null.\n+                             */\n+                            var activeDelta = type === changedActiveType ? typeState.isActive : null;\n+                            if (activeDelta === false) removedVariantIndex = i;\n+                            /**\n+                             * If this prop is an inherited variant, rather than been set directly on the\n+                             * component itself, we want to make sure we allow the parent to trigger animations.\n+                             *\n+                             * TODO: Can probably change this to a !isControllingVariants check\n+                             */\n+                            var isInherited = prop === context[type] && prop !== props[type] && propIsVariant;\n+                            /**\n+                             *\n+                             */\n+                            if (isInherited && isInitialRender && visualElement.manuallyAnimateOnMount) {\n+                                isInherited = false;\n+                            }\n+                            /**\n+                             * Set all encountered keys so far as the protected keys for this type. This will\n+                             * be any key that has been animated or otherwise handled by active, higher-priortiy types.\n+                             */\n+                            typeState.protectedKeys = tslib.__assign({}, encounteredKeys);\n+                            // Check if we can skip analysing this prop early\n+                            if (\n+                                // If it isn't active and hasn't *just* been set as inactive\n+                                !typeState.isActive && activeDelta === null ||\n+                                // If we didn't and don't have any defined prop for this animation type\n+                                !prop && !typeState.prevProp ||\n+                                // Or if the prop doesn't define an animation\n+                                isAnimationControls(prop) || typeof prop === \"boolean\") {\n+                                return \"continue\";\n+                            }\n+                            /**\n+                             * As we go look through the values defined on this type, if we detect\n+                             * a changed value or a value that was removed in a higher priority, we set\n+                             * this to true and add this prop to the animation list.\n+                             */\n+                            var variantDidChange = checkVariantsDidChange(typeState.prevProp, prop);\n+                            var shouldAnimateType = variantDidChange ||\n+                                // If we're making this variant active, we want to always make it active\n+                                type === changedActiveType && typeState.isActive && !isInherited && propIsVariant ||\n+                                // If we removed a higher-priority variant (i is in reverse order)\n+                                i > removedVariantIndex && propIsVariant;\n+                            /**\n+                             * As animations can be set as variant lists, variants or target objects, we\n+                             * coerce everything to an array if it isn't one already\n+                             */\n+                            var definitionList = Array.isArray(prop) ? prop : [prop];\n+                            /**\n+                             * Build an object of all the resolved values. We'll use this in the subsequent\n+                             * animateChanges calls to determine whether a value has changed.\n+                             */\n+                            var resolvedValues = definitionList.reduce(buildResolvedTypeValues, {});\n+                            if (activeDelta === false) resolvedValues = {};\n+                            /**\n+                             * Now we need to loop through all the keys in the prev prop and this prop,\n+                             * and decide:\n+                             * 1. If the value has changed, and needs animating\n+                             * 2. If it has been removed, and needs adding to the removedKeys set\n+                             * 3. If it has been removed in a higher priority type and needs animating\n+                             * 4. If it hasn't been removed in a higher priority but hasn't changed, and\n+                             *    needs adding to the type's protectedKeys list.\n+                             */\n+                            var _b = typeState.prevResolvedValues,\n+                                prevResolvedValues = _b === void 0 ? {} : _b;\n+                            var allKeys = tslib.__assign(tslib.__assign({}, prevResolvedValues), resolvedValues);\n+                            var markToAnimate = function(key) {\n+                                shouldAnimateType = true;\n+                                removedKeys.delete(key);\n+                                typeState.needsAnimating[key] = true;\n+                            };\n+                            for (var key in allKeys) {\n+                                var next = resolvedValues[key];\n+                                var prev = prevResolvedValues[key];\n+                                // If we've already handled this we can just skip ahead\n+                                if (encounteredKeys.hasOwnProperty(key)) continue;\n+                                /**\n+                                 * If the value has changed, we probably want to animate it.\n+                                 */\n+                                if (next !== prev) {\n+                                    /**\n+                                     * If both values are keyframes, we need to shallow compare them to\n+                                     * detect whether any value has changed. If it has, we animate it.\n+                                     */\n+                                    if (isKeyframesTarget(next) && isKeyframesTarget(prev)) {\n+                                        if (!shallowCompare(next, prev) || variantDidChange) {\n+                                            markToAnimate(key);\n+                                        } else {\n+                                            /**\n+                                             * If it hasn't changed, we want to ensure it doesn't animate by\n+                                             * adding it to the list of protected keys.\n+                                             */\n+                                            typeState.protectedKeys[key] = true;\n+                                        }\n+                                    } else if (next !== undefined) {\n+                                        // If next is defined and doesn't equal prev, it needs animating\n+                                        markToAnimate(key);\n+                                    } else {\n+                                        // If it's undefined, it's been removed.\n+                                        removedKeys.add(key);\n+                                    }\n+                                } else if (next !== undefined && removedKeys.has(key)) {\n+                                    /**\n+                                     * If next hasn't changed and it isn't undefined, we want to check if it's\n+                                     * been removed by a higher priority\n+                                     */\n+                                    markToAnimate(key);\n+                                } else {\n+                                    /**\n+                                     * If it hasn't changed, we add it to the list of protected values\n+                                     * to ensure it doesn't get animated.\n+                                     */\n+                                    typeState.protectedKeys[key] = true;\n+                                }\n+                            }\n+                            /**\n+                             * Update the typeState so next time animateChanges is called we can compare the\n+                             * latest prop and resolvedValues to these.\n+                             */\n+                            typeState.prevProp = prop;\n+                            typeState.prevResolvedValues = resolvedValues;\n+                            /**\n+                             *\n+                             */\n+                            if (typeState.isActive) {\n+                                encounteredKeys = tslib.__assign(tslib.__assign({}, encounteredKeys), resolvedValues);\n+                            }\n+                            if (isInitialRender && visualElement.blockInitialAnimation) {\n+                                shouldAnimateType = false;\n+                            }\n+                            /**\n+                             * If this is an inherited prop we want to hard-block animations\n+                             * TODO: Test as this should probably still handle animations triggered\n+                             * by removed values?\n+                             */\n+                            if (shouldAnimateType && !isInherited) {\n+                                animations.push.apply(animations, tslib.__spreadArray([], tslib.__read(definitionList.map(function(animation) {\n+                                    return {\n+                                        animation: animation,\n+                                        options: tslib.__assign({\n+                                            type: type\n+                                        }, options)\n+                                    };\n+                                })), false));\n+                            }\n+                        };\n+                        /**\n+                         * Iterate through all animation types in reverse priority order. For each, we want to\n+                         * detect which values it's handling and whether or not they've changed (and therefore\n+                         * need to be animated). If any values have been removed, we want to detect those in\n+                         * lower priority props and flag for animation.\n+                         */\n+                        for (var i = 0; i < numAnimationTypes; i++) {\n+                            _loop_1(i);\n+                        }\n+                        allAnimatedKeys = tslib.__assign({}, encounteredKeys);\n+                        /**\n+                         * If there are some removed value that haven't been dealt with,\n+                         * we need to create a new animation that falls back either to the value\n+                         * defined in the style prop, or the last read value.\n+                         */\n+                        if (removedKeys.size) {\n+                            var fallbackAnimation_1 = {};\n+                            removedKeys.forEach(function(key) {\n+                                var fallbackTarget = visualElement.getBaseTarget(key);\n+                                if (fallbackTarget !== undefined) {\n+                                    fallbackAnimation_1[key] = fallbackTarget;\n+                                }\n+                            });\n+                            animations.push({\n+                                animation: fallbackAnimation_1\n+                            });\n+                        }\n+                        var shouldAnimate = Boolean(animations.length);\n+                        if (isInitialRender && props.initial === false && !visualElement.manuallyAnimateOnMount) {\n+                            shouldAnimate = false;\n+                        }\n+                        isInitialRender = false;\n+                        return shouldAnimate ? animate(animations) : Promise.resolve();\n+                    }\n+                    /**\n+                     * Change whether a certain animation type is active.\n+                     */\n+                    function setActive(type, isActive, options) {\n+                        var _a;\n+                        // If the active state hasn't changed, we can safely do nothing here\n+                        if (state[type].isActive === isActive) return Promise.resolve();\n+                        // Propagate active change to children\n+                        (_a = visualElement.variantChildren) === null || _a === void 0 ? void 0 : _a.forEach(function(child) {\n+                            var _a;\n+                            return (_a = child.animationState) === null || _a === void 0 ? void 0 : _a.setActive(type, isActive);\n+                        });\n+                        state[type].isActive = isActive;\n+                        var animations = animateChanges(options, type);\n+                        for (var key in state) {\n+                            state[key].protectedKeys = {};\n+                        }\n+                        return animations;\n+                    }\n+                    return {\n+                        isAnimated: isAnimated,\n+                        animateChanges: animateChanges,\n+                        setActive: setActive,\n+                        setAnimateFunction: setAnimateFunction,\n+                        getState: function() {\n+                            return state;\n+                        }\n+                    };\n+                }\n+\n+                function checkVariantsDidChange(prev, next) {\n+                    if (typeof next === \"string\") {\n+                        return next !== prev;\n+                    } else if (isVariantLabels(next)) {\n+                        return !shallowCompare(next, prev);\n+                    }\n+                    return false;\n+                }\n+\n+                function createTypeState(isActive) {\n+                    if (isActive === void 0) {\n+                        isActive = false;\n+                    }\n+                    return {\n+                        isActive: isActive,\n+                        protectedKeys: {},\n+                        needsAnimating: {},\n+                        prevResolvedValues: {}\n+                    };\n+                }\n+\n+                function createState() {\n+                    var _a;\n+                    return _a = {}, _a[exports.AnimationType.Animate] = createTypeState(true), _a[exports.AnimationType.InView] = createTypeState(), _a[exports.AnimationType.Hover] = createTypeState(), _a[exports.AnimationType.Tap] = createTypeState(), _a[exports.AnimationType.Drag] = createTypeState(), _a[exports.AnimationType.Focus] = createTypeState(), _a[exports.AnimationType.Exit] = createTypeState(), _a;\n+                }\n+                var animations = {\n+                    animation: makeRenderlessComponent(function(_a) {\n+                        var visualElement = _a.visualElement,\n+                            animate = _a.animate;\n+                        /**\n+                         * We dynamically generate the AnimationState manager as it contains a reference\n+                         * to the underlying animation library. We only want to load that if we load this,\n+                         * so people can optionally code split it out using the `m` component.\n+                         */\n+                        visualElement.animationState || (visualElement.animationState = createAnimationState(visualElement));\n+                        /**\n+                         * Subscribe any provided AnimationControls to the component's VisualElement\n+                         */\n+                        if (isAnimationControls(animate)) {\n+                            React.useEffect(function() {\n+                                return animate.subscribe(visualElement);\n+                            }, [animate]);\n+                        }\n+                    }),\n+                    exit: makeRenderlessComponent(function(props) {\n+                        var custom = props.custom,\n+                            visualElement = props.visualElement;\n+                        var _a = tslib.__read(usePresence(), 2),\n+                            isPresent = _a[0],\n+                            safeToRemove = _a[1];\n+                        var presenceContext = React.useContext(PresenceContext);\n+                        React.useEffect(function() {\n+                            var _a, _b;\n+                            visualElement.isPresent = isPresent;\n+                            var animation = (_a = visualElement.animationState) === null || _a === void 0 ? void 0 : _a.setActive(exports.AnimationType.Exit, !isPresent, {\n+                                custom: (_b = presenceContext === null || presenceContext === void 0 ? void 0 : presenceContext.custom) !== null && _b !== void 0 ? _b : custom\n+                            });\n+                            !isPresent && (animation === null || animation === void 0 ? void 0 : animation.then(safeToRemove));\n+                        }, [isPresent]);\n+                    })\n+                };\n+\n+                /**\n+                 * @internal\n+                 */\n+                var PanSession = /** @class */ function() {\n+                    function PanSession(event, handlers, _a) {\n+                        var _this = this;\n+                        var _b = _a === void 0 ? {} : _a,\n+                            transformPagePoint = _b.transformPagePoint;\n+                        /**\n+                         * @internal\n+                         */\n+                        this.startEvent = null;\n+                        /**\n+                         * @internal\n+                         */\n+                        this.lastMoveEvent = null;\n+                        /**\n+                         * @internal\n+                         */\n+                        this.lastMoveEventInfo = null;\n+                        /**\n+                         * @internal\n+                         */\n+                        this.handlers = {};\n+                        this.updatePoint = function() {\n+                            if (!(_this.lastMoveEvent && _this.lastMoveEventInfo)) return;\n+                            var info = getPanInfo(_this.lastMoveEventInfo, _this.history);\n+                            var isPanStarted = _this.startEvent !== null;\n+                            // Only start panning if the offset is larger than 3 pixels. If we make it\n+                            // any larger than this we'll want to reset the pointer history\n+                            // on the first update to avoid visual snapping to the cursoe.\n+                            var isDistancePastThreshold = popmotion.distance(info.offset, {\n+                                x: 0,\n+                                y: 0\n+                            }) >= 3;\n+                            if (!isPanStarted && !isDistancePastThreshold) return;\n+                            var point = info.point;\n+                            var timestamp = sync.getFrameData().timestamp;\n+                            _this.history.push(tslib.__assign(tslib.__assign({}, point), {\n+                                timestamp: timestamp\n+                            }));\n+                            var _a = _this.handlers,\n+                                onStart = _a.onStart,\n+                                onMove = _a.onMove;\n+                            if (!isPanStarted) {\n+                                onStart && onStart(_this.lastMoveEvent, info);\n+                                _this.startEvent = _this.lastMoveEvent;\n+                            }\n+                            onMove && onMove(_this.lastMoveEvent, info);\n+                        };\n+                        this.handlePointerMove = function(event, info) {\n+                            _this.lastMoveEvent = event;\n+                            _this.lastMoveEventInfo = transformPoint(info, _this.transformPagePoint);\n+                            // Because Safari doesn't trigger mouseup events when it's above a `<select>`\n+                            if (isMouseEvent(event) && event.buttons === 0) {\n+                                _this.handlePointerUp(event, info);\n+                                return;\n+                            }\n+                            // Throttle mouse move event to once per frame\n+                            sync__default[\"default\"].update(_this.updatePoint, true);\n+                        };\n+                        this.handlePointerUp = function(event, info) {\n+                            _this.end();\n+                            var _a = _this.handlers,\n+                                onEnd = _a.onEnd,\n+                                onSessionEnd = _a.onSessionEnd;\n+                            var panInfo = getPanInfo(transformPoint(info, _this.transformPagePoint), _this.history);\n+                            if (_this.startEvent && onEnd) {\n+                                onEnd(event, panInfo);\n+                            }\n+                            onSessionEnd && onSessionEnd(event, panInfo);\n+                        };\n+                        // If we have more than one touch, don't start detecting this gesture\n+                        if (isTouchEvent(event) && event.touches.length > 1) return;\n+                        this.handlers = handlers;\n+                        this.transformPagePoint = transformPagePoint;\n+                        var info = extractEventInfo(event);\n+                        var initialInfo = transformPoint(info, this.transformPagePoint);\n+                        var point = initialInfo.point;\n+                        var timestamp = sync.getFrameData().timestamp;\n+                        this.history = [tslib.__assign(tslib.__assign({}, point), {\n+                            timestamp: timestamp\n+                        })];\n+                        var onSessionStart = handlers.onSessionStart;\n+                        onSessionStart && onSessionStart(event, getPanInfo(initialInfo, this.history));\n+                        this.removeListeners = popmotion.pipe(addPointerEvent(window, \"pointermove\", this.handlePointerMove), addPointerEvent(window, \"pointerup\", this.handlePointerUp), addPointerEvent(window, \"pointercancel\", this.handlePointerUp));\n+                    }\n+                    PanSession.prototype.updateHandlers = function(handlers) {\n+                        this.handlers = handlers;\n+                    };\n+                    PanSession.prototype.end = function() {\n+                        this.removeListeners && this.removeListeners();\n+                        sync.cancelSync.update(this.updatePoint);\n+                    };\n+                    return PanSession;\n+                }();\n+\n+                function transformPoint(info, transformPagePoint) {\n+                    return transformPagePoint ? {\n+                        point: transformPagePoint(info.point)\n+                    } : info;\n+                }\n+\n+                function subtractPoint(a, b) {\n+                    return {\n+                        x: a.x - b.x,\n+                        y: a.y - b.y\n+                    };\n+                }\n+\n+                function getPanInfo(_a, history) {\n+                    var point = _a.point;\n+                    return {\n+                        point: point,\n+                        delta: subtractPoint(point, lastDevicePoint(history)),\n+                        offset: subtractPoint(point, startDevicePoint(history)),\n+                        velocity: getVelocity(history, 0.1)\n+                    };\n+                }\n+\n+                function startDevicePoint(history) {\n+                    return history[0];\n+                }\n+\n+                function lastDevicePoint(history) {\n+                    return history[history.length - 1];\n+                }\n+\n+                function getVelocity(history, timeDelta) {\n+                    if (history.length < 2) {\n+                        return {\n+                            x: 0,\n+                            y: 0\n+                        };\n+                    }\n+                    var i = history.length - 1;\n+                    var timestampedPoint = null;\n+                    var lastPoint = lastDevicePoint(history);\n+                    while (i >= 0) {\n+                        timestampedPoint = history[i];\n+                        if (lastPoint.timestamp - timestampedPoint.timestamp > secondsToMilliseconds(timeDelta)) {\n+                            break;\n+                        }\n+                        i--;\n+                    }\n+                    if (!timestampedPoint) {\n+                        return {\n+                            x: 0,\n+                            y: 0\n+                        };\n+                    }\n+                    var time = (lastPoint.timestamp - timestampedPoint.timestamp) / 1000;\n+                    if (time === 0) {\n+                        return {\n+                            x: 0,\n+                            y: 0\n+                        };\n+                    }\n+                    var currentVelocity = {\n+                        x: (lastPoint.x - timestampedPoint.x) / time,\n+                        y: (lastPoint.y - timestampedPoint.y) / time\n+                    };\n+                    if (currentVelocity.x === Infinity) {\n+                        currentVelocity.x = 0;\n+                    }\n+                    if (currentVelocity.y === Infinity) {\n+                        currentVelocity.y = 0;\n+                    }\n+                    return currentVelocity;\n+                }\n+\n+                function calcLength(axis) {\n+                    return axis.max - axis.min;\n+                }\n+\n+                function isNear(value, target, maxDistance) {\n+                    if (target === void 0) {\n+                        target = 0;\n+                    }\n+                    if (maxDistance === void 0) {\n+                        maxDistance = 0.01;\n+                    }\n+                    return popmotion.distance(value, target) < maxDistance;\n+                }\n+\n+                function calcAxisDelta(delta, source, target, origin) {\n+                    if (origin === void 0) {\n+                        origin = 0.5;\n+                    }\n+                    delta.origin = origin;\n+                    delta.originPoint = popmotion.mix(source.min, source.max, delta.origin);\n+                    delta.scale = calcLength(target) / calcLength(source);\n+                    if (isNear(delta.scale, 1, 0.0001) || isNaN(delta.scale)) delta.scale = 1;\n+                    delta.translate = popmotion.mix(target.min, target.max, delta.origin) - delta.originPoint;\n+                    if (isNear(delta.translate) || isNaN(delta.translate)) delta.translate = 0;\n+                }\n+\n+                function calcBoxDelta(delta, source, target, origin) {\n+                    calcAxisDelta(delta.x, source.x, target.x, origin === null || origin === void 0 ? void 0 : origin.originX);\n+                    calcAxisDelta(delta.y, source.y, target.y, origin === null || origin === void 0 ? void 0 : origin.originY);\n+                }\n+\n+                function calcRelativeAxis(target, relative, parent) {\n+                    target.min = parent.min + relative.min;\n+                    target.max = target.min + calcLength(relative);\n+                }\n+\n+                function calcRelativeBox(target, relative, parent) {\n+                    calcRelativeAxis(target.x, relative.x, parent.x);\n+                    calcRelativeAxis(target.y, relative.y, parent.y);\n+                }\n+\n+                function calcRelativeAxisPosition(target, layout, parent) {\n+                    target.min = layout.min - parent.min;\n+                    target.max = target.min + calcLength(layout);\n+                }\n+\n+                function calcRelativePosition(target, layout, parent) {\n+                    calcRelativeAxisPosition(target.x, layout.x, parent.x);\n+                    calcRelativeAxisPosition(target.y, layout.y, parent.y);\n+                }\n+\n+                /**\n+                 * Apply constraints to a point. These constraints are both physical along an\n+                 * axis, and an elastic factor that determines how much to constrain the point\n+                 * by if it does lie outside the defined parameters.\n+                 */\n+                function applyConstraints(point, _a, elastic) {\n+                    var min = _a.min,\n+                        max = _a.max;\n+                    if (min !== undefined && point < min) {\n+                        // If we have a min point defined, and this is outside of that, constrain\n+                        point = elastic ? popmotion.mix(min, point, elastic.min) : Math.max(point, min);\n+                    } else if (max !== undefined && point > max) {\n+                        // If we have a max point defined, and this is outside of that, constrain\n+                        point = elastic ? popmotion.mix(max, point, elastic.max) : Math.min(point, max);\n+                    }\n+                    return point;\n+                }\n+                /**\n+                 * Calculate constraints in terms of the viewport when defined relatively to the\n+                 * measured axis. This is measured from the nearest edge, so a max constraint of 200\n+                 * on an axis with a max value of 300 would return a constraint of 500 - axis length\n+                 */\n+                function calcRelativeAxisConstraints(axis, min, max) {\n+                    return {\n+                        min: min !== undefined ? axis.min + min : undefined,\n+                        max: max !== undefined ? axis.max + max - (axis.max - axis.min) : undefined\n+                    };\n+                }\n+                /**\n+                 * Calculate constraints in terms of the viewport when\n+                 * defined relatively to the measured bounding box.\n+                 */\n+                function calcRelativeConstraints(layoutBox, _a) {\n+                    var top = _a.top,\n+                        left = _a.left,\n+                        bottom = _a.bottom,\n+                        right = _a.right;\n+                    return {\n+                        x: calcRelativeAxisConstraints(layoutBox.x, left, right),\n+                        y: calcRelativeAxisConstraints(layoutBox.y, top, bottom)\n+                    };\n+                }\n+                /**\n+                 * Calculate viewport constraints when defined as another viewport-relative axis\n+                 */\n+                function calcViewportAxisConstraints(layoutAxis, constraintsAxis) {\n+                    var _a;\n+                    var min = constraintsAxis.min - layoutAxis.min;\n+                    var max = constraintsAxis.max - layoutAxis.max;\n+                    // If the constraints axis is actually smaller than the layout axis then we can\n+                    // flip the constraints\n+                    if (constraintsAxis.max - constraintsAxis.min < layoutAxis.max - layoutAxis.min) {\n+                        _a = tslib.__read([max, min], 2), min = _a[0], max = _a[1];\n+                    }\n+                    return {\n+                        min: min,\n+                        max: max\n+                    };\n+                }\n+                /**\n+                 * Calculate viewport constraints when defined as another viewport-relative box\n+                 */\n+                function calcViewportConstraints(layoutBox, constraintsBox) {\n+                    return {\n+                        x: calcViewportAxisConstraints(layoutBox.x, constraintsBox.x),\n+                        y: calcViewportAxisConstraints(layoutBox.y, constraintsBox.y)\n+                    };\n+                }\n+                /**\n+                 * Calculate a transform origin relative to the source axis, between 0-1, that results\n+                 * in an asthetically pleasing scale/transform needed to project from source to target.\n+                 */\n+                function calcOrigin(source, target) {\n+                    var origin = 0.5;\n+                    var sourceLength = calcLength(source);\n+                    var targetLength = calcLength(target);\n+                    if (targetLength > sourceLength) {\n+                        origin = popmotion.progress(target.min, target.max - sourceLength, source.min);\n+                    } else if (sourceLength > targetLength) {\n+                        origin = popmotion.progress(source.min, source.max - targetLength, target.min);\n+                    }\n+                    return popmotion.clamp(0, 1, origin);\n+                }\n+                /**\n+                 * Rebase the calculated viewport constraints relative to the layout.min point.\n+                 */\n+                function rebaseAxisConstraints(layout, constraints) {\n+                    var relativeConstraints = {};\n+                    if (constraints.min !== undefined) {\n+                        relativeConstraints.min = constraints.min - layout.min;\n+                    }\n+                    if (constraints.max !== undefined) {\n+                        relativeConstraints.max = constraints.max - layout.min;\n+                    }\n+                    return relativeConstraints;\n+                }\n+                var defaultElastic = 0.35;\n+                /**\n+                 * Accepts a dragElastic prop and returns resolved elastic values for each axis.\n+                 */\n+                function resolveDragElastic(dragElastic) {\n+                    if (dragElastic === void 0) {\n+                        dragElastic = defaultElastic;\n+                    }\n+                    if (dragElastic === false) {\n+                        dragElastic = 0;\n+                    } else if (dragElastic === true) {\n+                        dragElastic = defaultElastic;\n+                    }\n+                    return {\n+                        x: resolveAxisElastic(dragElastic, \"left\", \"right\"),\n+                        y: resolveAxisElastic(dragElastic, \"top\", \"bottom\")\n+                    };\n+                }\n+\n+                function resolveAxisElastic(dragElastic, minLabel, maxLabel) {\n+                    return {\n+                        min: resolvePointElastic(dragElastic, minLabel),\n+                        max: resolvePointElastic(dragElastic, maxLabel)\n+                    };\n+                }\n+\n+                function resolvePointElastic(dragElastic, label) {\n+                    var _a;\n+                    return typeof dragElastic === \"number\" ? dragElastic : (_a = dragElastic[label]) !== null && _a !== void 0 ? _a : 0;\n+                }\n+                var createAxisDelta = function() {\n+                    return {\n+                        translate: 0,\n+                        scale: 1,\n+                        origin: 0,\n+                        originPoint: 0\n+                    };\n+                };\n+                var createDelta = function() {\n+                    return {\n+                        x: createAxisDelta(),\n+                        y: createAxisDelta()\n+                    };\n+                };\n+                var createAxis = function() {\n+                    return {\n+                        min: 0,\n+                        max: 0\n+                    };\n+                };\n+                var createBox = function() {\n+                    return {\n+                        x: createAxis(),\n+                        y: createAxis()\n+                    };\n+                };\n+\n+                function eachAxis(callback) {\n+                    return [callback(\"x\"), callback(\"y\")];\n+                }\n+\n+                /**\n+                 * Bounding boxes tend to be defined as top, left, right, bottom. For various operations\n+                 * it's easier to consider each axis individually. This function returns a bounding box\n+                 * as a map of single-axis min/max values.\n+                 */\n+                function convertBoundingBoxToBox(_a) {\n+                    var top = _a.top,\n+                        left = _a.left,\n+                        right = _a.right,\n+                        bottom = _a.bottom;\n+                    return {\n+                        x: {\n+                            min: left,\n+                            max: right\n+                        },\n+                        y: {\n+                            min: top,\n+                            max: bottom\n+                        }\n+                    };\n+                }\n+\n+                function convertBoxToBoundingBox(_a) {\n+                    var x = _a.x,\n+                        y = _a.y;\n+                    return {\n+                        top: y.min,\n+                        right: x.max,\n+                        bottom: y.max,\n+                        left: x.min\n+                    };\n+                }\n+                /**\n+                 * Applies a TransformPoint function to a bounding box. TransformPoint is usually a function\n+                 * provided by Framer to allow measured points to be corrected for device scaling. This is used\n+                 * when measuring DOM elements and DOM event points.\n+                 */\n+                function transformBoxPoints(point, transformPoint) {\n+                    if (!transformPoint) return point;\n+                    var topLeft = transformPoint({\n+                        x: point.left,\n+                        y: point.top\n+                    });\n+                    var bottomRight = transformPoint({\n+                        x: point.right,\n+                        y: point.bottom\n+                    });\n+                    return {\n+                        top: topLeft.y,\n+                        left: topLeft.x,\n+                        bottom: bottomRight.y,\n+                        right: bottomRight.x\n+                    };\n+                }\n+\n+                function isIdentityScale(scale) {\n+                    return scale === undefined || scale === 1;\n+                }\n+\n+                function hasScale(_a) {\n+                    var scale = _a.scale,\n+                        scaleX = _a.scaleX,\n+                        scaleY = _a.scaleY;\n+                    return !isIdentityScale(scale) || !isIdentityScale(scaleX) || !isIdentityScale(scaleY);\n+                }\n+\n+                function hasTransform(values) {\n+                    return hasScale(values) || hasTranslate(values.x) || hasTranslate(values.y) || values.z || values.rotate || values.rotateX || values.rotateY;\n+                }\n+\n+                function hasTranslate(value) {\n+                    return value && value !== \"0%\";\n+                }\n+\n+                /**\n+                 * Scales a point based on a factor and an originPoint\n+                 */\n+                function scalePoint(point, scale, originPoint) {\n+                    var distanceFromOrigin = point - originPoint;\n+                    var scaled = scale * distanceFromOrigin;\n+                    return originPoint + scaled;\n+                }\n+                /**\n+                 * Applies a translate/scale delta to a point\n+                 */\n+                function applyPointDelta(point, translate, scale, originPoint, boxScale) {\n+                    if (boxScale !== undefined) {\n+                        point = scalePoint(point, boxScale, originPoint);\n+                    }\n+                    return scalePoint(point, scale, originPoint) + translate;\n+                }\n+                /**\n+                 * Applies a translate/scale delta to an axis\n+                 */\n+                function applyAxisDelta(axis, translate, scale, originPoint, boxScale) {\n+                    if (translate === void 0) {\n+                        translate = 0;\n+                    }\n+                    if (scale === void 0) {\n+                        scale = 1;\n+                    }\n+                    axis.min = applyPointDelta(axis.min, translate, scale, originPoint, boxScale);\n+                    axis.max = applyPointDelta(axis.max, translate, scale, originPoint, boxScale);\n+                }\n+                /**\n+                 * Applies a translate/scale delta to a box\n+                 */\n+                function applyBoxDelta(box, _a) {\n+                    var x = _a.x,\n+                        y = _a.y;\n+                    applyAxisDelta(box.x, x.translate, x.scale, x.originPoint);\n+                    applyAxisDelta(box.y, y.translate, y.scale, y.originPoint);\n+                }\n+                /**\n+                 * Apply a tree of deltas to a box. We do this to calculate the effect of all the transforms\n+                 * in a tree upon our box before then calculating how to project it into our desired viewport-relative box\n+                 *\n+                 * This is the final nested loop within updateLayoutDelta for future refactoring\n+                 */\n+                function applyTreeDeltas(box, treeScale, treePath, isSharedTransition) {\n+                    var _a, _b;\n+                    if (isSharedTransition === void 0) {\n+                        isSharedTransition = false;\n+                    }\n+                    var treeLength = treePath.length;\n+                    if (!treeLength) return;\n+                    // Reset the treeScale\n+                    treeScale.x = treeScale.y = 1;\n+                    var node;\n+                    var delta;\n+                    for (var i = 0; i < treeLength; i++) {\n+                        node = treePath[i];\n+                        delta = node.projectionDelta;\n+                        if (((_b = (_a = node.instance) === null || _a === void 0 ? void 0 : _a.style) === null || _b === void 0 ? void 0 : _b.display) === \"contents\") continue;\n+                        if (isSharedTransition && node.options.layoutScroll && node.scroll && node !== node.root) {\n+                            transformBox(box, {\n+                                x: -node.scroll.x,\n+                                y: -node.scroll.y\n+                            });\n+                        }\n+                        if (delta) {\n+                            // Incoporate each ancestor's scale into a culmulative treeScale for this component\n+                            treeScale.x *= delta.x.scale;\n+                            treeScale.y *= delta.y.scale;\n+                            // Apply each ancestor's calculated delta into this component's recorded layout box\n+                            applyBoxDelta(box, delta);\n+                        }\n+                        if (isSharedTransition && hasTransform(node.latestValues)) {\n+                            transformBox(box, node.latestValues);\n+                        }\n+                    }\n+                }\n+\n+                function translateAxis(axis, distance) {\n+                    axis.min = axis.min + distance;\n+                    axis.max = axis.max + distance;\n+                }\n+                /**\n+                 * Apply a transform to an axis from the latest resolved motion values.\n+                 * This function basically acts as a bridge between a flat motion value map\n+                 * and applyAxisDelta\n+                 */\n+                function transformAxis(axis, transforms, _a) {\n+                    var _b = tslib.__read(_a, 3),\n+                        key = _b[0],\n+                        scaleKey = _b[1],\n+                        originKey = _b[2];\n+                    var axisOrigin = transforms[originKey] !== undefined ? transforms[originKey] : 0.5;\n+                    var originPoint = popmotion.mix(axis.min, axis.max, axisOrigin);\n+                    // Apply the axis delta to the final axis\n+                    applyAxisDelta(axis, transforms[key], transforms[scaleKey], originPoint, transforms.scale);\n+                }\n+                /**\n+                 * The names of the motion values we want to apply as translation, scale and origin.\n+                 */\n+                var xKeys$1 = [\"x\", \"scaleX\", \"originX\"];\n+                var yKeys$1 = [\"y\", \"scaleY\", \"originY\"];\n+                /**\n+                 * Apply a transform to a box from the latest resolved motion values.\n+                 */\n+                function transformBox(box, transform) {\n+                    transformAxis(box.x, transform, xKeys$1);\n+                    transformAxis(box.y, transform, yKeys$1);\n+                }\n+\n+                function measureViewportBox(instance, transformPoint) {\n+                    return convertBoundingBoxToBox(transformBoxPoints(instance.getBoundingClientRect(), transformPoint));\n+                }\n+\n+                function measurePageBox(element, rootProjectionNode, transformPagePoint) {\n+                    var viewportBox = measureViewportBox(element, transformPagePoint);\n+                    var scroll = rootProjectionNode.scroll;\n+                    if (scroll) {\n+                        translateAxis(viewportBox.x, scroll.x);\n+                        translateAxis(viewportBox.y, scroll.y);\n+                    }\n+                    return viewportBox;\n+                }\n+                var elementDragControls = new WeakMap();\n+                /**\n+                 *\n+                 */\n+                // let latestPointerEvent: AnyPointerEvent\n+                var VisualElementDragControls = /** @class */ function() {\n+                    function VisualElementDragControls(visualElement) {\n+                        // This is a reference to the global drag gesture lock, ensuring only one component\n+                        // can \"capture\" the drag of one or both axes.\n+                        // TODO: Look into moving this into pansession?\n+                        this.openGlobalLock = null;\n+                        this.isDragging = false;\n+                        this.currentDirection = null;\n+                        this.originPoint = {\n+                            x: 0,\n+                            y: 0\n+                        };\n+                        /**\n+                         * The permitted boundaries of travel, in pixels.\n+                         */\n+                        this.constraints = false;\n+                        this.hasMutatedConstraints = false;\n+                        /**\n+                         * The per-axis resolved elastic values.\n+                         */\n+                        this.elastic = createBox();\n+                        this.visualElement = visualElement;\n+                    }\n+                    VisualElementDragControls.prototype.start = function(originEvent, _a) {\n+                        var _this = this;\n+                        var _b = _a === void 0 ? {} : _a,\n+                            _c = _b.snapToCursor,\n+                            snapToCursor = _c === void 0 ? false : _c;\n+                        /**\n+                         * Don't start dragging if this component is exiting\n+                         */\n+                        if (this.visualElement.isPresent === false) return;\n+                        var onSessionStart = function(event) {\n+                            // Stop any animations on both axis values immediately. This allows the user to throw and catch\n+                            // the component.\n+                            _this.stopAnimation();\n+                            if (snapToCursor) {\n+                                _this.snapToCursor(extractEventInfo(event, \"page\").point);\n+                            }\n+                        };\n+                        var onStart = function(event, info) {\n+                            var _a;\n+                            // Attempt to grab the global drag gesture lock - maybe make this part of PanSession\n+                            var _b = _this.getProps(),\n+                                drag = _b.drag,\n+                                dragPropagation = _b.dragPropagation,\n+                                onDragStart = _b.onDragStart;\n+                            if (drag && !dragPropagation) {\n+                                if (_this.openGlobalLock) _this.openGlobalLock();\n+                                _this.openGlobalLock = getGlobalLock(drag);\n+                                // If we don 't have the lock, don't start dragging\n+                                if (!_this.openGlobalLock) return;\n+                            }\n+                            _this.isDragging = true;\n+                            _this.currentDirection = null;\n+                            _this.resolveConstraints();\n+                            if (_this.visualElement.projection) {\n+                                _this.visualElement.projection.isAnimationBlocked = true;\n+                                _this.visualElement.projection.target = undefined;\n+                            }\n+                            /**\n+                             * Record gesture origin\n+                             */\n+                            eachAxis(function(axis) {\n+                                var _a, _b;\n+                                var current = _this.getAxisMotionValue(axis).get() || 0;\n+                                /**\n+                                 * If the MotionValue is a percentage value convert to px\n+                                 */\n+                                if (styleValueTypes.percent.test(current)) {\n+                                    var measuredAxis = (_b = (_a = _this.visualElement.projection) === null || _a === void 0 ? void 0 : _a.layout) === null || _b === void 0 ? void 0 : _b.actual[axis];\n+                                    if (measuredAxis) {\n+                                        var length_1 = calcLength(measuredAxis);\n+                                        current = length_1 * (parseFloat(current) / 100);\n+                                    }\n+                                }\n+                                _this.originPoint[axis] = current;\n+                            });\n+                            // Fire onDragStart event\n+                            onDragStart === null || onDragStart === void 0 ? void 0 : onDragStart(event, info);\n+                            (_a = _this.visualElement.animationState) === null || _a === void 0 ? void 0 : _a.setActive(exports.AnimationType.Drag, true);\n+                        };\n+                        var onMove = function(event, info) {\n+                            // latestPointerEvent = event\n+                            var _a = _this.getProps(),\n+                                dragPropagation = _a.dragPropagation,\n+                                dragDirectionLock = _a.dragDirectionLock,\n+                                onDirectionLock = _a.onDirectionLock,\n+                                onDrag = _a.onDrag;\n+                            // If we didn't successfully receive the gesture lock, early return.\n+                            if (!dragPropagation && !_this.openGlobalLock) return;\n+                            var offset = info.offset;\n+                            // Attempt to detect drag direction if directionLock is true\n+                            if (dragDirectionLock && _this.currentDirection === null) {\n+                                _this.currentDirection = getCurrentDirection(offset);\n+                                // If we've successfully set a direction, notify listener\n+                                if (_this.currentDirection !== null) {\n+                                    onDirectionLock === null || onDirectionLock === void 0 ? void 0 : onDirectionLock(_this.currentDirection);\n+                                }\n+                                return;\n+                            }\n+                            // Update each point with the latest position\n+                            _this.updateAxis(\"x\", info.point, offset);\n+                            _this.updateAxis(\"y\", info.point, offset);\n+                            /**\n+                             * Ideally we would leave the renderer to fire naturally at the end of\n+                             * this frame but if the element is about to change layout as the result\n+                             * of a re-render we want to ensure the browser can read the latest\n+                             * bounding box to ensure the pointer and element don't fall out of sync.\n+                             */\n+                            _this.visualElement.syncRender();\n+                            /**\n+                             * This must fire after the syncRender call as it might trigger a state\n+                             * change which itself might trigger a layout update.\n+                             */\n+                            onDrag === null || onDrag === void 0 ? void 0 : onDrag(event, info);\n+                        };\n+                        var onSessionEnd = function(event, info) {\n+                            return _this.stop(event, info);\n+                        };\n+                        this.panSession = new PanSession(originEvent, {\n+                            onSessionStart: onSessionStart,\n+                            onStart: onStart,\n+                            onMove: onMove,\n+                            onSessionEnd: onSessionEnd\n+                        }, {\n+                            transformPagePoint: this.visualElement.getTransformPagePoint()\n+                        });\n+                    };\n+                    VisualElementDragControls.prototype.stop = function(event, info) {\n+                        var isDragging = this.isDragging;\n+                        this.cancel();\n+                        if (!isDragging) return;\n+                        var velocity = info.velocity;\n+                        this.startAnimation(velocity);\n+                        var onDragEnd = this.getProps().onDragEnd;\n+                        onDragEnd === null || onDragEnd === void 0 ? void 0 : onDragEnd(event, info);\n+                    };\n+                    VisualElementDragControls.prototype.cancel = function() {\n+                        var _a, _b;\n+                        this.isDragging = false;\n+                        if (this.visualElement.projection) {\n+                            this.visualElement.projection.isAnimationBlocked = false;\n+                        }\n+                        (_a = this.panSession) === null || _a === void 0 ? void 0 : _a.end();\n+                        this.panSession = undefined;\n+                        var dragPropagation = this.getProps().dragPropagation;\n+                        if (!dragPropagation && this.openGlobalLock) {\n+                            this.openGlobalLock();\n+                            this.openGlobalLock = null;\n+                        }\n+                        (_b = this.visualElement.animationState) === null || _b === void 0 ? void 0 : _b.setActive(exports.AnimationType.Drag, false);\n+                    };\n+                    VisualElementDragControls.prototype.updateAxis = function(axis, _point, offset) {\n+                        var drag = this.getProps().drag;\n+                        // If we're not dragging this axis, do an early return.\n+                        if (!offset || !shouldDrag(axis, drag, this.currentDirection)) return;\n+                        var axisValue = this.getAxisMotionValue(axis);\n+                        var next = this.originPoint[axis] + offset[axis];\n+                        // Apply constraints\n+                        if (this.constraints && this.constraints[axis]) {\n+                            next = applyConstraints(next, this.constraints[axis], this.elastic[axis]);\n+                        }\n+                        axisValue.set(next);\n+                    };\n+                    VisualElementDragControls.prototype.resolveConstraints = function() {\n+                        var _this = this;\n+                        var _a = this.getProps(),\n+                            dragConstraints = _a.dragConstraints,\n+                            dragElastic = _a.dragElastic;\n+                        var layout = (this.visualElement.projection || {}).layout;\n+                        var prevConstraints = this.constraints;\n+                        if (dragConstraints && isRefObject(dragConstraints)) {\n+                            if (!this.constraints) {\n+                                this.constraints = this.resolveRefConstraints();\n+                            }\n+                        } else {\n+                            if (dragConstraints && layout) {\n+                                this.constraints = calcRelativeConstraints(layout.actual, dragConstraints);\n+                            } else {\n+                                this.constraints = false;\n+                            }\n+                        }\n+                        this.elastic = resolveDragElastic(dragElastic);\n+                        /**\n+                         * If we're outputting to external MotionValues, we want to rebase the measured constraints\n+                         * from viewport-relative to component-relative.\n+                         */\n+                        if (prevConstraints !== this.constraints && layout && this.constraints && !this.hasMutatedConstraints) {\n+                            eachAxis(function(axis) {\n+                                if (_this.getAxisMotionValue(axis)) {\n+                                    _this.constraints[axis] = rebaseAxisConstraints(layout.actual[axis], _this.constraints[axis]);\n+                                }\n+                            });\n+                        }\n+                    };\n+                    VisualElementDragControls.prototype.resolveRefConstraints = function() {\n+                        var _a = this.getProps(),\n+                            constraints = _a.dragConstraints,\n+                            onMeasureDragConstraints = _a.onMeasureDragConstraints;\n+                        if (!constraints || !isRefObject(constraints)) return false;\n+                        var constraintsElement = constraints.current;\n+                        heyListen.invariant(constraintsElement !== null, \"If `dragConstraints` is set as a React ref, that ref must be passed to another component's `ref` prop.\");\n+                        var projection = this.visualElement.projection;\n+                        // TODO\n+                        if (!projection || !projection.layout) return false;\n+                        var constraintsBox = measurePageBox(constraintsElement, projection.root, this.visualElement.getTransformPagePoint());\n+                        var measuredConstraints = calcViewportConstraints(projection.layout.actual, constraintsBox);\n+                        /**\n+                         * If there's an onMeasureDragConstraints listener we call it and\n+                         * if different constraints are returned, set constraints to that\n+                         */\n+                        if (onMeasureDragConstraints) {\n+                            var userConstraints = onMeasureDragConstraints(convertBoxToBoundingBox(measuredConstraints));\n+                            this.hasMutatedConstraints = !!userConstraints;\n+                            if (userConstraints) {\n+                                measuredConstraints = convertBoundingBoxToBox(userConstraints);\n+                            }\n+                        }\n+                        return measuredConstraints;\n+                    };\n+                    VisualElementDragControls.prototype.startAnimation = function(velocity) {\n+                        var _this = this;\n+                        var _a = this.getProps(),\n+                            drag = _a.drag,\n+                            dragMomentum = _a.dragMomentum,\n+                            dragElastic = _a.dragElastic,\n+                            dragTransition = _a.dragTransition,\n+                            dragSnapToOrigin = _a.dragSnapToOrigin,\n+                            onDragTransitionEnd = _a.onDragTransitionEnd;\n+                        var constraints = this.constraints || {};\n+                        var momentumAnimations = eachAxis(function(axis) {\n+                            var _a;\n+                            if (!shouldDrag(axis, drag, _this.currentDirection)) {\n+                                return;\n+                            }\n+                            var transition = (_a = constraints === null || constraints === void 0 ? void 0 : constraints[axis]) !== null && _a !== void 0 ? _a : {};\n+                            if (dragSnapToOrigin) transition = {\n+                                min: 0,\n+                                max: 0\n+                            };\n+                            /**\n+                             * Overdamp the boundary spring if `dragElastic` is disabled. There's still a frame\n+                             * of spring animations so we should look into adding a disable spring option to `inertia`.\n+                             * We could do something here where we affect the `bounceStiffness` and `bounceDamping`\n+                             * using the value of `dragElastic`.\n+                             */\n+                            var bounceStiffness = dragElastic ? 200 : 1000000;\n+                            var bounceDamping = dragElastic ? 40 : 10000000;\n+                            var inertia = tslib.__assign(tslib.__assign({\n+                                type: \"inertia\",\n+                                velocity: dragMomentum ? velocity[axis] : 0,\n+                                bounceStiffness: bounceStiffness,\n+                                bounceDamping: bounceDamping,\n+                                timeConstant: 750,\n+                                restDelta: 1,\n+                                restSpeed: 10\n+                            }, dragTransition), transition);\n+                            // If we're not animating on an externally-provided `MotionValue` we can use the\n+                            // component's animation controls which will handle interactions with whileHover (etc),\n+                            // otherwise we just have to animate the `MotionValue` itself.\n+                            return _this.startAxisValueAnimation(axis, inertia);\n+                        });\n+                        // Run all animations and then resolve the new drag constraints.\n+                        return Promise.all(momentumAnimations).then(onDragTransitionEnd);\n+                    };\n+                    VisualElementDragControls.prototype.startAxisValueAnimation = function(axis, transition) {\n+                        var axisValue = this.getAxisMotionValue(axis);\n+                        return startAnimation(axis, axisValue, 0, transition);\n+                    };\n+                    VisualElementDragControls.prototype.stopAnimation = function() {\n+                        var _this = this;\n+                        eachAxis(function(axis) {\n+                            return _this.getAxisMotionValue(axis).stop();\n+                        });\n+                    };\n+                    /**\n+                     * Drag works differently depending on which props are provided.\n+                     *\n+                     * - If _dragX and _dragY are provided, we output the gesture delta directly to those motion values.\n+                     * - Otherwise, we apply the delta to the x/y motion values.\n+                     */\n+                    VisualElementDragControls.prototype.getAxisMotionValue = function(axis) {\n+                        var _a, _b;\n+                        var dragKey = \"_drag\" + axis.toUpperCase();\n+                        var externalMotionValue = this.visualElement.getProps()[dragKey];\n+                        return externalMotionValue ? externalMotionValue : this.visualElement.getValue(axis, (_b = (_a = this.visualElement.getProps().initial) === null || _a === void 0 ? void 0 : _a[axis]) !== null && _b !== void 0 ? _b : 0);\n+                    };\n+                    VisualElementDragControls.prototype.snapToCursor = function(point) {\n+                        var _this = this;\n+                        eachAxis(function(axis) {\n+                            var drag = _this.getProps().drag;\n+                            // If we're not dragging this axis, do an early return.\n+                            if (!shouldDrag(axis, drag, _this.currentDirection)) return;\n+                            var projection = _this.visualElement.projection;\n+                            var axisValue = _this.getAxisMotionValue(axis);\n+                            if (projection && projection.layout) {\n+                                var _a = projection.layout.actual[axis],\n+                                    min = _a.min,\n+                                    max = _a.max;\n+                                axisValue.set(point[axis] - popmotion.mix(min, max, 0.5));\n+                            }\n+                        });\n+                    };\n+                    /**\n+                     * When the viewport resizes we want to check if the measured constraints\n+                     * have changed and, if so, reposition the element within those new constraints\n+                     * relative to where it was before the resize.\n+                     */\n+                    VisualElementDragControls.prototype.scalePositionWithinConstraints = function() {\n+                        var _this = this;\n+                        var _a;\n+                        var _b = this.getProps(),\n+                            drag = _b.drag,\n+                            dragConstraints = _b.dragConstraints;\n+                        var projection = this.visualElement.projection;\n+                        if (!isRefObject(dragConstraints) || !projection || !this.constraints) return;\n+                        /**\n+                         * Stop current animations as there can be visual glitching if we try to do\n+                         * this mid-animation\n+                         */\n+                        this.stopAnimation();\n+                        /**\n+                         * Record the relative position of the dragged element relative to the\n+                         * constraints box and save as a progress value.\n+                         */\n+                        var boxProgress = {\n+                            x: 0,\n+                            y: 0\n+                        };\n+                        eachAxis(function(axis) {\n+                            var axisValue = _this.getAxisMotionValue(axis);\n+                            if (axisValue) {\n+                                var latest = axisValue.get();\n+                                boxProgress[axis] = calcOrigin({\n+                                    min: latest,\n+                                    max: latest\n+                                }, _this.constraints[axis]);\n+                            }\n+                        });\n+                        /**\n+                         * Update the layout of this element and resolve the latest drag constraints\n+                         */\n+                        var transformTemplate = this.visualElement.getProps().transformTemplate;\n+                        this.visualElement.getInstance().style.transform = transformTemplate ? transformTemplate({}, \"\") : \"none\";\n+                        (_a = projection.root) === null || _a === void 0 ? void 0 : _a.updateScroll();\n+                        projection.updateLayout();\n+                        this.resolveConstraints();\n+                        /**\n+                         * For each axis, calculate the current progress of the layout axis\n+                         * within the new constraints.\n+                         */\n+                        eachAxis(function(axis) {\n+                            if (!shouldDrag(axis, drag, null)) return;\n+                            /**\n+                             * Calculate a new transform based on the previous box progress\n+                             */\n+                            var axisValue = _this.getAxisMotionValue(axis);\n+                            var _a = _this.constraints[axis],\n+                                min = _a.min,\n+                                max = _a.max;\n+                            axisValue.set(popmotion.mix(min, max, boxProgress[axis]));\n+                        });\n+                    };\n+                    VisualElementDragControls.prototype.addListeners = function() {\n+                        var _this = this;\n+                        var _a;\n+                        elementDragControls.set(this.visualElement, this);\n+                        var element = this.visualElement.getInstance();\n+                        /**\n+                         * Attach a pointerdown event listener on this DOM element to initiate drag tracking.\n+                         */\n+                        var stopPointerListener = addPointerEvent(element, \"pointerdown\", function(event) {\n+                            var _a = _this.getProps(),\n+                                drag = _a.drag,\n+                                _b = _a.dragListener,\n+                                dragListener = _b === void 0 ? true : _b;\n+                            drag && dragListener && _this.start(event);\n+                        });\n+                        var measureDragConstraints = function() {\n+                            var dragConstraints = _this.getProps().dragConstraints;\n+                            if (isRefObject(dragConstraints)) {\n+                                _this.constraints = _this.resolveRefConstraints();\n+                            }\n+                        };\n+                        var projection = this.visualElement.projection;\n+                        var stopMeasureLayoutListener = projection.addEventListener(\"measure\", measureDragConstraints);\n+                        if (projection && !projection.layout) {\n+                            (_a = projection.root) === null || _a === void 0 ? void 0 : _a.updateScroll();\n+                            projection.updateLayout();\n+                        }\n+                        measureDragConstraints();\n+                        /**\n+                         * Attach a window resize listener to scale the draggable target within its defined\n+                         * constraints as the window resizes.\n+                         */\n+                        var stopResizeListener = addDomEvent(window, \"resize\", function() {\n+                            return _this.scalePositionWithinConstraints();\n+                        });\n+                        /**\n+                         * If the element's layout changes, calculate the delta and apply that to\n+                         * the drag gesture's origin point.\n+                         */\n+                        projection.addEventListener(\"didUpdate\", function(_a) {\n+                            var delta = _a.delta,\n+                                hasLayoutChanged = _a.hasLayoutChanged;\n+                            if (_this.isDragging && hasLayoutChanged) {\n+                                eachAxis(function(axis) {\n+                                    var motionValue = _this.getAxisMotionValue(axis);\n+                                    if (!motionValue) return;\n+                                    _this.originPoint[axis] += delta[axis].translate;\n+                                    motionValue.set(motionValue.get() + delta[axis].translate);\n+                                });\n+                                _this.visualElement.syncRender();\n+                            }\n+                        });\n+                        return function() {\n+                            stopResizeListener();\n+                            stopPointerListener();\n+                            stopMeasureLayoutListener();\n+                        };\n+                    };\n+                    VisualElementDragControls.prototype.getProps = function() {\n+                        var props = this.visualElement.getProps();\n+                        var _a = props.drag,\n+                            drag = _a === void 0 ? false : _a,\n+                            _b = props.dragDirectionLock,\n+                            dragDirectionLock = _b === void 0 ? false : _b,\n+                            _c = props.dragPropagation,\n+                            dragPropagation = _c === void 0 ? false : _c,\n+                            _d = props.dragConstraints,\n+                            dragConstraints = _d === void 0 ? false : _d,\n+                            _e = props.dragElastic,\n+                            dragElastic = _e === void 0 ? defaultElastic : _e,\n+                            _f = props.dragMomentum,\n+                            dragMomentum = _f === void 0 ? true : _f;\n+                        return tslib.__assign(tslib.__assign({}, props), {\n+                            drag: drag,\n+                            dragDirectionLock: dragDirectionLock,\n+                            dragPropagation: dragPropagation,\n+                            dragConstraints: dragConstraints,\n+                            dragElastic: dragElastic,\n+                            dragMomentum: dragMomentum\n+                        });\n+                    };\n+                    return VisualElementDragControls;\n+                }();\n+\n+                function shouldDrag(direction, drag, currentDirection) {\n+                    return (drag === true || drag === direction) && (currentDirection === null || currentDirection === direction);\n+                }\n+                /**\n+                 * Based on an x/y offset determine the current drag direction. If both axis' offsets are lower\n+                 * than the provided threshold, return `null`.\n+                 *\n+                 * @param offset - The x/y offset from origin.\n+                 * @param lockThreshold - (Optional) - the minimum absolute offset before we can determine a drag direction.\n+                 */\n+                function getCurrentDirection(offset, lockThreshold) {\n+                    if (lockThreshold === void 0) {\n+                        lockThreshold = 10;\n+                    }\n+                    var direction = null;\n+                    if (Math.abs(offset.y) > lockThreshold) {\n+                        direction = \"y\";\n+                    } else if (Math.abs(offset.x) > lockThreshold) {\n+                        direction = \"x\";\n+                    }\n+                    return direction;\n+                }\n+\n+                /**\n+                 * A hook that allows an element to be dragged.\n+                 *\n+                 * @internal\n+                 */\n+                function useDrag(props) {\n+                    var groupDragControls = props.dragControls,\n+                        visualElement = props.visualElement;\n+                    var dragControls = useConstant(function() {\n+                        return new VisualElementDragControls(visualElement);\n+                    });\n+                    // If we've been provided a DragControls for manual control over the drag gesture,\n+                    // subscribe this component to it on mount.\n+                    React.useEffect(function() {\n+                        return groupDragControls && groupDragControls.subscribe(dragControls);\n+                    }, [dragControls, groupDragControls]);\n+                    // Apply the event listeners to the element\n+                    React.useEffect(function() {\n+                        return dragControls.addListeners();\n+                    }, [dragControls]);\n+                }\n+\n+                /**\n+                 *\n+                 * @param handlers -\n+                 * @param ref -\n+                 *\n+                 * @privateRemarks\n+                 * Currently this sets new pan gesture functions every render. The memo route has been explored\n+                 * in the past but ultimately we're still creating new functions every render. An optimisation\n+                 * to explore is creating the pan gestures and loading them into a `ref`.\n+                 *\n+                 * @internal\n+                 */\n+                function usePanGesture(_a) {\n+                    var onPan = _a.onPan,\n+                        onPanStart = _a.onPanStart,\n+                        onPanEnd = _a.onPanEnd,\n+                        onPanSessionStart = _a.onPanSessionStart,\n+                        visualElement = _a.visualElement;\n+                    var hasPanEvents = onPan || onPanStart || onPanEnd || onPanSessionStart;\n+                    var panSession = React.useRef(null);\n+                    var transformPagePoint = React.useContext(MotionConfigContext).transformPagePoint;\n+                    var handlers = {\n+                        onSessionStart: onPanSessionStart,\n+                        onStart: onPanStart,\n+                        onMove: onPan,\n+                        onEnd: function(event, info) {\n+                            panSession.current = null;\n+                            onPanEnd && onPanEnd(event, info);\n+                        }\n+                    };\n+                    React.useEffect(function() {\n+                        if (panSession.current !== null) {\n+                            panSession.current.updateHandlers(handlers);\n+                        }\n+                    });\n+\n+                    function onPointerDown(event) {\n+                        panSession.current = new PanSession(event, handlers, {\n+                            transformPagePoint: transformPagePoint\n+                        });\n+                    }\n+                    usePointerEvent(visualElement, \"pointerdown\", hasPanEvents && onPointerDown);\n+                    useUnmountEffect(function() {\n+                        return panSession.current && panSession.current.end();\n+                    });\n+                }\n+                var drag = {\n+                    pan: makeRenderlessComponent(usePanGesture),\n+                    drag: makeRenderlessComponent(useDrag)\n+                };\n+                var names = [\"LayoutMeasure\", \"BeforeLayoutMeasure\", \"LayoutUpdate\", \"ViewportBoxUpdate\", \"Update\", \"Render\", \"AnimationComplete\", \"LayoutAnimationComplete\", \"AnimationStart\", \"LayoutAnimationStart\", \"SetAxisTarget\", \"Unmount\"];\n+\n+                function createLifecycles() {\n+                    var managers = names.map(function() {\n+                        return new SubscriptionManager();\n+                    });\n+                    var propSubscriptions = {};\n+                    var lifecycles = {\n+                        clearAllListeners: function() {\n+                            return managers.forEach(function(manager) {\n+                                return manager.clear();\n+                            });\n+                        },\n+                        updatePropListeners: function(props) {\n+                            names.forEach(function(name) {\n+                                var _a;\n+                                var on = \"on\" + name;\n+                                var propListener = props[on];\n+                                // Unsubscribe existing subscription\n+                                (_a = propSubscriptions[name]) === null || _a === void 0 ? void 0 : _a.call(propSubscriptions);\n+                                // Add new subscription\n+                                if (propListener) {\n+                                    propSubscriptions[name] = lifecycles[on](propListener);\n+                                }\n+                            });\n+                        }\n+                    };\n+                    managers.forEach(function(manager, i) {\n+                        lifecycles[\"on\" + names[i]] = function(handler) {\n+                            return manager.add(handler);\n+                        };\n+                        lifecycles[\"notify\" + names[i]] = function() {\n+                            var args = [];\n+                            for (var _i = 0; _i < arguments.length; _i++) {\n+                                args[_i] = arguments[_i];\n+                            }\n+                            return manager.notify.apply(manager, tslib.__spreadArray([], tslib.__read(args), false));\n+                        };\n+                    });\n+                    return lifecycles;\n+                }\n+\n+                function updateMotionValuesFromProps(element, next, prev) {\n+                    var _a;\n+                    for (var key in next) {\n+                        var nextValue = next[key];\n+                        var prevValue = prev[key];\n+                        if (isMotionValue(nextValue)) {\n+                            /**\n+                             * If this is a motion value found in props or style, we want to add it\n+                             * to our visual element's motion value map.\n+                             */\n+                            element.addValue(key, nextValue);\n+                            /**\n+                             * Check the version of the incoming motion value with this version\n+                             * and warn against mismatches.\n+                             */\n+                            if (true) {\n+                                warnOnce(nextValue.version === \"6.5.1\", \"Attempting to mix Framer Motion versions \".concat(nextValue.version, \" with 6.5.1 may not work as expected.\"));\n+                            }\n+                        } else if (isMotionValue(prevValue)) {\n+                            /**\n+                             * If we're swapping to a new motion value, create a new motion value\n+                             * from that\n+                             */\n+                            element.addValue(key, motionValue(nextValue));\n+                        } else if (prevValue !== nextValue) {\n+                            /**\n+                             * If this is a flat value that has changed, update the motion value\n+                             * or create one if it doesn't exist. We only want to do this if we're\n+                             * not handling the value with our animation state.\n+                             */\n+                            if (element.hasValue(key)) {\n+                                var existingValue = element.getValue(key);\n+                                // TODO: Only update values that aren't being animated or even looked at\n+                                !existingValue.hasAnimated && existingValue.set(nextValue);\n+                            } else {\n+                                element.addValue(key, motionValue((_a = element.getStaticValue(key)) !== null && _a !== void 0 ? _a : nextValue));\n+                            }\n+                        }\n+                    }\n+                    // Handle removed values\n+                    for (var key in prev) {\n+                        if (next[key] === undefined) element.removeValue(key);\n+                    }\n+                    return next;\n+                }\n+                var visualElement = function(_a) {\n+                    var _b = _a.treeType,\n+                        treeType = _b === void 0 ? \"\" : _b,\n+                        build = _a.build,\n+                        getBaseTarget = _a.getBaseTarget,\n+                        makeTargetAnimatable = _a.makeTargetAnimatable,\n+                        measureViewportBox = _a.measureViewportBox,\n+                        renderInstance = _a.render,\n+                        readValueFromInstance = _a.readValueFromInstance,\n+                        removeValueFromRenderState = _a.removeValueFromRenderState,\n+                        sortNodePosition = _a.sortNodePosition,\n+                        scrapeMotionValuesFromProps = _a.scrapeMotionValuesFromProps;\n+                    return function(_a, options) {\n+                        var parent = _a.parent,\n+                            props = _a.props,\n+                            presenceId = _a.presenceId,\n+                            blockInitialAnimation = _a.blockInitialAnimation,\n+                            visualState = _a.visualState,\n+                            shouldReduceMotion = _a.shouldReduceMotion;\n+                        if (options === void 0) {\n+                            options = {};\n+                        }\n+                        var isMounted = false;\n+                        var latestValues = visualState.latestValues,\n+                            renderState = visualState.renderState;\n+                        /**\n+                         * The instance of the render-specific node that will be hydrated by the\n+                         * exposed React ref. So for example, this visual element can host a\n+                         * HTMLElement, plain object, or Three.js object. The functions provided\n+                         * in VisualElementConfig allow us to interface with this instance.\n+                         */\n+                        var instance;\n+                        /**\n+                         * Manages the subscriptions for a visual element's lifecycle, for instance\n+                         * onRender\n+                         */\n+                        var lifecycles = createLifecycles();\n+                        /**\n+                         * A map of all motion values attached to this visual element. Motion\n+                         * values are source of truth for any given animated value. A motion\n+                         * value might be provided externally by the component via props.\n+                         */\n+                        var values = new Map();\n+                        /**\n+                         * A map of every subscription that binds the provided or generated\n+                         * motion values onChange listeners to this visual element.\n+                         */\n+                        var valueSubscriptions = new Map();\n+                        /**\n+                         * A reference to the previously-provided motion values as returned\n+                         * from scrapeMotionValuesFromProps. We use the keys in here to determine\n+                         * if any motion values need to be removed after props are updated.\n+                         */\n+                        var prevMotionValues = {};\n+                        /**\n+                         * When values are removed from all animation props we need to search\n+                         * for a fallback value to animate to. These values are tracked in baseTarget.\n+                         */\n+                        var baseTarget = tslib.__assign({}, latestValues);\n+                        // Internal methods ========================\n+                        /**\n+                         * On mount, this will be hydrated with a callback to disconnect\n+                         * this visual element from its parent on unmount.\n+                         */\n+                        var removeFromVariantTree;\n+                        /**\n+                         * Render the element with the latest styles outside of the React\n+                         * render lifecycle\n+                         */\n+                        function render() {\n+                            if (!instance || !isMounted) return;\n+                            triggerBuild();\n+                            renderInstance(instance, renderState, props.style, element.projection);\n+                        }\n+\n+                        function triggerBuild() {\n+                            build(element, renderState, latestValues, options, props);\n+                        }\n+\n+                        function update() {\n+                            lifecycles.notifyUpdate(latestValues);\n+                        }\n+                        /**\n+                         *\n+                         */\n+                        function bindToMotionValue(key, value) {\n+                            var removeOnChange = value.onChange(function(latestValue) {\n+                                latestValues[key] = latestValue;\n+                                props.onUpdate && sync__default[\"default\"].update(update, false, true);\n+                            });\n+                            var removeOnRenderRequest = value.onRenderRequest(element.scheduleRender);\n+                            valueSubscriptions.set(key, function() {\n+                                removeOnChange();\n+                                removeOnRenderRequest();\n+                            });\n+                        }\n+                        /**\n+                         * Any motion values that are provided to the element when created\n+                         * aren't yet bound to the element, as this would technically be impure.\n+                         * However, we iterate through the motion values and set them to the\n+                         * initial values for this component.\n+                         *\n+                         * TODO: This is impure and we should look at changing this to run on mount.\n+                         * Doing so will break some tests but this isn't neccessarily a breaking change,\n+                         * more a reflection of the test.\n+                         */\n+                        var initialMotionValues = scrapeMotionValuesFromProps(props);\n+                        for (var key in initialMotionValues) {\n+                            var value = initialMotionValues[key];\n+                            if (latestValues[key] !== undefined && isMotionValue(value)) {\n+                                value.set(latestValues[key], false);\n+                            }\n+                        }\n+                        /**\n+                         * Determine what role this visual element should take in the variant tree.\n+                         */\n+                        var isControllingVariants = checkIfControllingVariants(props);\n+                        var isVariantNode = checkIfVariantNode(props);\n+                        var element = tslib.__assign(tslib.__assign({\n+                            treeType: treeType,\n+                            /**\n+                             * This is a mirror of the internal instance prop, which keeps\n+                             * VisualElement type-compatible with React's RefObject.\n+                             */\n+                            current: null,\n+                            /**\n+                             * The depth of this visual element within the visual element tree.\n+                             */\n+                            depth: parent ? parent.depth + 1 : 0,\n+                            parent: parent,\n+                            children: new Set(),\n+                            /**\n+                             *\n+                             */\n+                            presenceId: presenceId,\n+                            shouldReduceMotion: shouldReduceMotion,\n+                            /**\n+                             * If this component is part of the variant tree, it should track\n+                             * any children that are also part of the tree. This is essentially\n+                             * a shadow tree to simplify logic around how to stagger over children.\n+                             */\n+                            variantChildren: isVariantNode ? new Set() : undefined,\n+                            /**\n+                             * Whether this instance is visible. This can be changed imperatively\n+                             * by the projection tree, is analogous to CSS's visibility in that\n+                             * hidden elements should take up layout, and needs enacting by the configured\n+                             * render function.\n+                             */\n+                            isVisible: undefined,\n+                            /**\n+                             * Normally, if a component is controlled by a parent's variants, it can\n+                             * rely on that ancestor to trigger animations further down the tree.\n+                             * However, if a component is created after its parent is mounted, the parent\n+                             * won't trigger that mount animation so the child needs to.\n+                             *\n+                             * TODO: This might be better replaced with a method isParentMounted\n+                             */\n+                            manuallyAnimateOnMount: Boolean(parent === null || parent === void 0 ? void 0 : parent.isMounted()),\n+                            /**\n+                             * This can be set by AnimatePresence to force components that mount\n+                             * at the same time as it to mount as if they have initial={false} set.\n+                             */\n+                            blockInitialAnimation: blockInitialAnimation,\n+                            /**\n+                             * Determine whether this component has mounted yet. This is mostly used\n+                             * by variant children to determine whether they need to trigger their\n+                             * own animations on mount.\n+                             */\n+                            isMounted: function() {\n+                                return Boolean(instance);\n+                            },\n+                            mount: function(newInstance) {\n+                                isMounted = true;\n+                                instance = element.current = newInstance;\n+                                if (element.projection) {\n+                                    element.projection.mount(newInstance);\n+                                }\n+                                if (isVariantNode && parent && !isControllingVariants) {\n+                                    removeFromVariantTree = parent === null || parent === void 0 ? void 0 : parent.addVariantChild(element);\n+                                }\n+                                values.forEach(function(value, key) {\n+                                    return bindToMotionValue(key, value);\n+                                });\n+                                parent === null || parent === void 0 ? void 0 : parent.children.add(element);\n+                                element.setProps(props);\n+                            },\n+                            /**\n+                             *\n+                             */\n+                            unmount: function() {\n+                                var _a;\n+                                (_a = element.projection) === null || _a === void 0 ? void 0 : _a.unmount();\n+                                sync.cancelSync.update(update);\n+                                sync.cancelSync.render(render);\n+                                valueSubscriptions.forEach(function(remove) {\n+                                    return remove();\n+                                });\n+                                removeFromVariantTree === null || removeFromVariantTree === void 0 ? void 0 : removeFromVariantTree();\n+                                parent === null || parent === void 0 ? void 0 : parent.children.delete(element);\n+                                lifecycles.clearAllListeners();\n+                                instance = undefined;\n+                                isMounted = false;\n+                            },\n+                            /**\n+                             * Add a child visual element to our set of children.\n+                             */\n+                            addVariantChild: function(child) {\n+                                var _a;\n+                                var closestVariantNode = element.getClosestVariantNode();\n+                                if (closestVariantNode) {\n+                                    (_a = closestVariantNode.variantChildren) === null || _a === void 0 ? void 0 : _a.add(child);\n+                                    return function() {\n+                                        return closestVariantNode.variantChildren.delete(child);\n+                                    };\n+                                }\n+                            },\n+                            sortNodePosition: function(other) {\n+                                /**\n+                                 * If these nodes aren't even of the same type we can't compare their depth.\n+                                 */\n+                                if (!sortNodePosition || treeType !== other.treeType) return 0;\n+                                return sortNodePosition(element.getInstance(), other.getInstance());\n+                            },\n+                            /**\n+                             * Returns the closest variant node in the tree starting from\n+                             * this visual element.\n+                             */\n+                            getClosestVariantNode: function() {\n+                                return isVariantNode ? element : parent === null || parent === void 0 ? void 0 : parent.getClosestVariantNode();\n+                            },\n+                            /**\n+                             * Expose the latest layoutId prop.\n+                             */\n+                            getLayoutId: function() {\n+                                return props.layoutId;\n+                            },\n+                            /**\n+                             * Returns the current instance.\n+                             */\n+                            getInstance: function() {\n+                                return instance;\n+                            },\n+                            /**\n+                             * Get/set the latest static values.\n+                             */\n+                            getStaticValue: function(key) {\n+                                return latestValues[key];\n+                            },\n+                            setStaticValue: function(key, value) {\n+                                return latestValues[key] = value;\n+                            },\n+                            /**\n+                             * Returns the latest motion value state. Currently only used to take\n+                             * a snapshot of the visual element - perhaps this can return the whole\n+                             * visual state\n+                             */\n+                            getLatestValues: function() {\n+                                return latestValues;\n+                            },\n+                            /**\n+                             * Set the visiblity of the visual element. If it's changed, schedule\n+                             * a render to reflect these changes.\n+                             */\n+                            setVisibility: function(visibility) {\n+                                if (element.isVisible === visibility) return;\n+                                element.isVisible = visibility;\n+                                element.scheduleRender();\n+                            },\n+                            /**\n+                             * Make a target animatable by Popmotion. For instance, if we're\n+                             * trying to animate width from 100px to 100vw we need to measure 100vw\n+                             * in pixels to determine what we really need to animate to. This is also\n+                             * pluggable to support Framer's custom value types like Color,\n+                             * and CSS variables.\n+                             */\n+                            makeTargetAnimatable: function(target, canMutate) {\n+                                if (canMutate === void 0) {\n+                                    canMutate = true;\n+                                }\n+                                return makeTargetAnimatable(element, target, props, canMutate);\n+                            },\n+                            /**\n+                             * Measure the current viewport box with or without transforms.\n+                             * Only measures axis-aligned boxes, rotate and skew must be manually\n+                             * removed with a re-render to work.\n+                             */\n+                            measureViewportBox: function() {\n+                                return measureViewportBox(instance, props);\n+                            },\n+                            // Motion values ========================\n+                            /**\n+                             * Add a motion value and bind it to this visual element.\n+                             */\n+                            addValue: function(key, value) {\n+                                // Remove existing value if it exists\n+                                if (element.hasValue(key)) element.removeValue(key);\n+                                values.set(key, value);\n+                                latestValues[key] = value.get();\n+                                bindToMotionValue(key, value);\n+                            },\n+                            /**\n+                             * Remove a motion value and unbind any active subscriptions.\n+                             */\n+                            removeValue: function(key) {\n+                                var _a;\n+                                values.delete(key);\n+                                (_a = valueSubscriptions.get(key)) === null || _a === void 0 ? void 0 : _a();\n+                                valueSubscriptions.delete(key);\n+                                delete latestValues[key];\n+                                removeValueFromRenderState(key, renderState);\n+                            },\n+                            /**\n+                             * Check whether we have a motion value for this key\n+                             */\n+                            hasValue: function(key) {\n+                                return values.has(key);\n+                            },\n+                            /**\n+                             * Get a motion value for this key. If called with a default\n+                             * value, we'll create one if none exists.\n+                             */\n+                            getValue: function(key, defaultValue) {\n+                                var value = values.get(key);\n+                                if (value === undefined && defaultValue !== undefined) {\n+                                    value = motionValue(defaultValue);\n+                                    element.addValue(key, value);\n+                                }\n+                                return value;\n+                            },\n+                            /**\n+                             * Iterate over our motion values.\n+                             */\n+                            forEachValue: function(callback) {\n+                                return values.forEach(callback);\n+                            },\n+                            /**\n+                             * If we're trying to animate to a previously unencountered value,\n+                             * we need to check for it in our state and as a last resort read it\n+                             * directly from the instance (which might have performance implications).\n+                             */\n+                            readValue: function(key) {\n+                                var _a;\n+                                return (_a = latestValues[key]) !== null && _a !== void 0 ? _a : readValueFromInstance(instance, key, options);\n+                            },\n+                            /**\n+                             * Set the base target to later animate back to. This is currently\n+                             * only hydrated on creation and when we first read a value.\n+                             */\n+                            setBaseTarget: function(key, value) {\n+                                baseTarget[key] = value;\n+                            },\n+                            /**\n+                             * Find the base target for a value thats been removed from all animation\n+                             * props.\n+                             */\n+                            getBaseTarget: function(key) {\n+                                if (getBaseTarget) {\n+                                    var target = getBaseTarget(props, key);\n+                                    if (target !== undefined && !isMotionValue(target)) return target;\n+                                }\n+                                return baseTarget[key];\n+                            }\n+                        }, lifecycles), {\n+                            /**\n+                             * Build the renderer state based on the latest visual state.\n+                             */\n+                            build: function() {\n+                                triggerBuild();\n+                                return renderState;\n+                            },\n+                            /**\n+                             * Schedule a render on the next animation frame.\n+                             */\n+                            scheduleRender: function() {\n+                                sync__default[\"default\"].render(render, false, true);\n+                            },\n+                            /**\n+                             * Synchronously fire render. It's prefered that we batch renders but\n+                             * in many circumstances, like layout measurement, we need to run this\n+                             * synchronously. However in those instances other measures should be taken\n+                             * to batch reads/writes.\n+                             */\n+                            syncRender: render,\n+                            /**\n+                             * Update the provided props. Ensure any newly-added motion values are\n+                             * added to our map, old ones removed, and listeners updated.\n+                             */\n+                            setProps: function(newProps) {\n+                                if (newProps.transformTemplate || props.transformTemplate) {\n+                                    element.scheduleRender();\n+                                }\n+                                props = newProps;\n+                                lifecycles.updatePropListeners(newProps);\n+                                prevMotionValues = updateMotionValuesFromProps(element, scrapeMotionValuesFromProps(props), prevMotionValues);\n+                            },\n+                            getProps: function() {\n+                                return props;\n+                            },\n+                            // Variants ==============================\n+                            /**\n+                             * Returns the variant definition with a given name.\n+                             */\n+                            getVariant: function(name) {\n+                                var _a;\n+                                return (_a = props.variants) === null || _a === void 0 ? void 0 : _a[name];\n+                            },\n+                            /**\n+                             * Returns the defined default transition on this component.\n+                             */\n+                            getDefaultTransition: function() {\n+                                return props.transition;\n+                            },\n+                            getTransformPagePoint: function() {\n+                                return props.transformPagePoint;\n+                            },\n+                            /**\n+                             * Used by child variant nodes to get the closest ancestor variant props.\n+                             */\n+                            getVariantContext: function(startAtParent) {\n+                                if (startAtParent === void 0) {\n+                                    startAtParent = false;\n+                                }\n+                                if (startAtParent) return parent === null || parent === void 0 ? void 0 : parent.getVariantContext();\n+                                if (!isControllingVariants) {\n+                                    var context_1 = (parent === null || parent === void 0 ? void 0 : parent.getVariantContext()) || {};\n+                                    if (props.initial !== undefined) {\n+                                        context_1.initial = props.initial;\n+                                    }\n+                                    return context_1;\n+                                }\n+                                var context = {};\n+                                for (var i = 0; i < numVariantProps; i++) {\n+                                    var name_1 = variantProps[i];\n+                                    var prop = props[name_1];\n+                                    if (isVariantLabel(prop) || prop === false) {\n+                                        context[name_1] = prop;\n+                                    }\n+                                }\n+                                return context;\n+                            }\n+                        });\n+                        return element;\n+                    };\n+                };\n+                var variantProps = tslib.__spreadArray([\"initial\"], tslib.__read(variantPriorityOrder), false);\n+                var numVariantProps = variantProps.length;\n+\n+                function isCSSVariable(value) {\n+                    return typeof value === \"string\" && value.startsWith(\"var(--\");\n+                }\n+                /**\n+                 * Parse Framer's special CSS variable format into a CSS token and a fallback.\n+                 *\n+                 * ```\n+                 * `var(--foo, #fff)` => [`--foo`, '#fff']\n+                 * ```\n+                 *\n+                 * @param current\n+                 */\n+                var cssVariableRegex = /var\\((--[a-zA-Z0-9-_]+),? ?([a-zA-Z0-9 ()%#.,-]+)?\\)/;\n+\n+                function parseCSSVariable(current) {\n+                    var match = cssVariableRegex.exec(current);\n+                    if (!match) return [, ];\n+                    var _a = tslib.__read(match, 3),\n+                        token = _a[1],\n+                        fallback = _a[2];\n+                    return [token, fallback];\n+                }\n+                var maxDepth = 4;\n+\n+                function getVariableValue(current, element, depth) {\n+                    if (depth === void 0) {\n+                        depth = 1;\n+                    }\n+                    heyListen.invariant(depth <= maxDepth, \"Max CSS variable fallback depth detected in property \\\"\".concat(current, \"\\\". This may indicate a circular fallback dependency.\"));\n+                    var _a = tslib.__read(parseCSSVariable(current), 2),\n+                        token = _a[0],\n+                        fallback = _a[1];\n+                    // No CSS variable detected\n+                    if (!token) return;\n+                    // Attempt to read this CSS variable off the element\n+                    var resolved = window.getComputedStyle(element).getPropertyValue(token);\n+                    if (resolved) {\n+                        return resolved.trim();\n+                    } else if (isCSSVariable(fallback)) {\n+                        // The fallback might itself be a CSS variable, in which case we attempt to resolve it too.\n+                        return getVariableValue(fallback, element, depth + 1);\n+                    } else {\n+                        return fallback;\n+                    }\n+                }\n+                /**\n+                 * Resolve CSS variables from\n+                 *\n+                 * @internal\n+                 */\n+                function resolveCSSVariables(visualElement, _a, transitionEnd) {\n+                    var _b;\n+                    var target = tslib.__rest(_a, []);\n+                    var element = visualElement.getInstance();\n+                    if (!(element instanceof Element)) return {\n+                        target: target,\n+                        transitionEnd: transitionEnd\n+                    };\n+                    // If `transitionEnd` isn't `undefined`, clone it. We could clone `target` and `transitionEnd`\n+                    // only if they change but I think this reads clearer and this isn't a performance-critical path.\n+                    if (transitionEnd) {\n+                        transitionEnd = tslib.__assign({}, transitionEnd);\n+                    }\n+                    // Go through existing `MotionValue`s and ensure any existing CSS variables are resolved\n+                    visualElement.forEachValue(function(value) {\n+                        var current = value.get();\n+                        if (!isCSSVariable(current)) return;\n+                        var resolved = getVariableValue(current, element);\n+                        if (resolved) value.set(resolved);\n+                    });\n+                    // Cycle through every target property and resolve CSS variables. Currently\n+                    // we only read single-var properties like `var(--foo)`, not `calc(var(--foo) + 20px)`\n+                    for (var key in target) {\n+                        var current = target[key];\n+                        if (!isCSSVariable(current)) continue;\n+                        var resolved = getVariableValue(current, element);\n+                        if (!resolved) continue;\n+                        // Clone target if it hasn't already been\n+                        target[key] = resolved;\n+                        // If the user hasn't already set this key on `transitionEnd`, set it to the unresolved\n+                        // CSS variable. This will ensure that after the animation the component will reflect\n+                        // changes in the value of the CSS variable.\n+                        if (transitionEnd)(_b = transitionEnd[key]) !== null && _b !== void 0 ? _b : transitionEnd[key] = current;\n+                    }\n+                    return {\n+                        target: target,\n+                        transitionEnd: transitionEnd\n+                    };\n+                }\n+                var positionalKeys = new Set([\"width\", \"height\", \"top\", \"left\", \"right\", \"bottom\", \"x\", \"y\"]);\n+                var isPositionalKey = function(key) {\n+                    return positionalKeys.has(key);\n+                };\n+                var hasPositionalKey = function(target) {\n+                    return Object.keys(target).some(isPositionalKey);\n+                };\n+                var setAndResetVelocity = function(value, to) {\n+                    // Looks odd but setting it twice doesn't render, it'll just\n+                    // set both prev and current to the latest value\n+                    value.set(to, false);\n+                    value.set(to);\n+                };\n+                var isNumOrPxType = function(v) {\n+                    return v === styleValueTypes.number || v === styleValueTypes.px;\n+                };\n+                var BoundingBoxDimension;\n+                (function(BoundingBoxDimension) {\n+                    BoundingBoxDimension[\"width\"] = \"width\";\n+                    BoundingBoxDimension[\"height\"] = \"height\";\n+                    BoundingBoxDimension[\"left\"] = \"left\";\n+                    BoundingBoxDimension[\"right\"] = \"right\";\n+                    BoundingBoxDimension[\"top\"] = \"top\";\n+                    BoundingBoxDimension[\"bottom\"] = \"bottom\";\n+                })(BoundingBoxDimension || (BoundingBoxDimension = {}));\n+                var getPosFromMatrix = function(matrix, pos) {\n+                    return parseFloat(matrix.split(\", \")[pos]);\n+                };\n+                var getTranslateFromMatrix = function(pos2, pos3) {\n+                    return function(_bbox, _a) {\n+                        var transform = _a.transform;\n+                        if (transform === \"none\" || !transform) return 0;\n+                        var matrix3d = transform.match(/^matrix3d\\((.+)\\)$/);\n+                        if (matrix3d) {\n+                            return getPosFromMatrix(matrix3d[1], pos3);\n+                        } else {\n+                            var matrix = transform.match(/^matrix\\((.+)\\)$/);\n+                            if (matrix) {\n+                                return getPosFromMatrix(matrix[1], pos2);\n+                            } else {\n+                                return 0;\n+                            }\n+                        }\n+                    };\n+                };\n+                var transformKeys = new Set([\"x\", \"y\", \"z\"]);\n+                var nonTranslationalTransformKeys = transformProps.filter(function(key) {\n+                    return !transformKeys.has(key);\n+                });\n+\n+                function removeNonTranslationalTransform(visualElement) {\n+                    var removedTransforms = [];\n+                    nonTranslationalTransformKeys.forEach(function(key) {\n+                        var value = visualElement.getValue(key);\n+                        if (value !== undefined) {\n+                            removedTransforms.push([key, value.get()]);\n+                            value.set(key.startsWith(\"scale\") ? 1 : 0);\n+                        }\n+                    });\n+                    // Apply changes to element before measurement\n+                    if (removedTransforms.length) visualElement.syncRender();\n+                    return removedTransforms;\n+                }\n+                var positionalValues = {\n+                    // Dimensions\n+                    width: function(_a, _b) {\n+                        var x = _a.x;\n+                        var _c = _b.paddingLeft,\n+                            paddingLeft = _c === void 0 ? \"0\" : _c,\n+                            _d = _b.paddingRight,\n+                            paddingRight = _d === void 0 ? \"0\" : _d;\n+                        return x.max - x.min - parseFloat(paddingLeft) - parseFloat(paddingRight);\n+                    },\n+                    height: function(_a, _b) {\n+                        var y = _a.y;\n+                        var _c = _b.paddingTop,\n+                            paddingTop = _c === void 0 ? \"0\" : _c,\n+                            _d = _b.paddingBottom,\n+                            paddingBottom = _d === void 0 ? \"0\" : _d;\n+                        return y.max - y.min - parseFloat(paddingTop) - parseFloat(paddingBottom);\n+                    },\n+                    top: function(_bbox, _a) {\n+                        var top = _a.top;\n+                        return parseFloat(top);\n+                    },\n+                    left: function(_bbox, _a) {\n+                        var left = _a.left;\n+                        return parseFloat(left);\n+                    },\n+                    bottom: function(_a, _b) {\n+                        var y = _a.y;\n+                        var top = _b.top;\n+                        return parseFloat(top) + (y.max - y.min);\n+                    },\n+                    right: function(_a, _b) {\n+                        var x = _a.x;\n+                        var left = _b.left;\n+                        return parseFloat(left) + (x.max - x.min);\n+                    },\n+                    // Transform\n+                    x: getTranslateFromMatrix(4, 13),\n+                    y: getTranslateFromMatrix(5, 14)\n+                };\n+                var convertChangedValueTypes = function(target, visualElement, changedKeys) {\n+                    var originBbox = visualElement.measureViewportBox();\n+                    var element = visualElement.getInstance();\n+                    var elementComputedStyle = getComputedStyle(element);\n+                    var display = elementComputedStyle.display;\n+                    var origin = {};\n+                    // If the element is currently set to display: \"none\", make it visible before\n+                    // measuring the target bounding box\n+                    if (display === \"none\") {\n+                        visualElement.setStaticValue(\"display\", target.display || \"block\");\n+                    }\n+                    /**\n+                     * Record origins before we render and update styles\n+                     */\n+                    changedKeys.forEach(function(key) {\n+                        origin[key] = positionalValues[key](originBbox, elementComputedStyle);\n+                    });\n+                    // Apply the latest values (as set in checkAndConvertChangedValueTypes)\n+                    visualElement.syncRender();\n+                    var targetBbox = visualElement.measureViewportBox();\n+                    changedKeys.forEach(function(key) {\n+                        // Restore styles to their **calculated computed style**, not their actual\n+                        // originally set style. This allows us to animate between equivalent pixel units.\n+                        var value = visualElement.getValue(key);\n+                        setAndResetVelocity(value, origin[key]);\n+                        target[key] = positionalValues[key](targetBbox, elementComputedStyle);\n+                    });\n+                    return target;\n+                };\n+                var checkAndConvertChangedValueTypes = function(visualElement, target, origin, transitionEnd) {\n+                    if (origin === void 0) {\n+                        origin = {};\n+                    }\n+                    if (transitionEnd === void 0) {\n+                        transitionEnd = {};\n+                    }\n+                    target = tslib.__assign({}, target);\n+                    transitionEnd = tslib.__assign({}, transitionEnd);\n+                    var targetPositionalKeys = Object.keys(target).filter(isPositionalKey);\n+                    // We want to remove any transform values that could affect the element's bounding box before\n+                    // it's measured. We'll reapply these later.\n+                    var removedTransformValues = [];\n+                    var hasAttemptedToRemoveTransformValues = false;\n+                    var changedValueTypeKeys = [];\n+                    targetPositionalKeys.forEach(function(key) {\n+                        var value = visualElement.getValue(key);\n+                        if (!visualElement.hasValue(key)) return;\n+                        var from = origin[key];\n+                        var fromType = findDimensionValueType(from);\n+                        var to = target[key];\n+                        var toType;\n+                        // TODO: The current implementation of this basically throws an error\n+                        // if you try and do value conversion via keyframes. There's probably\n+                        // a way of doing this but the performance implications would need greater scrutiny,\n+                        // as it'd be doing multiple resize-remeasure operations.\n+                        if (isKeyframesTarget(to)) {\n+                            var numKeyframes = to.length;\n+                            var fromIndex = to[0] === null ? 1 : 0;\n+                            from = to[fromIndex];\n+                            fromType = findDimensionValueType(from);\n+                            for (var i = fromIndex; i < numKeyframes; i++) {\n+                                if (!toType) {\n+                                    toType = findDimensionValueType(to[i]);\n+                                    heyListen.invariant(toType === fromType || isNumOrPxType(fromType) && isNumOrPxType(toType), \"Keyframes must be of the same dimension as the current value\");\n+                                } else {\n+                                    heyListen.invariant(findDimensionValueType(to[i]) === toType, \"All keyframes must be of the same type\");\n+                                }\n+                            }\n+                        } else {\n+                            toType = findDimensionValueType(to);\n+                        }\n+                        if (fromType !== toType) {\n+                            // If they're both just number or px, convert them both to numbers rather than\n+                            // relying on resize/remeasure to convert (which is wasteful in this situation)\n+                            if (isNumOrPxType(fromType) && isNumOrPxType(toType)) {\n+                                var current = value.get();\n+                                if (typeof current === \"string\") {\n+                                    value.set(parseFloat(current));\n+                                }\n+                                if (typeof to === \"string\") {\n+                                    target[key] = parseFloat(to);\n+                                } else if (Array.isArray(to) && toType === styleValueTypes.px) {\n+                                    target[key] = to.map(parseFloat);\n+                                }\n+                            } else if ((fromType === null || fromType === void 0 ? void 0 : fromType.transform) && (toType === null || toType === void 0 ? void 0 : toType.transform) && (from === 0 || to === 0)) {\n+                                // If one or the other value is 0, it's safe to coerce it to the\n+                                // type of the other without measurement\n+                                if (from === 0) {\n+                                    value.set(toType.transform(from));\n+                                } else {\n+                                    target[key] = fromType.transform(to);\n+                                }\n+                            } else {\n+                                // If we're going to do value conversion via DOM measurements, we first\n+                                // need to remove non-positional transform values that could affect the bbox measurements.\n+                                if (!hasAttemptedToRemoveTransformValues) {\n+                                    removedTransformValues = removeNonTranslationalTransform(visualElement);\n+                                    hasAttemptedToRemoveTransformValues = true;\n+                                }\n+                                changedValueTypeKeys.push(key);\n+                                transitionEnd[key] = transitionEnd[key] !== undefined ? transitionEnd[key] : target[key];\n+                                setAndResetVelocity(value, to);\n+                            }\n+                        }\n+                    });\n+                    if (changedValueTypeKeys.length) {\n+                        var scrollY_1 = changedValueTypeKeys.indexOf(\"height\") >= 0 ? window.pageYOffset : null;\n+                        var convertedTarget = convertChangedValueTypes(target, visualElement, changedValueTypeKeys);\n+                        // If we removed transform values, reapply them before the next render\n+                        if (removedTransformValues.length) {\n+                            removedTransformValues.forEach(function(_a) {\n+                                var _b = tslib.__read(_a, 2),\n+                                    key = _b[0],\n+                                    value = _b[1];\n+                                visualElement.getValue(key).set(value);\n+                            });\n+                        }\n+                        // Reapply original values\n+                        visualElement.syncRender();\n+                        // Restore scroll position\n+                        if (scrollY_1 !== null) window.scrollTo({\n+                            top: scrollY_1\n+                        });\n+                        return {\n+                            target: convertedTarget,\n+                            transitionEnd: transitionEnd\n+                        };\n+                    } else {\n+                        return {\n+                            target: target,\n+                            transitionEnd: transitionEnd\n+                        };\n+                    }\n+                };\n+                /**\n+                 * Convert value types for x/y/width/height/top/left/bottom/right\n+                 *\n+                 * Allows animation between `'auto'` -> `'100%'` or `0` -> `'calc(50% - 10vw)'`\n+                 *\n+                 * @internal\n+                 */\n+                function unitConversion(visualElement, target, origin, transitionEnd) {\n+                    return hasPositionalKey(target) ? checkAndConvertChangedValueTypes(visualElement, target, origin, transitionEnd) : {\n+                        target: target,\n+                        transitionEnd: transitionEnd\n+                    };\n+                }\n+\n+                /**\n+                 * Parse a DOM variant to make it animatable. This involves resolving CSS variables\n+                 * and ensuring animations like \"20%\" => \"calc(50vw)\" are performed in pixels.\n+                 */\n+                var parseDomVariant = function(visualElement, target, origin, transitionEnd) {\n+                    var resolved = resolveCSSVariables(visualElement, target, transitionEnd);\n+                    target = resolved.target;\n+                    transitionEnd = resolved.transitionEnd;\n+                    return unitConversion(visualElement, target, origin, transitionEnd);\n+                };\n+\n+                function getComputedStyle$1(element) {\n+                    return window.getComputedStyle(element);\n+                }\n+                var htmlConfig = {\n+                    treeType: \"dom\",\n+                    readValueFromInstance: function(domElement, key) {\n+                        if (isTransformProp(key)) {\n+                            var defaultType = getDefaultValueType(key);\n+                            return defaultType ? defaultType.default || 0 : 0;\n+                        } else {\n+                            var computedStyle = getComputedStyle$1(domElement);\n+                            return (isCSSVariable$1(key) ? computedStyle.getPropertyValue(key) : computedStyle[key]) || 0;\n+                        }\n+                    },\n+                    sortNodePosition: function(a, b) {\n+                        /**\n+                         * compareDocumentPosition returns a bitmask, by using the bitwise &\n+                         * we're returning true if 2 in that bitmask is set to true. 2 is set\n+                         * to true if b preceeds a.\n+                         */\n+                        return a.compareDocumentPosition(b) & 2 ? 1 : -1;\n+                    },\n+                    getBaseTarget: function(props, key) {\n+                        var _a;\n+                        return (_a = props.style) === null || _a === void 0 ? void 0 : _a[key];\n+                    },\n+                    measureViewportBox: function(element, _a) {\n+                        var transformPagePoint = _a.transformPagePoint;\n+                        return measureViewportBox(element, transformPagePoint);\n+                    },\n+                    /**\n+                     * Reset the transform on the current Element. This is called as part\n+                     * of a batched process across the entire layout tree. To remove this write\n+                     * cycle it'd be interesting to see if it's possible to \"undo\" all the current\n+                     * layout transforms up the tree in the same way this.getBoundingBoxWithoutTransforms\n+                     * works\n+                     */\n+                    resetTransform: function(element, domElement, props) {\n+                        var transformTemplate = props.transformTemplate;\n+                        domElement.style.transform = transformTemplate ? transformTemplate({}, \"\") : \"none\";\n+                        // Ensure that whatever happens next, we restore our transform on the next frame\n+                        element.scheduleRender();\n+                    },\n+                    restoreTransform: function(instance, mutableState) {\n+                        instance.style.transform = mutableState.style.transform;\n+                    },\n+                    removeValueFromRenderState: function(key, _a) {\n+                        var vars = _a.vars,\n+                            style = _a.style;\n+                        delete vars[key];\n+                        delete style[key];\n+                    },\n+                    /**\n+                     * Ensure that HTML and Framer-specific value types like `px`->`%` and `Color`\n+                     * can be animated by Motion.\n+                     */\n+                    makeTargetAnimatable: function(element, _a, _b, isMounted) {\n+                        var transformValues = _b.transformValues;\n+                        if (isMounted === void 0) {\n+                            isMounted = true;\n+                        }\n+                        var transition = _a.transition,\n+                            transitionEnd = _a.transitionEnd,\n+                            target = tslib.__rest(_a, [\"transition\", \"transitionEnd\"]);\n+                        var origin = getOrigin(target, transition || {}, element);\n+                        /**\n+                         * If Framer has provided a function to convert `Color` etc value types, convert them\n+                         */\n+                        if (transformValues) {\n+                            if (transitionEnd) transitionEnd = transformValues(transitionEnd);\n+                            if (target) target = transformValues(target);\n+                            if (origin) origin = transformValues(origin);\n+                        }\n+                        if (isMounted) {\n+                            checkTargetForNewValues(element, target, origin);\n+                            var parsed = parseDomVariant(element, target, origin, transitionEnd);\n+                            transitionEnd = parsed.transitionEnd;\n+                            target = parsed.target;\n+                        }\n+                        return tslib.__assign({\n+                            transition: transition,\n+                            transitionEnd: transitionEnd\n+                        }, target);\n+                    },\n+                    scrapeMotionValuesFromProps: scrapeMotionValuesFromProps$1,\n+                    build: function(element, renderState, latestValues, options, props) {\n+                        if (element.isVisible !== undefined) {\n+                            renderState.style.visibility = element.isVisible ? \"visible\" : \"hidden\";\n+                        }\n+                        buildHTMLStyles(renderState, latestValues, options, props.transformTemplate);\n+                    },\n+                    render: renderHTML\n+                };\n+                var htmlVisualElement = visualElement(htmlConfig);\n+                var svgVisualElement = visualElement(tslib.__assign(tslib.__assign({}, htmlConfig), {\n+                    getBaseTarget: function(props, key) {\n+                        return props[key];\n+                    },\n+                    readValueFromInstance: function(domElement, key) {\n+                        var _a;\n+                        if (isTransformProp(key)) {\n+                            return ((_a = getDefaultValueType(key)) === null || _a === void 0 ? void 0 : _a.default) || 0;\n+                        }\n+                        key = !camelCaseAttributes.has(key) ? camelToDash(key) : key;\n+                        return domElement.getAttribute(key);\n+                    },\n+                    scrapeMotionValuesFromProps: scrapeMotionValuesFromProps,\n+                    build: function(_element, renderState, latestValues, options, props) {\n+                        buildSVGAttrs(renderState, latestValues, options, props.transformTemplate);\n+                    },\n+                    render: renderSVG\n+                }));\n+                var createDomVisualElement = function(Component, options) {\n+                    return isSVGComponent(Component) ? svgVisualElement(options, {\n+                        enableHardwareAcceleration: false\n+                    }) : htmlVisualElement(options, {\n+                        enableHardwareAcceleration: true\n+                    });\n+                };\n+\n+                function pixelsToPercent(pixels, axis) {\n+                    if (axis.max === axis.min) return 0;\n+                    return pixels / (axis.max - axis.min) * 100;\n+                }\n+                /**\n+                 * We always correct borderRadius as a percentage rather than pixels to reduce paints.\n+                 * For example, if you are projecting a box that is 100px wide with a 10px borderRadius\n+                 * into a box that is 200px wide with a 20px borderRadius, that is actually a 10%\n+                 * borderRadius in both states. If we animate between the two in pixels that will trigger\n+                 * a paint each time. If we animate between the two in percentage we'll avoid a paint.\n+                 */\n+                var correctBorderRadius = {\n+                    correct: function(latest, node) {\n+                        if (!node.target) return latest;\n+                        /**\n+                         * If latest is a string, if it's a percentage we can return immediately as it's\n+                         * going to be stretched appropriately. Otherwise, if it's a pixel, convert it to a number.\n+                         */\n+                        if (typeof latest === \"string\") {\n+                            if (styleValueTypes.px.test(latest)) {\n+                                latest = parseFloat(latest);\n+                            } else {\n+                                return latest;\n+                            }\n+                        }\n+                        /**\n+                         * If latest is a number, it's a pixel value. We use the current viewportBox to calculate that\n+                         * pixel value as a percentage of each axis\n+                         */\n+                        var x = pixelsToPercent(latest, node.target.x);\n+                        var y = pixelsToPercent(latest, node.target.y);\n+                        return \"\".concat(x, \"% \").concat(y, \"%\");\n+                    }\n+                };\n+                var varToken = \"_$css\";\n+                var correctBoxShadow = {\n+                    correct: function(latest, _a) {\n+                        var treeScale = _a.treeScale,\n+                            projectionDelta = _a.projectionDelta;\n+                        var original = latest;\n+                        /**\n+                         * We need to first strip and store CSS variables from the string.\n+                         */\n+                        var containsCSSVariables = latest.includes(\"var(\");\n+                        var cssVariables = [];\n+                        if (containsCSSVariables) {\n+                            latest = latest.replace(cssVariableRegex, function(match) {\n+                                cssVariables.push(match);\n+                                return varToken;\n+                            });\n+                        }\n+                        var shadow = styleValueTypes.complex.parse(latest);\n+                        // TODO: Doesn't support multiple shadows\n+                        if (shadow.length > 5) return original;\n+                        var template = styleValueTypes.complex.createTransformer(latest);\n+                        var offset = typeof shadow[0] !== \"number\" ? 1 : 0;\n+                        // Calculate the overall context scale\n+                        var xScale = projectionDelta.x.scale * treeScale.x;\n+                        var yScale = projectionDelta.y.scale * treeScale.y;\n+                        shadow[0 + offset] /= xScale;\n+                        shadow[1 + offset] /= yScale;\n+                        /**\n+                         * Ideally we'd correct x and y scales individually, but because blur and\n+                         * spread apply to both we have to take a scale average and apply that instead.\n+                         * We could potentially improve the outcome of this by incorporating the ratio between\n+                         * the two scales.\n+                         */\n+                        var averageScale = popmotion.mix(xScale, yScale, 0.5);\n+                        // Blur\n+                        if (typeof shadow[2 + offset] === \"number\") shadow[2 + offset] /= averageScale;\n+                        // Spread\n+                        if (typeof shadow[3 + offset] === \"number\") shadow[3 + offset] /= averageScale;\n+                        var output = template(shadow);\n+                        if (containsCSSVariables) {\n+                            var i_1 = 0;\n+                            output = output.replace(varToken, function() {\n+                                var cssVariable = cssVariables[i_1];\n+                                i_1++;\n+                                return cssVariable;\n+                            });\n+                        }\n+                        return output;\n+                    }\n+                };\n+                var MeasureLayoutWithContext = /** @class */ function(_super) {\n+                    tslib.__extends(MeasureLayoutWithContext, _super);\n+\n+                    function MeasureLayoutWithContext() {\n+                        return _super !== null && _super.apply(this, arguments) || this;\n+                    }\n+                    /**\n+                     * This only mounts projection nodes for components that\n+                     * need measuring, we might want to do it for all components\n+                     * in order to incorporate transforms\n+                     */\n+                    MeasureLayoutWithContext.prototype.componentDidMount = function() {\n+                        var _this = this;\n+                        var _a = this.props,\n+                            visualElement = _a.visualElement,\n+                            layoutGroup = _a.layoutGroup,\n+                            switchLayoutGroup = _a.switchLayoutGroup,\n+                            layoutId = _a.layoutId;\n+                        var projection = visualElement.projection;\n+                        addScaleCorrector(defaultScaleCorrectors);\n+                        if (projection) {\n+                            if (layoutGroup === null || layoutGroup === void 0 ? void 0 : layoutGroup.group) layoutGroup.group.add(projection);\n+                            if ((switchLayoutGroup === null || switchLayoutGroup === void 0 ? void 0 : switchLayoutGroup.register) && layoutId) {\n+                                switchLayoutGroup.register(projection);\n+                            }\n+                            projection.root.didUpdate();\n+                            projection.addEventListener(\"animationComplete\", function() {\n+                                _this.safeToRemove();\n+                            });\n+                            projection.setOptions(tslib.__assign(tslib.__assign({}, projection.options), {\n+                                onExitComplete: function() {\n+                                    return _this.safeToRemove();\n+                                }\n+                            }));\n+                        }\n+                        globalProjectionState.hasEverUpdated = true;\n+                    };\n+                    MeasureLayoutWithContext.prototype.getSnapshotBeforeUpdate = function(prevProps) {\n+                        var _this = this;\n+                        var _a = this.props,\n+                            layoutDependency = _a.layoutDependency,\n+                            visualElement = _a.visualElement,\n+                            drag = _a.drag,\n+                            isPresent = _a.isPresent;\n+                        var projection = visualElement.projection;\n+                        if (!projection) return null;\n+                        /**\n+                         * TODO: We use this data in relegate to determine whether to\n+                         * promote a previous element. There's no guarantee its presence data\n+                         * will have updated by this point - if a bug like this arises it will\n+                         * have to be that we markForRelegation and then find a new lead some other way,\n+                         * perhaps in didUpdate\n+                         */\n+                        projection.isPresent = isPresent;\n+                        if (drag || prevProps.layoutDependency !== layoutDependency || layoutDependency === undefined) {\n+                            projection.willUpdate();\n+                        } else {\n+                            this.safeToRemove();\n+                        }\n+                        if (prevProps.isPresent !== isPresent) {\n+                            if (isPresent) {\n+                                projection.promote();\n+                            } else if (!projection.relegate()) {\n+                                /**\n+                                 * If there's another stack member taking over from this one,\n+                                 * it's in charge of the exit animation and therefore should\n+                                 * be in charge of the safe to remove. Otherwise we call it here.\n+                                 */\n+                                sync__default[\"default\"].postRender(function() {\n+                                    var _a;\n+                                    if (!((_a = projection.getStack()) === null || _a === void 0 ? void 0 : _a.members.length)) {\n+                                        _this.safeToRemove();\n+                                    }\n+                                });\n+                            }\n+                        }\n+                        return null;\n+                    };\n+                    MeasureLayoutWithContext.prototype.componentDidUpdate = function() {\n+                        var projection = this.props.visualElement.projection;\n+                        if (projection) {\n+                            projection.root.didUpdate();\n+                            if (!projection.currentAnimation && projection.isLead()) {\n+                                this.safeToRemove();\n+                            }\n+                        }\n+                    };\n+                    MeasureLayoutWithContext.prototype.componentWillUnmount = function() {\n+                        var _a = this.props,\n+                            visualElement = _a.visualElement,\n+                            layoutGroup = _a.layoutGroup,\n+                            promoteContext = _a.switchLayoutGroup;\n+                        var projection = visualElement.projection;\n+                        if (projection) {\n+                            projection.scheduleCheckAfterUnmount();\n+                            if (layoutGroup === null || layoutGroup === void 0 ? void 0 : layoutGroup.group) layoutGroup.group.remove(projection);\n+                            if (promoteContext === null || promoteContext === void 0 ? void 0 : promoteContext.deregister) promoteContext.deregister(projection);\n+                        }\n+                    };\n+                    MeasureLayoutWithContext.prototype.safeToRemove = function() {\n+                        var safeToRemove = this.props.safeToRemove;\n+                        safeToRemove === null || safeToRemove === void 0 ? void 0 : safeToRemove();\n+                    };\n+                    MeasureLayoutWithContext.prototype.render = function() {\n+                        return null;\n+                    };\n+                    return MeasureLayoutWithContext;\n+                }(React__default[\"default\"].Component);\n+\n+                function MeasureLayout(props) {\n+                    var _a = tslib.__read(usePresence(), 2),\n+                        isPresent = _a[0],\n+                        safeToRemove = _a[1];\n+                    var layoutGroup = React.useContext(LayoutGroupContext);\n+                    return React__default[\"default\"].createElement(MeasureLayoutWithContext, tslib.__assign({}, props, {\n+                        layoutGroup: layoutGroup,\n+                        switchLayoutGroup: React.useContext(SwitchLayoutGroupContext),\n+                        isPresent: isPresent,\n+                        safeToRemove: safeToRemove\n+                    }));\n+                }\n+                var defaultScaleCorrectors = {\n+                    borderRadius: tslib.__assign(tslib.__assign({}, correctBorderRadius), {\n+                        applyTo: [\"borderTopLeftRadius\", \"borderTopRightRadius\", \"borderBottomLeftRadius\", \"borderBottomRightRadius\"]\n+                    }),\n+                    borderTopLeftRadius: correctBorderRadius,\n+                    borderTopRightRadius: correctBorderRadius,\n+                    borderBottomLeftRadius: correctBorderRadius,\n+                    borderBottomRightRadius: correctBorderRadius,\n+                    boxShadow: correctBoxShadow\n+                };\n+                var layoutFeatures = {\n+                    measureLayout: MeasureLayout\n+                };\n+\n+                /**\n+                 * Animate a single value or a `MotionValue`.\n+                 *\n+                 * The first argument is either a `MotionValue` to animate, or an initial animation value.\n+                 *\n+                 * The second is either a value to animate to, or an array of keyframes to animate through.\n+                 *\n+                 * The third argument can be either tween or spring options, and optional lifecycle methods: `onUpdate`, `onPlay`, `onComplete`, `onRepeat` and `onStop`.\n+                 *\n+                 * Returns `AnimationPlaybackControls`, currently just a `stop` method.\n+                 *\n+                 * ```javascript\n+                 * const x = useMotionValue(0)\n+                 *\n+                 * useEffect(() => {\n+                 *   const controls = animate(x, 100, {\n+                 *     type: \"spring\",\n+                 *     stiffness: 2000,\n+                 *     onComplete: v => {}\n+                 *   })\n+                 *\n+                 *   return controls.stop\n+                 * })\n+                 * ```\n+                 *\n+                 * @public\n+                 */\n+                function animate(from, to, transition) {\n+                    if (transition === void 0) {\n+                        transition = {};\n+                    }\n+                    var value = isMotionValue(from) ? from : motionValue(from);\n+                    startAnimation(\"\", value, to, transition);\n+                    return {\n+                        stop: function() {\n+                            return value.stop();\n+                        },\n+                        isAnimating: function() {\n+                            return value.isAnimating();\n+                        }\n+                    };\n+                }\n+                var borders = [\"TopLeft\", \"TopRight\", \"BottomLeft\", \"BottomRight\"];\n+                var numBorders = borders.length;\n+                var asNumber = function(value) {\n+                    return typeof value === \"string\" ? parseFloat(value) : value;\n+                };\n+                var isPx = function(value) {\n+                    return typeof value === \"number\" || styleValueTypes.px.test(value);\n+                };\n+\n+                function mixValues(target, follow, lead, progress, shouldCrossfadeOpacity, isOnlyMember) {\n+                    var _a, _b, _c, _d;\n+                    if (shouldCrossfadeOpacity) {\n+                        target.opacity = popmotion.mix(0,\n+                            // (follow?.opacity as number) ?? 0,\n+                            // TODO Reinstate this if only child\n+                            (_a = lead.opacity) !== null && _a !== void 0 ? _a : 1, easeCrossfadeIn(progress));\n+                        target.opacityExit = popmotion.mix((_b = follow.opacity) !== null && _b !== void 0 ? _b : 1, 0, easeCrossfadeOut(progress));\n+                    } else if (isOnlyMember) {\n+                        target.opacity = popmotion.mix((_c = follow.opacity) !== null && _c !== void 0 ? _c : 1, (_d = lead.opacity) !== null && _d !== void 0 ? _d : 1, progress);\n+                    }\n+                    /**\n+                     * Mix border radius\n+                     */\n+                    for (var i = 0; i < numBorders; i++) {\n+                        var borderLabel = \"border\".concat(borders[i], \"Radius\");\n+                        var followRadius = getRadius(follow, borderLabel);\n+                        var leadRadius = getRadius(lead, borderLabel);\n+                        if (followRadius === undefined && leadRadius === undefined) continue;\n+                        followRadius || (followRadius = 0);\n+                        leadRadius || (leadRadius = 0);\n+                        var canMix = followRadius === 0 || leadRadius === 0 || isPx(followRadius) === isPx(leadRadius);\n+                        if (canMix) {\n+                            target[borderLabel] = Math.max(popmotion.mix(asNumber(followRadius), asNumber(leadRadius), progress), 0);\n+                            if (styleValueTypes.percent.test(leadRadius) || styleValueTypes.percent.test(followRadius)) {\n+                                target[borderLabel] += \"%\";\n+                            }\n+                        } else {\n+                            target[borderLabel] = leadRadius;\n+                        }\n+                    }\n+                    /**\n+                     * Mix rotation\n+                     */\n+                    if (follow.rotate || lead.rotate) {\n+                        target.rotate = popmotion.mix(follow.rotate || 0, lead.rotate || 0, progress);\n+                    }\n+                }\n+\n+                function getRadius(values, radiusName) {\n+                    var _a;\n+                    return (_a = values[radiusName]) !== null && _a !== void 0 ? _a : values.borderRadius;\n+                }\n+                // /**\n+                //  * We only want to mix the background color if there's a follow element\n+                //  * that we're not crossfading opacity between. For instance with switch\n+                //  * AnimateSharedLayout animations, this helps the illusion of a continuous\n+                //  * element being animated but also cuts down on the number of paints triggered\n+                //  * for elements where opacity is doing that work for us.\n+                //  */\n+                // if (\n+                //     !hasFollowElement &&\n+                //     latestLeadValues.backgroundColor &&\n+                //     latestFollowValues.backgroundColor\n+                // ) {\n+                //     /**\n+                //      * This isn't ideal performance-wise as mixColor is creating a new function every frame.\n+                //      * We could probably create a mixer that runs at the start of the animation but\n+                //      * the idea behind the crossfader is that it runs dynamically between two potentially\n+                //      * changing targets (ie opacity or borderRadius may be animating independently via variants)\n+                //      */\n+                //     leadState.backgroundColor = followState.backgroundColor = mixColor(\n+                //         latestFollowValues.backgroundColor as string,\n+                //         latestLeadValues.backgroundColor as string\n+                //     )(p)\n+                // }\n+                var easeCrossfadeIn = compress(0, 0.5, popmotion.circOut);\n+                var easeCrossfadeOut = compress(0.5, 0.95, popmotion.linear);\n+\n+                function compress(min, max, easing) {\n+                    return function(p) {\n+                        // Could replace ifs with clamp\n+                        if (p < min) return 0;\n+                        if (p > max) return 1;\n+                        return easing(popmotion.progress(min, max, p));\n+                    };\n+                }\n+\n+                /**\n+                 * Reset an axis to the provided origin box.\n+                 *\n+                 * This is a mutative operation.\n+                 */\n+                function copyAxisInto(axis, originAxis) {\n+                    axis.min = originAxis.min;\n+                    axis.max = originAxis.max;\n+                }\n+                /**\n+                 * Reset a box to the provided origin box.\n+                 *\n+                 * This is a mutative operation.\n+                 */\n+                function copyBoxInto(box, originBox) {\n+                    copyAxisInto(box.x, originBox.x);\n+                    copyAxisInto(box.y, originBox.y);\n+                }\n+\n+                /**\n+                 * Remove a delta from a point. This is essentially the steps of applyPointDelta in reverse\n+                 */\n+                function removePointDelta(point, translate, scale, originPoint, boxScale) {\n+                    point -= translate;\n+                    point = scalePoint(point, 1 / scale, originPoint);\n+                    if (boxScale !== undefined) {\n+                        point = scalePoint(point, 1 / boxScale, originPoint);\n+                    }\n+                    return point;\n+                }\n+                /**\n+                 * Remove a delta from an axis. This is essentially the steps of applyAxisDelta in reverse\n+                 */\n+                function removeAxisDelta(axis, translate, scale, origin, boxScale, originAxis, sourceAxis) {\n+                    if (translate === void 0) {\n+                        translate = 0;\n+                    }\n+                    if (scale === void 0) {\n+                        scale = 1;\n+                    }\n+                    if (origin === void 0) {\n+                        origin = 0.5;\n+                    }\n+                    if (originAxis === void 0) {\n+                        originAxis = axis;\n+                    }\n+                    if (sourceAxis === void 0) {\n+                        sourceAxis = axis;\n+                    }\n+                    if (styleValueTypes.percent.test(translate)) {\n+                        translate = parseFloat(translate);\n+                        var relativeProgress = popmotion.mix(sourceAxis.min, sourceAxis.max, translate / 100);\n+                        translate = relativeProgress - sourceAxis.min;\n+                    }\n+                    if (typeof translate !== \"number\") return;\n+                    var originPoint = popmotion.mix(originAxis.min, originAxis.max, origin);\n+                    if (axis === originAxis) originPoint -= translate;\n+                    axis.min = removePointDelta(axis.min, translate, scale, originPoint, boxScale);\n+                    axis.max = removePointDelta(axis.max, translate, scale, originPoint, boxScale);\n+                }\n+                /**\n+                 * Remove a transforms from an axis. This is essentially the steps of applyAxisTransforms in reverse\n+                 * and acts as a bridge between motion values and removeAxisDelta\n+                 */\n+                function removeAxisTransforms(axis, transforms, _a, origin, sourceAxis) {\n+                    var _b = tslib.__read(_a, 3),\n+                        key = _b[0],\n+                        scaleKey = _b[1],\n+                        originKey = _b[2];\n+                    removeAxisDelta(axis, transforms[key], transforms[scaleKey], transforms[originKey], transforms.scale, origin, sourceAxis);\n+                }\n+                /**\n+                 * The names of the motion values we want to apply as translation, scale and origin.\n+                 */\n+                var xKeys = [\"x\", \"scaleX\", \"originX\"];\n+                var yKeys = [\"y\", \"scaleY\", \"originY\"];\n+                /**\n+                 * Remove a transforms from an box. This is essentially the steps of applyAxisBox in reverse\n+                 * and acts as a bridge between motion values and removeAxisDelta\n+                 */\n+                function removeBoxTransforms(box, transforms, originBox, sourceBox) {\n+                    removeAxisTransforms(box.x, transforms, xKeys, originBox === null || originBox === void 0 ? void 0 : originBox.x, sourceBox === null || sourceBox === void 0 ? void 0 : sourceBox.x);\n+                    removeAxisTransforms(box.y, transforms, yKeys, originBox === null || originBox === void 0 ? void 0 : originBox.y, sourceBox === null || sourceBox === void 0 ? void 0 : sourceBox.y);\n+                }\n+\n+                function isAxisDeltaZero(delta) {\n+                    return delta.translate === 0 && delta.scale === 1;\n+                }\n+\n+                function isDeltaZero(delta) {\n+                    return isAxisDeltaZero(delta.x) && isAxisDeltaZero(delta.y);\n+                }\n+\n+                function boxEquals(a, b) {\n+                    return a.x.min === b.x.min && a.x.max === b.x.max && a.y.min === b.y.min && a.y.max === b.y.max;\n+                }\n+                var NodeStack = /** @class */ function() {\n+                    function NodeStack() {\n+                        this.members = [];\n+                    }\n+                    NodeStack.prototype.add = function(node) {\n+                        addUniqueItem(this.members, node);\n+                        node.scheduleRender();\n+                    };\n+                    NodeStack.prototype.remove = function(node) {\n+                        removeItem(this.members, node);\n+                        if (node === this.prevLead) {\n+                            this.prevLead = undefined;\n+                        }\n+                        if (node === this.lead) {\n+                            var prevLead = this.members[this.members.length - 1];\n+                            if (prevLead) {\n+                                this.promote(prevLead);\n+                            }\n+                        }\n+                    };\n+                    NodeStack.prototype.relegate = function(node) {\n+                        var indexOfNode = this.members.findIndex(function(member) {\n+                            return node === member;\n+                        });\n+                        if (indexOfNode === 0) return false;\n+                        /**\n+                         * Find the next projection node that is present\n+                         */\n+                        var prevLead;\n+                        for (var i = indexOfNode; i >= 0; i--) {\n+                            var member = this.members[i];\n+                            if (member.isPresent !== false) {\n+                                prevLead = member;\n+                                break;\n+                            }\n+                        }\n+                        if (prevLead) {\n+                            this.promote(prevLead);\n+                            return true;\n+                        } else {\n+                            return false;\n+                        }\n+                    };\n+                    NodeStack.prototype.promote = function(node, preserveFollowOpacity) {\n+                        var _a;\n+                        var prevLead = this.lead;\n+                        if (node === prevLead) return;\n+                        this.prevLead = prevLead;\n+                        this.lead = node;\n+                        node.show();\n+                        if (prevLead) {\n+                            prevLead.instance && prevLead.scheduleRender();\n+                            node.scheduleRender();\n+                            node.resumeFrom = prevLead;\n+                            if (preserveFollowOpacity) {\n+                                node.resumeFrom.preserveOpacity = true;\n+                            }\n+                            if (prevLead.snapshot) {\n+                                node.snapshot = prevLead.snapshot;\n+                                node.snapshot.latestValues = prevLead.animationValues || prevLead.latestValues;\n+                                node.snapshot.isShared = true;\n+                            }\n+                            if ((_a = node.root) === null || _a === void 0 ? void 0 : _a.isUpdating) {\n+                                node.isLayoutDirty = true;\n+                            }\n+                            var crossfade = node.options.crossfade;\n+                            if (crossfade === false) {\n+                                prevLead.hide();\n+                            }\n+                            /**\n+                             * TODO:\n+                             *   - Test border radius when previous node was deleted\n+                             *   - boxShadow mixing\n+                             *   - Shared between element A in scrolled container and element B (scroll stays the same or changes)\n+                             *   - Shared between element A in transformed container and element B (transform stays the same or changes)\n+                             *   - Shared between element A in scrolled page and element B (scroll stays the same or changes)\n+                             * ---\n+                             *   - Crossfade opacity of root nodes\n+                             *   - layoutId changes after animation\n+                             *   - layoutId changes mid animation\n+                             */\n+                        }\n+                    };\n+                    NodeStack.prototype.exitAnimationComplete = function() {\n+                        this.members.forEach(function(node) {\n+                            var _a, _b, _c, _d, _e;\n+                            (_b = (_a = node.options).onExitComplete) === null || _b === void 0 ? void 0 : _b.call(_a);\n+                            (_e = (_c = node.resumingFrom) === null || _c === void 0 ? void 0 : (_d = _c.options).onExitComplete) === null || _e === void 0 ? void 0 : _e.call(_d);\n+                        });\n+                    };\n+                    NodeStack.prototype.scheduleRender = function() {\n+                        this.members.forEach(function(node) {\n+                            node.instance && node.scheduleRender(false);\n+                        });\n+                    };\n+                    /**\n+                     * Clear any leads that have been removed this render to prevent them from being\n+                     * used in future animations and to prevent memory leaks\n+                     */\n+                    NodeStack.prototype.removeLeadSnapshot = function() {\n+                        if (this.lead && this.lead.snapshot) {\n+                            this.lead.snapshot = undefined;\n+                        }\n+                    };\n+                    return NodeStack;\n+                }();\n+                var identityProjection = \"translate3d(0px, 0px, 0) scale(1, 1) scale(1, 1)\";\n+\n+                function buildProjectionTransform(delta, treeScale, latestTransform) {\n+                    /**\n+                     * The translations we use to calculate are always relative to the viewport coordinate space.\n+                     * But when we apply scales, we also scale the coordinate space of an element and its children.\n+                     * For instance if we have a treeScale (the culmination of all parent scales) of 0.5 and we need\n+                     * to move an element 100 pixels, we actually need to move it 200 in within that scaled space.\n+                     */\n+                    var xTranslate = delta.x.translate / treeScale.x;\n+                    var yTranslate = delta.y.translate / treeScale.y;\n+                    var transform = \"translate3d(\".concat(xTranslate, \"px, \").concat(yTranslate, \"px, 0) \");\n+                    /**\n+                     * Apply scale correction for the tree transform.\n+                     * This will apply scale to the screen-orientated axes.\n+                     */\n+                    transform += \"scale(\".concat(1 / treeScale.x, \", \").concat(1 / treeScale.y, \") \");\n+                    if (latestTransform) {\n+                        var rotate = latestTransform.rotate,\n+                            rotateX = latestTransform.rotateX,\n+                            rotateY = latestTransform.rotateY;\n+                        if (rotate) transform += \"rotate(\".concat(rotate, \"deg) \");\n+                        if (rotateX) transform += \"rotateX(\".concat(rotateX, \"deg) \");\n+                        if (rotateY) transform += \"rotateY(\".concat(rotateY, \"deg) \");\n+                    }\n+                    /**\n+                     * Apply scale to match the size of the element to the size we want it.\n+                     * This will apply scale to the element-orientated axes.\n+                     */\n+                    var elementScaleX = delta.x.scale * treeScale.x;\n+                    var elementScaleY = delta.y.scale * treeScale.y;\n+                    transform += \"scale(\".concat(elementScaleX, \", \").concat(elementScaleY, \")\");\n+                    return transform === identityProjection ? \"none\" : transform;\n+                }\n+                var compareByDepth = function(a, b) {\n+                    return a.depth - b.depth;\n+                };\n+                var FlatTree = /** @class */ function() {\n+                    function FlatTree() {\n+                        this.children = [];\n+                        this.isDirty = false;\n+                    }\n+                    FlatTree.prototype.add = function(child) {\n+                        addUniqueItem(this.children, child);\n+                        this.isDirty = true;\n+                    };\n+                    FlatTree.prototype.remove = function(child) {\n+                        removeItem(this.children, child);\n+                        this.isDirty = true;\n+                    };\n+                    FlatTree.prototype.forEach = function(callback) {\n+                        this.isDirty && this.children.sort(compareByDepth);\n+                        this.isDirty = false;\n+                        this.children.forEach(callback);\n+                    };\n+                    return FlatTree;\n+                }();\n+\n+                /**\n+                 * We use 1000 as the animation target as 0-1000 maps better to pixels than 0-1\n+                 * which has a noticeable difference in spring animations\n+                 */\n+                var animationTarget = 1000;\n+\n+                function createProjectionNode(_a) {\n+                    var attachResizeListener = _a.attachResizeListener,\n+                        defaultParent = _a.defaultParent,\n+                        measureScroll = _a.measureScroll,\n+                        checkIsScrollRoot = _a.checkIsScrollRoot,\n+                        resetTransform = _a.resetTransform;\n+                    return /** @class */ function() {\n+                        function ProjectionNode(id, latestValues, parent) {\n+                            var _this = this;\n+                            if (latestValues === void 0) {\n+                                latestValues = {};\n+                            }\n+                            if (parent === void 0) {\n+                                parent = defaultParent === null || defaultParent === void 0 ? void 0 : defaultParent();\n+                            }\n+                            /**\n+                             * A Set containing all this component's children. This is used to iterate\n+                             * through the children.\n+                             *\n+                             * TODO: This could be faster to iterate as a flat array stored on the root node.\n+                             */\n+                            this.children = new Set();\n+                            /**\n+                             * Options for the node. We use this to configure what kind of layout animations\n+                             * we should perform (if any).\n+                             */\n+                            this.options = {};\n+                            /**\n+                             * We use this to detect when its safe to shut down part of a projection tree.\n+                             * We have to keep projecting children for scale correction and relative projection\n+                             * until all their parents stop performing layout animations.\n+                             */\n+                            this.isTreeAnimating = false;\n+                            this.isAnimationBlocked = false;\n+                            /**\n+                             * Flag to true if we think this layout has been changed. We can't always know this,\n+                             * currently we set it to true every time a component renders, or if it has a layoutDependency\n+                             * if that has changed between renders. Additionally, components can be grouped by LayoutGroup\n+                             * and if one node is dirtied, they all are.\n+                             */\n+                            this.isLayoutDirty = false;\n+                            /**\n+                             * Block layout updates for instant layout transitions throughout the tree.\n+                             */\n+                            this.updateManuallyBlocked = false;\n+                            this.updateBlockedByResize = false;\n+                            /**\n+                             * Set to true between the start of the first `willUpdate` call and the end of the `didUpdate`\n+                             * call.\n+                             */\n+                            this.isUpdating = false;\n+                            /**\n+                             * If this is an SVG element we currently disable projection transforms\n+                             */\n+                            this.isSVG = false;\n+                            /**\n+                             * Flag to true (during promotion) if a node doing an instant layout transition needs to reset\n+                             * its projection styles.\n+                             */\n+                            this.needsReset = false;\n+                            /**\n+                             * Flags whether this node should have its transform reset prior to measuring.\n+                             */\n+                            this.shouldResetTransform = false;\n+                            /**\n+                             * An object representing the calculated contextual/accumulated/tree scale.\n+                             * This will be used to scale calculcated projection transforms, as these are\n+                             * calculated in screen-space but need to be scaled for elements to actually\n+                             * make it to their calculated destinations.\n+                             *\n+                             * TODO: Lazy-init\n+                             */\n+                            this.treeScale = {\n+                                x: 1,\n+                                y: 1\n+                            };\n+                            /**\n+                             *\n+                             */\n+                            this.eventHandlers = new Map();\n+                            // Note: Currently only running on root node\n+                            this.potentialNodes = new Map();\n+                            this.checkUpdateFailed = function() {\n+                                if (_this.isUpdating) {\n+                                    _this.isUpdating = false;\n+                                    _this.clearAllSnapshots();\n+                                }\n+                            };\n+                            this.updateProjection = function() {\n+                                _this.nodes.forEach(resolveTargetDelta);\n+                                _this.nodes.forEach(calcProjection);\n+                            };\n+                            this.hasProjected = false;\n+                            this.isVisible = true;\n+                            this.animationProgress = 0;\n+                            /**\n+                             * Shared layout\n+                             */\n+                            // TODO Only running on root node\n+                            this.sharedNodes = new Map();\n+                            this.id = id;\n+                            this.latestValues = latestValues;\n+                            this.root = parent ? parent.root || parent : this;\n+                            this.path = parent ? tslib.__spreadArray(tslib.__spreadArray([], tslib.__read(parent.path), false), [parent], false) : [];\n+                            this.parent = parent;\n+                            this.depth = parent ? parent.depth + 1 : 0;\n+                            id && this.root.registerPotentialNode(id, this);\n+                            for (var i = 0; i < this.path.length; i++) {\n+                                this.path[i].shouldResetTransform = true;\n+                            }\n+                            if (this.root === this) this.nodes = new FlatTree();\n+                        }\n+                        ProjectionNode.prototype.addEventListener = function(name, handler) {\n+                            if (!this.eventHandlers.has(name)) {\n+                                this.eventHandlers.set(name, new SubscriptionManager());\n+                            }\n+                            return this.eventHandlers.get(name).add(handler);\n+                        };\n+                        ProjectionNode.prototype.notifyListeners = function(name) {\n+                            var args = [];\n+                            for (var _i = 1; _i < arguments.length; _i++) {\n+                                args[_i - 1] = arguments[_i];\n+                            }\n+                            var subscriptionManager = this.eventHandlers.get(name);\n+                            subscriptionManager === null || subscriptionManager === void 0 ? void 0 : subscriptionManager.notify.apply(subscriptionManager, tslib.__spreadArray([], tslib.__read(args), false));\n+                        };\n+                        ProjectionNode.prototype.hasListeners = function(name) {\n+                            return this.eventHandlers.has(name);\n+                        };\n+                        ProjectionNode.prototype.registerPotentialNode = function(id, node) {\n+                            this.potentialNodes.set(id, node);\n+                        };\n+                        /**\n+                         * Lifecycles\n+                         */\n+                        ProjectionNode.prototype.mount = function(instance, isLayoutDirty) {\n+                            var _this = this;\n+                            var _a;\n+                            if (isLayoutDirty === void 0) {\n+                                isLayoutDirty = false;\n+                            }\n+                            if (this.instance) return;\n+                            this.isSVG = instance instanceof SVGElement && instance.tagName !== \"svg\";\n+                            this.instance = instance;\n+                            var _b = this.options,\n+                                layoutId = _b.layoutId,\n+                                layout = _b.layout,\n+                                visualElement = _b.visualElement;\n+                            if (visualElement && !visualElement.getInstance()) {\n+                                visualElement.mount(instance);\n+                            }\n+                            this.root.nodes.add(this);\n+                            (_a = this.parent) === null || _a === void 0 ? void 0 : _a.children.add(this);\n+                            this.id && this.root.potentialNodes.delete(this.id);\n+                            if (isLayoutDirty && (layout || layoutId)) {\n+                                this.isLayoutDirty = true;\n+                            }\n+                            if (attachResizeListener) {\n+                                var unblockTimeout_1;\n+                                var resizeUnblockUpdate_1 = function() {\n+                                    return _this.root.updateBlockedByResize = false;\n+                                };\n+                                attachResizeListener(instance, function() {\n+                                    _this.root.updateBlockedByResize = true;\n+                                    clearTimeout(unblockTimeout_1);\n+                                    unblockTimeout_1 = window.setTimeout(resizeUnblockUpdate_1, 250);\n+                                    if (globalProjectionState.hasAnimatedSinceResize) {\n+                                        globalProjectionState.hasAnimatedSinceResize = false;\n+                                        _this.nodes.forEach(finishAnimation);\n+                                    }\n+                                });\n+                            }\n+                            if (layoutId) {\n+                                this.root.registerSharedNode(layoutId, this);\n+                            }\n+                            // Only register the handler if it requires layout animation\n+                            if (this.options.animate !== false && visualElement && (layoutId || layout)) {\n+                                this.addEventListener(\"didUpdate\", function(_a) {\n+                                    var _b, _c, _d, _e, _f;\n+                                    var delta = _a.delta,\n+                                        hasLayoutChanged = _a.hasLayoutChanged,\n+                                        hasRelativeTargetChanged = _a.hasRelativeTargetChanged,\n+                                        newLayout = _a.layout;\n+                                    if (_this.isTreeAnimationBlocked()) {\n+                                        _this.target = undefined;\n+                                        _this.relativeTarget = undefined;\n+                                        return;\n+                                    }\n+                                    // TODO: Check here if an animation exists\n+                                    var layoutTransition = (_c = (_b = _this.options.transition) !== null && _b !== void 0 ? _b : visualElement.getDefaultTransition()) !== null && _c !== void 0 ? _c : defaultLayoutTransition;\n+                                    var _g = visualElement.getProps(),\n+                                        onLayoutAnimationStart = _g.onLayoutAnimationStart,\n+                                        onLayoutAnimationComplete = _g.onLayoutAnimationComplete;\n+                                    /**\n+                                     * The target layout of the element might stay the same,\n+                                     * but its position relative to its parent has changed.\n+                                     */\n+                                    var targetChanged = !_this.targetLayout || !boxEquals(_this.targetLayout, newLayout) || hasRelativeTargetChanged;\n+                                    /**\n+                                     * If the layout hasn't seemed to have changed, it might be that the\n+                                     * element is visually in the same place in the document but its position\n+                                     * relative to its parent has indeed changed. So here we check for that.\n+                                     */\n+                                    var hasOnlyRelativeTargetChanged = !hasLayoutChanged && hasRelativeTargetChanged;\n+                                    if (((_d = _this.resumeFrom) === null || _d === void 0 ? void 0 : _d.instance) || hasOnlyRelativeTargetChanged || hasLayoutChanged && (targetChanged || !_this.currentAnimation)) {\n+                                        if (_this.resumeFrom) {\n+                                            _this.resumingFrom = _this.resumeFrom;\n+                                            _this.resumingFrom.resumingFrom = undefined;\n+                                        }\n+                                        _this.setAnimationOrigin(delta, hasOnlyRelativeTargetChanged);\n+                                        var animationOptions = tslib.__assign(tslib.__assign({}, getValueTransition(layoutTransition, \"layout\")), {\n+                                            onPlay: onLayoutAnimationStart,\n+                                            onComplete: onLayoutAnimationComplete\n+                                        });\n+                                        if (visualElement.shouldReduceMotion) {\n+                                            animationOptions.delay = 0;\n+                                            animationOptions.type = false;\n+                                        }\n+                                        _this.startAnimation(animationOptions);\n+                                    } else {\n+                                        /**\n+                                         * If the layout hasn't changed and we have an animation that hasn't started yet,\n+                                         * finish it immediately. Otherwise it will be animating from a location\n+                                         * that was probably never commited to screen and look like a jumpy box.\n+                                         */\n+                                        if (!hasLayoutChanged && _this.animationProgress === 0) {\n+                                            _this.finishAnimation();\n+                                        }\n+                                        _this.isLead() && ((_f = (_e = _this.options).onExitComplete) === null || _f === void 0 ? void 0 : _f.call(_e));\n+                                    }\n+                                    _this.targetLayout = newLayout;\n+                                });\n+                            }\n+                        };\n+                        ProjectionNode.prototype.unmount = function() {\n+                            var _a, _b;\n+                            this.options.layoutId && this.willUpdate();\n+                            this.root.nodes.remove(this);\n+                            (_a = this.getStack()) === null || _a === void 0 ? void 0 : _a.remove(this);\n+                            (_b = this.parent) === null || _b === void 0 ? void 0 : _b.children.delete(this);\n+                            this.instance = undefined;\n+                            sync.cancelSync.preRender(this.updateProjection);\n+                        };\n+                        // only on the root\n+                        ProjectionNode.prototype.blockUpdate = function() {\n+                            this.updateManuallyBlocked = true;\n+                        };\n+                        ProjectionNode.prototype.unblockUpdate = function() {\n+                            this.updateManuallyBlocked = false;\n+                        };\n+                        ProjectionNode.prototype.isUpdateBlocked = function() {\n+                            return this.updateManuallyBlocked || this.updateBlockedByResize;\n+                        };\n+                        ProjectionNode.prototype.isTreeAnimationBlocked = function() {\n+                            var _a;\n+                            return this.isAnimationBlocked || ((_a = this.parent) === null || _a === void 0 ? void 0 : _a.isTreeAnimationBlocked()) || false;\n+                        };\n+                        // Note: currently only running on root node\n+                        ProjectionNode.prototype.startUpdate = function() {\n+                            var _a;\n+                            if (this.isUpdateBlocked()) return;\n+                            this.isUpdating = true;\n+                            (_a = this.nodes) === null || _a === void 0 ? void 0 : _a.forEach(resetRotation);\n+                        };\n+                        ProjectionNode.prototype.willUpdate = function(shouldNotifyListeners) {\n+                            var _a, _b, _c;\n+                            if (shouldNotifyListeners === void 0) {\n+                                shouldNotifyListeners = true;\n+                            }\n+                            if (this.root.isUpdateBlocked()) {\n+                                (_b = (_a = this.options).onExitComplete) === null || _b === void 0 ? void 0 : _b.call(_a);\n+                                return;\n+                            }!this.root.isUpdating && this.root.startUpdate();\n+                            if (this.isLayoutDirty) return;\n+                            this.isLayoutDirty = true;\n+                            for (var i = 0; i < this.path.length; i++) {\n+                                var node = this.path[i];\n+                                node.shouldResetTransform = true;\n+                                /**\n+                                 * TODO: Check we haven't updated the scroll\n+                                 * since the last didUpdate\n+                                 */\n+                                node.updateScroll();\n+                            }\n+                            var _d = this.options,\n+                                layoutId = _d.layoutId,\n+                                layout = _d.layout;\n+                            if (layoutId === undefined && !layout) return;\n+                            var transformTemplate = (_c = this.options.visualElement) === null || _c === void 0 ? void 0 : _c.getProps().transformTemplate;\n+                            this.prevTransformTemplateValue = transformTemplate === null || transformTemplate === void 0 ? void 0 : transformTemplate(this.latestValues, \"\");\n+                            this.updateSnapshot();\n+                            shouldNotifyListeners && this.notifyListeners(\"willUpdate\");\n+                        };\n+                        // Note: Currently only running on root node\n+                        ProjectionNode.prototype.didUpdate = function() {\n+                            var updateWasBlocked = this.isUpdateBlocked();\n+                            // When doing an instant transition, we skip the layout update,\n+                            // but should still clean up the measurements so that the next\n+                            // snapshot could be taken correctly.\n+                            if (updateWasBlocked) {\n+                                this.unblockUpdate();\n+                                this.clearAllSnapshots();\n+                                this.nodes.forEach(clearMeasurements);\n+                                return;\n+                            }\n+                            if (!this.isUpdating) return;\n+                            this.isUpdating = false;\n+                            /**\n+                             * Search for and mount newly-added projection elements.\n+                             *\n+                             * TODO: Every time a new component is rendered we could search up the tree for\n+                             * the closest mounted node and query from there rather than document.\n+                             */\n+                            if (this.potentialNodes.size) {\n+                                this.potentialNodes.forEach(mountNodeEarly);\n+                                this.potentialNodes.clear();\n+                            }\n+                            /**\n+                             * Write\n+                             */\n+                            this.nodes.forEach(resetTransformStyle);\n+                            /**\n+                             * Read ==================\n+                             */\n+                            // Update layout measurements of updated children\n+                            this.nodes.forEach(updateLayout);\n+                            /**\n+                             * Write\n+                             */\n+                            // Notify listeners that the layout is updated\n+                            this.nodes.forEach(notifyLayoutUpdate);\n+                            this.clearAllSnapshots();\n+                            // Flush any scheduled updates\n+                            sync.flushSync.update();\n+                            sync.flushSync.preRender();\n+                            sync.flushSync.render();\n+                        };\n+                        ProjectionNode.prototype.clearAllSnapshots = function() {\n+                            this.nodes.forEach(clearSnapshot);\n+                            this.sharedNodes.forEach(removeLeadSnapshots);\n+                        };\n+                        ProjectionNode.prototype.scheduleUpdateProjection = function() {\n+                            sync__default[\"default\"].preRender(this.updateProjection, false, true);\n+                        };\n+                        ProjectionNode.prototype.scheduleCheckAfterUnmount = function() {\n+                            var _this = this;\n+                            /**\n+                             * If the unmounting node is in a layoutGroup and did trigger a willUpdate,\n+                             * we manually call didUpdate to give a chance to the siblings to animate.\n+                             * Otherwise, cleanup all snapshots to prevents future nodes from reusing them.\n+                             */\n+                            sync__default[\"default\"].postRender(function() {\n+                                if (_this.isLayoutDirty) {\n+                                    _this.root.didUpdate();\n+                                } else {\n+                                    _this.root.checkUpdateFailed();\n+                                }\n+                            });\n+                        };\n+                        /**\n+                         * Update measurements\n+                         */\n+                        ProjectionNode.prototype.updateSnapshot = function() {\n+                            if (this.snapshot || !this.instance) return;\n+                            var measured = this.measure();\n+                            var layout = this.removeTransform(this.removeElementScroll(measured));\n+                            roundBox(layout);\n+                            this.snapshot = {\n+                                measured: measured,\n+                                layout: layout,\n+                                latestValues: {}\n+                            };\n+                        };\n+                        ProjectionNode.prototype.updateLayout = function() {\n+                            var _a;\n+                            if (!this.instance) return;\n+                            // TODO: Incorporate into a forwarded scroll offset\n+                            this.updateScroll();\n+                            if (!(this.options.alwaysMeasureLayout && this.isLead()) && !this.isLayoutDirty) {\n+                                return;\n+                            }\n+                            /**\n+                             * When a node is mounted, it simply resumes from the prevLead's\n+                             * snapshot instead of taking a new one, but the ancestors scroll\n+                             * might have updated while the prevLead is unmounted. We need to\n+                             * update the scroll again to make sure the layout we measure is\n+                             * up to date.\n+                             */\n+                            if (this.resumeFrom && !this.resumeFrom.instance) {\n+                                for (var i = 0; i < this.path.length; i++) {\n+                                    var node = this.path[i];\n+                                    node.updateScroll();\n+                                }\n+                            }\n+                            var measured = this.measure();\n+                            roundBox(measured);\n+                            var prevLayout = this.layout;\n+                            this.layout = {\n+                                measured: measured,\n+                                actual: this.removeElementScroll(measured)\n+                            };\n+                            this.layoutCorrected = createBox();\n+                            this.isLayoutDirty = false;\n+                            this.projectionDelta = undefined;\n+                            this.notifyListeners(\"measure\", this.layout.actual);\n+                            (_a = this.options.visualElement) === null || _a === void 0 ? void 0 : _a.notifyLayoutMeasure(this.layout.actual, prevLayout === null || prevLayout === void 0 ? void 0 : prevLayout.actual);\n+                        };\n+                        ProjectionNode.prototype.updateScroll = function() {\n+                            if (this.options.layoutScroll && this.instance) {\n+                                this.isScrollRoot = checkIsScrollRoot(this.instance);\n+                                this.scroll = measureScroll(this.instance);\n+                            }\n+                        };\n+                        ProjectionNode.prototype.resetTransform = function() {\n+                            var _a;\n+                            if (!resetTransform) return;\n+                            var isResetRequested = this.isLayoutDirty || this.shouldResetTransform;\n+                            var hasProjection = this.projectionDelta && !isDeltaZero(this.projectionDelta);\n+                            var transformTemplate = (_a = this.options.visualElement) === null || _a === void 0 ? void 0 : _a.getProps().transformTemplate;\n+                            var transformTemplateValue = transformTemplate === null || transformTemplate === void 0 ? void 0 : transformTemplate(this.latestValues, \"\");\n+                            var transformTemplateHasChanged = transformTemplateValue !== this.prevTransformTemplateValue;\n+                            if (isResetRequested && (hasProjection || hasTransform(this.latestValues) || transformTemplateHasChanged)) {\n+                                resetTransform(this.instance, transformTemplateValue);\n+                                this.shouldResetTransform = false;\n+                                this.scheduleRender();\n+                            }\n+                        };\n+                        ProjectionNode.prototype.measure = function() {\n+                            var visualElement = this.options.visualElement;\n+                            if (!visualElement) return createBox();\n+                            var box = visualElement.measureViewportBox();\n+                            // Remove viewport scroll to give page-relative coordinates\n+                            var scroll = this.root.scroll;\n+                            if (scroll) {\n+                                translateAxis(box.x, scroll.x);\n+                                translateAxis(box.y, scroll.y);\n+                            }\n+                            return box;\n+                        };\n+                        ProjectionNode.prototype.removeElementScroll = function(box) {\n+                            var boxWithoutScroll = createBox();\n+                            copyBoxInto(boxWithoutScroll, box);\n+                            /**\n+                             * Performance TODO: Keep a cumulative scroll offset down the tree\n+                             * rather than loop back up the path.\n+                             */\n+                            for (var i = 0; i < this.path.length; i++) {\n+                                var node = this.path[i];\n+                                var scroll_1 = node.scroll,\n+                                    options = node.options,\n+                                    isScrollRoot = node.isScrollRoot;\n+                                if (node !== this.root && scroll_1 && options.layoutScroll) {\n+                                    /**\n+                                     * If this is a new scroll root, we want to remove all previous scrolls\n+                                     * from the viewport box.\n+                                     */\n+                                    if (isScrollRoot) {\n+                                        copyBoxInto(boxWithoutScroll, box);\n+                                        var rootScroll = this.root.scroll;\n+                                        /**\n+                                         * Undo the application of page scroll that was originally added\n+                                         * to the measured bounding box.\n+                                         */\n+                                        if (rootScroll) {\n+                                            translateAxis(boxWithoutScroll.x, -rootScroll.x);\n+                                            translateAxis(boxWithoutScroll.y, -rootScroll.y);\n+                                        }\n+                                    }\n+                                    translateAxis(boxWithoutScroll.x, scroll_1.x);\n+                                    translateAxis(boxWithoutScroll.y, scroll_1.y);\n+                                }\n+                            }\n+                            return boxWithoutScroll;\n+                        };\n+                        ProjectionNode.prototype.applyTransform = function(box, transformOnly) {\n+                            if (transformOnly === void 0) {\n+                                transformOnly = false;\n+                            }\n+                            var withTransforms = createBox();\n+                            copyBoxInto(withTransforms, box);\n+                            for (var i = 0; i < this.path.length; i++) {\n+                                var node = this.path[i];\n+                                if (!transformOnly && node.options.layoutScroll && node.scroll && node !== node.root) {\n+                                    transformBox(withTransforms, {\n+                                        x: -node.scroll.x,\n+                                        y: -node.scroll.y\n+                                    });\n+                                }\n+                                if (!hasTransform(node.latestValues)) continue;\n+                                transformBox(withTransforms, node.latestValues);\n+                            }\n+                            if (hasTransform(this.latestValues)) {\n+                                transformBox(withTransforms, this.latestValues);\n+                            }\n+                            return withTransforms;\n+                        };\n+                        ProjectionNode.prototype.removeTransform = function(box) {\n+                            var _a;\n+                            var boxWithoutTransform = createBox();\n+                            copyBoxInto(boxWithoutTransform, box);\n+                            for (var i = 0; i < this.path.length; i++) {\n+                                var node = this.path[i];\n+                                if (!node.instance) continue;\n+                                if (!hasTransform(node.latestValues)) continue;\n+                                hasScale(node.latestValues) && node.updateSnapshot();\n+                                var sourceBox = createBox();\n+                                var nodeBox = node.measure();\n+                                copyBoxInto(sourceBox, nodeBox);\n+                                removeBoxTransforms(boxWithoutTransform, node.latestValues, (_a = node.snapshot) === null || _a === void 0 ? void 0 : _a.layout, sourceBox);\n+                            }\n+                            if (hasTransform(this.latestValues)) {\n+                                removeBoxTransforms(boxWithoutTransform, this.latestValues);\n+                            }\n+                            return boxWithoutTransform;\n+                        };\n+                        /**\n+                         *\n+                         */\n+                        ProjectionNode.prototype.setTargetDelta = function(delta) {\n+                            this.targetDelta = delta;\n+                            this.root.scheduleUpdateProjection();\n+                        };\n+                        ProjectionNode.prototype.setOptions = function(options) {\n+                            var _a;\n+                            this.options = tslib.__assign(tslib.__assign(tslib.__assign({}, this.options), options), {\n+                                crossfade: (_a = options.crossfade) !== null && _a !== void 0 ? _a : true\n+                            });\n+                        };\n+                        ProjectionNode.prototype.clearMeasurements = function() {\n+                            this.scroll = undefined;\n+                            this.layout = undefined;\n+                            this.snapshot = undefined;\n+                            this.prevTransformTemplateValue = undefined;\n+                            this.targetDelta = undefined;\n+                            this.target = undefined;\n+                            this.isLayoutDirty = false;\n+                        };\n+                        /**\n+                         * Frame calculations\n+                         */\n+                        ProjectionNode.prototype.resolveTargetDelta = function() {\n+                            var _a;\n+                            var _b = this.options,\n+                                layout = _b.layout,\n+                                layoutId = _b.layoutId;\n+                            /**\n+                             * If we have no layout, we can't perform projection, so early return\n+                             */\n+                            if (!this.layout || !(layout || layoutId)) return;\n+                            /**\n+                             * If we don't have a targetDelta but do have a layout, we can attempt to resolve\n+                             * a relativeParent. This will allow a component to perform scale correction\n+                             * even if no animation has started.\n+                             */\n+                            // TODO If this is unsuccessful this currently happens every frame\n+                            if (!this.targetDelta && !this.relativeTarget) {\n+                                // TODO: This is a semi-repetition of further down this function, make DRY\n+                                this.relativeParent = this.getClosestProjectingParent();\n+                                if (this.relativeParent && this.relativeParent.layout) {\n+                                    this.relativeTarget = createBox();\n+                                    this.relativeTargetOrigin = createBox();\n+                                    calcRelativePosition(this.relativeTargetOrigin, this.layout.actual, this.relativeParent.layout.actual);\n+                                    copyBoxInto(this.relativeTarget, this.relativeTargetOrigin);\n+                                }\n+                            }\n+                            /**\n+                             * If we have no relative target or no target delta our target isn't valid\n+                             * for this frame.\n+                             */\n+                            if (!this.relativeTarget && !this.targetDelta) return;\n+                            /**\n+                             * Lazy-init target data structure\n+                             */\n+                            if (!this.target) {\n+                                this.target = createBox();\n+                                this.targetWithTransforms = createBox();\n+                            }\n+                            /**\n+                             * If we've got a relative box for this component, resolve it into a target relative to the parent.\n+                             */\n+                            if (this.relativeTarget && this.relativeTargetOrigin && ((_a = this.relativeParent) === null || _a === void 0 ? void 0 : _a.target)) {\n+                                calcRelativeBox(this.target, this.relativeTarget, this.relativeParent.target);\n+                                /**\n+                                 * If we've only got a targetDelta, resolve it into a target\n+                                 */\n+                            } else if (this.targetDelta) {\n+                                if (Boolean(this.resumingFrom)) {\n+                                    // TODO: This is creating a new object every frame\n+                                    this.target = this.applyTransform(this.layout.actual);\n+                                } else {\n+                                    copyBoxInto(this.target, this.layout.actual);\n+                                }\n+                                applyBoxDelta(this.target, this.targetDelta);\n+                            } else {\n+                                /**\n+                                 * If no target, use own layout as target\n+                                 */\n+                                copyBoxInto(this.target, this.layout.actual);\n+                            }\n+                            /**\n+                             * If we've been told to attempt to resolve a relative target, do so.\n+                             */\n+                            if (this.attemptToResolveRelativeTarget) {\n+                                this.attemptToResolveRelativeTarget = false;\n+                                this.relativeParent = this.getClosestProjectingParent();\n+                                if (this.relativeParent && Boolean(this.relativeParent.resumingFrom) === Boolean(this.resumingFrom) && !this.relativeParent.options.layoutScroll && this.relativeParent.target) {\n+                                    this.relativeTarget = createBox();\n+                                    this.relativeTargetOrigin = createBox();\n+                                    calcRelativePosition(this.relativeTargetOrigin, this.target, this.relativeParent.target);\n+                                    copyBoxInto(this.relativeTarget, this.relativeTargetOrigin);\n+                                }\n+                            }\n+                        };\n+                        ProjectionNode.prototype.getClosestProjectingParent = function() {\n+                            if (!this.parent || hasTransform(this.parent.latestValues)) return undefined;\n+                            if ((this.parent.relativeTarget || this.parent.targetDelta) && this.parent.layout) {\n+                                return this.parent;\n+                            } else {\n+                                return this.parent.getClosestProjectingParent();\n+                            }\n+                        };\n+                        ProjectionNode.prototype.calcProjection = function() {\n+                            var _a;\n+                            var _b = this.options,\n+                                layout = _b.layout,\n+                                layoutId = _b.layoutId;\n+                            /**\n+                             * If this section of the tree isn't animating we can\n+                             * delete our target sources for the following frame.\n+                             */\n+                            this.isTreeAnimating = Boolean(((_a = this.parent) === null || _a === void 0 ? void 0 : _a.isTreeAnimating) || this.currentAnimation || this.pendingAnimation);\n+                            if (!this.isTreeAnimating) {\n+                                this.targetDelta = this.relativeTarget = undefined;\n+                            }\n+                            if (!this.layout || !(layout || layoutId)) return;\n+                            var lead = this.getLead();\n+                            /**\n+                             * Reset the corrected box with the latest values from box, as we're then going\n+                             * to perform mutative operations on it.\n+                             */\n+                            copyBoxInto(this.layoutCorrected, this.layout.actual);\n+                            /**\n+                             * Apply all the parent deltas to this box to produce the corrected box. This\n+                             * is the layout box, as it will appear on screen as a result of the transforms of its parents.\n+                             */\n+                            applyTreeDeltas(this.layoutCorrected, this.treeScale, this.path, Boolean(this.resumingFrom) || this !== lead);\n+                            var target = lead.target;\n+                            if (!target) return;\n+                            if (!this.projectionDelta) {\n+                                this.projectionDelta = createDelta();\n+                                this.projectionDeltaWithTransform = createDelta();\n+                            }\n+                            var prevTreeScaleX = this.treeScale.x;\n+                            var prevTreeScaleY = this.treeScale.y;\n+                            var prevProjectionTransform = this.projectionTransform;\n+                            /**\n+                             * Update the delta between the corrected box and the target box before user-set transforms were applied.\n+                             * This will allow us to calculate the corrected borderRadius and boxShadow to compensate\n+                             * for our layout reprojection, but still allow them to be scaled correctly by the user.\n+                             * It might be that to simplify this we may want to accept that user-set scale is also corrected\n+                             * and we wouldn't have to keep and calc both deltas, OR we could support a user setting\n+                             * to allow people to choose whether these styles are corrected based on just the\n+                             * layout reprojection or the final bounding box.\n+                             */\n+                            calcBoxDelta(this.projectionDelta, this.layoutCorrected, target, this.latestValues);\n+                            this.projectionTransform = buildProjectionTransform(this.projectionDelta, this.treeScale);\n+                            if (this.projectionTransform !== prevProjectionTransform || this.treeScale.x !== prevTreeScaleX || this.treeScale.y !== prevTreeScaleY) {\n+                                this.hasProjected = true;\n+                                this.scheduleRender();\n+                                this.notifyListeners(\"projectionUpdate\", target);\n+                            }\n+                        };\n+                        ProjectionNode.prototype.hide = function() {\n+                            this.isVisible = false;\n+                            // TODO: Schedule render\n+                        };\n+                        ProjectionNode.prototype.show = function() {\n+                            this.isVisible = true;\n+                            // TODO: Schedule render\n+                        };\n+                        ProjectionNode.prototype.scheduleRender = function(notifyAll) {\n+                            var _a, _b, _c;\n+                            if (notifyAll === void 0) {\n+                                notifyAll = true;\n+                            }\n+                            (_b = (_a = this.options).scheduleRender) === null || _b === void 0 ? void 0 : _b.call(_a);\n+                            notifyAll && ((_c = this.getStack()) === null || _c === void 0 ? void 0 : _c.scheduleRender());\n+                            if (this.resumingFrom && !this.resumingFrom.instance) {\n+                                this.resumingFrom = undefined;\n+                            }\n+                        };\n+                        ProjectionNode.prototype.setAnimationOrigin = function(delta, hasOnlyRelativeTargetChanged) {\n+                            var _this = this;\n+                            var _a;\n+                            if (hasOnlyRelativeTargetChanged === void 0) {\n+                                hasOnlyRelativeTargetChanged = false;\n+                            }\n+                            var snapshot = this.snapshot;\n+                            var snapshotLatestValues = (snapshot === null || snapshot === void 0 ? void 0 : snapshot.latestValues) || {};\n+                            var mixedValues = tslib.__assign({}, this.latestValues);\n+                            var targetDelta = createDelta();\n+                            this.relativeTarget = this.relativeTargetOrigin = undefined;\n+                            this.attemptToResolveRelativeTarget = !hasOnlyRelativeTargetChanged;\n+                            var relativeLayout = createBox();\n+                            var isSharedLayoutAnimation = snapshot === null || snapshot === void 0 ? void 0 : snapshot.isShared;\n+                            var isOnlyMember = (((_a = this.getStack()) === null || _a === void 0 ? void 0 : _a.members.length) || 0) <= 1;\n+                            var shouldCrossfadeOpacity = Boolean(isSharedLayoutAnimation && !isOnlyMember && this.options.crossfade === true && !this.path.some(hasOpacityCrossfade));\n+                            this.animationProgress = 0;\n+                            this.mixTargetDelta = function(latest) {\n+                                var _a;\n+                                var progress = latest / 1000;\n+                                mixAxisDelta(targetDelta.x, delta.x, progress);\n+                                mixAxisDelta(targetDelta.y, delta.y, progress);\n+                                _this.setTargetDelta(targetDelta);\n+                                if (_this.relativeTarget && _this.relativeTargetOrigin && _this.layout && ((_a = _this.relativeParent) === null || _a === void 0 ? void 0 : _a.layout)) {\n+                                    calcRelativePosition(relativeLayout, _this.layout.actual, _this.relativeParent.layout.actual);\n+                                    mixBox(_this.relativeTarget, _this.relativeTargetOrigin, relativeLayout, progress);\n+                                }\n+                                if (isSharedLayoutAnimation) {\n+                                    _this.animationValues = mixedValues;\n+                                    mixValues(mixedValues, snapshotLatestValues, _this.latestValues, progress, shouldCrossfadeOpacity, isOnlyMember);\n+                                }\n+                                _this.root.scheduleUpdateProjection();\n+                                _this.scheduleRender();\n+                                _this.animationProgress = progress;\n+                            };\n+                            this.mixTargetDelta(0);\n+                        };\n+                        ProjectionNode.prototype.startAnimation = function(options) {\n+                            var _this = this;\n+                            var _a, _b;\n+                            this.notifyListeners(\"animationStart\");\n+                            (_a = this.currentAnimation) === null || _a === void 0 ? void 0 : _a.stop();\n+                            if (this.resumingFrom) {\n+                                (_b = this.resumingFrom.currentAnimation) === null || _b === void 0 ? void 0 : _b.stop();\n+                            }\n+                            if (this.pendingAnimation) {\n+                                sync.cancelSync.update(this.pendingAnimation);\n+                                this.pendingAnimation = undefined;\n+                            }\n+                            /**\n+                             * Start the animation in the next frame to have a frame with progress 0,\n+                             * where the target is the same as when the animation started, so we can\n+                             * calculate the relative positions correctly for instant transitions.\n+                             */\n+                            this.pendingAnimation = sync__default[\"default\"].update(function() {\n+                                globalProjectionState.hasAnimatedSinceResize = true;\n+                                _this.currentAnimation = animate(0, animationTarget, tslib.__assign(tslib.__assign({}, options), {\n+                                    onUpdate: function(latest) {\n+                                        var _a;\n+                                        _this.mixTargetDelta(latest);\n+                                        (_a = options.onUpdate) === null || _a === void 0 ? void 0 : _a.call(options, latest);\n+                                    },\n+                                    onComplete: function() {\n+                                        var _a;\n+                                        (_a = options.onComplete) === null || _a === void 0 ? void 0 : _a.call(options);\n+                                        _this.completeAnimation();\n+                                    }\n+                                }));\n+                                if (_this.resumingFrom) {\n+                                    _this.resumingFrom.currentAnimation = _this.currentAnimation;\n+                                }\n+                                _this.pendingAnimation = undefined;\n+                            });\n+                        };\n+                        ProjectionNode.prototype.completeAnimation = function() {\n+                            var _a;\n+                            if (this.resumingFrom) {\n+                                this.resumingFrom.currentAnimation = undefined;\n+                                this.resumingFrom.preserveOpacity = undefined;\n+                            }\n+                            (_a = this.getStack()) === null || _a === void 0 ? void 0 : _a.exitAnimationComplete();\n+                            this.resumingFrom = this.currentAnimation = this.animationValues = undefined;\n+                            this.notifyListeners(\"animationComplete\");\n+                        };\n+                        ProjectionNode.prototype.finishAnimation = function() {\n+                            var _a;\n+                            if (this.currentAnimation) {\n+                                (_a = this.mixTargetDelta) === null || _a === void 0 ? void 0 : _a.call(this, animationTarget);\n+                                this.currentAnimation.stop();\n+                            }\n+                            this.completeAnimation();\n+                        };\n+                        ProjectionNode.prototype.applyTransformsToTarget = function() {\n+                            var _a = this.getLead(),\n+                                targetWithTransforms = _a.targetWithTransforms,\n+                                target = _a.target,\n+                                layout = _a.layout,\n+                                latestValues = _a.latestValues;\n+                            if (!targetWithTransforms || !target || !layout) return;\n+                            copyBoxInto(targetWithTransforms, target);\n+                            /**\n+                             * Apply the latest user-set transforms to the targetBox to produce the targetBoxFinal.\n+                             * This is the final box that we will then project into by calculating a transform delta and\n+                             * applying it to the corrected box.\n+                             */\n+                            transformBox(targetWithTransforms, latestValues);\n+                            /**\n+                             * Update the delta between the corrected box and the final target box, after\n+                             * user-set transforms are applied to it. This will be used by the renderer to\n+                             * create a transform style that will reproject the element from its actual layout\n+                             * into the desired bounding box.\n+                             */\n+                            calcBoxDelta(this.projectionDeltaWithTransform, this.layoutCorrected, targetWithTransforms, latestValues);\n+                        };\n+                        ProjectionNode.prototype.registerSharedNode = function(layoutId, node) {\n+                            var _a, _b, _c;\n+                            if (!this.sharedNodes.has(layoutId)) {\n+                                this.sharedNodes.set(layoutId, new NodeStack());\n+                            }\n+                            var stack = this.sharedNodes.get(layoutId);\n+                            stack.add(node);\n+                            node.promote({\n+                                transition: (_a = node.options.initialPromotionConfig) === null || _a === void 0 ? void 0 : _a.transition,\n+                                preserveFollowOpacity: (_c = (_b = node.options.initialPromotionConfig) === null || _b === void 0 ? void 0 : _b.shouldPreserveFollowOpacity) === null || _c === void 0 ? void 0 : _c.call(_b, node)\n+                            });\n+                        };\n+                        ProjectionNode.prototype.isLead = function() {\n+                            var stack = this.getStack();\n+                            return stack ? stack.lead === this : true;\n+                        };\n+                        ProjectionNode.prototype.getLead = function() {\n+                            var _a;\n+                            var layoutId = this.options.layoutId;\n+                            return layoutId ? ((_a = this.getStack()) === null || _a === void 0 ? void 0 : _a.lead) || this : this;\n+                        };\n+                        ProjectionNode.prototype.getPrevLead = function() {\n+                            var _a;\n+                            var layoutId = this.options.layoutId;\n+                            return layoutId ? (_a = this.getStack()) === null || _a === void 0 ? void 0 : _a.prevLead : undefined;\n+                        };\n+                        ProjectionNode.prototype.getStack = function() {\n+                            var layoutId = this.options.layoutId;\n+                            if (layoutId) return this.root.sharedNodes.get(layoutId);\n+                        };\n+                        ProjectionNode.prototype.promote = function(_a) {\n+                            var _b = _a === void 0 ? {} : _a,\n+                                needsReset = _b.needsReset,\n+                                transition = _b.transition,\n+                                preserveFollowOpacity = _b.preserveFollowOpacity;\n+                            var stack = this.getStack();\n+                            if (stack) stack.promote(this, preserveFollowOpacity);\n+                            if (needsReset) {\n+                                this.projectionDelta = undefined;\n+                                this.needsReset = true;\n+                            }\n+                            if (transition) this.setOptions({\n+                                transition: transition\n+                            });\n+                        };\n+                        ProjectionNode.prototype.relegate = function() {\n+                            var stack = this.getStack();\n+                            if (stack) {\n+                                return stack.relegate(this);\n+                            } else {\n+                                return false;\n+                            }\n+                        };\n+                        ProjectionNode.prototype.resetRotation = function() {\n+                            var visualElement = this.options.visualElement;\n+                            if (!visualElement) return;\n+                            // If there's no detected rotation values, we can early return without a forced render.\n+                            var hasRotate = false;\n+                            // Keep a record of all the values we've reset\n+                            var resetValues = {};\n+                            // Check the rotate value of all axes and reset to 0\n+                            for (var i = 0; i < transformAxes.length; i++) {\n+                                var axis = transformAxes[i];\n+                                var key = \"rotate\" + axis;\n+                                // If this rotation doesn't exist as a motion value, then we don't\n+                                // need to reset it\n+                                if (!visualElement.getStaticValue(key)) {\n+                                    continue;\n+                                }\n+                                hasRotate = true;\n+                                // Record the rotation and then temporarily set it to 0\n+                                resetValues[key] = visualElement.getStaticValue(key);\n+                                visualElement.setStaticValue(key, 0);\n+                            }\n+                            // If there's no rotation values, we don't need to do any more.\n+                            if (!hasRotate) return;\n+                            // Force a render of this element to apply the transform with all rotations\n+                            // set to 0.\n+                            visualElement === null || visualElement === void 0 ? void 0 : visualElement.syncRender();\n+                            // Put back all the values we reset\n+                            for (var key in resetValues) {\n+                                visualElement.setStaticValue(key, resetValues[key]);\n+                            }\n+                            // Schedule a render for the next frame. This ensures we won't visually\n+                            // see the element with the reset rotate value applied.\n+                            visualElement.scheduleRender();\n+                        };\n+                        ProjectionNode.prototype.getProjectionStyles = function(styleProp) {\n+                            var _a, _b, _c, _d, _e, _f;\n+                            if (styleProp === void 0) {\n+                                styleProp = {};\n+                            }\n+                            // TODO: Return lifecycle-persistent object\n+                            var styles = {};\n+                            if (!this.instance || this.isSVG) return styles;\n+                            if (!this.isVisible) {\n+                                return {\n+                                    visibility: \"hidden\"\n+                                };\n+                            } else {\n+                                styles.visibility = \"\";\n+                            }\n+                            var transformTemplate = (_a = this.options.visualElement) === null || _a === void 0 ? void 0 : _a.getProps().transformTemplate;\n+                            if (this.needsReset) {\n+                                this.needsReset = false;\n+                                styles.opacity = \"\";\n+                                styles.pointerEvents = resolveMotionValue(styleProp.pointerEvents) || \"\";\n+                                styles.transform = transformTemplate ? transformTemplate(this.latestValues, \"\") : \"none\";\n+                                return styles;\n+                            }\n+                            var lead = this.getLead();\n+                            if (!this.projectionDelta || !this.layout || !lead.target) {\n+                                var emptyStyles = {};\n+                                if (this.options.layoutId) {\n+                                    emptyStyles.opacity = (_b = this.latestValues.opacity) !== null && _b !== void 0 ? _b : 1;\n+                                    emptyStyles.pointerEvents = resolveMotionValue(styleProp.pointerEvents) || \"\";\n+                                }\n+                                if (this.hasProjected && !hasTransform(this.latestValues)) {\n+                                    emptyStyles.transform = transformTemplate ? transformTemplate({}, \"\") : \"none\";\n+                                    this.hasProjected = false;\n+                                }\n+                                return emptyStyles;\n+                            }\n+                            var valuesToRender = lead.animationValues || lead.latestValues;\n+                            this.applyTransformsToTarget();\n+                            styles.transform = buildProjectionTransform(this.projectionDeltaWithTransform, this.treeScale, valuesToRender);\n+                            if (transformTemplate) {\n+                                styles.transform = transformTemplate(valuesToRender, styles.transform);\n+                            }\n+                            var _g = this.projectionDelta,\n+                                x = _g.x,\n+                                y = _g.y;\n+                            styles.transformOrigin = \"\".concat(x.origin * 100, \"% \").concat(y.origin * 100, \"% 0\");\n+                            if (lead.animationValues) {\n+                                /**\n+                                 * If the lead component is animating, assign this either the entering/leaving\n+                                 * opacity\n+                                 */\n+                                styles.opacity = lead === this ? (_d = (_c = valuesToRender.opacity) !== null && _c !== void 0 ? _c : this.latestValues.opacity) !== null && _d !== void 0 ? _d : 1 : this.preserveOpacity ? this.latestValues.opacity : valuesToRender.opacityExit;\n+                            } else {\n+                                /**\n+                                 * Or we're not animating at all, set the lead component to its actual\n+                                 * opacity and other components to hidden.\n+                                 */\n+                                styles.opacity = lead === this ? (_e = valuesToRender.opacity) !== null && _e !== void 0 ? _e : \"\" : (_f = valuesToRender.opacityExit) !== null && _f !== void 0 ? _f : 0;\n+                            }\n+                            /**\n+                             * Apply scale correction\n+                             */\n+                            for (var key in scaleCorrectors) {\n+                                if (valuesToRender[key] === undefined) continue;\n+                                var _h = scaleCorrectors[key],\n+                                    correct = _h.correct,\n+                                    applyTo = _h.applyTo;\n+                                var corrected = correct(valuesToRender[key], lead);\n+                                if (applyTo) {\n+                                    var num = applyTo.length;\n+                                    for (var i = 0; i < num; i++) {\n+                                        styles[applyTo[i]] = corrected;\n+                                    }\n+                                } else {\n+                                    styles[key] = corrected;\n+                                }\n+                            }\n+                            /**\n+                             * Disable pointer events on follow components. This is to ensure\n+                             * that if a follow component covers a lead component it doesn't block\n+                             * pointer events on the lead.\n+                             */\n+                            if (this.options.layoutId) {\n+                                styles.pointerEvents = lead === this ? resolveMotionValue(styleProp.pointerEvents) || \"\" : \"none\";\n+                            }\n+                            return styles;\n+                        };\n+                        ProjectionNode.prototype.clearSnapshot = function() {\n+                            this.resumeFrom = this.snapshot = undefined;\n+                        };\n+                        // Only run on root\n+                        ProjectionNode.prototype.resetTree = function() {\n+                            this.root.nodes.forEach(function(node) {\n+                                var _a;\n+                                return (_a = node.currentAnimation) === null || _a === void 0 ? void 0 : _a.stop();\n+                            });\n+                            this.root.nodes.forEach(clearMeasurements);\n+                            this.root.sharedNodes.clear();\n+                        };\n+                        return ProjectionNode;\n+                    }();\n+                }\n+\n+                function updateLayout(node) {\n+                    node.updateLayout();\n+                }\n+\n+                function notifyLayoutUpdate(node) {\n+                    var _a, _b, _c, _d;\n+                    var snapshot = (_b = (_a = node.resumeFrom) === null || _a === void 0 ? void 0 : _a.snapshot) !== null && _b !== void 0 ? _b : node.snapshot;\n+                    if (node.isLead() && node.layout && snapshot && node.hasListeners(\"didUpdate\")) {\n+                        var _e = node.layout,\n+                            layout_1 = _e.actual,\n+                            measuredLayout = _e.measured;\n+                        // TODO Maybe we want to also resize the layout snapshot so we don't trigger\n+                        // animations for instance if layout=\"size\" and an element has only changed position\n+                        if (node.options.animationType === \"size\") {\n+                            eachAxis(function(axis) {\n+                                var axisSnapshot = snapshot.isShared ? snapshot.measured[axis] : snapshot.layout[axis];\n+                                var length = calcLength(axisSnapshot);\n+                                axisSnapshot.min = layout_1[axis].min;\n+                                axisSnapshot.max = axisSnapshot.min + length;\n+                            });\n+                        } else if (node.options.animationType === \"position\") {\n+                            eachAxis(function(axis) {\n+                                var axisSnapshot = snapshot.isShared ? snapshot.measured[axis] : snapshot.layout[axis];\n+                                var length = calcLength(layout_1[axis]);\n+                                axisSnapshot.max = axisSnapshot.min + length;\n+                            });\n+                        }\n+                        var layoutDelta = createDelta();\n+                        calcBoxDelta(layoutDelta, layout_1, snapshot.layout);\n+                        var visualDelta = createDelta();\n+                        if (snapshot.isShared) {\n+                            calcBoxDelta(visualDelta, node.applyTransform(measuredLayout, true), snapshot.measured);\n+                        } else {\n+                            calcBoxDelta(visualDelta, layout_1, snapshot.layout);\n+                        }\n+                        var hasLayoutChanged = !isDeltaZero(layoutDelta);\n+                        var hasRelativeTargetChanged = false;\n+                        if (!node.resumeFrom) {\n+                            node.relativeParent = node.getClosestProjectingParent();\n+                            /**\n+                             * If the relativeParent is itself resuming from a different element then\n+                             * the relative snapshot is not relavent\n+                             */\n+                            if (node.relativeParent && !node.relativeParent.resumeFrom) {\n+                                var _f = node.relativeParent,\n+                                    parentSnapshot = _f.snapshot,\n+                                    parentLayout = _f.layout;\n+                                if (parentSnapshot && parentLayout) {\n+                                    var relativeSnapshot = createBox();\n+                                    calcRelativePosition(relativeSnapshot, snapshot.layout, parentSnapshot.layout);\n+                                    var relativeLayout = createBox();\n+                                    calcRelativePosition(relativeLayout, layout_1, parentLayout.actual);\n+                                    if (!boxEquals(relativeSnapshot, relativeLayout)) {\n+                                        hasRelativeTargetChanged = true;\n+                                    }\n+                                }\n+                            }\n+                        }\n+                        node.notifyListeners(\"didUpdate\", {\n+                            layout: layout_1,\n+                            snapshot: snapshot,\n+                            delta: visualDelta,\n+                            layoutDelta: layoutDelta,\n+                            hasLayoutChanged: hasLayoutChanged,\n+                            hasRelativeTargetChanged: hasRelativeTargetChanged\n+                        });\n+                    } else if (node.isLead()) {\n+                        (_d = (_c = node.options).onExitComplete) === null || _d === void 0 ? void 0 : _d.call(_c);\n+                    }\n+                    /**\n+                     * Clearing transition\n+                     * TODO: Investigate why this transition is being passed in as {type: false } from Framer\n+                     * and why we need it at all\n+                     */\n+                    node.options.transition = undefined;\n+                }\n+\n+                function clearSnapshot(node) {\n+                    node.clearSnapshot();\n+                }\n+\n+                function clearMeasurements(node) {\n+                    node.clearMeasurements();\n+                }\n+\n+                function resetTransformStyle(node) {\n+                    var visualElement = node.options.visualElement;\n+                    if (visualElement === null || visualElement === void 0 ? void 0 : visualElement.getProps().onBeforeLayoutMeasure) {\n+                        visualElement.notifyBeforeLayoutMeasure();\n+                    }\n+                    node.resetTransform();\n+                }\n+\n+                function finishAnimation(node) {\n+                    node.finishAnimation();\n+                    node.targetDelta = node.relativeTarget = node.target = undefined;\n+                }\n+\n+                function resolveTargetDelta(node) {\n+                    node.resolveTargetDelta();\n+                }\n+\n+                function calcProjection(node) {\n+                    node.calcProjection();\n+                }\n+\n+                function resetRotation(node) {\n+                    node.resetRotation();\n+                }\n+\n+                function removeLeadSnapshots(stack) {\n+                    stack.removeLeadSnapshot();\n+                }\n+\n+                function mixAxisDelta(output, delta, p) {\n+                    output.translate = popmotion.mix(delta.translate, 0, p);\n+                    output.scale = popmotion.mix(delta.scale, 1, p);\n+                    output.origin = delta.origin;\n+                    output.originPoint = delta.originPoint;\n+                }\n+\n+                function mixAxis(output, from, to, p) {\n+                    output.min = popmotion.mix(from.min, to.min, p);\n+                    output.max = popmotion.mix(from.max, to.max, p);\n+                }\n+\n+                function mixBox(output, from, to, p) {\n+                    mixAxis(output.x, from.x, to.x, p);\n+                    mixAxis(output.y, from.y, to.y, p);\n+                }\n+\n+                function hasOpacityCrossfade(node) {\n+                    return node.animationValues && node.animationValues.opacityExit !== undefined;\n+                }\n+                var defaultLayoutTransition = {\n+                    duration: 0.45,\n+                    ease: [0.4, 0, 0.1, 1]\n+                };\n+\n+                function mountNodeEarly(node, id) {\n+                    /**\n+                     * Rather than searching the DOM from document we can search the\n+                     * path for the deepest mounted ancestor and search from there\n+                     */\n+                    var searchNode = node.root;\n+                    for (var i = node.path.length - 1; i >= 0; i--) {\n+                        if (Boolean(node.path[i].instance)) {\n+                            searchNode = node.path[i];\n+                            break;\n+                        }\n+                    }\n+                    var searchElement = searchNode && searchNode !== node.root ? searchNode.instance : document;\n+                    var element = searchElement.querySelector(\"[data-projection-id=\\\"\".concat(id, \"\\\"]\"));\n+                    if (element) node.mount(element, true);\n+                }\n+\n+                function roundAxis(axis) {\n+                    axis.min = Math.round(axis.min);\n+                    axis.max = Math.round(axis.max);\n+                }\n+\n+                function roundBox(box) {\n+                    roundAxis(box.x);\n+                    roundAxis(box.y);\n+                }\n+                var DocumentProjectionNode = createProjectionNode({\n+                    attachResizeListener: function(ref, notify) {\n+                        return addDomEvent(ref, \"resize\", notify);\n+                    },\n+                    measureScroll: function() {\n+                        return {\n+                            x: document.documentElement.scrollLeft || document.body.scrollLeft,\n+                            y: document.documentElement.scrollTop || document.body.scrollTop\n+                        };\n+                    },\n+                    checkIsScrollRoot: function() {\n+                        return true;\n+                    }\n+                });\n+                var rootProjectionNode = {\n+                    current: undefined\n+                };\n+                var HTMLProjectionNode = createProjectionNode({\n+                    measureScroll: function(instance) {\n+                        return {\n+                            x: instance.scrollLeft,\n+                            y: instance.scrollTop\n+                        };\n+                    },\n+                    defaultParent: function() {\n+                        if (!rootProjectionNode.current) {\n+                            var documentNode = new DocumentProjectionNode(0, {});\n+                            documentNode.mount(window);\n+                            documentNode.setOptions({\n+                                layoutScroll: true\n+                            });\n+                            rootProjectionNode.current = documentNode;\n+                        }\n+                        return rootProjectionNode.current;\n+                    },\n+                    resetTransform: function(instance, value) {\n+                        instance.style.transform = value !== null && value !== void 0 ? value : \"none\";\n+                    },\n+                    checkIsScrollRoot: function(instance) {\n+                        return Boolean(window.getComputedStyle(instance).position === \"fixed\");\n+                    }\n+                });\n+                var featureBundle = tslib.__assign(tslib.__assign(tslib.__assign(tslib.__assign({}, animations), gestureAnimations), drag), layoutFeatures);\n+                /**\n+                 * HTML & SVG components, optimised for use with gestures and animation. These can be used as\n+                 * drop-in replacements for any HTML & SVG component, all CSS & SVG properties are supported.\n+                 *\n+                 * @public\n+                 */\n+                var motion = /*@__PURE__*/ createMotionProxy(function(Component, config) {\n+                    return createDomMotionConfig(Component, config, featureBundle, createDomVisualElement, HTMLProjectionNode);\n+                });\n+                /**\n+                 * Create a DOM `motion` component with the provided string. This is primarily intended\n+                 * as a full alternative to `motion` for consumers who have to support environments that don't\n+                 * support `Proxy`.\n+                 *\n+                 * ```javascript\n+                 * import { createDomMotionComponent } from \"framer-motion\"\n+                 *\n+                 * const motion = {\n+                 *   div: createDomMotionComponent('div')\n+                 * }\n+                 * ```\n+                 *\n+                 * @public\n+                 */\n+                function createDomMotionComponent(key) {\n+                    return createMotionComponent(createDomMotionConfig(key, {\n+                        forwardMotionProps: false\n+                    }, featureBundle, createDomVisualElement, HTMLProjectionNode));\n+                }\n+\n+                /**\n+                 * @public\n+                 */\n+                var m = createMotionProxy(createDomMotionConfig);\n+\n+                function useIsMounted() {\n+                    var isMounted = React.useRef(false);\n+                    useIsomorphicLayoutEffect(function() {\n+                        isMounted.current = true;\n+                        return function() {\n+                            isMounted.current = false;\n+                        };\n+                    }, []);\n+                    return isMounted;\n+                }\n+\n+                function useForceUpdate() {\n+                    var isMounted = useIsMounted();\n+                    var _a = tslib.__read(React.useState(0), 2),\n+                        forcedRenderCount = _a[0],\n+                        setForcedRenderCount = _a[1];\n+                    var forceRender = React.useCallback(function() {\n+                        isMounted.current && setForcedRenderCount(forcedRenderCount + 1);\n+                    }, [forcedRenderCount]);\n+                    /**\n+                     * Defer this to the end of the next animation frame in case there are multiple\n+                     * synchronous calls.\n+                     */\n+                    var deferredForceRender = React.useCallback(function() {\n+                        return sync__default[\"default\"].postRender(forceRender);\n+                    }, [forceRender]);\n+                    return [deferredForceRender, forcedRenderCount];\n+                }\n+                var PresenceChild = function(_a) {\n+                    var children = _a.children,\n+                        initial = _a.initial,\n+                        isPresent = _a.isPresent,\n+                        onExitComplete = _a.onExitComplete,\n+                        custom = _a.custom,\n+                        presenceAffectsLayout = _a.presenceAffectsLayout;\n+                    var presenceChildren = useConstant(newChildrenMap);\n+                    var id = useId();\n+                    var context = React.useMemo(function() {\n+                            return {\n+                                id: id,\n+                                initial: initial,\n+                                isPresent: isPresent,\n+                                custom: custom,\n+                                onExitComplete: function(childId) {\n+                                    var e_1, _a;\n+                                    presenceChildren.set(childId, true);\n+                                    try {\n+                                        for (var _b = tslib.__values(presenceChildren.values()), _c = _b.next(); !_c.done; _c = _b.next()) {\n+                                            var isComplete = _c.value;\n+                                            if (!isComplete) return; // can stop searching when any is incomplete\n+                                        }\n+                                    } catch (e_1_1) {\n+                                        e_1 = {\n+                                            error: e_1_1\n+                                        };\n+                                    } finally {\n+                                        try {\n+                                            if (_c && !_c.done && (_a = _b.return)) _a.call(_b);\n+                                        } finally {\n+                                            if (e_1) throw e_1.error;\n+                                        }\n+                                    }\n+                                    onExitComplete === null || onExitComplete === void 0 ? void 0 : onExitComplete();\n+                                },\n+                                register: function(childId) {\n+                                    presenceChildren.set(childId, false);\n+                                    return function() {\n+                                        return presenceChildren.delete(childId);\n+                                    };\n+                                }\n+                            };\n+                        },\n+                        /**\n+                         * If the presence of a child affects the layout of the components around it,\n+                         * we want to make a new context value to ensure they get re-rendered\n+                         * so they can detect that layout change.\n+                         */\n+                        presenceAffectsLayout ? undefined : [isPresent]);\n+                    React.useMemo(function() {\n+                        presenceChildren.forEach(function(_, key) {\n+                            return presenceChildren.set(key, false);\n+                        });\n+                    }, [isPresent]);\n+                    /**\n+                     * If there's no `motion` components to fire exit animations, we want to remove this\n+                     * component immediately.\n+                     */\n+                    React__namespace.useEffect(function() {\n+                        !isPresent && !presenceChildren.size && (onExitComplete === null || onExitComplete === void 0 ? void 0 : onExitComplete());\n+                    }, [isPresent]);\n+                    return React__namespace.createElement(PresenceContext.Provider, {\n+                        value: context\n+                    }, children);\n+                };\n+\n+                function newChildrenMap() {\n+                    return new Map();\n+                }\n+                var getChildKey = function(child) {\n+                    return child.key || \"\";\n+                };\n+\n+                function updateChildLookup(children, allChildren) {\n+                    children.forEach(function(child) {\n+                        var key = getChildKey(child);\n+                        allChildren.set(key, child);\n+                    });\n+                }\n+\n+                function onlyElements(children) {\n+                    var filtered = [];\n+                    // We use forEach here instead of map as map mutates the component key by preprending `.$`\n+                    React.Children.forEach(children, function(child) {\n+                        if (React.isValidElement(child)) filtered.push(child);\n+                    });\n+                    return filtered;\n+                }\n+                /**\n+                 * `AnimatePresence` enables the animation of components that have been removed from the tree.\n+                 *\n+                 * When adding/removing more than a single child, every child **must** be given a unique `key` prop.\n+                 *\n+                 * Any `motion` components that have an `exit` property defined will animate out when removed from\n+                 * the tree.\n+                 *\n+                 * ```jsx\n+                 * import { motion, AnimatePresence } from 'framer-motion'\n+                 *\n+                 * export const Items = ({ items }) => (\n+                 *   <AnimatePresence>\n+                 *     {items.map(item => (\n+                 *       <motion.div\n+                 *         key={item.id}\n+                 *         initial={{ opacity: 0 }}\n+                 *         animate={{ opacity: 1 }}\n+                 *         exit={{ opacity: 0 }}\n+                 *       />\n+                 *     ))}\n+                 *   </AnimatePresence>\n+                 * )\n+                 * ```\n+                 *\n+                 * You can sequence exit animations throughout a tree using variants.\n+                 *\n+                 * If a child contains multiple `motion` components with `exit` props, it will only unmount the child\n+                 * once all `motion` components have finished animating out. Likewise, any components using\n+                 * `usePresence` all need to call `safeToRemove`.\n+                 *\n+                 * @public\n+                 */\n+                var AnimatePresence = function(_a) {\n+                    var children = _a.children,\n+                        custom = _a.custom,\n+                        _b = _a.initial,\n+                        initial = _b === void 0 ? true : _b,\n+                        onExitComplete = _a.onExitComplete,\n+                        exitBeforeEnter = _a.exitBeforeEnter,\n+                        _c = _a.presenceAffectsLayout,\n+                        presenceAffectsLayout = _c === void 0 ? true : _c;\n+                    // We want to force a re-render once all exiting animations have finished. We\n+                    // either use a local forceRender function, or one from a parent context if it exists.\n+                    var _d = tslib.__read(useForceUpdate(), 1),\n+                        forceRender = _d[0];\n+                    var forceRenderLayoutGroup = React.useContext(LayoutGroupContext).forceRender;\n+                    if (forceRenderLayoutGroup) forceRender = forceRenderLayoutGroup;\n+                    var isMounted = useIsMounted();\n+                    // Filter out any children that aren't ReactElements. We can only track ReactElements with a props.key\n+                    var filteredChildren = onlyElements(children);\n+                    var childrenToRender = filteredChildren;\n+                    var exiting = new Set();\n+                    // Keep a living record of the children we're actually rendering so we\n+                    // can diff to figure out which are entering and exiting\n+                    var presentChildren = React.useRef(childrenToRender);\n+                    // A lookup table to quickly reference components by key\n+                    var allChildren = React.useRef(new Map()).current;\n+                    // If this is the initial component render, just deal with logic surrounding whether\n+                    // we play onMount animations or not.\n+                    var isInitialRender = React.useRef(true);\n+                    useIsomorphicLayoutEffect(function() {\n+                        isInitialRender.current = false;\n+                        updateChildLookup(filteredChildren, allChildren);\n+                        presentChildren.current = childrenToRender;\n+                    });\n+                    useUnmountEffect(function() {\n+                        isInitialRender.current = true;\n+                        allChildren.clear();\n+                        exiting.clear();\n+                    });\n+                    if (isInitialRender.current) {\n+                        return React__namespace.createElement(React__namespace.Fragment, null, childrenToRender.map(function(child) {\n+                            return React__namespace.createElement(PresenceChild, {\n+                                key: getChildKey(child),\n+                                isPresent: true,\n+                                initial: initial ? undefined : false,\n+                                presenceAffectsLayout: presenceAffectsLayout\n+                            }, child);\n+                        }));\n+                    }\n+                    // If this is a subsequent render, deal with entering and exiting children\n+                    childrenToRender = tslib.__spreadArray([], tslib.__read(childrenToRender), false);\n+                    // Diff the keys of the currently-present and target children to update our\n+                    // exiting list.\n+                    var presentKeys = presentChildren.current.map(getChildKey);\n+                    var targetKeys = filteredChildren.map(getChildKey);\n+                    // Diff the present children with our target children and mark those that are exiting\n+                    var numPresent = presentKeys.length;\n+                    for (var i = 0; i < numPresent; i++) {\n+                        var key = presentKeys[i];\n+                        if (targetKeys.indexOf(key) === -1) {\n+                            exiting.add(key);\n+                        }\n+                    }\n+                    // If we currently have exiting children, and we're deferring rendering incoming children\n+                    // until after all current children have exiting, empty the childrenToRender array\n+                    if (exitBeforeEnter && exiting.size) {\n+                        childrenToRender = [];\n+                    }\n+                    // Loop through all currently exiting components and clone them to overwrite `animate`\n+                    // with any `exit` prop they might have defined.\n+                    exiting.forEach(function(key) {\n+                        // If this component is actually entering again, early return\n+                        if (targetKeys.indexOf(key) !== -1) return;\n+                        var child = allChildren.get(key);\n+                        if (!child) return;\n+                        var insertionIndex = presentKeys.indexOf(key);\n+                        var onExit = function() {\n+                            allChildren.delete(key);\n+                            exiting.delete(key);\n+                            // Remove this child from the present children\n+                            var removeIndex = presentChildren.current.findIndex(function(presentChild) {\n+                                return presentChild.key === key;\n+                            });\n+                            presentChildren.current.splice(removeIndex, 1);\n+                            // Defer re-rendering until all exiting children have indeed left\n+                            if (!exiting.size) {\n+                                presentChildren.current = filteredChildren;\n+                                if (isMounted.current === false) return;\n+                                forceRender();\n+                                onExitComplete && onExitComplete();\n+                            }\n+                        };\n+                        childrenToRender.splice(insertionIndex, 0, React__namespace.createElement(PresenceChild, {\n+                            key: getChildKey(child),\n+                            isPresent: false,\n+                            onExitComplete: onExit,\n+                            custom: custom,\n+                            presenceAffectsLayout: presenceAffectsLayout\n+                        }, child));\n+                    });\n+                    // Add `MotionContext` even to children that don't need it to ensure we're rendering\n+                    // the same tree between renders\n+                    childrenToRender = childrenToRender.map(function(child) {\n+                        var key = child.key;\n+                        return exiting.has(key) ? child : React__namespace.createElement(PresenceChild, {\n+                            key: getChildKey(child),\n+                            isPresent: true,\n+                            presenceAffectsLayout: presenceAffectsLayout\n+                        }, child);\n+                    });\n+                    if (env !== \"production\" && exitBeforeEnter && childrenToRender.length > 1) {\n+                        console.warn(\"You're attempting to animate multiple children within AnimatePresence, but its exitBeforeEnter prop is set to true. This will lead to odd visual behaviour.\");\n+                    }\n+                    return React__namespace.createElement(React__namespace.Fragment, null, exiting.size ? childrenToRender : childrenToRender.map(function(child) {\n+                        return React.cloneElement(child);\n+                    }));\n+                };\n+\n+                /**\n+                 * @deprecated\n+                 */\n+                var DeprecatedLayoutGroupContext = React.createContext(null);\n+                var notify = function(node) {\n+                    return !node.isLayoutDirty && node.willUpdate(false);\n+                };\n+\n+                function nodeGroup() {\n+                    var nodes = new Set();\n+                    var subscriptions = new WeakMap();\n+                    var dirtyAll = function() {\n+                        return nodes.forEach(notify);\n+                    };\n+                    return {\n+                        add: function(node) {\n+                            nodes.add(node);\n+                            subscriptions.set(node, node.addEventListener(\"willUpdate\", dirtyAll));\n+                        },\n+                        remove: function(node) {\n+                            var _a;\n+                            nodes.delete(node);\n+                            (_a = subscriptions.get(node)) === null || _a === void 0 ? void 0 : _a();\n+                            subscriptions.delete(node);\n+                            dirtyAll();\n+                        },\n+                        dirty: dirtyAll\n+                    };\n+                }\n+                var shouldInheritGroup = function(inherit) {\n+                    return inherit === true;\n+                };\n+                var shouldInheritId = function(inherit) {\n+                    return shouldInheritGroup(inherit === true) || inherit === \"id\";\n+                };\n+                var LayoutGroup = function(_a) {\n+                    var _b, _c;\n+                    var children = _a.children,\n+                        id = _a.id,\n+                        inheritId = _a.inheritId,\n+                        _d = _a.inherit,\n+                        inherit = _d === void 0 ? true : _d;\n+                    // Maintain backwards-compatibility with inheritId until 7.0\n+                    if (inheritId !== undefined) inherit = inheritId;\n+                    var layoutGroupContext = React.useContext(LayoutGroupContext);\n+                    var deprecatedLayoutGroupContext = React.useContext(DeprecatedLayoutGroupContext);\n+                    var _e = tslib.__read(useForceUpdate(), 2),\n+                        forceRender = _e[0],\n+                        key = _e[1];\n+                    var context = React.useRef(null);\n+                    var upstreamId = (_b = layoutGroupContext.id) !== null && _b !== void 0 ? _b : deprecatedLayoutGroupContext;\n+                    if (context.current === null) {\n+                        if (shouldInheritId(inherit) && upstreamId) {\n+                            id = id ? upstreamId + \"-\" + id : upstreamId;\n+                        }\n+                        context.current = {\n+                            id: id,\n+                            group: shouldInheritGroup(inherit) ? (_c = layoutGroupContext === null || layoutGroupContext === void 0 ? void 0 : layoutGroupContext.group) !== null && _c !== void 0 ? _c : nodeGroup() : nodeGroup()\n+                        };\n+                    }\n+                    var memoizedContext = React.useMemo(function() {\n+                        return tslib.__assign(tslib.__assign({}, context.current), {\n+                            forceRender: forceRender\n+                        });\n+                    }, [key]);\n+                    return React__namespace.createElement(LayoutGroupContext.Provider, {\n+                        value: memoizedContext\n+                    }, children);\n+                };\n+                var id = 0;\n+                var AnimateSharedLayout = function(_a) {\n+                    var children = _a.children;\n+                    React__namespace.useEffect(function() {\n+                        heyListen.warning(false, \"AnimateSharedLayout is deprecated: https://www.framer.com/docs/guide-upgrade/##shared-layout-animations\");\n+                    }, []);\n+                    return React__namespace.createElement(LayoutGroup, {\n+                        id: useConstant(function() {\n+                            return \"asl-\".concat(id++);\n+                        })\n+                    }, children);\n+                };\n+\n+                /**\n+                 * `MotionConfig` is used to set configuration options for all children `motion` components.\n+                 *\n+                 * ```jsx\n+                 * import { motion, MotionConfig } from \"framer-motion\"\n+                 *\n+                 * export function App() {\n+                 *   return (\n+                 *     <MotionConfig transition={{ type: \"spring\" }}>\n+                 *       <motion.div animate={{ x: 100 }} />\n+                 *     </MotionConfig>\n+                 *   )\n+                 * }\n+                 * ```\n+                 *\n+                 * @public\n+                 */\n+                function MotionConfig(_a) {\n+                    var children = _a.children,\n+                        isValidProp = _a.isValidProp,\n+                        config = tslib.__rest(_a, [\"children\", \"isValidProp\"]);\n+                    isValidProp && loadExternalIsValidProp(isValidProp);\n+                    /**\n+                     * Inherit props from any parent MotionConfig components\n+                     */\n+                    config = tslib.__assign(tslib.__assign({}, React.useContext(MotionConfigContext)), config);\n+                    /**\n+                     * Don't allow isStatic to change between renders as it affects how many hooks\n+                     * motion components fire.\n+                     */\n+                    config.isStatic = useConstant(function() {\n+                        return config.isStatic;\n+                    });\n+                    /**\n+                     * Creating a new config context object will re-render every `motion` component\n+                     * every time it renders. So we only want to create a new one sparingly.\n+                     */\n+                    var context = React.useMemo(function() {\n+                        return config;\n+                    }, [JSON.stringify(config.transition), config.transformPagePoint, config.reducedMotion]);\n+                    return React__namespace.createElement(MotionConfigContext.Provider, {\n+                        value: context\n+                    }, children);\n+                }\n+\n+                /**\n+                 * Used in conjunction with the `m` component to reduce bundle size.\n+                 *\n+                 * `m` is a version of the `motion` component that only loads functionality\n+                 * critical for the initial render.\n+                 *\n+                 * `LazyMotion` can then be used to either synchronously or asynchronously\n+                 * load animation and gesture support.\n+                 *\n+                 * ```jsx\n+                 * // Synchronous loading\n+                 * import { LazyMotion, m, domAnimations } from \"framer-motion\"\n+                 *\n+                 * function App() {\n+                 *   return (\n+                 *     <LazyMotion features={domAnimations}>\n+                 *       <m.div animate={{ scale: 2 }} />\n+                 *     </LazyMotion>\n+                 *   )\n+                 * }\n+                 *\n+                 * // Asynchronous loading\n+                 * import { LazyMotion, m } from \"framer-motion\"\n+                 *\n+                 * function App() {\n+                 *   return (\n+                 *     <LazyMotion features={() => import('./path/to/domAnimations')}>\n+                 *       <m.div animate={{ scale: 2 }} />\n+                 *     </LazyMotion>\n+                 *   )\n+                 * }\n+                 * ```\n+                 *\n+                 * @public\n+                 */\n+                function LazyMotion(_a) {\n+                    var children = _a.children,\n+                        features = _a.features,\n+                        _b = _a.strict,\n+                        strict = _b === void 0 ? false : _b;\n+                    var _c = tslib.__read(React.useState(!isLazyBundle(features)), 2),\n+                        setIsLoaded = _c[1];\n+                    var loadedRenderer = React.useRef(undefined);\n+                    /**\n+                     * If this is a synchronous load, load features immediately\n+                     */\n+                    if (!isLazyBundle(features)) {\n+                        var renderer = features.renderer,\n+                            loadedFeatures = tslib.__rest(features, [\"renderer\"]);\n+                        loadedRenderer.current = renderer;\n+                        loadFeatures(loadedFeatures);\n+                    }\n+                    React.useEffect(function() {\n+                        if (isLazyBundle(features)) {\n+                            features().then(function(_a) {\n+                                var renderer = _a.renderer,\n+                                    loadedFeatures = tslib.__rest(_a, [\"renderer\"]);\n+                                loadFeatures(loadedFeatures);\n+                                loadedRenderer.current = renderer;\n+                                setIsLoaded(true);\n+                            });\n+                        }\n+                    }, []);\n+                    return React__namespace.createElement(LazyContext.Provider, {\n+                        value: {\n+                            renderer: loadedRenderer.current,\n+                            strict: strict\n+                        }\n+                    }, children);\n+                }\n+\n+                function isLazyBundle(features) {\n+                    return typeof features === \"function\";\n+                }\n+                var ReorderContext = React.createContext(null);\n+\n+                function checkReorder(order, value, offset, velocity) {\n+                    if (!velocity) return order;\n+                    var index = order.findIndex(function(item) {\n+                        return item.value === value;\n+                    });\n+                    if (index === -1) return order;\n+                    var nextOffset = velocity > 0 ? 1 : -1;\n+                    var nextItem = order[index + nextOffset];\n+                    if (!nextItem) return order;\n+                    var item = order[index];\n+                    var nextLayout = nextItem.layout;\n+                    var nextItemCenter = popmotion.mix(nextLayout.min, nextLayout.max, 0.5);\n+                    if (nextOffset === 1 && item.layout.max + offset > nextItemCenter || nextOffset === -1 && item.layout.min + offset < nextItemCenter) {\n+                        return moveItem(order, index, index + nextOffset);\n+                    }\n+                    return order;\n+                }\n+\n+                function ReorderGroup(_a, externalRef) {\n+                    var children = _a.children,\n+                        _b = _a.as,\n+                        as = _b === void 0 ? \"ul\" : _b,\n+                        _c = _a.axis,\n+                        axis = _c === void 0 ? \"y\" : _c,\n+                        onReorder = _a.onReorder,\n+                        values = _a.values,\n+                        props = tslib.__rest(_a, [\"children\", \"as\", \"axis\", \"onReorder\", \"values\"]);\n+                    var Component = useConstant(function() {\n+                        return motion(as);\n+                    });\n+                    var order = [];\n+                    var isReordering = React.useRef(false);\n+                    heyListen.invariant(Boolean(values), \"Reorder.Group must be provided a values prop\");\n+                    var context = {\n+                        axis: axis,\n+                        registerItem: function(value, layout) {\n+                            /**\n+                             * Ensure entries can't add themselves more than once\n+                             */\n+                            if (layout && order.findIndex(function(entry) {\n+                                    return value === entry.value;\n+                                }) === -1) {\n+                                order.push({\n+                                    value: value,\n+                                    layout: layout[axis]\n+                                });\n+                                order.sort(compareMin);\n+                            }\n+                        },\n+                        updateOrder: function(id, offset, velocity) {\n+                            if (isReordering.current) return;\n+                            var newOrder = checkReorder(order, id, offset, velocity);\n+                            if (order !== newOrder) {\n+                                isReordering.current = true;\n+                                onReorder(newOrder.map(getValue).filter(function(value) {\n+                                    return values.indexOf(value) !== -1;\n+                                }));\n+                            }\n+                        }\n+                    };\n+                    React.useEffect(function() {\n+                        isReordering.current = false;\n+                    });\n+                    return React__namespace.createElement(Component, tslib.__assign({}, props, {\n+                        ref: externalRef\n+                    }), React__namespace.createElement(ReorderContext.Provider, {\n+                        value: context\n+                    }, children));\n+                }\n+                var Group = React.forwardRef(ReorderGroup);\n+\n+                function getValue(item) {\n+                    return item.value;\n+                }\n+\n+                function compareMin(a, b) {\n+                    return a.layout.min - b.layout.min;\n+                }\n+\n+                /**\n+                 * Creates a `MotionValue` to track the state and velocity of a value.\n+                 *\n+                 * Usually, these are created automatically. For advanced use-cases, like use with `useTransform`, you can create `MotionValue`s externally and pass them into the animated component via the `style` prop.\n+                 *\n+                 * ```jsx\n+                 * export const MyComponent = () => {\n+                 *   const scale = useMotionValue(1)\n+                 *\n+                 *   return <motion.div style={{ scale }} />\n+                 * }\n+                 * ```\n+                 *\n+                 * @param initial - The initial state.\n+                 *\n+                 * @public\n+                 */\n+                function useMotionValue(initial) {\n+                    var value = useConstant(function() {\n+                        return motionValue(initial);\n+                    });\n+                    /**\n+                     * If this motion value is being used in static mode, like on\n+                     * the Framer canvas, force components to rerender when the motion\n+                     * value is updated.\n+                     */\n+                    var isStatic = React.useContext(MotionConfigContext).isStatic;\n+                    if (isStatic) {\n+                        var _a = tslib.__read(React.useState(initial), 2),\n+                            setLatest_1 = _a[1];\n+                        React.useEffect(function() {\n+                            return value.onChange(setLatest_1);\n+                        }, []);\n+                    }\n+                    return value;\n+                }\n+                var isCustomValueType = function(v) {\n+                    return typeof v === \"object\" && v.mix;\n+                };\n+                var getMixer = function(v) {\n+                    return isCustomValueType(v) ? v.mix : undefined;\n+                };\n+\n+                function transform() {\n+                    var args = [];\n+                    for (var _i = 0; _i < arguments.length; _i++) {\n+                        args[_i] = arguments[_i];\n+                    }\n+                    var useImmediate = !Array.isArray(args[0]);\n+                    var argOffset = useImmediate ? 0 : -1;\n+                    var inputValue = args[0 + argOffset];\n+                    var inputRange = args[1 + argOffset];\n+                    var outputRange = args[2 + argOffset];\n+                    var options = args[3 + argOffset];\n+                    var interpolator = popmotion.interpolate(inputRange, outputRange, tslib.__assign({\n+                        mixer: getMixer(outputRange[0])\n+                    }, options));\n+                    return useImmediate ? interpolator(inputValue) : interpolator;\n+                }\n+\n+                function useOnChange(value, callback) {\n+                    useIsomorphicLayoutEffect(function() {\n+                        if (isMotionValue(value)) return value.onChange(callback);\n+                    }, [callback]);\n+                }\n+\n+                function useMultiOnChange(values, handler) {\n+                    useIsomorphicLayoutEffect(function() {\n+                        var subscriptions = values.map(function(value) {\n+                            return value.onChange(handler);\n+                        });\n+                        return function() {\n+                            return subscriptions.forEach(function(unsubscribe) {\n+                                return unsubscribe();\n+                            });\n+                        };\n+                    });\n+                }\n+\n+                function useCombineMotionValues(values, combineValues) {\n+                    /**\n+                     * Initialise the returned motion value. This remains the same between renders.\n+                     */\n+                    var value = useMotionValue(combineValues());\n+                    /**\n+                     * Create a function that will update the template motion value with the latest values.\n+                     * This is pre-bound so whenever a motion value updates it can schedule its\n+                     * execution in Framesync. If it's already been scheduled it won't be fired twice\n+                     * in a single frame.\n+                     */\n+                    var updateValue = function() {\n+                        return value.set(combineValues());\n+                    };\n+                    /**\n+                     * Synchronously update the motion value with the latest values during the render.\n+                     * This ensures that within a React render, the styles applied to the DOM are up-to-date.\n+                     */\n+                    updateValue();\n+                    /**\n+                     * Subscribe to all motion values found within the template. Whenever any of them change,\n+                     * schedule an update.\n+                     */\n+                    useMultiOnChange(values, function() {\n+                        return sync__default[\"default\"].update(updateValue, false, true);\n+                    });\n+                    return value;\n+                }\n+\n+                function useTransform(input, inputRangeOrTransformer, outputRange, options) {\n+                    var transformer = typeof inputRangeOrTransformer === \"function\" ? inputRangeOrTransformer : transform(inputRangeOrTransformer, outputRange, options);\n+                    return Array.isArray(input) ? useListTransform(input, transformer) : useListTransform([input], function(_a) {\n+                        var _b = tslib.__read(_a, 1),\n+                            latest = _b[0];\n+                        return transformer(latest);\n+                    });\n+                }\n+\n+                function useListTransform(values, transformer) {\n+                    var latest = useConstant(function() {\n+                        return [];\n+                    });\n+                    return useCombineMotionValues(values, function() {\n+                        latest.length = 0;\n+                        var numValues = values.length;\n+                        for (var i = 0; i < numValues; i++) {\n+                            latest[i] = values[i].get();\n+                        }\n+                        return transformer(latest);\n+                    });\n+                }\n+\n+                function useDefaultMotionValue(value, defaultValue) {\n+                    if (defaultValue === void 0) {\n+                        defaultValue = 0;\n+                    }\n+                    return isMotionValue(value) ? value : useMotionValue(defaultValue);\n+                }\n+\n+                function ReorderItem(_a, externalRef) {\n+                    var children = _a.children,\n+                        style = _a.style,\n+                        value = _a.value,\n+                        _b = _a.as,\n+                        as = _b === void 0 ? \"li\" : _b,\n+                        onDrag = _a.onDrag,\n+                        _c = _a.layout,\n+                        layout = _c === void 0 ? true : _c,\n+                        props = tslib.__rest(_a, [\"children\", \"style\", \"value\", \"as\", \"onDrag\", \"layout\"]);\n+                    var Component = useConstant(function() {\n+                        return motion(as);\n+                    });\n+                    var context = React.useContext(ReorderContext);\n+                    var point = {\n+                        x: useDefaultMotionValue(style === null || style === void 0 ? void 0 : style.x),\n+                        y: useDefaultMotionValue(style === null || style === void 0 ? void 0 : style.y)\n+                    };\n+                    var zIndex = useTransform([point.x, point.y], function(_a) {\n+                        var _b = tslib.__read(_a, 2),\n+                            latestX = _b[0],\n+                            latestY = _b[1];\n+                        return latestX || latestY ? 1 : \"unset\";\n+                    });\n+                    var measuredLayout = React.useRef(null);\n+                    heyListen.invariant(Boolean(context), \"Reorder.Item must be a child of Reorder.Group\");\n+                    var _d = context,\n+                        axis = _d.axis,\n+                        registerItem = _d.registerItem,\n+                        updateOrder = _d.updateOrder;\n+                    React.useEffect(function() {\n+                        registerItem(value, measuredLayout.current);\n+                    }, [context]);\n+                    return React__namespace.createElement(Component, tslib.__assign({\n+                        drag: axis\n+                    }, props, {\n+                        dragSnapToOrigin: true,\n+                        style: tslib.__assign(tslib.__assign({}, style), {\n+                            x: point.x,\n+                            y: point.y,\n+                            zIndex: zIndex\n+                        }),\n+                        layout: layout,\n+                        onDrag: function(event, gesturePoint) {\n+                            var velocity = gesturePoint.velocity;\n+                            velocity[axis] && updateOrder(value, point[axis].get(), velocity[axis]);\n+                            onDrag === null || onDrag === void 0 ? void 0 : onDrag(event, gesturePoint);\n+                        },\n+                        onLayoutMeasure: function(measured) {\n+                            measuredLayout.current = measured;\n+                        },\n+                        ref: externalRef\n+                    }), children);\n+                }\n+                var Item = React.forwardRef(ReorderItem);\n+                var Reorder = {\n+                    Group: Group,\n+                    Item: Item\n+                };\n+\n+                /**\n+                 * @public\n+                 */\n+                var domAnimation = tslib.__assign(tslib.__assign({\n+                    renderer: createDomVisualElement\n+                }, animations), gestureAnimations);\n+\n+                /**\n+                 * @public\n+                 */\n+                var domMax = tslib.__assign(tslib.__assign(tslib.__assign(tslib.__assign({}, domAnimation), drag), layoutFeatures), {\n+                    projectionNodeConstructor: HTMLProjectionNode\n+                });\n+\n+                /**\n+                 * Combine multiple motion values into a new one using a string template literal.\n+                 *\n+                 * ```jsx\n+                 * import {\n+                 *   motion,\n+                 *   useSpring,\n+                 *   useMotionValue,\n+                 *   useMotionTemplate\n+                 * } from \"framer-motion\"\n+                 *\n+                 * function Component() {\n+                 *   const shadowX = useSpring(0)\n+                 *   const shadowY = useMotionValue(0)\n+                 *   const shadow = useMotionTemplate`drop-shadow(${shadowX}px ${shadowY}px 20px rgba(0,0,0,0.3))`\n+                 *\n+                 *   return <motion.div style={{ filter: shadow }} />\n+                 * }\n+                 * ```\n+                 *\n+                 * @public\n+                 */\n+                function useMotionTemplate(fragments) {\n+                    var values = [];\n+                    for (var _i = 1; _i < arguments.length; _i++) {\n+                        values[_i - 1] = arguments[_i];\n+                    }\n+                    /**\n+                     * Create a function that will build a string from the latest motion values.\n+                     */\n+                    var numFragments = fragments.length;\n+\n+                    function buildValue() {\n+                        var output = \"\";\n+                        for (var i = 0; i < numFragments; i++) {\n+                            output += fragments[i];\n+                            var value = values[i];\n+                            if (value) output += values[i].get();\n+                        }\n+                        return output;\n+                    }\n+                    return useCombineMotionValues(values, buildValue);\n+                }\n+\n+                /**\n+                 * Creates a `MotionValue` that, when `set`, will use a spring animation to animate to its new state.\n+                 *\n+                 * It can either work as a stand-alone `MotionValue` by initialising it with a value, or as a subscriber\n+                 * to another `MotionValue`.\n+                 *\n+                 * @remarks\n+                 *\n+                 * ```jsx\n+                 * const x = useSpring(0, { stiffness: 300 })\n+                 * const y = useSpring(x, { damping: 10 })\n+                 * ```\n+                 *\n+                 * @param inputValue - `MotionValue` or number. If provided a `MotionValue`, when the input `MotionValue` changes, the created `MotionValue` will spring towards that value.\n+                 * @param springConfig - Configuration options for the spring.\n+                 * @returns `MotionValue`\n+                 *\n+                 * @public\n+                 */\n+                function useSpring(source, config) {\n+                    if (config === void 0) {\n+                        config = {};\n+                    }\n+                    var isStatic = React.useContext(MotionConfigContext).isStatic;\n+                    var activeSpringAnimation = React.useRef(null);\n+                    var value = useMotionValue(isMotionValue(source) ? source.get() : source);\n+                    React.useMemo(function() {\n+                        return value.attach(function(v, set) {\n+                            /**\n+                             * A more hollistic approach to this might be to use isStatic to fix VisualElement animations\n+                             * at that level, but this will work for now\n+                             */\n+                            if (isStatic) return set(v);\n+                            if (activeSpringAnimation.current) {\n+                                activeSpringAnimation.current.stop();\n+                            }\n+                            activeSpringAnimation.current = popmotion.animate(tslib.__assign(tslib.__assign({\n+                                from: value.get(),\n+                                to: v,\n+                                velocity: value.getVelocity()\n+                            }, config), {\n+                                onUpdate: set\n+                            }));\n+                            return value.get();\n+                        });\n+                    }, [JSON.stringify(config)]);\n+                    useOnChange(source, function(v) {\n+                        return value.set(parseFloat(v));\n+                    });\n+                    return value;\n+                }\n+\n+                /**\n+                 * Creates a `MotionValue` that updates when the velocity of the provided `MotionValue` changes.\n+                 *\n+                 * ```javascript\n+                 * const x = useMotionValue(0)\n+                 * const xVelocity = useVelocity(x)\n+                 * const xAcceleration = useVelocity(xVelocity)\n+                 * ```\n+                 *\n+                 * @public\n+                 */\n+                function useVelocity(value) {\n+                    var velocity = useMotionValue(value.getVelocity());\n+                    React.useEffect(function() {\n+                        return value.velocityUpdateSubscribers.add(function(newVelocity) {\n+                            velocity.set(newVelocity);\n+                        });\n+                    }, [value]);\n+                    return velocity;\n+                }\n+                var createScrollMotionValues = function() {\n+                    return {\n+                        scrollX: motionValue(0),\n+                        scrollY: motionValue(0),\n+                        scrollXProgress: motionValue(0),\n+                        scrollYProgress: motionValue(0)\n+                    };\n+                };\n+\n+                function useScroll(_a) {\n+                    if (_a === void 0) {\n+                        _a = {};\n+                    }\n+                    var container = _a.container,\n+                        target = _a.target,\n+                        options = tslib.__rest(_a, [\"container\", \"target\"]);\n+                    var values = useConstant(createScrollMotionValues);\n+                    useIsomorphicLayoutEffect(function() {\n+                        return dom.scroll(function(_a) {\n+                            var x = _a.x,\n+                                y = _a.y;\n+                            values.scrollX.set(x.current);\n+                            values.scrollXProgress.set(x.progress);\n+                            values.scrollY.set(y.current);\n+                            values.scrollYProgress.set(y.progress);\n+                        }, tslib.__assign(tslib.__assign({}, options), {\n+                            container: (container === null || container === void 0 ? void 0 : container.current) || undefined,\n+                            target: (target === null || target === void 0 ? void 0 : target.current) || undefined\n+                        }));\n+                    }, []);\n+                    return values;\n+                }\n+\n+                function useElementScroll(ref) {\n+                    warnOnce(false, \"useElementScroll is deprecated. Convert to useScroll({ container: ref }).\");\n+                    return useScroll({\n+                        container: ref\n+                    });\n+                }\n+\n+                function useViewportScroll() {\n+                    warnOnce(false, \"useViewportScroll is deprecated. Convert to useScroll().\");\n+                    return useScroll();\n+                }\n+                var getCurrentTime = typeof performance !== \"undefined\" ? function() {\n+                    return performance.now();\n+                } : function() {\n+                    return Date.now();\n+                };\n+\n+                function useAnimationFrame(callback) {\n+                    var initialTimestamp = useConstant(getCurrentTime);\n+                    var isStatic = React.useContext(MotionConfigContext).isStatic;\n+                    React.useEffect(function() {\n+                        if (isStatic) return;\n+                        var provideTimeSinceStart = function(_a) {\n+                            var timestamp = _a.timestamp;\n+                            callback(timestamp - initialTimestamp);\n+                        };\n+                        sync__default[\"default\"].update(provideTimeSinceStart, true);\n+                        return function() {\n+                            return sync.cancelSync.update(provideTimeSinceStart);\n+                        };\n+                    }, [callback]);\n+                }\n+\n+                function useTime() {\n+                    var time = useMotionValue(0);\n+                    useAnimationFrame(function(t) {\n+                        return time.set(t);\n+                    });\n+                    return time;\n+                }\n+\n+                /**\n+                 * @public\n+                 */\n+                function animationControls() {\n+                    /**\n+                     * Track whether the host component has mounted.\n+                     */\n+                    var hasMounted = false;\n+                    /**\n+                     * Pending animations that are started before a component is mounted.\n+                     * TODO: Remove this as animations should only run in effects\n+                     */\n+                    var pendingAnimations = [];\n+                    /**\n+                     * A collection of linked component animation controls.\n+                     */\n+                    var subscribers = new Set();\n+                    var controls = {\n+                        subscribe: function(visualElement) {\n+                            subscribers.add(visualElement);\n+                            return function() {\n+                                return void subscribers.delete(visualElement);\n+                            };\n+                        },\n+                        start: function(definition, transitionOverride) {\n+                            /**\n+                             * TODO: We only perform this hasMounted check because in Framer we used to\n+                             * encourage the ability to start an animation within the render phase. This\n+                             * isn't behaviour concurrent-safe so when we make Framer concurrent-safe\n+                             * we can ditch this.\n+                             */\n+                            if (hasMounted) {\n+                                var animations_1 = [];\n+                                subscribers.forEach(function(visualElement) {\n+                                    animations_1.push(animateVisualElement(visualElement, definition, {\n+                                        transitionOverride: transitionOverride\n+                                    }));\n+                                });\n+                                return Promise.all(animations_1);\n+                            } else {\n+                                return new Promise(function(resolve) {\n+                                    pendingAnimations.push({\n+                                        animation: [definition, transitionOverride],\n+                                        resolve: resolve\n+                                    });\n+                                });\n+                            }\n+                        },\n+                        set: function(definition) {\n+                            heyListen.invariant(hasMounted, \"controls.set() should only be called after a component has mounted. Consider calling within a useEffect hook.\");\n+                            return subscribers.forEach(function(visualElement) {\n+                                setValues(visualElement, definition);\n+                            });\n+                        },\n+                        stop: function() {\n+                            subscribers.forEach(function(visualElement) {\n+                                stopAnimation(visualElement);\n+                            });\n+                        },\n+                        mount: function() {\n+                            hasMounted = true;\n+                            pendingAnimations.forEach(function(_a) {\n+                                var animation = _a.animation,\n+                                    resolve = _a.resolve;\n+                                controls.start.apply(controls, tslib.__spreadArray([], tslib.__read(animation), false)).then(resolve);\n+                            });\n+                            return function() {\n+                                hasMounted = false;\n+                                controls.stop();\n+                            };\n+                        }\n+                    };\n+                    return controls;\n+                }\n+\n+                /**\n+                 * Creates `AnimationControls`, which can be used to manually start, stop\n+                 * and sequence animations on one or more components.\n+                 *\n+                 * The returned `AnimationControls` should be passed to the `animate` property\n+                 * of the components you want to animate.\n+                 *\n+                 * These components can then be animated with the `start` method.\n+                 *\n+                 * ```jsx\n+                 * import * as React from 'react'\n+                 * import { motion, useAnimation } from 'framer-motion'\n+                 *\n+                 * export function MyComponent(props) {\n+                 *    const controls = useAnimation()\n+                 *\n+                 *    controls.start({\n+                 *        x: 100,\n+                 *        transition: { duration: 0.5 },\n+                 *    })\n+                 *\n+                 *    return <motion.div animate={controls} />\n+                 * }\n+                 * ```\n+                 *\n+                 * @returns Animation controller with `start` and `stop` methods\n+                 *\n+                 * @public\n+                 */\n+                function useAnimationControls() {\n+                    var controls = useConstant(animationControls);\n+                    React.useEffect(controls.mount, []);\n+                    return controls;\n+                }\n+                var useAnimation = useAnimationControls;\n+\n+                /**\n+                 * Cycles through a series of visual properties. Can be used to toggle between or cycle through animations. It works similar to `useState` in React. It is provided an initial array of possible states, and returns an array of two arguments.\n+                 *\n+                 * An index value can be passed to the returned `cycle` function to cycle to a specific index.\n+                 *\n+                 * ```jsx\n+                 * import * as React from \"react\"\n+                 * import { motion, useCycle } from \"framer-motion\"\n+                 *\n+                 * export const MyComponent = () => {\n+                 *   const [x, cycleX] = useCycle(0, 50, 100)\n+                 *\n+                 *   return (\n+                 *     <motion.div\n+                 *       animate={{ x: x }}\n+                 *       onTap={() => cycleX()}\n+                 *      />\n+                 *    )\n+                 * }\n+                 * ```\n+                 *\n+                 * @param items - items to cycle through\n+                 * @returns [currentState, cycleState]\n+                 *\n+                 * @public\n+                 */\n+                function useCycle() {\n+                    var items = [];\n+                    for (var _i = 0; _i < arguments.length; _i++) {\n+                        items[_i] = arguments[_i];\n+                    }\n+                    var index = React.useRef(0);\n+                    var _a = tslib.__read(React.useState(items[index.current]), 2),\n+                        item = _a[0],\n+                        setItem = _a[1];\n+                    var runCycle = React.useCallback(function(next) {\n+                        index.current = typeof next !== \"number\" ? popmotion.wrap(0, items.length, index.current + 1) : next;\n+                        setItem(items[index.current]);\n+                    }, tslib.__spreadArray([items.length], tslib.__read(items), false));\n+                    return [item, runCycle];\n+                }\n+\n+                function useInView(ref, _a) {\n+                    var _b = _a === void 0 ? {} : _a,\n+                        root = _b.root,\n+                        margin = _b.margin,\n+                        amount = _b.amount,\n+                        _c = _b.once,\n+                        once = _c === void 0 ? false : _c;\n+                    var _d = tslib.__read(React.useState(false), 2),\n+                        isInView = _d[0],\n+                        setInView = _d[1];\n+                    React.useEffect(function() {\n+                        var _a;\n+                        if (!ref.current || once && isInView) return;\n+                        var onEnter = function() {\n+                            setInView(true);\n+                            return once ? undefined : function() {\n+                                return setInView(false);\n+                            };\n+                        };\n+                        var options = {\n+                            root: (_a = root === null || root === void 0 ? void 0 : root.current) !== null && _a !== void 0 ? _a : undefined,\n+                            margin: margin,\n+                            amount: amount === \"some\" ? \"any\" : amount\n+                        };\n+                        return dom.inView(ref.current, onEnter, options);\n+                    }, [root, ref, margin, once]);\n+                    return isInView;\n+                }\n+\n+                /**\n+                 * Can manually trigger a drag gesture on one or more `drag`-enabled `motion` components.\n+                 *\n+                 * ```jsx\n+                 * const dragControls = useDragControls()\n+                 *\n+                 * function startDrag(event) {\n+                 *   dragControls.start(event, { snapToCursor: true })\n+                 * }\n+                 *\n+                 * return (\n+                 *   <>\n+                 *     <div onPointerDown={startDrag} />\n+                 *     <motion.div drag=\"x\" dragControls={dragControls} />\n+                 *   </>\n+                 * )\n+                 * ```\n+                 *\n+                 * @public\n+                 */\n+                var DragControls = /** @class */ function() {\n+                    function DragControls() {\n+                        this.componentControls = new Set();\n+                    }\n+                    /**\n+                     * Subscribe a component's internal `VisualElementDragControls` to the user-facing API.\n+                     *\n+                     * @internal\n+                     */\n+                    DragControls.prototype.subscribe = function(controls) {\n+                        var _this = this;\n+                        this.componentControls.add(controls);\n+                        return function() {\n+                            return _this.componentControls.delete(controls);\n+                        };\n+                    };\n+                    /**\n+                     * Start a drag gesture on every `motion` component that has this set of drag controls\n+                     * passed into it via the `dragControls` prop.\n+                     *\n+                     * ```jsx\n+                     * dragControls.start(e, {\n+                     *   snapToCursor: true\n+                     * })\n+                     * ```\n+                     *\n+                     * @param event - PointerEvent\n+                     * @param options - Options\n+                     *\n+                     * @public\n+                     */\n+                    DragControls.prototype.start = function(event, options) {\n+                        this.componentControls.forEach(function(controls) {\n+                            controls.start(event.nativeEvent || event, options);\n+                        });\n+                    };\n+                    return DragControls;\n+                }();\n+                var createDragControls = function() {\n+                    return new DragControls();\n+                };\n+                /**\n+                 * Usually, dragging is initiated by pressing down on a `motion` component with a `drag` prop\n+                 * and moving it. For some use-cases, for instance clicking at an arbitrary point on a video scrubber, we\n+                 * might want to initiate that dragging from a different component than the draggable one.\n+                 *\n+                 * By creating a `dragControls` using the `useDragControls` hook, we can pass this into\n+                 * the draggable component's `dragControls` prop. It exposes a `start` method\n+                 * that can start dragging from pointer events on other components.\n+                 *\n+                 * ```jsx\n+                 * const dragControls = useDragControls()\n+                 *\n+                 * function startDrag(event) {\n+                 *   dragControls.start(event, { snapToCursor: true })\n+                 * }\n+                 *\n+                 * return (\n+                 *   <>\n+                 *     <div onPointerDown={startDrag} />\n+                 *     <motion.div drag=\"x\" dragControls={dragControls} />\n+                 *   </>\n+                 * )\n+                 * ```\n+                 *\n+                 * @public\n+                 */\n+                function useDragControls() {\n+                    return useConstant(createDragControls);\n+                }\n+\n+                function useInstantLayoutTransition() {\n+                    return startTransition;\n+                }\n+\n+                function startTransition(cb) {\n+                    if (!rootProjectionNode.current) return;\n+                    rootProjectionNode.current.isUpdating = false;\n+                    rootProjectionNode.current.blockUpdate();\n+                    cb === null || cb === void 0 ? void 0 : cb();\n+                }\n+\n+                function useInstantTransition() {\n+                    var _a = tslib.__read(useForceUpdate(), 2),\n+                        forceUpdate = _a[0],\n+                        forcedRenderCount = _a[1];\n+                    var startInstantLayoutTransition = useInstantLayoutTransition();\n+                    React.useEffect(function() {\n+                        /**\n+                         * Unblock after two animation frames, otherwise this will unblock too soon.\n+                         */\n+                        sync__default[\"default\"].postRender(function() {\n+                            return sync__default[\"default\"].postRender(function() {\n+                                return instantAnimationState.current = false;\n+                            });\n+                        });\n+                    }, [forcedRenderCount]);\n+                    return function(callback) {\n+                        startInstantLayoutTransition(function() {\n+                            instantAnimationState.current = true;\n+                            forceUpdate();\n+                            callback();\n+                        });\n+                    };\n+                }\n+\n+                function useResetProjection() {\n+                    var reset = React__namespace.useCallback(function() {\n+                        var root = rootProjectionNode.current;\n+                        if (!root) return;\n+                        root.resetTree();\n+                    }, []);\n+                    return reset;\n+                }\n+                var createObject = function() {\n+                    return {};\n+                };\n+                var stateVisualElement = visualElement({\n+                    build: function() {},\n+                    measureViewportBox: createBox,\n+                    resetTransform: function() {},\n+                    restoreTransform: function() {},\n+                    removeValueFromRenderState: function() {},\n+                    render: function() {},\n+                    scrapeMotionValuesFromProps: createObject,\n+                    readValueFromInstance: function(_state, key, options) {\n+                        return options.initialState[key] || 0;\n+                    },\n+                    makeTargetAnimatable: function(element, _a) {\n+                        var transition = _a.transition,\n+                            transitionEnd = _a.transitionEnd,\n+                            target = tslib.__rest(_a, [\"transition\", \"transitionEnd\"]);\n+                        var origin = getOrigin(target, transition || {}, element);\n+                        checkTargetForNewValues(element, target, origin);\n+                        return tslib.__assign({\n+                            transition: transition,\n+                            transitionEnd: transitionEnd\n+                        }, target);\n+                    }\n+                });\n+                var useVisualState = makeUseVisualState({\n+                    scrapeMotionValuesFromProps: createObject,\n+                    createRenderState: createObject\n+                });\n+                /**\n+                 * This is not an officially supported API and may be removed\n+                 * on any version.\n+                 */\n+                function useAnimatedState(initialState) {\n+                    var _a = tslib.__read(React.useState(initialState), 2),\n+                        animationState = _a[0],\n+                        setAnimationState = _a[1];\n+                    var visualState = useVisualState({}, false);\n+                    var element = useConstant(function() {\n+                        return stateVisualElement({\n+                            props: {},\n+                            visualState: visualState\n+                        }, {\n+                            initialState: initialState\n+                        });\n+                    });\n+                    React.useEffect(function() {\n+                        element.mount({});\n+                        return element.unmount;\n+                    }, [element]);\n+                    React.useEffect(function() {\n+                        element.setProps({\n+                            onUpdate: function(v) {\n+                                setAnimationState(tslib.__assign({}, v));\n+                            }\n+                        });\n+                    }, [setAnimationState, element]);\n+                    var startAnimation = useConstant(function() {\n+                        return function(animationDefinition) {\n+                            return animateVisualElement(element, animationDefinition);\n+                        };\n+                    });\n+                    return [animationState, startAnimation];\n+                }\n+\n+                // Keep things reasonable and avoid scale: Infinity. In practise we might need\n+                // to add another value, opacity, that could interpolate scaleX/Y [0,0.01] => [0,1]\n+                // to simply hide content at unreasonable scales.\n+                var maxScale = 100000;\n+                var invertScale = function(scale) {\n+                    return scale > 0.001 ? 1 / scale : maxScale;\n+                };\n+                var hasWarned = false;\n+                /**\n+                 * Returns a `MotionValue` each for `scaleX` and `scaleY` that update with the inverse\n+                 * of their respective parent scales.\n+                 *\n+                 * This is useful for undoing the distortion of content when scaling a parent component.\n+                 *\n+                 * By default, `useInvertedScale` will automatically fetch `scaleX` and `scaleY` from the nearest parent.\n+                 * By passing other `MotionValue`s in as `useInvertedScale({ scaleX, scaleY })`, it will invert the output\n+                 * of those instead.\n+                 *\n+                 * ```jsx\n+                 * const MyComponent = () => {\n+                 *   const { scaleX, scaleY } = useInvertedScale()\n+                 *   return <motion.div style={{ scaleX, scaleY }} />\n+                 * }\n+                 * ```\n+                 *\n+                 * @deprecated\n+                 */\n+                function useInvertedScale(scale) {\n+                    var parentScaleX = useMotionValue(1);\n+                    var parentScaleY = useMotionValue(1);\n+                    var visualElement = useVisualElementContext();\n+                    heyListen.invariant(!!(scale || visualElement), \"If no scale values are provided, useInvertedScale must be used within a child of another motion component.\");\n+                    heyListen.warning(hasWarned, \"useInvertedScale is deprecated and will be removed in 3.0. Use the layout prop instead.\");\n+                    hasWarned = true;\n+                    if (scale) {\n+                        parentScaleX = scale.scaleX || parentScaleX;\n+                        parentScaleY = scale.scaleY || parentScaleY;\n+                    } else if (visualElement) {\n+                        parentScaleX = visualElement.getValue(\"scaleX\", 1);\n+                        parentScaleY = visualElement.getValue(\"scaleY\", 1);\n+                    }\n+                    var scaleX = useTransform(parentScaleX, invertScale);\n+                    var scaleY = useTransform(parentScaleY, invertScale);\n+                    return {\n+                        scaleX: scaleX,\n+                        scaleY: scaleY\n+                    };\n+                }\n+                exports.AnimatePresence = AnimatePresence;\n+                exports.AnimateSharedLayout = AnimateSharedLayout;\n+                exports.DeprecatedLayoutGroupContext = DeprecatedLayoutGroupContext;\n+                exports.DragControls = DragControls;\n+                exports.FlatTree = FlatTree;\n+                exports.LayoutGroup = LayoutGroup;\n+                exports.LayoutGroupContext = LayoutGroupContext;\n+                exports.LazyMotion = LazyMotion;\n+                exports.MotionConfig = MotionConfig;\n+                exports.MotionConfigContext = MotionConfigContext;\n+                exports.MotionContext = MotionContext;\n+                exports.MotionValue = MotionValue;\n+                exports.PresenceContext = PresenceContext;\n+                exports.Reorder = Reorder;\n+                exports.SwitchLayoutGroupContext = SwitchLayoutGroupContext;\n+                exports.addPointerEvent = addPointerEvent;\n+                exports.addScaleCorrector = addScaleCorrector;\n+                exports.animate = animate;\n+                exports.animateVisualElement = animateVisualElement;\n+                exports.animationControls = animationControls;\n+                exports.animations = animations;\n+                exports.calcLength = calcLength;\n+                exports.checkTargetForNewValues = checkTargetForNewValues;\n+                exports.createBox = createBox;\n+                exports.createDomMotionComponent = createDomMotionComponent;\n+                exports.createMotionComponent = createMotionComponent;\n+                exports.domAnimation = domAnimation;\n+                exports.domMax = domMax;\n+                exports.filterProps = filterProps;\n+                exports.isBrowser = isBrowser;\n+                exports.isDragActive = isDragActive;\n+                exports.isMotionValue = isMotionValue;\n+                exports.isValidMotionProp = isValidMotionProp;\n+                exports.m = m;\n+                exports.makeUseVisualState = makeUseVisualState;\n+                exports.motion = motion;\n+                exports.motionValue = motionValue;\n+                exports.resolveMotionValue = resolveMotionValue;\n+                exports.transform = transform;\n+                exports.useAnimation = useAnimation;\n+                exports.useAnimationControls = useAnimationControls;\n+                exports.useAnimationFrame = useAnimationFrame;\n+                exports.useCycle = useCycle;\n+                exports.useDeprecatedAnimatedState = useAnimatedState;\n+                exports.useDeprecatedInvertedScale = useInvertedScale;\n+                exports.useDomEvent = useDomEvent;\n+                exports.useDragControls = useDragControls;\n+                exports.useElementScroll = useElementScroll;\n+                exports.useForceUpdate = useForceUpdate;\n+                exports.useInView = useInView;\n+                exports.useInstantLayoutTransition = useInstantLayoutTransition;\n+                exports.useInstantTransition = useInstantTransition;\n+                exports.useIsPresent = useIsPresent;\n+                exports.useIsomorphicLayoutEffect = useIsomorphicLayoutEffect;\n+                exports.useMotionTemplate = useMotionTemplate;\n+                exports.useMotionValue = useMotionValue;\n+                exports.usePresence = usePresence;\n+                exports.useReducedMotion = useReducedMotion;\n+                exports.useReducedMotionConfig = useReducedMotionConfig;\n+                exports.useResetProjection = useResetProjection;\n+                exports.useScroll = useScroll;\n+                exports.useSpring = useSpring;\n+                exports.useTime = useTime;\n+                exports.useTransform = useTransform;\n+                exports.useUnmountEffect = useUnmountEffect;\n+                exports.useVelocity = useVelocity;\n+                exports.useViewportScroll = useViewportScroll;\n+                exports.useVisualElementContext = useVisualElementContext;\n+                exports.visualElement = visualElement;\n+                exports.wrapHandler = wrapHandler;\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/framesync/dist/framesync.cjs.js\":\n+            /*!*************************************************************!*\\\n+              !*** ../../../node_modules/framesync/dist/framesync.cjs.js ***!\n+              \\*************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                const defaultTimestep = 1 / 60 * 1000;\n+                const getCurrentTime = typeof performance !== \"undefined\" ? () => performance.now() : () => Date.now();\n+                const onNextFrame = typeof window !== \"undefined\" ? callback => window.requestAnimationFrame(callback) : callback => setTimeout(() => callback(getCurrentTime()), defaultTimestep);\n+\n+                function createRenderStep(runNextFrame) {\n+                    let toRun = [];\n+                    let toRunNextFrame = [];\n+                    let numToRun = 0;\n+                    let isProcessing = false;\n+                    let flushNextFrame = false;\n+                    const toKeepAlive = new WeakSet();\n+                    const step = {\n+                        schedule: (callback, keepAlive = false, immediate = false) => {\n+                            const addToCurrentFrame = immediate && isProcessing;\n+                            const buffer = addToCurrentFrame ? toRun : toRunNextFrame;\n+                            if (keepAlive) toKeepAlive.add(callback);\n+                            if (buffer.indexOf(callback) === -1) {\n+                                buffer.push(callback);\n+                                if (addToCurrentFrame && isProcessing) numToRun = toRun.length;\n+                            }\n+                            return callback;\n+                        },\n+                        cancel: callback => {\n+                            const index = toRunNextFrame.indexOf(callback);\n+                            if (index !== -1) toRunNextFrame.splice(index, 1);\n+                            toKeepAlive.delete(callback);\n+                        },\n+                        process: frameData => {\n+                            if (isProcessing) {\n+                                flushNextFrame = true;\n+                                return;\n+                            }\n+                            isProcessing = true;\n+                            [toRun, toRunNextFrame] = [toRunNextFrame, toRun];\n+                            toRunNextFrame.length = 0;\n+                            numToRun = toRun.length;\n+                            if (numToRun) {\n+                                for (let i = 0; i < numToRun; i++) {\n+                                    const callback = toRun[i];\n+                                    callback(frameData);\n+                                    if (toKeepAlive.has(callback)) {\n+                                        step.schedule(callback);\n+                                        runNextFrame();\n+                                    }\n+                                }\n+                            }\n+                            isProcessing = false;\n+                            if (flushNextFrame) {\n+                                flushNextFrame = false;\n+                                step.process(frameData);\n+                            }\n+                        }\n+                    };\n+                    return step;\n+                }\n+                const maxElapsed = 40;\n+                let useDefaultElapsed = true;\n+                let runNextFrame = false;\n+                let isProcessing = false;\n+                const frame = {\n+                    delta: 0,\n+                    timestamp: 0\n+                };\n+                const stepsOrder = [\"read\", \"update\", \"preRender\", \"render\", \"postRender\"];\n+                const steps = stepsOrder.reduce((acc, key) => {\n+                    acc[key] = createRenderStep(() => runNextFrame = true);\n+                    return acc;\n+                }, {});\n+                const sync = stepsOrder.reduce((acc, key) => {\n+                    const step = steps[key];\n+                    acc[key] = (process, keepAlive = false, immediate = false) => {\n+                        if (!runNextFrame) startLoop();\n+                        return step.schedule(process, keepAlive, immediate);\n+                    };\n+                    return acc;\n+                }, {});\n+                const cancelSync = stepsOrder.reduce((acc, key) => {\n+                    acc[key] = steps[key].cancel;\n+                    return acc;\n+                }, {});\n+                const flushSync = stepsOrder.reduce((acc, key) => {\n+                    acc[key] = () => steps[key].process(frame);\n+                    return acc;\n+                }, {});\n+                const processStep = stepId => steps[stepId].process(frame);\n+                const processFrame = timestamp => {\n+                    runNextFrame = false;\n+                    frame.delta = useDefaultElapsed ? defaultTimestep : Math.max(Math.min(timestamp - frame.timestamp, maxElapsed), 1);\n+                    frame.timestamp = timestamp;\n+                    isProcessing = true;\n+                    stepsOrder.forEach(processStep);\n+                    isProcessing = false;\n+                    if (runNextFrame) {\n+                        useDefaultElapsed = false;\n+                        onNextFrame(processFrame);\n+                    }\n+                };\n+                const startLoop = () => {\n+                    runNextFrame = true;\n+                    useDefaultElapsed = true;\n+                    if (!isProcessing) onNextFrame(processFrame);\n+                };\n+                const getFrameData = () => frame;\n+                exports.cancelSync = cancelSync;\n+                exports[\"default\"] = sync;\n+                exports.flushSync = flushSync;\n+                exports.getFrameData = getFrameData;\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/get-nonce/dist/es2015/index.js\":\n+            /*!************************************************************!*\\\n+              !*** ../../../node_modules/get-nonce/dist/es2015/index.js ***!\n+              \\************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.setNonce = exports.getNonce = void 0;\n+                var currentNonce;\n+                var setNonce = function(nonce) {\n+                    currentNonce = nonce;\n+                };\n+                exports.setNonce = setNonce;\n+                var getNonce = function() {\n+                    if (currentNonce) {\n+                        return currentNonce;\n+                    }\n+                    if (true) {\n+                        return __webpack_require__.nc;\n+                    }\n+                    return undefined;\n+                };\n+                exports.getNonce = getNonce;\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/get-value/index.js\":\n+            /*!************************************************!*\\\n+              !*** ../../../node_modules/get-value/index.js ***!\n+              \\************************************************/\n+            /***/\n+            (function(module, __unused_webpack_exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                /*!\n+                 * get-value <https://github.com/jonschlinkert/get-value>\n+                 *\n+                 * Copyright (c) 2014-2018, Jon Schlinkert.\n+                 * Released under the MIT License.\n+                 */\n+\n+                const isObject = __webpack_require__( /*! isobject */ \"../../../node_modules/isobject/index.js\");\n+                module.exports = function(target, path, options) {\n+                    if (!isObject(options)) {\n+                        options = {\n+                            default: options\n+                        };\n+                    }\n+                    if (!isValidObject(target)) {\n+                        return typeof options.default !== 'undefined' ? options.default : target;\n+                    }\n+                    if (typeof path === 'number') {\n+                        path = String(path);\n+                    }\n+                    const isArray = Array.isArray(path);\n+                    const isString = typeof path === 'string';\n+                    const splitChar = options.separator || '.';\n+                    const joinChar = options.joinChar || (typeof splitChar === 'string' ? splitChar : '.');\n+                    if (!isString && !isArray) {\n+                        return target;\n+                    }\n+                    if (isString && path in target) {\n+                        return isValid(path, target, options) ? target[path] : options.default;\n+                    }\n+                    let segs = isArray ? path : split(path, splitChar, options);\n+                    let len = segs.length;\n+                    let idx = 0;\n+                    do {\n+                        let prop = segs[idx];\n+                        if (typeof prop === 'number') {\n+                            prop = String(prop);\n+                        }\n+                        while (prop && prop.slice(-1) === '\\\\') {\n+                            prop = join([prop.slice(0, -1), segs[++idx] || ''], joinChar, options);\n+                        }\n+                        if (prop in target) {\n+                            if (!isValid(prop, target, options)) {\n+                                return options.default;\n+                            }\n+                            target = target[prop];\n+                        } else {\n+                            let hasProp = false;\n+                            let n = idx + 1;\n+                            while (n < len) {\n+                                prop = join([prop, segs[n++]], joinChar, options);\n+                                if (hasProp = prop in target) {\n+                                    if (!isValid(prop, target, options)) {\n+                                        return options.default;\n+                                    }\n+                                    target = target[prop];\n+                                    idx = n - 1;\n+                                    break;\n+                                }\n+                            }\n+                            if (!hasProp) {\n+                                return options.default;\n+                            }\n+                        }\n+                    } while (++idx < len && isValidObject(target));\n+                    if (idx === len) {\n+                        return target;\n+                    }\n+                    return options.default;\n+                };\n+\n+                function join(segs, joinChar, options) {\n+                    if (typeof options.join === 'function') {\n+                        return options.join(segs);\n+                    }\n+                    return segs[0] + joinChar + segs[1];\n+                }\n+\n+                function split(path, splitChar, options) {\n+                    if (typeof options.split === 'function') {\n+                        return options.split(path);\n+                    }\n+                    return path.split(splitChar);\n+                }\n+\n+                function isValid(key, target, options) {\n+                    if (typeof options.isValid === 'function') {\n+                        return options.isValid(key, target);\n+                    }\n+                    return true;\n+                }\n+\n+                function isValidObject(val) {\n+                    return isObject(val) || Array.isArray(val) || typeof val === 'function';\n+                }\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/graphql-ws/lib/client.mjs\":\n+            /*!*******************************************************!*\\\n+              !*** ../../../node_modules/graphql-ws/lib/client.mjs ***!\n+              \\*******************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                var _exportNames = {\n+                    createClient: true\n+                };\n+                exports.createClient = createClient;\n+                var _common = __webpack_require__( /*! ./common.mjs */ \"../../../node_modules/graphql-ws/lib/common.mjs\");\n+                Object.keys(_common).forEach(function(key) {\n+                    if (key === \"default\" || key === \"__esModule\") return;\n+                    if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;\n+                    if (key in exports && exports[key] === _common[key]) return;\n+                    Object.defineProperty(exports, key, {\n+                        enumerable: true,\n+                        get: function() {\n+                            return _common[key];\n+                        }\n+                    });\n+                });\n+                var _utils = __webpack_require__( /*! ./utils.mjs */ \"../../../node_modules/graphql-ws/lib/utils.mjs\");\n+                /**\n+                 *\n+                 * client\n+                 *\n+                 */\n+                var __await = void 0 && (void 0).__await || function(v) {\n+                    return this instanceof __await ? (this.v = v, this) : new __await(v);\n+                };\n+                var __asyncGenerator = void 0 && (void 0).__asyncGenerator || function(thisArg, _arguments, generator) {\n+                    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n+                    var g = generator.apply(thisArg, _arguments || []),\n+                        i,\n+                        q = [];\n+                    return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function() {\n+                        return this;\n+                    }, i;\n+\n+                    function verb(n) {\n+                        if (g[n]) i[n] = function(v) {\n+                            return new Promise(function(a, b) {\n+                                q.push([n, v, a, b]) > 1 || resume(n, v);\n+                            });\n+                        };\n+                    }\n+\n+                    function resume(n, v) {\n+                        try {\n+                            step(g[n](v));\n+                        } catch (e) {\n+                            settle(q[0][3], e);\n+                        }\n+                    }\n+\n+                    function step(r) {\n+                        r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r);\n+                    }\n+\n+                    function fulfill(value) {\n+                        resume(\"next\", value);\n+                    }\n+\n+                    function reject(value) {\n+                        resume(\"throw\", value);\n+                    }\n+\n+                    function settle(f, v) {\n+                        if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]);\n+                    }\n+                };\n+\n+                /** This file is the entry point for browsers, re-export common elements. */\n+\n+                /**\n+                 * Creates a disposable GraphQL over WebSocket client.\n+                 *\n+                 * @category Client\n+                 */\n+                function createClient(options) {\n+                    const {\n+                        url,\n+                        connectionParams,\n+                        lazy = true,\n+                        onNonLazyError = console.error,\n+                        lazyCloseTimeout: lazyCloseTimeoutMs = 0,\n+                        keepAlive = 0,\n+                        disablePong,\n+                        connectionAckWaitTimeout = 0,\n+                        retryAttempts = 5,\n+                        retryWait = async function randomisedExponentialBackoff(retries) {\n+                            let retryDelay = 1000; // start with 1s delay\n+                            for (let i = 0; i < retries; i++) {\n+                                retryDelay *= 2;\n+                            }\n+                            await new Promise(resolve => setTimeout(resolve, retryDelay +\n+                                // add random timeout from 300ms to 3s\n+                                Math.floor(Math.random() * (3000 - 300) + 300)));\n+                        },\n+                        shouldRetry = isLikeCloseEvent,\n+                        isFatalConnectionProblem,\n+                        on,\n+                        webSocketImpl,\n+                        /**\n+                         * Generates a v4 UUID to be used as the ID using `Math`\n+                         * as the random number generator. Supply your own generator\n+                         * in case you need more uniqueness.\n+                         *\n+                         * Reference: https://gist.github.com/jed/982883\n+                         */\n+                        generateID = function generateUUID() {\n+                            return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, c => {\n+                                const r = Math.random() * 16 | 0,\n+                                    v = c == 'x' ? r : r & 0x3 | 0x8;\n+                                return v.toString(16);\n+                            });\n+                        },\n+                        jsonMessageReplacer: replacer,\n+                        jsonMessageReviver: reviver\n+                    } = options;\n+                    let ws;\n+                    if (webSocketImpl) {\n+                        if (!isWebSocket(webSocketImpl)) {\n+                            throw new Error('Invalid WebSocket implementation provided');\n+                        }\n+                        ws = webSocketImpl;\n+                    } else if (typeof WebSocket !== 'undefined') {\n+                        ws = WebSocket;\n+                    } else if (typeof __webpack_require__.g !== 'undefined') {\n+                        ws = __webpack_require__.g.WebSocket ||\n+                            // @ts-expect-error: Support more browsers\n+                            __webpack_require__.g.MozWebSocket;\n+                    } else if (typeof window !== 'undefined') {\n+                        ws = window.WebSocket ||\n+                            // @ts-expect-error: Support more browsers\n+                            window.MozWebSocket;\n+                    }\n+                    if (!ws) throw new Error(\"WebSocket implementation missing; on Node you can `import WebSocket from 'ws';` and pass `webSocketImpl: WebSocket` to `createClient`\");\n+                    const WebSocketImpl = ws;\n+                    // websocket status emitter, subscriptions are handled differently\n+                    const emitter = (() => {\n+                        const message = (() => {\n+                            const listeners = {};\n+                            return {\n+                                on(id, listener) {\n+                                    listeners[id] = listener;\n+                                    return () => {\n+                                        delete listeners[id];\n+                                    };\n+                                },\n+                                emit(message) {\n+                                    var _a;\n+                                    if ('id' in message)(_a = listeners[message.id]) === null || _a === void 0 ? void 0 : _a.call(listeners, message);\n+                                }\n+                            };\n+                        })();\n+                        const listeners = {\n+                            connecting: (on === null || on === void 0 ? void 0 : on.connecting) ? [on.connecting] : [],\n+                            opened: (on === null || on === void 0 ? void 0 : on.opened) ? [on.opened] : [],\n+                            connected: (on === null || on === void 0 ? void 0 : on.connected) ? [on.connected] : [],\n+                            ping: (on === null || on === void 0 ? void 0 : on.ping) ? [on.ping] : [],\n+                            pong: (on === null || on === void 0 ? void 0 : on.pong) ? [on.pong] : [],\n+                            message: (on === null || on === void 0 ? void 0 : on.message) ? [message.emit, on.message] : [message.emit],\n+                            closed: (on === null || on === void 0 ? void 0 : on.closed) ? [on.closed] : [],\n+                            error: (on === null || on === void 0 ? void 0 : on.error) ? [on.error] : []\n+                        };\n+                        return {\n+                            onMessage: message.on,\n+                            on(event, listener) {\n+                                const l = listeners[event];\n+                                l.push(listener);\n+                                return () => {\n+                                    l.splice(l.indexOf(listener), 1);\n+                                };\n+                            },\n+                            emit(event, ...args) {\n+                                // we copy the listeners so that unlistens dont \"pull the rug under our feet\"\n+                                for (const listener of [...listeners[event]]) {\n+                                    // @ts-expect-error: The args should fit\n+                                    listener(...args);\n+                                }\n+                            }\n+                        };\n+                    })();\n+                    // invokes the callback either when an error or closed event is emitted,\n+                    // first one that gets called prevails, other emissions are ignored\n+                    function errorOrClosed(cb) {\n+                        const listening = [\n+                            // errors are fatal and more critical than close events, throw them first\n+                            emitter.on('error', err => {\n+                                listening.forEach(unlisten => unlisten());\n+                                cb(err);\n+                            }),\n+                            // closes can be graceful and not fatal, throw them second (if error didnt throw)\n+                            emitter.on('closed', event => {\n+                                listening.forEach(unlisten => unlisten());\n+                                cb(event);\n+                            })\n+                        ];\n+                    }\n+                    let connecting,\n+                        locks = 0,\n+                        lazyCloseTimeout,\n+                        retrying = false,\n+                        retries = 0,\n+                        disposed = false;\n+                    async function connect() {\n+                        // clear the lazy close timeout immediatelly so that close gets debounced\n+                        // see: https://github.com/enisdenjo/graphql-ws/issues/388\n+                        clearTimeout(lazyCloseTimeout);\n+                        const [socket, throwOnClose] = await (connecting !== null && connecting !== void 0 ? connecting : connecting = new Promise((connected, denied) => (async () => {\n+                            if (retrying) {\n+                                await retryWait(retries);\n+                                // subscriptions might complete while waiting for retry\n+                                if (!locks) {\n+                                    connecting = undefined;\n+                                    return denied({\n+                                        code: 1000,\n+                                        reason: 'All Subscriptions Gone'\n+                                    });\n+                                }\n+                                retries++;\n+                            }\n+                            emitter.emit('connecting');\n+                            const socket = new WebSocketImpl(typeof url === 'function' ? await url() : url, _common.GRAPHQL_TRANSPORT_WS_PROTOCOL);\n+                            let connectionAckTimeout, queuedPing;\n+\n+                            function enqueuePing() {\n+                                if (isFinite(keepAlive) && keepAlive > 0) {\n+                                    clearTimeout(queuedPing); // in case where a pong was received before a ping (this is valid behaviour)\n+                                    queuedPing = setTimeout(() => {\n+                                        if (socket.readyState === WebSocketImpl.OPEN) {\n+                                            socket.send((0, _common.stringifyMessage)({\n+                                                type: _common.MessageType.Ping\n+                                            }));\n+                                            emitter.emit('ping', false, undefined);\n+                                        }\n+                                    }, keepAlive);\n+                                }\n+                            }\n+                            errorOrClosed(errOrEvent => {\n+                                connecting = undefined;\n+                                clearTimeout(connectionAckTimeout);\n+                                clearTimeout(queuedPing);\n+                                denied(errOrEvent);\n+                                if (isLikeCloseEvent(errOrEvent) && errOrEvent.code === 4499) {\n+                                    socket.close(4499, 'Terminated'); // close event is artificial and emitted manually, see `Client.terminate()` below\n+                                    socket.onerror = null;\n+                                    socket.onclose = null;\n+                                }\n+                            });\n+                            socket.onerror = err => emitter.emit('error', err);\n+                            socket.onclose = event => emitter.emit('closed', event);\n+                            socket.onopen = async () => {\n+                                try {\n+                                    emitter.emit('opened', socket);\n+                                    const payload = typeof connectionParams === 'function' ? await connectionParams() : connectionParams;\n+                                    // connectionParams might take too long causing the server to kick off the client\n+                                    // the necessary error/close event is already reported - simply stop execution\n+                                    if (socket.readyState !== WebSocketImpl.OPEN) return;\n+                                    socket.send((0, _common.stringifyMessage)(payload ? {\n+                                        type: _common.MessageType.ConnectionInit,\n+                                        payload\n+                                    } : {\n+                                        type: _common.MessageType.ConnectionInit\n+                                        // payload is completely absent if not provided\n+                                    }, replacer));\n+                                    if (isFinite(connectionAckWaitTimeout) && connectionAckWaitTimeout > 0) {\n+                                        connectionAckTimeout = setTimeout(() => {\n+                                            socket.close(_common.CloseCode.ConnectionAcknowledgementTimeout, 'Connection acknowledgement timeout');\n+                                        }, connectionAckWaitTimeout);\n+                                    }\n+                                    enqueuePing(); // enqueue ping (noop if disabled)\n+                                } catch (err) {\n+                                    emitter.emit('error', err);\n+                                    socket.close(_common.CloseCode.InternalClientError, (0, _utils.limitCloseReason)(err instanceof Error ? err.message : new Error(err).message, 'Internal client error'));\n+                                }\n+                            };\n+                            let acknowledged = false;\n+                            socket.onmessage = ({\n+                                data\n+                            }) => {\n+                                try {\n+                                    const message = (0, _common.parseMessage)(data, reviver);\n+                                    emitter.emit('message', message);\n+                                    if (message.type === 'ping' || message.type === 'pong') {\n+                                        emitter.emit(message.type, true, message.payload); // received\n+                                        if (message.type === 'pong') {\n+                                            enqueuePing(); // enqueue next ping (noop if disabled)\n+                                        } else if (!disablePong) {\n+                                            // respond with pong on ping\n+                                            socket.send((0, _common.stringifyMessage)(message.payload ? {\n+                                                type: _common.MessageType.Pong,\n+                                                payload: message.payload\n+                                            } : {\n+                                                type: _common.MessageType.Pong\n+                                                // payload is completely absent if not provided\n+                                            }));\n+                                            emitter.emit('pong', false, message.payload);\n+                                        }\n+                                        return; // ping and pongs can be received whenever\n+                                    }\n+                                    if (acknowledged) return; // already connected and acknowledged\n+                                    if (message.type !== _common.MessageType.ConnectionAck) throw new Error(`First message cannot be of type ${message.type}`);\n+                                    clearTimeout(connectionAckTimeout);\n+                                    acknowledged = true;\n+                                    emitter.emit('connected', socket, message.payload); // connected = socket opened + acknowledged\n+                                    retrying = false; // future lazy connects are not retries\n+                                    retries = 0; // reset the retries on connect\n+                                    connected([socket, new Promise((_, reject) => errorOrClosed(reject))]);\n+                                } catch (err) {\n+                                    socket.onmessage = null; // stop reading messages as soon as reading breaks once\n+                                    emitter.emit('error', err);\n+                                    socket.close(_common.CloseCode.BadResponse, (0, _utils.limitCloseReason)(err instanceof Error ? err.message : new Error(err).message, 'Bad response'));\n+                                }\n+                            };\n+                        })()));\n+                        // if the provided socket is in a closing state, wait for the throw on close\n+                        if (socket.readyState === WebSocketImpl.CLOSING) await throwOnClose;\n+                        let release = () => {\n+                            // releases this connection\n+                        };\n+                        const released = new Promise(resolve => release = resolve);\n+                        return [socket, release, Promise.race([\n+                            // wait for\n+                            released.then(() => {\n+                                if (!locks) {\n+                                    // and if no more locks are present, complete the connection\n+                                    const complete = () => socket.close(1000, 'Normal Closure');\n+                                    if (isFinite(lazyCloseTimeoutMs) && lazyCloseTimeoutMs > 0) {\n+                                        // if the keepalive is set, allow for the specified calmdown time and\n+                                        // then complete if the socket is still open.\n+                                        lazyCloseTimeout = setTimeout(() => {\n+                                            if (socket.readyState === WebSocketImpl.OPEN) complete();\n+                                        }, lazyCloseTimeoutMs);\n+                                    } else {\n+                                        // otherwise complete immediately\n+                                        complete();\n+                                    }\n+                                }\n+                            }),\n+                            // or\n+                            throwOnClose\n+                        ])];\n+                    }\n+                    /**\n+                     * Checks the `connect` problem and evaluates if the client should retry.\n+                     */\n+                    function shouldRetryConnectOrThrow(errOrCloseEvent) {\n+                        // some close codes are worth reporting immediately\n+                        if (isLikeCloseEvent(errOrCloseEvent) && (isFatalInternalCloseCode(errOrCloseEvent.code) || [_common.CloseCode.InternalServerError, _common.CloseCode.InternalClientError, _common.CloseCode.BadRequest, _common.CloseCode.BadResponse, _common.CloseCode.Unauthorized,\n+                                // CloseCode.Forbidden, might grant access out after retry\n+                                _common.CloseCode.SubprotocolNotAcceptable,\n+                                // CloseCode.ConnectionInitialisationTimeout, might not time out after retry\n+                                // CloseCode.ConnectionAcknowledgementTimeout, might not time out after retry\n+                                _common.CloseCode.SubscriberAlreadyExists, _common.CloseCode.TooManyInitialisationRequests\n+                                // 4499, // Terminated, probably because the socket froze, we want to retry\n+                            ].includes(errOrCloseEvent.code))) throw errOrCloseEvent;\n+                        // client was disposed, no retries should proceed regardless\n+                        if (disposed) return false;\n+                        // normal closure (possibly all subscriptions have completed)\n+                        // if no locks were acquired in the meantime, shouldnt try again\n+                        if (isLikeCloseEvent(errOrCloseEvent) && errOrCloseEvent.code === 1000) return locks > 0;\n+                        // retries are not allowed or we tried to many times, report error\n+                        if (!retryAttempts || retries >= retryAttempts) throw errOrCloseEvent;\n+                        // throw non-retryable connection problems\n+                        if (!shouldRetry(errOrCloseEvent)) throw errOrCloseEvent;\n+                        // @deprecated throw fatal connection problems immediately\n+                        if (isFatalConnectionProblem === null || isFatalConnectionProblem === void 0 ? void 0 : isFatalConnectionProblem(errOrCloseEvent)) throw errOrCloseEvent;\n+                        // looks good, start retrying\n+                        return retrying = true;\n+                    }\n+                    // in non-lazy (hot?) mode always hold one connection lock to persist the socket\n+                    if (!lazy) {\n+                        (async () => {\n+                            locks++;\n+                            for (;;) {\n+                                try {\n+                                    const [, , throwOnClose] = await connect();\n+                                    await throwOnClose; // will always throw because releaser is not used\n+                                } catch (errOrCloseEvent) {\n+                                    try {\n+                                        if (!shouldRetryConnectOrThrow(errOrCloseEvent)) return;\n+                                    } catch (errOrCloseEvent) {\n+                                        // report thrown error, no further retries\n+                                        return onNonLazyError === null || onNonLazyError === void 0 ? void 0 : onNonLazyError(errOrCloseEvent);\n+                                    }\n+                                }\n+                            }\n+                        })();\n+                    }\n+                    return {\n+                        on: emitter.on,\n+                        subscribe(payload, sink) {\n+                            const id = generateID(payload);\n+                            let done = false,\n+                                errored = false,\n+                                releaser = () => {\n+                                    // for handling completions before connect\n+                                    locks--;\n+                                    done = true;\n+                                };\n+                            (async () => {\n+                                locks++;\n+                                for (;;) {\n+                                    try {\n+                                        const [socket, release, waitForReleaseOrThrowOnClose] = await connect();\n+                                        // if done while waiting for connect, release the connection lock right away\n+                                        if (done) return release();\n+                                        const unlisten = emitter.onMessage(id, message => {\n+                                            switch (message.type) {\n+                                                case _common.MessageType.Next: {\n+                                                    // eslint-disable-next-line @typescript-eslint/no-explicit-any -- payload will fit type\n+                                                    sink.next(message.payload);\n+                                                    return;\n+                                                }\n+                                                case _common.MessageType.Error: {\n+                                                    errored = true, done = true;\n+                                                    sink.error(message.payload);\n+                                                    releaser();\n+                                                    return;\n+                                                }\n+                                                case _common.MessageType.Complete: {\n+                                                    done = true;\n+                                                    releaser(); // release completes the sink\n+                                                    return;\n+                                                }\n+                                            }\n+                                        });\n+                                        socket.send((0, _common.stringifyMessage)({\n+                                            id,\n+                                            type: _common.MessageType.Subscribe,\n+                                            payload\n+                                        }, replacer));\n+                                        releaser = () => {\n+                                            if (!done && socket.readyState === WebSocketImpl.OPEN)\n+                                                // if not completed already and socket is open, send complete message to server on release\n+                                                socket.send((0, _common.stringifyMessage)({\n+                                                    id,\n+                                                    type: _common.MessageType.Complete\n+                                                }, replacer));\n+                                            locks--;\n+                                            done = true;\n+                                            release();\n+                                        };\n+                                        // either the releaser will be called, connection completed and\n+                                        // the promise resolved or the socket closed and the promise rejected.\n+                                        // whatever happens though, we want to stop listening for messages\n+                                        await waitForReleaseOrThrowOnClose.finally(unlisten);\n+                                        return; // completed, shouldnt try again\n+                                    } catch (errOrCloseEvent) {\n+                                        if (!shouldRetryConnectOrThrow(errOrCloseEvent)) return;\n+                                    }\n+                                }\n+                            })().then(() => {\n+                                    // delivering either an error or a complete terminates the sequence\n+                                    if (!errored) sink.complete();\n+                                }) // resolves on release or normal closure\n+                                .catch(err => {\n+                                    sink.error(err);\n+                                }); // rejects on close events and errors\n+                            return () => {\n+                                // dispose only of active subscriptions\n+                                if (!done) releaser();\n+                            };\n+                        },\n+                        iterate(request) {\n+                            const pending = [];\n+                            const deferred = {\n+                                done: false,\n+                                error: null,\n+                                resolve: () => {\n+                                    // noop\n+                                }\n+                            };\n+                            const dispose = this.subscribe(request, {\n+                                next(val) {\n+                                    pending.push(val);\n+                                    deferred.resolve();\n+                                },\n+                                error(err) {\n+                                    deferred.done = true;\n+                                    deferred.error = err;\n+                                    deferred.resolve();\n+                                },\n+                                complete() {\n+                                    deferred.done = true;\n+                                    deferred.resolve();\n+                                }\n+                            });\n+                            const iterator = function iterator() {\n+                                return __asyncGenerator(this, arguments, function* iterator_1() {\n+                                    for (;;) {\n+                                        if (!pending.length) {\n+                                            // only wait if there are no pending messages available\n+                                            yield __await(new Promise(resolve => deferred.resolve = resolve));\n+                                        }\n+                                        // first flush\n+                                        while (pending.length) {\n+                                            // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n+                                            yield yield __await(pending.shift());\n+                                        }\n+                                        // then error\n+                                        if (deferred.error) {\n+                                            throw deferred.error;\n+                                        }\n+                                        // or complete\n+                                        if (deferred.done) {\n+                                            return yield __await(void 0);\n+                                        }\n+                                    }\n+                                });\n+                            }();\n+                            iterator.throw = async err => {\n+                                if (!deferred.done) {\n+                                    deferred.done = true;\n+                                    deferred.error = err;\n+                                    deferred.resolve();\n+                                }\n+                                return {\n+                                    done: true,\n+                                    value: undefined\n+                                };\n+                            };\n+                            iterator.return = async () => {\n+                                dispose();\n+                                return {\n+                                    done: true,\n+                                    value: undefined\n+                                };\n+                            };\n+                            return iterator;\n+                        },\n+                        async dispose() {\n+                            disposed = true;\n+                            if (connecting) {\n+                                // if there is a connection, close it\n+                                const [socket] = await connecting;\n+                                socket.close(1000, 'Normal Closure');\n+                            }\n+                        },\n+                        terminate() {\n+                            if (connecting) {\n+                                // only if there is a connection\n+                                emitter.emit('closed', {\n+                                    code: 4499,\n+                                    reason: 'Terminated',\n+                                    wasClean: false\n+                                });\n+                            }\n+                        }\n+                    };\n+                }\n+\n+                function isLikeCloseEvent(val) {\n+                    return (0, _utils.isObject)(val) && 'code' in val && 'reason' in val;\n+                }\n+\n+                function isFatalInternalCloseCode(code) {\n+                    if ([1000, 1001, 1006, 1005, 1012, 1013, 1013 // Bad Gateway\n+                        ].includes(code)) return false;\n+                    // all other internal errors are fatal\n+                    return code >= 1000 && code <= 1999;\n+                }\n+\n+                function isWebSocket(val) {\n+                    return typeof val === 'function' && 'constructor' in val && 'CLOSED' in val && 'CLOSING' in val && 'CONNECTING' in val && 'OPEN' in val;\n+                }\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/graphql-ws/lib/common.mjs\":\n+            /*!*******************************************************!*\\\n+              !*** ../../../node_modules/graphql-ws/lib/common.mjs ***!\n+              \\*******************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.MessageType = exports.GRAPHQL_TRANSPORT_WS_PROTOCOL = exports.DEPRECATED_GRAPHQL_WS_PROTOCOL = exports.CloseCode = void 0;\n+                exports.isMessage = isMessage;\n+                exports.parseMessage = parseMessage;\n+                exports.stringifyMessage = stringifyMessage;\n+                exports.validateMessage = validateMessage;\n+                var _utils = __webpack_require__( /*! ./utils.mjs */ \"../../../node_modules/graphql-ws/lib/utils.mjs\");\n+                /**\n+                 *\n+                 * common\n+                 *\n+                 */\n+\n+                /**\n+                 * The WebSocket sub-protocol used for the [GraphQL over WebSocket Protocol](https://github.com/graphql/graphql-over-http/blob/main/rfcs/GraphQLOverWebSocket.md).\n+                 *\n+                 * @category Common\n+                 */\n+                const GRAPHQL_TRANSPORT_WS_PROTOCOL = exports.GRAPHQL_TRANSPORT_WS_PROTOCOL = 'graphql-transport-ws';\n+                /**\n+                 * The deprecated subprotocol used by [subscriptions-transport-ws](https://github.com/apollographql/subscriptions-transport-ws).\n+                 *\n+                 * @private\n+                 */\n+                const DEPRECATED_GRAPHQL_WS_PROTOCOL = exports.DEPRECATED_GRAPHQL_WS_PROTOCOL = 'graphql-ws';\n+                /**\n+                 * `graphql-ws` expected and standard close codes of the [GraphQL over WebSocket Protocol](https://github.com/graphql/graphql-over-http/blob/main/rfcs/GraphQLOverWebSocket.md).\n+                 *\n+                 * @category Common\n+                 */\n+                var CloseCode;\n+                (function(CloseCode) {\n+                    CloseCode[CloseCode[\"InternalServerError\"] = 4500] = \"InternalServerError\";\n+                    CloseCode[CloseCode[\"InternalClientError\"] = 4005] = \"InternalClientError\";\n+                    CloseCode[CloseCode[\"BadRequest\"] = 4400] = \"BadRequest\";\n+                    CloseCode[CloseCode[\"BadResponse\"] = 4004] = \"BadResponse\";\n+                    /** Tried subscribing before connect ack */\n+                    CloseCode[CloseCode[\"Unauthorized\"] = 4401] = \"Unauthorized\";\n+                    CloseCode[CloseCode[\"Forbidden\"] = 4403] = \"Forbidden\";\n+                    CloseCode[CloseCode[\"SubprotocolNotAcceptable\"] = 4406] = \"SubprotocolNotAcceptable\";\n+                    CloseCode[CloseCode[\"ConnectionInitialisationTimeout\"] = 4408] = \"ConnectionInitialisationTimeout\";\n+                    CloseCode[CloseCode[\"ConnectionAcknowledgementTimeout\"] = 4504] = \"ConnectionAcknowledgementTimeout\";\n+                    /** Subscriber distinction is very important */\n+                    CloseCode[CloseCode[\"SubscriberAlreadyExists\"] = 4409] = \"SubscriberAlreadyExists\";\n+                    CloseCode[CloseCode[\"TooManyInitialisationRequests\"] = 4429] = \"TooManyInitialisationRequests\";\n+                })(CloseCode || (exports.CloseCode = CloseCode = {}));\n+                /**\n+                 * Types of messages allowed to be sent by the client/server over the WS protocol.\n+                 *\n+                 * @category Common\n+                 */\n+                var MessageType;\n+                (function(MessageType) {\n+                    MessageType[\"ConnectionInit\"] = \"connection_init\";\n+                    MessageType[\"ConnectionAck\"] = \"connection_ack\";\n+                    MessageType[\"Ping\"] = \"ping\";\n+                    MessageType[\"Pong\"] = \"pong\";\n+                    MessageType[\"Subscribe\"] = \"subscribe\";\n+                    MessageType[\"Next\"] = \"next\";\n+                    MessageType[\"Error\"] = \"error\";\n+                    MessageType[\"Complete\"] = \"complete\";\n+                })(MessageType || (exports.MessageType = MessageType = {}));\n+                /**\n+                 * Validates the message against the GraphQL over WebSocket Protocol.\n+                 *\n+                 * Invalid messages will throw descriptive errors.\n+                 *\n+                 * @category Common\n+                 */\n+                function validateMessage(val) {\n+                    if (!(0, _utils.isObject)(val)) {\n+                        throw new Error(`Message is expected to be an object, but got ${(0, _utils.extendedTypeof)(val)}`);\n+                    }\n+                    if (!val.type) {\n+                        throw new Error(`Message is missing the 'type' property`);\n+                    }\n+                    if (typeof val.type !== 'string') {\n+                        throw new Error(`Message is expects the 'type' property to be a string, but got ${(0, _utils.extendedTypeof)(val.type)}`);\n+                    }\n+                    switch (val.type) {\n+                        case MessageType.ConnectionInit:\n+                        case MessageType.ConnectionAck:\n+                        case MessageType.Ping:\n+                        case MessageType.Pong: {\n+                            if (val.payload != null && !(0, _utils.isObject)(val.payload)) {\n+                                throw new Error(`\"${val.type}\" message expects the 'payload' property to be an object or nullish or missing, but got \"${val.payload}\"`);\n+                            }\n+                            break;\n+                        }\n+                        case MessageType.Subscribe: {\n+                            if (typeof val.id !== 'string') {\n+                                throw new Error(`\"${val.type}\" message expects the 'id' property to be a string, but got ${(0, _utils.extendedTypeof)(val.id)}`);\n+                            }\n+                            if (!val.id) {\n+                                throw new Error(`\"${val.type}\" message requires a non-empty 'id' property`);\n+                            }\n+                            if (!(0, _utils.isObject)(val.payload)) {\n+                                throw new Error(`\"${val.type}\" message expects the 'payload' property to be an object, but got ${(0, _utils.extendedTypeof)(val.payload)}`);\n+                            }\n+                            if (typeof val.payload.query !== 'string') {\n+                                throw new Error(`\"${val.type}\" message payload expects the 'query' property to be a string, but got ${(0, _utils.extendedTypeof)(val.payload.query)}`);\n+                            }\n+                            if (val.payload.variables != null && !(0, _utils.isObject)(val.payload.variables)) {\n+                                throw new Error(`\"${val.type}\" message payload expects the 'variables' property to be a an object or nullish or missing, but got ${(0, _utils.extendedTypeof)(val.payload.variables)}`);\n+                            }\n+                            if (val.payload.operationName != null && (0, _utils.extendedTypeof)(val.payload.operationName) !== 'string') {\n+                                throw new Error(`\"${val.type}\" message payload expects the 'operationName' property to be a string or nullish or missing, but got ${(0, _utils.extendedTypeof)(val.payload.operationName)}`);\n+                            }\n+                            if (val.payload.extensions != null && !(0, _utils.isObject)(val.payload.extensions)) {\n+                                throw new Error(`\"${val.type}\" message payload expects the 'extensions' property to be a an object or nullish or missing, but got ${(0, _utils.extendedTypeof)(val.payload.extensions)}`);\n+                            }\n+                            break;\n+                        }\n+                        case MessageType.Next: {\n+                            if (typeof val.id !== 'string') {\n+                                throw new Error(`\"${val.type}\" message expects the 'id' property to be a string, but got ${(0, _utils.extendedTypeof)(val.id)}`);\n+                            }\n+                            if (!val.id) {\n+                                throw new Error(`\"${val.type}\" message requires a non-empty 'id' property`);\n+                            }\n+                            if (!(0, _utils.isObject)(val.payload)) {\n+                                throw new Error(`\"${val.type}\" message expects the 'payload' property to be an object, but got ${(0, _utils.extendedTypeof)(val.payload)}`);\n+                            }\n+                            break;\n+                        }\n+                        case MessageType.Error: {\n+                            if (typeof val.id !== 'string') {\n+                                throw new Error(`\"${val.type}\" message expects the 'id' property to be a string, but got ${(0, _utils.extendedTypeof)(val.id)}`);\n+                            }\n+                            if (!val.id) {\n+                                throw new Error(`\"${val.type}\" message requires a non-empty 'id' property`);\n+                            }\n+                            if (!(0, _utils.areGraphQLErrors)(val.payload)) {\n+                                throw new Error(`\"${val.type}\" message expects the 'payload' property to be an array of GraphQL errors, but got ${JSON.stringify(val.payload)}`);\n+                            }\n+                            break;\n+                        }\n+                        case MessageType.Complete: {\n+                            if (typeof val.id !== 'string') {\n+                                throw new Error(`\"${val.type}\" message expects the 'id' property to be a string, but got ${(0, _utils.extendedTypeof)(val.id)}`);\n+                            }\n+                            if (!val.id) {\n+                                throw new Error(`\"${val.type}\" message requires a non-empty 'id' property`);\n+                            }\n+                            break;\n+                        }\n+                        default:\n+                            throw new Error(`Invalid message 'type' property \"${val.type}\"`);\n+                    }\n+                    return val;\n+                }\n+                /**\n+                 * Checks if the provided value is a valid GraphQL over WebSocket message.\n+                 *\n+                 * @deprecated Use `validateMessage` instead.\n+                 *\n+                 * @category Common\n+                 */\n+                function isMessage(val) {\n+                    try {\n+                        validateMessage(val);\n+                        return true;\n+                    } catch (_a) {\n+                        return false;\n+                    }\n+                }\n+                /**\n+                 * Parses the raw websocket message data to a valid message.\n+                 *\n+                 * @category Common\n+                 */\n+                function parseMessage(data, reviver) {\n+                    return validateMessage(typeof data === 'string' ? JSON.parse(data, reviver) : data);\n+                }\n+                /**\n+                 * Stringifies a valid message ready to be sent through the socket.\n+                 *\n+                 * @category Common\n+                 */\n+                function stringifyMessage(msg, replacer) {\n+                    validateMessage(msg);\n+                    return JSON.stringify(msg, replacer);\n+                }\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/graphql-ws/lib/index.js\":\n+            /*!*****************************************************!*\\\n+              !*** ../../../node_modules/graphql-ws/lib/index.js ***!\n+              \\*****************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                var __createBinding = void 0 && (void 0).__createBinding || (Object.create ? function(o, m, k, k2) {\n+                    if (k2 === undefined) k2 = k;\n+                    var desc = Object.getOwnPropertyDescriptor(m, k);\n+                    if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n+                        desc = {\n+                            enumerable: true,\n+                            get: function() {\n+                                return m[k];\n+                            }\n+                        };\n+                    }\n+                    Object.defineProperty(o, k2, desc);\n+                } : function(o, m, k, k2) {\n+                    if (k2 === undefined) k2 = k;\n+                    o[k2] = m[k];\n+                });\n+                var __exportStar = void 0 && (void 0).__exportStar || function(m, exports) {\n+                    for (var p in m)\n+                        if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);\n+                };\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                __exportStar(__webpack_require__( /*! ./client */ \"../../../node_modules/graphql-ws/lib/client.mjs\"), exports);\n+                __exportStar(__webpack_require__( /*! ./server */ \"../../../node_modules/graphql-ws/lib/server.mjs\"), exports);\n+                __exportStar(__webpack_require__( /*! ./common */ \"../../../node_modules/graphql-ws/lib/common.mjs\"), exports);\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/graphql-ws/lib/server.mjs\":\n+            /*!*******************************************************!*\\\n+              !*** ../../../node_modules/graphql-ws/lib/server.mjs ***!\n+              \\*******************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.handleProtocols = handleProtocols;\n+                exports.makeServer = makeServer;\n+                var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n+                var _common = __webpack_require__( /*! ./common.mjs */ \"../../../node_modules/graphql-ws/lib/common.mjs\");\n+                var _utils = __webpack_require__( /*! ./utils.mjs */ \"../../../node_modules/graphql-ws/lib/utils.mjs\");\n+                /**\n+                 *\n+                 * server\n+                 *\n+                 */\n+                var __asyncValues = void 0 && (void 0).__asyncValues || function(o) {\n+                    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n+                    var m = o[Symbol.asyncIterator],\n+                        i;\n+                    return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function() {\n+                        return this;\n+                    }, i);\n+\n+                    function verb(n) {\n+                        i[n] = o[n] && function(v) {\n+                            return new Promise(function(resolve, reject) {\n+                                v = o[n](v), settle(resolve, reject, v.done, v.value);\n+                            });\n+                        };\n+                    }\n+\n+                    function settle(resolve, reject, d, v) {\n+                        Promise.resolve(v).then(function(v) {\n+                            resolve({\n+                                value: v,\n+                                done: d\n+                            });\n+                        }, reject);\n+                    }\n+                };\n+                /**\n+                 * Makes a Protocol complient WebSocket GraphQL server. The server\n+                 * is actually an API which is to be used with your favourite WebSocket\n+                 * server library!\n+                 *\n+                 * Read more about the [GraphQL over WebSocket Protocol](https://github.com/graphql/graphql-over-http/blob/main/rfcs/GraphQLOverWebSocket.md).\n+                 *\n+                 * @category Server\n+                 */\n+                function makeServer(options) {\n+                    const {\n+                        schema,\n+                        context,\n+                        roots,\n+                        validate,\n+                        execute,\n+                        subscribe,\n+                        connectionInitWaitTimeout = 3000,\n+                        // 3 seconds\n+                        onConnect,\n+                        onDisconnect,\n+                        onClose,\n+                        onSubscribe,\n+                        onOperation,\n+                        onNext,\n+                        onError,\n+                        onComplete,\n+                        jsonMessageReviver: reviver,\n+                        jsonMessageReplacer: replacer\n+                    } = options;\n+                    return {\n+                        opened(socket, extra) {\n+                            const ctx = {\n+                                connectionInitReceived: false,\n+                                acknowledged: false,\n+                                subscriptions: {},\n+                                extra\n+                            };\n+                            if (socket.protocol !== _common.GRAPHQL_TRANSPORT_WS_PROTOCOL) {\n+                                socket.close(_common.CloseCode.SubprotocolNotAcceptable, 'Subprotocol not acceptable');\n+                                return async (code, reason) => {\n+                                    /* nothing was set up, just notify the closure */\n+                                    await (onClose === null || onClose === void 0 ? void 0 : onClose(ctx, code, reason));\n+                                };\n+                            }\n+                            // kick the client off (close socket) if the connection has\n+                            // not been initialised after the specified wait timeout\n+                            const connectionInitWait = connectionInitWaitTimeout > 0 && isFinite(connectionInitWaitTimeout) ? setTimeout(() => {\n+                                if (!ctx.connectionInitReceived) socket.close(_common.CloseCode.ConnectionInitialisationTimeout, 'Connection initialisation timeout');\n+                            }, connectionInitWaitTimeout) : null;\n+                            socket.onMessage(async function onMessage(data) {\n+                                var _a, e_1, _b, _c;\n+                                var _d;\n+                                let message;\n+                                try {\n+                                    message = (0, _common.parseMessage)(data, reviver);\n+                                } catch (err) {\n+                                    return socket.close(_common.CloseCode.BadRequest, 'Invalid message received');\n+                                }\n+                                switch (message.type) {\n+                                    case _common.MessageType.ConnectionInit: {\n+                                        if (ctx.connectionInitReceived) return socket.close(_common.CloseCode.TooManyInitialisationRequests, 'Too many initialisation requests');\n+                                        // @ts-expect-error: I can write\n+                                        ctx.connectionInitReceived = true;\n+                                        if ((0, _utils.isObject)(message.payload))\n+                                            // @ts-expect-error: I can write\n+                                            ctx.connectionParams = message.payload;\n+                                        const permittedOrPayload = await (onConnect === null || onConnect === void 0 ? void 0 : onConnect(ctx));\n+                                        if (permittedOrPayload === false) return socket.close(_common.CloseCode.Forbidden, 'Forbidden');\n+                                        await socket.send((0, _common.stringifyMessage)((0, _utils.isObject)(permittedOrPayload) ? {\n+                                            type: _common.MessageType.ConnectionAck,\n+                                            payload: permittedOrPayload\n+                                        } : {\n+                                            type: _common.MessageType.ConnectionAck\n+                                            // payload is completely absent if not provided\n+                                        }, replacer));\n+                                        // @ts-expect-error: I can write\n+                                        ctx.acknowledged = true;\n+                                        return;\n+                                    }\n+                                    case _common.MessageType.Ping: {\n+                                        if (socket.onPing)\n+                                            // if the onPing listener is registered, automatic pong is disabled\n+                                            return await socket.onPing(message.payload);\n+                                        await socket.send((0, _common.stringifyMessage)(message.payload ? {\n+                                            type: _common.MessageType.Pong,\n+                                            payload: message.payload\n+                                        } : {\n+                                            type: _common.MessageType.Pong\n+                                            // payload is completely absent if not provided\n+                                        }));\n+                                        return;\n+                                    }\n+                                    case _common.MessageType.Pong:\n+                                        return await ((_d = socket.onPong) === null || _d === void 0 ? void 0 : _d.call(socket, message.payload));\n+                                    case _common.MessageType.Subscribe: {\n+                                        if (!ctx.acknowledged) return socket.close(_common.CloseCode.Unauthorized, 'Unauthorized');\n+                                        const {\n+                                            id,\n+                                            payload\n+                                        } = message;\n+                                        if (id in ctx.subscriptions) return socket.close(_common.CloseCode.SubscriberAlreadyExists, `Subscriber for ${id} already exists`);\n+                                        // if this turns out to be a streaming operation, the subscription value\n+                                        // will change to an `AsyncIterable`, otherwise it will stay as is\n+                                        ctx.subscriptions[id] = null;\n+                                        const emit = {\n+                                            next: async (result, args) => {\n+                                                let nextMessage = {\n+                                                    id,\n+                                                    type: _common.MessageType.Next,\n+                                                    payload: result\n+                                                };\n+                                                const maybeResult = await (onNext === null || onNext === void 0 ? void 0 : onNext(ctx, nextMessage, args, result));\n+                                                if (maybeResult) nextMessage = Object.assign(Object.assign({}, nextMessage), {\n+                                                    payload: maybeResult\n+                                                });\n+                                                await socket.send((0, _common.stringifyMessage)(nextMessage, replacer));\n+                                            },\n+                                            error: async errors => {\n+                                                let errorMessage = {\n+                                                    id,\n+                                                    type: _common.MessageType.Error,\n+                                                    payload: errors\n+                                                };\n+                                                const maybeErrors = await (onError === null || onError === void 0 ? void 0 : onError(ctx, errorMessage, errors));\n+                                                if (maybeErrors) errorMessage = Object.assign(Object.assign({}, errorMessage), {\n+                                                    payload: maybeErrors\n+                                                });\n+                                                await socket.send((0, _common.stringifyMessage)(errorMessage, replacer));\n+                                            },\n+                                            complete: async notifyClient => {\n+                                                const completeMessage = {\n+                                                    id,\n+                                                    type: _common.MessageType.Complete\n+                                                };\n+                                                await (onComplete === null || onComplete === void 0 ? void 0 : onComplete(ctx, completeMessage));\n+                                                if (notifyClient) await socket.send((0, _common.stringifyMessage)(completeMessage, replacer));\n+                                            }\n+                                        };\n+                                        try {\n+                                            let execArgs;\n+                                            const maybeExecArgsOrErrors = await (onSubscribe === null || onSubscribe === void 0 ? void 0 : onSubscribe(ctx, message));\n+                                            if (maybeExecArgsOrErrors) {\n+                                                if ((0, _utils.areGraphQLErrors)(maybeExecArgsOrErrors)) return await emit.error(maybeExecArgsOrErrors);\n+                                                else if (Array.isArray(maybeExecArgsOrErrors)) throw new Error('Invalid return value from onSubscribe hook, expected an array of GraphQLError objects');\n+                                                // not errors, is exec args\n+                                                execArgs = maybeExecArgsOrErrors;\n+                                            } else {\n+                                                // you either provide a schema dynamically through\n+                                                // `onSubscribe` or you set one up during the server setup\n+                                                if (!schema) throw new Error('The GraphQL schema is not provided');\n+                                                const args = {\n+                                                    operationName: payload.operationName,\n+                                                    document: (0, _graphql.parse)(payload.query),\n+                                                    variableValues: payload.variables\n+                                                };\n+                                                execArgs = Object.assign(Object.assign({}, args), {\n+                                                    schema: typeof schema === 'function' ? await schema(ctx, message, args) : schema\n+                                                });\n+                                                const validationErrors = (validate !== null && validate !== void 0 ? validate : _graphql.validate)(execArgs.schema, execArgs.document);\n+                                                if (validationErrors.length > 0) return await emit.error(validationErrors);\n+                                            }\n+                                            const operationAST = (0, _graphql.getOperationAST)(execArgs.document, execArgs.operationName);\n+                                            if (!operationAST) return await emit.error([new _graphql.GraphQLError('Unable to identify operation')]);\n+                                            // if `onSubscribe` didnt specify a rootValue, inject one\n+                                            if (!('rootValue' in execArgs)) execArgs.rootValue = roots === null || roots === void 0 ? void 0 : roots[operationAST.operation];\n+                                            // if `onSubscribe` didn't specify a context, inject one\n+                                            if (!('contextValue' in execArgs)) execArgs.contextValue = typeof context === 'function' ? await context(ctx, message, execArgs) : context;\n+                                            // the execution arguments have been prepared\n+                                            // perform the operation and act accordingly\n+                                            let operationResult;\n+                                            if (operationAST.operation === 'subscription') operationResult = await (subscribe !== null && subscribe !== void 0 ? subscribe : _graphql.subscribe)(execArgs);\n+                                            // operation === 'query' || 'mutation'\n+                                            else operationResult = await (execute !== null && execute !== void 0 ? execute : _graphql.execute)(execArgs);\n+                                            const maybeResult = await (onOperation === null || onOperation === void 0 ? void 0 : onOperation(ctx, message, execArgs, operationResult));\n+                                            if (maybeResult) operationResult = maybeResult;\n+                                            if ((0, _utils.isAsyncIterable)(operationResult)) {\n+                                                /** multiple emitted results */\n+                                                if (!(id in ctx.subscriptions)) {\n+                                                    // subscription was completed/canceled before the operation settled\n+                                                    if ((0, _utils.isAsyncGenerator)(operationResult)) operationResult.return(undefined);\n+                                                } else {\n+                                                    ctx.subscriptions[id] = operationResult;\n+                                                    try {\n+                                                        for (var _e = true, operationResult_1 = __asyncValues(operationResult), operationResult_1_1; operationResult_1_1 = await operationResult_1.next(), _a = operationResult_1_1.done, !_a; _e = true) {\n+                                                            _c = operationResult_1_1.value;\n+                                                            _e = false;\n+                                                            const result = _c;\n+                                                            await emit.next(result, execArgs);\n+                                                        }\n+                                                    } catch (e_1_1) {\n+                                                        e_1 = {\n+                                                            error: e_1_1\n+                                                        };\n+                                                    } finally {\n+                                                        try {\n+                                                            if (!_e && !_a && (_b = operationResult_1.return)) await _b.call(operationResult_1);\n+                                                        } finally {\n+                                                            if (e_1) throw e_1.error;\n+                                                        }\n+                                                    }\n+                                                }\n+                                            } else {\n+                                                /** single emitted result */\n+                                                // if the client completed the subscription before the single result\n+                                                // became available, he effectively canceled it and no data should be sent\n+                                                if (id in ctx.subscriptions) await emit.next(operationResult, execArgs);\n+                                            }\n+                                            // lack of subscription at this point indicates that the client\n+                                            // completed the subscription, he doesnt need to be reminded\n+                                            await emit.complete(id in ctx.subscriptions);\n+                                        } finally {\n+                                            // whatever happens to the subscription, we finally want to get rid of the reservation\n+                                            delete ctx.subscriptions[id];\n+                                        }\n+                                        return;\n+                                    }\n+                                    case _common.MessageType.Complete: {\n+                                        const subscription = ctx.subscriptions[message.id];\n+                                        delete ctx.subscriptions[message.id]; // deleting the subscription means no further activity should take place\n+                                        if ((0, _utils.isAsyncGenerator)(subscription)) await subscription.return(undefined);\n+                                        return;\n+                                    }\n+                                    default:\n+                                        throw new Error(`Unexpected message of type ${message.type} received`);\n+                                }\n+                            });\n+                            // wait for close, cleanup and the disconnect callback\n+                            return async (code, reason) => {\n+                                if (connectionInitWait) clearTimeout(connectionInitWait);\n+                                for (const sub of Object.values(ctx.subscriptions)) {\n+                                    if ((0, _utils.isAsyncGenerator)(sub)) await sub.return(undefined);\n+                                }\n+                                if (ctx.acknowledged) await (onDisconnect === null || onDisconnect === void 0 ? void 0 : onDisconnect(ctx, code, reason));\n+                                await (onClose === null || onClose === void 0 ? void 0 : onClose(ctx, code, reason));\n+                            };\n+                        }\n+                    };\n+                }\n+                /**\n+                 * Helper utility for choosing the \"graphql-transport-ws\" subprotocol from\n+                 * a set of WebSocket subprotocols.\n+                 *\n+                 * Accepts a set of already extracted WebSocket subprotocols or the raw\n+                 * Sec-WebSocket-Protocol header value. In either case, if the right\n+                 * protocol appears, it will be returned.\n+                 *\n+                 * By specification, the server should not provide a value with Sec-WebSocket-Protocol\n+                 * if it does not agree with client's subprotocols. The client has a responsibility\n+                 * to handle the connection afterwards.\n+                 *\n+                 * @category Server\n+                 */\n+                function handleProtocols(protocols) {\n+                    switch (true) {\n+                        case protocols instanceof Set && protocols.has(_common.GRAPHQL_TRANSPORT_WS_PROTOCOL):\n+                        case Array.isArray(protocols) && protocols.includes(_common.GRAPHQL_TRANSPORT_WS_PROTOCOL):\n+                        case typeof protocols === 'string' && protocols.split(',').map(p => p.trim()).includes(_common.GRAPHQL_TRANSPORT_WS_PROTOCOL):\n+                            return _common.GRAPHQL_TRANSPORT_WS_PROTOCOL;\n+                        default:\n+                            return false;\n+                    }\n+                }\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/graphql-ws/lib/utils.mjs\":\n+            /*!******************************************************!*\\\n+              !*** ../../../node_modules/graphql-ws/lib/utils.mjs ***!\n+              \\******************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.areGraphQLErrors = areGraphQLErrors;\n+                exports.extendedTypeof = extendedTypeof;\n+                exports.isAsyncGenerator = isAsyncGenerator;\n+                exports.isAsyncIterable = isAsyncIterable;\n+                exports.isObject = isObject;\n+                exports.limitCloseReason = limitCloseReason;\n+                /** @private */\n+                function extendedTypeof(val) {\n+                    if (val === null) {\n+                        return 'null';\n+                    }\n+                    if (Array.isArray(val)) {\n+                        return 'array';\n+                    }\n+                    return typeof val;\n+                }\n+                /** @private */\n+                function isObject(val) {\n+                    return extendedTypeof(val) === 'object';\n+                }\n+                /** @private */\n+                function isAsyncIterable(val) {\n+                    return typeof Object(val)[Symbol.asyncIterator] === 'function';\n+                }\n+                /** @private */\n+                function isAsyncGenerator(val) {\n+                    return isObject(val) && typeof Object(val)[Symbol.asyncIterator] === 'function' && typeof val.return === 'function'\n+                    // for lazy ones, we only need the return anyway\n+                    // typeof val.throw === 'function' &&\n+                    // typeof val.next === 'function'\n+                    ;\n+                }\n+                /** @private */\n+                function areGraphQLErrors(obj) {\n+                    return Array.isArray(obj) &&\n+                        // must be at least one error\n+                        obj.length > 0 &&\n+                        // error has at least a message\n+                        obj.every(ob => 'message' in ob);\n+                }\n+                /**\n+                 * Limits the WebSocket close event reason to not exceed a length of one frame.\n+                 * Reference: https://datatracker.ietf.org/doc/html/rfc6455#section-5.2.\n+                 *\n+                 * @private\n+                 */\n+                function limitCloseReason(reason, whenTooLong) {\n+                    return reason.length < 124 ? reason : whenTooLong;\n+                }\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/graphql/error/GraphQLError.mjs\":\n+            /*!************************************************************!*\\\n+              !*** ../../../node_modules/graphql/error/GraphQLError.mjs ***!\n+              \\************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.GraphQLError = void 0;\n+                exports.formatError = formatError;\n+                exports.printError = printError;\n+                var _isObjectLike = __webpack_require__( /*! ../jsutils/isObjectLike.mjs */ \"../../../node_modules/graphql/jsutils/isObjectLike.mjs\");\n+                var _location = __webpack_require__( /*! ../language/location.mjs */ \"../../../node_modules/graphql/language/location.mjs\");\n+                var _printLocation = __webpack_require__( /*! ../language/printLocation.mjs */ \"../../../node_modules/graphql/language/printLocation.mjs\");\n+\n+                function toNormalizedOptions(args) {\n+                    const firstArg = args[0];\n+                    if (firstArg == null || 'kind' in firstArg || 'length' in firstArg) {\n+                        return {\n+                            nodes: firstArg,\n+                            source: args[1],\n+                            positions: args[2],\n+                            path: args[3],\n+                            originalError: args[4],\n+                            extensions: args[5]\n+                        };\n+                    }\n+                    return firstArg;\n+                }\n+                /**\n+                 * A GraphQLError describes an Error found during the parse, validate, or\n+                 * execute phases of performing a GraphQL operation. In addition to a message\n+                 * and stack trace, it also includes information about the locations in a\n+                 * GraphQL document and/or execution result that correspond to the Error.\n+                 */\n+\n+                class GraphQLError extends Error {\n+                    /**\n+                     * An array of `{ line, column }` locations within the source GraphQL document\n+                     * which correspond to this error.\n+                     *\n+                     * Errors during validation often contain multiple locations, for example to\n+                     * point out two things with the same name. Errors during execution include a\n+                     * single location, the field which produced the error.\n+                     *\n+                     * Enumerable, and appears in the result of JSON.stringify().\n+                     */\n+\n+                    /**\n+                     * An array describing the JSON-path into the execution response which\n+                     * corresponds to this error. Only included for errors during execution.\n+                     *\n+                     * Enumerable, and appears in the result of JSON.stringify().\n+                     */\n+\n+                    /**\n+                     * An array of GraphQL AST Nodes corresponding to this error.\n+                     */\n+\n+                    /**\n+                     * The source GraphQL document for the first location of this error.\n+                     *\n+                     * Note that if this Error represents more than one node, the source may not\n+                     * represent nodes after the first node.\n+                     */\n+\n+                    /**\n+                     * An array of character offsets within the source GraphQL document\n+                     * which correspond to this error.\n+                     */\n+\n+                    /**\n+                     * The original error thrown from a field resolver during execution.\n+                     */\n+\n+                    /**\n+                     * Extension fields to add to the formatted error.\n+                     */\n+\n+                    /**\n+                     * @deprecated Please use the `GraphQLErrorOptions` constructor overload instead.\n+                     */\n+                    constructor(message, ...rawArgs) {\n+                        var _this$nodes, _nodeLocations$, _ref;\n+                        const {\n+                            nodes,\n+                            source,\n+                            positions,\n+                            path,\n+                            originalError,\n+                            extensions\n+                        } = toNormalizedOptions(rawArgs);\n+                        super(message);\n+                        this.name = 'GraphQLError';\n+                        this.path = path !== null && path !== void 0 ? path : undefined;\n+                        this.originalError = originalError !== null && originalError !== void 0 ? originalError : undefined; // Compute list of blame nodes.\n+\n+                        this.nodes = undefinedIfEmpty(Array.isArray(nodes) ? nodes : nodes ? [nodes] : undefined);\n+                        const nodeLocations = undefinedIfEmpty((_this$nodes = this.nodes) === null || _this$nodes === void 0 ? void 0 : _this$nodes.map(node => node.loc).filter(loc => loc != null)); // Compute locations in the source for the given nodes/positions.\n+\n+                        this.source = source !== null && source !== void 0 ? source : nodeLocations === null || nodeLocations === void 0 ? void 0 : (_nodeLocations$ = nodeLocations[0]) === null || _nodeLocations$ === void 0 ? void 0 : _nodeLocations$.source;\n+                        this.positions = positions !== null && positions !== void 0 ? positions : nodeLocations === null || nodeLocations === void 0 ? void 0 : nodeLocations.map(loc => loc.start);\n+                        this.locations = positions && source ? positions.map(pos => (0, _location.getLocation)(source, pos)) : nodeLocations === null || nodeLocations === void 0 ? void 0 : nodeLocations.map(loc => (0, _location.getLocation)(loc.source, loc.start));\n+                        const originalExtensions = (0, _isObjectLike.isObjectLike)(originalError === null || originalError === void 0 ? void 0 : originalError.extensions) ? originalError === null || originalError === void 0 ? void 0 : originalError.extensions : undefined;\n+                        this.extensions = (_ref = extensions !== null && extensions !== void 0 ? extensions : originalExtensions) !== null && _ref !== void 0 ? _ref : Object.create(null); // Only properties prescribed by the spec should be enumerable.\n+                        // Keep the rest as non-enumerable.\n+\n+                        Object.defineProperties(this, {\n+                            message: {\n+                                writable: true,\n+                                enumerable: true\n+                            },\n+                            name: {\n+                                enumerable: false\n+                            },\n+                            nodes: {\n+                                enumerable: false\n+                            },\n+                            source: {\n+                                enumerable: false\n+                            },\n+                            positions: {\n+                                enumerable: false\n+                            },\n+                            originalError: {\n+                                enumerable: false\n+                            }\n+                        }); // Include (non-enumerable) stack trace.\n+\n+                        /* c8 ignore start */\n+                        // FIXME: https://github.com/graphql/graphql-js/issues/2317\n+\n+                        if (originalError !== null && originalError !== void 0 && originalError.stack) {\n+                            Object.defineProperty(this, 'stack', {\n+                                value: originalError.stack,\n+                                writable: true,\n+                                configurable: true\n+                            });\n+                        } else if (Error.captureStackTrace) {\n+                            Error.captureStackTrace(this, GraphQLError);\n+                        } else {\n+                            Object.defineProperty(this, 'stack', {\n+                                value: Error().stack,\n+                                writable: true,\n+                                configurable: true\n+                            });\n+                        }\n+                        /* c8 ignore stop */\n+                    }\n+                    get[Symbol.toStringTag]() {\n+                        return 'GraphQLError';\n+                    }\n+                    toString() {\n+                        let output = this.message;\n+                        if (this.nodes) {\n+                            for (const node of this.nodes) {\n+                                if (node.loc) {\n+                                    output += '\\n\\n' + (0, _printLocation.printLocation)(node.loc);\n+                                }\n+                            }\n+                        } else if (this.source && this.locations) {\n+                            for (const location of this.locations) {\n+                                output += '\\n\\n' + (0, _printLocation.printSourceLocation)(this.source, location);\n+                            }\n+                        }\n+                        return output;\n+                    }\n+                    toJSON() {\n+                        const formattedError = {\n+                            message: this.message\n+                        };\n+                        if (this.locations != null) {\n+                            formattedError.locations = this.locations;\n+                        }\n+                        if (this.path != null) {\n+                            formattedError.path = this.path;\n+                        }\n+                        if (this.extensions != null && Object.keys(this.extensions).length > 0) {\n+                            formattedError.extensions = this.extensions;\n+                        }\n+                        return formattedError;\n+                    }\n+                }\n+                exports.GraphQLError = GraphQLError;\n+\n+                function undefinedIfEmpty(array) {\n+                    return array === undefined || array.length === 0 ? undefined : array;\n+                }\n+                /**\n+                 * See: https://spec.graphql.org/draft/#sec-Errors\n+                 */\n+\n+                /**\n+                 * Prints a GraphQLError to a string, representing useful location information\n+                 * about the error's position in the source.\n+                 *\n+                 * @deprecated Please use `error.toString` instead. Will be removed in v17\n+                 */\n+                function printError(error) {\n+                    return error.toString();\n+                }\n+                /**\n+                 * Given a GraphQLError, format it according to the rules described by the\n+                 * Response Format, Errors section of the GraphQL Specification.\n+                 *\n+                 * @deprecated Please use `error.toJSON` instead. Will be removed in v17\n+                 */\n+\n+                function formatError(error) {\n+                    return error.toJSON();\n+                }\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/graphql/error/index.mjs\":\n+            /*!*****************************************************!*\\\n+              !*** ../../../node_modules/graphql/error/index.mjs ***!\n+              \\*****************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                Object.defineProperty(exports, \"GraphQLError\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _GraphQLError.GraphQLError;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"formatError\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _GraphQLError.formatError;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"locatedError\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _locatedError.locatedError;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"printError\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _GraphQLError.printError;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"syntaxError\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _syntaxError.syntaxError;\n+                    }\n+                }));\n+                var _GraphQLError = __webpack_require__( /*! ./GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n+                var _syntaxError = __webpack_require__( /*! ./syntaxError.mjs */ \"../../../node_modules/graphql/error/syntaxError.mjs\");\n+                var _locatedError = __webpack_require__( /*! ./locatedError.mjs */ \"../../../node_modules/graphql/error/locatedError.mjs\");\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/graphql/error/locatedError.mjs\":\n+            /*!************************************************************!*\\\n+              !*** ../../../node_modules/graphql/error/locatedError.mjs ***!\n+              \\************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.locatedError = locatedError;\n+                var _toError = __webpack_require__( /*! ../jsutils/toError.mjs */ \"../../../node_modules/graphql/jsutils/toError.mjs\");\n+                var _GraphQLError = __webpack_require__( /*! ./GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n+                /**\n+                 * Given an arbitrary value, presumably thrown while attempting to execute a\n+                 * GraphQL operation, produce a new GraphQLError aware of the location in the\n+                 * document responsible for the original Error.\n+                 */\n+\n+                function locatedError(rawOriginalError, nodes, path) {\n+                    var _nodes;\n+                    const originalError = (0, _toError.toError)(rawOriginalError); // Note: this uses a brand-check to support GraphQL errors originating from other contexts.\n+\n+                    if (isLocatedGraphQLError(originalError)) {\n+                        return originalError;\n+                    }\n+                    return new _GraphQLError.GraphQLError(originalError.message, {\n+                        nodes: (_nodes = originalError.nodes) !== null && _nodes !== void 0 ? _nodes : nodes,\n+                        source: originalError.source,\n+                        positions: originalError.positions,\n+                        path,\n+                        originalError\n+                    });\n+                }\n+\n+                function isLocatedGraphQLError(error) {\n+                    return Array.isArray(error.path);\n+                }\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/graphql/error/syntaxError.mjs\":\n+            /*!***********************************************************!*\\\n+              !*** ../../../node_modules/graphql/error/syntaxError.mjs ***!\n+              \\***********************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.syntaxError = syntaxError;\n+                var _GraphQLError = __webpack_require__( /*! ./GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n+                /**\n+                 * Produces a GraphQLError representing a syntax error, containing useful\n+                 * descriptive information about the syntax error's position in the source.\n+                 */\n+\n+                function syntaxError(source, position, description) {\n+                    return new _GraphQLError.GraphQLError(`Syntax Error: ${description}`, {\n+                        source,\n+                        positions: [position]\n+                    });\n+                }\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/graphql/execution/collectFields.mjs\":\n+            /*!*****************************************************************!*\\\n+              !*** ../../../node_modules/graphql/execution/collectFields.mjs ***!\n+              \\*****************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.collectFields = collectFields;\n+                exports.collectSubfields = collectSubfields;\n+                var _kinds = __webpack_require__( /*! ../language/kinds.mjs */ \"../../../node_modules/graphql/language/kinds.mjs\");\n+                var _definition = __webpack_require__( /*! ../type/definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n+                var _directives = __webpack_require__( /*! ../type/directives.mjs */ \"../../../node_modules/graphql/type/directives.mjs\");\n+                var _typeFromAST = __webpack_require__( /*! ../utilities/typeFromAST.mjs */ \"../../../node_modules/graphql/utilities/typeFromAST.mjs\");\n+                var _values = __webpack_require__( /*! ./values.mjs */ \"../../../node_modules/graphql/execution/values.mjs\");\n+                /**\n+                 * Given a selectionSet, collects all of the fields and returns them.\n+                 *\n+                 * CollectFields requires the \"runtime type\" of an object. For a field that\n+                 * returns an Interface or Union type, the \"runtime type\" will be the actual\n+                 * object type returned by that field.\n+                 *\n+                 * @internal\n+                 */\n+\n+                function collectFields(schema, fragments, variableValues, runtimeType, selectionSet) {\n+                    const fields = new Map();\n+                    collectFieldsImpl(schema, fragments, variableValues, runtimeType, selectionSet, fields, new Set());\n+                    return fields;\n+                }\n+                /**\n+                 * Given an array of field nodes, collects all of the subfields of the passed\n+                 * in fields, and returns them at the end.\n+                 *\n+                 * CollectSubFields requires the \"return type\" of an object. For a field that\n+                 * returns an Interface or Union type, the \"return type\" will be the actual\n+                 * object type returned by that field.\n+                 *\n+                 * @internal\n+                 */\n+\n+                function collectSubfields(schema, fragments, variableValues, returnType, fieldNodes) {\n+                    const subFieldNodes = new Map();\n+                    const visitedFragmentNames = new Set();\n+                    for (const node of fieldNodes) {\n+                        if (node.selectionSet) {\n+                            collectFieldsImpl(schema, fragments, variableValues, returnType, node.selectionSet, subFieldNodes, visitedFragmentNames);\n+                        }\n+                    }\n+                    return subFieldNodes;\n+                }\n+\n+                function collectFieldsImpl(schema, fragments, variableValues, runtimeType, selectionSet, fields, visitedFragmentNames) {\n+                    for (const selection of selectionSet.selections) {\n+                        switch (selection.kind) {\n+                            case _kinds.Kind.FIELD: {\n+                                if (!shouldIncludeNode(variableValues, selection)) {\n+                                    continue;\n+                                }\n+                                const name = getFieldEntryKey(selection);\n+                                const fieldList = fields.get(name);\n+                                if (fieldList !== undefined) {\n+                                    fieldList.push(selection);\n+                                } else {\n+                                    fields.set(name, [selection]);\n+                                }\n+                                break;\n+                            }\n+                            case _kinds.Kind.INLINE_FRAGMENT: {\n+                                if (!shouldIncludeNode(variableValues, selection) || !doesFragmentConditionMatch(schema, selection, runtimeType)) {\n+                                    continue;\n+                                }\n+                                collectFieldsImpl(schema, fragments, variableValues, runtimeType, selection.selectionSet, fields, visitedFragmentNames);\n+                                break;\n+                            }\n+                            case _kinds.Kind.FRAGMENT_SPREAD: {\n+                                const fragName = selection.name.value;\n+                                if (visitedFragmentNames.has(fragName) || !shouldIncludeNode(variableValues, selection)) {\n+                                    continue;\n+                                }\n+                                visitedFragmentNames.add(fragName);\n+                                const fragment = fragments[fragName];\n+                                if (!fragment || !doesFragmentConditionMatch(schema, fragment, runtimeType)) {\n+                                    continue;\n+                                }\n+                                collectFieldsImpl(schema, fragments, variableValues, runtimeType, fragment.selectionSet, fields, visitedFragmentNames);\n+                                break;\n+                            }\n+                        }\n+                    }\n+                }\n+                /**\n+                 * Determines if a field should be included based on the `@include` and `@skip`\n+                 * directives, where `@skip` has higher precedence than `@include`.\n+                 */\n+\n+                function shouldIncludeNode(variableValues, node) {\n+                    const skip = (0, _values.getDirectiveValues)(_directives.GraphQLSkipDirective, node, variableValues);\n+                    if ((skip === null || skip === void 0 ? void 0 : skip.if) === true) {\n+                        return false;\n+                    }\n+                    const include = (0, _values.getDirectiveValues)(_directives.GraphQLIncludeDirective, node, variableValues);\n+                    if ((include === null || include === void 0 ? void 0 : include.if) === false) {\n+                        return false;\n+                    }\n+                    return true;\n+                }\n+                /**\n+                 * Determines if a fragment is applicable to the given type.\n+                 */\n+\n+                function doesFragmentConditionMatch(schema, fragment, type) {\n+                    const typeConditionNode = fragment.typeCondition;\n+                    if (!typeConditionNode) {\n+                        return true;\n+                    }\n+                    const conditionalType = (0, _typeFromAST.typeFromAST)(schema, typeConditionNode);\n+                    if (conditionalType === type) {\n+                        return true;\n+                    }\n+                    if ((0, _definition.isAbstractType)(conditionalType)) {\n+                        return schema.isSubType(conditionalType, type);\n+                    }\n+                    return false;\n+                }\n+                /**\n+                 * Implements the logic to compute the key of a given field's entry\n+                 */\n+\n+                function getFieldEntryKey(node) {\n+                    return node.alias ? node.alias.value : node.name.value;\n+                }\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/graphql/execution/execute.mjs\":\n+            /*!***********************************************************!*\\\n+              !*** ../../../node_modules/graphql/execution/execute.mjs ***!\n+              \\***********************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.assertValidExecutionArguments = assertValidExecutionArguments;\n+                exports.buildExecutionContext = buildExecutionContext;\n+                exports.buildResolveInfo = buildResolveInfo;\n+                exports.defaultTypeResolver = exports.defaultFieldResolver = void 0;\n+                exports.execute = execute;\n+                exports.executeSync = executeSync;\n+                exports.getFieldDef = getFieldDef;\n+                var _devAssert = __webpack_require__( /*! ../jsutils/devAssert.mjs */ \"../../../node_modules/graphql/jsutils/devAssert.mjs\");\n+                var _inspect = __webpack_require__( /*! ../jsutils/inspect.mjs */ \"../../../node_modules/graphql/jsutils/inspect.mjs\");\n+                var _invariant = __webpack_require__( /*! ../jsutils/invariant.mjs */ \"../../../node_modules/graphql/jsutils/invariant.mjs\");\n+                var _isIterableObject = __webpack_require__( /*! ../jsutils/isIterableObject.mjs */ \"../../../node_modules/graphql/jsutils/isIterableObject.mjs\");\n+                var _isObjectLike = __webpack_require__( /*! ../jsutils/isObjectLike.mjs */ \"../../../node_modules/graphql/jsutils/isObjectLike.mjs\");\n+                var _isPromise = __webpack_require__( /*! ../jsutils/isPromise.mjs */ \"../../../node_modules/graphql/jsutils/isPromise.mjs\");\n+                var _memoize = __webpack_require__( /*! ../jsutils/memoize3.mjs */ \"../../../node_modules/graphql/jsutils/memoize3.mjs\");\n+                var _Path = __webpack_require__( /*! ../jsutils/Path.mjs */ \"../../../node_modules/graphql/jsutils/Path.mjs\");\n+                var _promiseForObject = __webpack_require__( /*! ../jsutils/promiseForObject.mjs */ \"../../../node_modules/graphql/jsutils/promiseForObject.mjs\");\n+                var _promiseReduce = __webpack_require__( /*! ../jsutils/promiseReduce.mjs */ \"../../../node_modules/graphql/jsutils/promiseReduce.mjs\");\n+                var _GraphQLError = __webpack_require__( /*! ../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n+                var _locatedError = __webpack_require__( /*! ../error/locatedError.mjs */ \"../../../node_modules/graphql/error/locatedError.mjs\");\n+                var _ast = __webpack_require__( /*! ../language/ast.mjs */ \"../../../node_modules/graphql/language/ast.mjs\");\n+                var _kinds = __webpack_require__( /*! ../language/kinds.mjs */ \"../../../node_modules/graphql/language/kinds.mjs\");\n+                var _definition = __webpack_require__( /*! ../type/definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n+                var _introspection = __webpack_require__( /*! ../type/introspection.mjs */ \"../../../node_modules/graphql/type/introspection.mjs\");\n+                var _validate = __webpack_require__( /*! ../type/validate.mjs */ \"../../../node_modules/graphql/type/validate.mjs\");\n+                var _collectFields = __webpack_require__( /*! ./collectFields.mjs */ \"../../../node_modules/graphql/execution/collectFields.mjs\");\n+                var _values = __webpack_require__( /*! ./values.mjs */ \"../../../node_modules/graphql/execution/values.mjs\");\n+                /**\n+                 * A memoized collection of relevant subfields with regard to the return\n+                 * type. Memoizing ensures the subfields are not repeatedly calculated, which\n+                 * saves overhead when resolving lists of values.\n+                 */\n+\n+                const collectSubfields = (0, _memoize.memoize3)((exeContext, returnType, fieldNodes) => (0, _collectFields.collectSubfields)(exeContext.schema, exeContext.fragments, exeContext.variableValues, returnType, fieldNodes));\n+                /**\n+                 * Terminology\n+                 *\n+                 * \"Definitions\" are the generic name for top-level statements in the document.\n+                 * Examples of this include:\n+                 * 1) Operations (such as a query)\n+                 * 2) Fragments\n+                 *\n+                 * \"Operations\" are a generic name for requests in the document.\n+                 * Examples of this include:\n+                 * 1) query,\n+                 * 2) mutation\n+                 *\n+                 * \"Selections\" are the definitions that can appear legally and at\n+                 * single level of the query. These include:\n+                 * 1) field references e.g `a`\n+                 * 2) fragment \"spreads\" e.g. `...c`\n+                 * 3) inline fragment \"spreads\" e.g. `...on Type { a }`\n+                 */\n+\n+                /**\n+                 * Data that must be available at all points during query execution.\n+                 *\n+                 * Namely, schema of the type system that is currently executing,\n+                 * and the fragments defined in the query document\n+                 */\n+\n+                /**\n+                 * Implements the \"Executing requests\" section of the GraphQL specification.\n+                 *\n+                 * Returns either a synchronous ExecutionResult (if all encountered resolvers\n+                 * are synchronous), or a Promise of an ExecutionResult that will eventually be\n+                 * resolved and never rejected.\n+                 *\n+                 * If the arguments to this function do not result in a legal execution context,\n+                 * a GraphQLError will be thrown immediately explaining the invalid input.\n+                 */\n+                function execute(args) {\n+                    // Temporary for v15 to v16 migration. Remove in v17\n+                    arguments.length < 2 || (0, _devAssert.devAssert)(false, 'graphql@16 dropped long-deprecated support for positional arguments, please pass an object instead.');\n+                    const {\n+                        schema,\n+                        document,\n+                        variableValues,\n+                        rootValue\n+                    } = args; // If arguments are missing or incorrect, throw an error.\n+\n+                    assertValidExecutionArguments(schema, document, variableValues); // If a valid execution context cannot be created due to incorrect arguments,\n+                    // a \"Response\" with only errors is returned.\n+\n+                    const exeContext = buildExecutionContext(args); // Return early errors if execution context failed.\n+\n+                    if (!('schema' in exeContext)) {\n+                        return {\n+                            errors: exeContext\n+                        };\n+                    } // Return a Promise that will eventually resolve to the data described by\n+                    // The \"Response\" section of the GraphQL specification.\n+                    //\n+                    // If errors are encountered while executing a GraphQL field, only that\n+                    // field and its descendants will be omitted, and sibling fields will still\n+                    // be executed. An execution which encounters errors will still result in a\n+                    // resolved Promise.\n+                    //\n+                    // Errors from sub-fields of a NonNull type may propagate to the top level,\n+                    // at which point we still log the error and null the parent field, which\n+                    // in this case is the entire response.\n+\n+                    try {\n+                        const {\n+                            operation\n+                        } = exeContext;\n+                        const result = executeOperation(exeContext, operation, rootValue);\n+                        if ((0, _isPromise.isPromise)(result)) {\n+                            return result.then(data => buildResponse(data, exeContext.errors), error => {\n+                                exeContext.errors.push(error);\n+                                return buildResponse(null, exeContext.errors);\n+                            });\n+                        }\n+                        return buildResponse(result, exeContext.errors);\n+                    } catch (error) {\n+                        exeContext.errors.push(error);\n+                        return buildResponse(null, exeContext.errors);\n+                    }\n+                }\n+                /**\n+                 * Also implements the \"Executing requests\" section of the GraphQL specification.\n+                 * However, it guarantees to complete synchronously (or throw an error) assuming\n+                 * that all field resolvers are also synchronous.\n+                 */\n+\n+                function executeSync(args) {\n+                    const result = execute(args); // Assert that the execution was synchronous.\n+\n+                    if ((0, _isPromise.isPromise)(result)) {\n+                        throw new Error('GraphQL execution failed to complete synchronously.');\n+                    }\n+                    return result;\n+                }\n+                /**\n+                 * Given a completed execution context and data, build the `{ errors, data }`\n+                 * response defined by the \"Response\" section of the GraphQL specification.\n+                 */\n+\n+                function buildResponse(data, errors) {\n+                    return errors.length === 0 ? {\n+                        data\n+                    } : {\n+                        errors,\n+                        data\n+                    };\n+                }\n+                /**\n+                 * Essential assertions before executing to provide developer feedback for\n+                 * improper use of the GraphQL library.\n+                 *\n+                 * @internal\n+                 */\n+\n+                function assertValidExecutionArguments(schema, document, rawVariableValues) {\n+                    document || (0, _devAssert.devAssert)(false, 'Must provide document.'); // If the schema used for execution is invalid, throw an error.\n+\n+                    (0, _validate.assertValidSchema)(schema); // Variables, if provided, must be an object.\n+\n+                    rawVariableValues == null || (0, _isObjectLike.isObjectLike)(rawVariableValues) || (0, _devAssert.devAssert)(false, 'Variables must be provided as an Object where each property is a variable value. Perhaps look to see if an unparsed JSON string was provided.');\n+                }\n+                /**\n+                 * Constructs a ExecutionContext object from the arguments passed to\n+                 * execute, which we will pass throughout the other execution methods.\n+                 *\n+                 * Throws a GraphQLError if a valid execution context cannot be created.\n+                 *\n+                 * @internal\n+                 */\n+\n+                function buildExecutionContext(args) {\n+                    var _definition$name, _operation$variableDe;\n+                    const {\n+                        schema,\n+                        document,\n+                        rootValue,\n+                        contextValue,\n+                        variableValues: rawVariableValues,\n+                        operationName,\n+                        fieldResolver,\n+                        typeResolver,\n+                        subscribeFieldResolver\n+                    } = args;\n+                    let operation;\n+                    const fragments = Object.create(null);\n+                    for (const definition of document.definitions) {\n+                        switch (definition.kind) {\n+                            case _kinds.Kind.OPERATION_DEFINITION:\n+                                if (operationName == null) {\n+                                    if (operation !== undefined) {\n+                                        return [new _GraphQLError.GraphQLError('Must provide operation name if query contains multiple operations.')];\n+                                    }\n+                                    operation = definition;\n+                                } else if (((_definition$name = definition.name) === null || _definition$name === void 0 ? void 0 : _definition$name.value) === operationName) {\n+                                    operation = definition;\n+                                }\n+                                break;\n+                            case _kinds.Kind.FRAGMENT_DEFINITION:\n+                                fragments[definition.name.value] = definition;\n+                                break;\n+                            default: // ignore non-executable definitions\n+                        }\n+                    }\n+                    if (!operation) {\n+                        if (operationName != null) {\n+                            return [new _GraphQLError.GraphQLError(`Unknown operation named \"${operationName}\".`)];\n+                        }\n+                        return [new _GraphQLError.GraphQLError('Must provide an operation.')];\n+                    } // FIXME: https://github.com/graphql/graphql-js/issues/2203\n+\n+                    /* c8 ignore next */\n+\n+                    const variableDefinitions = (_operation$variableDe = operation.variableDefinitions) !== null && _operation$variableDe !== void 0 ? _operation$variableDe : [];\n+                    const coercedVariableValues = (0, _values.getVariableValues)(schema, variableDefinitions, rawVariableValues !== null && rawVariableValues !== void 0 ? rawVariableValues : {}, {\n+                        maxErrors: 50\n+                    });\n+                    if (coercedVariableValues.errors) {\n+                        return coercedVariableValues.errors;\n+                    }\n+                    return {\n+                        schema,\n+                        fragments,\n+                        rootValue,\n+                        contextValue,\n+                        operation,\n+                        variableValues: coercedVariableValues.coerced,\n+                        fieldResolver: fieldResolver !== null && fieldResolver !== void 0 ? fieldResolver : defaultFieldResolver,\n+                        typeResolver: typeResolver !== null && typeResolver !== void 0 ? typeResolver : defaultTypeResolver,\n+                        subscribeFieldResolver: subscribeFieldResolver !== null && subscribeFieldResolver !== void 0 ? subscribeFieldResolver : defaultFieldResolver,\n+                        errors: []\n+                    };\n+                }\n+                /**\n+                 * Implements the \"Executing operations\" section of the spec.\n+                 */\n+\n+                function executeOperation(exeContext, operation, rootValue) {\n+                    const rootType = exeContext.schema.getRootType(operation.operation);\n+                    if (rootType == null) {\n+                        throw new _GraphQLError.GraphQLError(`Schema is not configured to execute ${operation.operation} operation.`, {\n+                            nodes: operation\n+                        });\n+                    }\n+                    const rootFields = (0, _collectFields.collectFields)(exeContext.schema, exeContext.fragments, exeContext.variableValues, rootType, operation.selectionSet);\n+                    const path = undefined;\n+                    switch (operation.operation) {\n+                        case _ast.OperationTypeNode.QUERY:\n+                            return executeFields(exeContext, rootType, rootValue, path, rootFields);\n+                        case _ast.OperationTypeNode.MUTATION:\n+                            return executeFieldsSerially(exeContext, rootType, rootValue, path, rootFields);\n+                        case _ast.OperationTypeNode.SUBSCRIPTION:\n+                            // TODO: deprecate `subscribe` and move all logic here\n+                            // Temporary solution until we finish merging execute and subscribe together\n+                            return executeFields(exeContext, rootType, rootValue, path, rootFields);\n+                    }\n+                }\n+                /**\n+                 * Implements the \"Executing selection sets\" section of the spec\n+                 * for fields that must be executed serially.\n+                 */\n+\n+                function executeFieldsSerially(exeContext, parentType, sourceValue, path, fields) {\n+                    return (0, _promiseReduce.promiseReduce)(fields.entries(), (results, [responseName, fieldNodes]) => {\n+                        const fieldPath = (0, _Path.addPath)(path, responseName, parentType.name);\n+                        const result = executeField(exeContext, parentType, sourceValue, fieldNodes, fieldPath);\n+                        if (result === undefined) {\n+                            return results;\n+                        }\n+                        if ((0, _isPromise.isPromise)(result)) {\n+                            return result.then(resolvedResult => {\n+                                results[responseName] = resolvedResult;\n+                                return results;\n+                            });\n+                        }\n+                        results[responseName] = result;\n+                        return results;\n+                    }, Object.create(null));\n+                }\n+                /**\n+                 * Implements the \"Executing selection sets\" section of the spec\n+                 * for fields that may be executed in parallel.\n+                 */\n+\n+                function executeFields(exeContext, parentType, sourceValue, path, fields) {\n+                    const results = Object.create(null);\n+                    let containsPromise = false;\n+                    try {\n+                        for (const [responseName, fieldNodes] of fields.entries()) {\n+                            const fieldPath = (0, _Path.addPath)(path, responseName, parentType.name);\n+                            const result = executeField(exeContext, parentType, sourceValue, fieldNodes, fieldPath);\n+                            if (result !== undefined) {\n+                                results[responseName] = result;\n+                                if ((0, _isPromise.isPromise)(result)) {\n+                                    containsPromise = true;\n+                                }\n+                            }\n+                        }\n+                    } catch (error) {\n+                        if (containsPromise) {\n+                            // Ensure that any promises returned by other fields are handled, as they may also reject.\n+                            return (0, _promiseForObject.promiseForObject)(results).finally(() => {\n+                                throw error;\n+                            });\n+                        }\n+                        throw error;\n+                    } // If there are no promises, we can just return the object\n+\n+                    if (!containsPromise) {\n+                        return results;\n+                    } // Otherwise, results is a map from field name to the result of resolving that\n+                    // field, which is possibly a promise. Return a promise that will return this\n+                    // same map, but with any promises replaced with the values they resolved to.\n+\n+                    return (0, _promiseForObject.promiseForObject)(results);\n+                }\n+                /**\n+                 * Implements the \"Executing fields\" section of the spec\n+                 * In particular, this function figures out the value that the field returns by\n+                 * calling its resolve function, then calls completeValue to complete promises,\n+                 * serialize scalars, or execute the sub-selection-set for objects.\n+                 */\n+\n+                function executeField(exeContext, parentType, source, fieldNodes, path) {\n+                    var _fieldDef$resolve;\n+                    const fieldDef = getFieldDef(exeContext.schema, parentType, fieldNodes[0]);\n+                    if (!fieldDef) {\n+                        return;\n+                    }\n+                    const returnType = fieldDef.type;\n+                    const resolveFn = (_fieldDef$resolve = fieldDef.resolve) !== null && _fieldDef$resolve !== void 0 ? _fieldDef$resolve : exeContext.fieldResolver;\n+                    const info = buildResolveInfo(exeContext, fieldDef, fieldNodes, parentType, path); // Get the resolve function, regardless of if its result is normal or abrupt (error).\n+\n+                    try {\n+                        // Build a JS object of arguments from the field.arguments AST, using the\n+                        // variables scope to fulfill any variable references.\n+                        // TODO: find a way to memoize, in case this field is within a List type.\n+                        const args = (0, _values.getArgumentValues)(fieldDef, fieldNodes[0], exeContext.variableValues); // The resolve function's optional third argument is a context value that\n+                        // is provided to every resolve function within an execution. It is commonly\n+                        // used to represent an authenticated user, or request-specific caches.\n+\n+                        const contextValue = exeContext.contextValue;\n+                        const result = resolveFn(source, args, contextValue, info);\n+                        let completed;\n+                        if ((0, _isPromise.isPromise)(result)) {\n+                            completed = result.then(resolved => completeValue(exeContext, returnType, fieldNodes, info, path, resolved));\n+                        } else {\n+                            completed = completeValue(exeContext, returnType, fieldNodes, info, path, result);\n+                        }\n+                        if ((0, _isPromise.isPromise)(completed)) {\n+                            // Note: we don't rely on a `catch` method, but we do expect \"thenable\"\n+                            // to take a second callback for the error case.\n+                            return completed.then(undefined, rawError => {\n+                                const error = (0, _locatedError.locatedError)(rawError, fieldNodes, (0, _Path.pathToArray)(path));\n+                                return handleFieldError(error, returnType, exeContext);\n+                            });\n+                        }\n+                        return completed;\n+                    } catch (rawError) {\n+                        const error = (0, _locatedError.locatedError)(rawError, fieldNodes, (0, _Path.pathToArray)(path));\n+                        return handleFieldError(error, returnType, exeContext);\n+                    }\n+                }\n+                /**\n+                 * @internal\n+                 */\n+\n+                function buildResolveInfo(exeContext, fieldDef, fieldNodes, parentType, path) {\n+                    // The resolve function's optional fourth argument is a collection of\n+                    // information about the current execution state.\n+                    return {\n+                        fieldName: fieldDef.name,\n+                        fieldNodes,\n+                        returnType: fieldDef.type,\n+                        parentType,\n+                        path,\n+                        schema: exeContext.schema,\n+                        fragments: exeContext.fragments,\n+                        rootValue: exeContext.rootValue,\n+                        operation: exeContext.operation,\n+                        variableValues: exeContext.variableValues\n+                    };\n+                }\n+\n+                function handleFieldError(error, returnType, exeContext) {\n+                    // If the field type is non-nullable, then it is resolved without any\n+                    // protection from errors, however it still properly locates the error.\n+                    if ((0, _definition.isNonNullType)(returnType)) {\n+                        throw error;\n+                    } // Otherwise, error protection is applied, logging the error and resolving\n+                    // a null value for this field if one is encountered.\n+\n+                    exeContext.errors.push(error);\n+                    return null;\n+                }\n+                /**\n+                 * Implements the instructions for completeValue as defined in the\n+                 * \"Value Completion\" section of the spec.\n+                 *\n+                 * If the field type is Non-Null, then this recursively completes the value\n+                 * for the inner type. It throws a field error if that completion returns null,\n+                 * as per the \"Nullability\" section of the spec.\n+                 *\n+                 * If the field type is a List, then this recursively completes the value\n+                 * for the inner type on each item in the list.\n+                 *\n+                 * If the field type is a Scalar or Enum, ensures the completed value is a legal\n+                 * value of the type by calling the `serialize` method of GraphQL type\n+                 * definition.\n+                 *\n+                 * If the field is an abstract type, determine the runtime type of the value\n+                 * and then complete based on that type\n+                 *\n+                 * Otherwise, the field type expects a sub-selection set, and will complete the\n+                 * value by executing all sub-selections.\n+                 */\n+\n+                function completeValue(exeContext, returnType, fieldNodes, info, path, result) {\n+                    // If result is an Error, throw a located error.\n+                    if (result instanceof Error) {\n+                        throw result;\n+                    } // If field type is NonNull, complete for inner type, and throw field error\n+                    // if result is null.\n+\n+                    if ((0, _definition.isNonNullType)(returnType)) {\n+                        const completed = completeValue(exeContext, returnType.ofType, fieldNodes, info, path, result);\n+                        if (completed === null) {\n+                            throw new Error(`Cannot return null for non-nullable field ${info.parentType.name}.${info.fieldName}.`);\n+                        }\n+                        return completed;\n+                    } // If result value is null or undefined then return null.\n+\n+                    if (result == null) {\n+                        return null;\n+                    } // If field type is List, complete each item in the list with the inner type\n+\n+                    if ((0, _definition.isListType)(returnType)) {\n+                        return completeListValue(exeContext, returnType, fieldNodes, info, path, result);\n+                    } // If field type is a leaf type, Scalar or Enum, serialize to a valid value,\n+                    // returning null if serialization is not possible.\n+\n+                    if ((0, _definition.isLeafType)(returnType)) {\n+                        return completeLeafValue(returnType, result);\n+                    } // If field type is an abstract type, Interface or Union, determine the\n+                    // runtime Object type and complete for that type.\n+\n+                    if ((0, _definition.isAbstractType)(returnType)) {\n+                        return completeAbstractValue(exeContext, returnType, fieldNodes, info, path, result);\n+                    } // If field type is Object, execute and complete all sub-selections.\n+\n+                    if ((0, _definition.isObjectType)(returnType)) {\n+                        return completeObjectValue(exeContext, returnType, fieldNodes, info, path, result);\n+                    }\n+                    /* c8 ignore next 6 */\n+                    // Not reachable, all possible output types have been considered.\n+\n+                    false || (0, _invariant.invariant)(false, 'Cannot complete value of unexpected output type: ' + (0, _inspect.inspect)(returnType));\n+                }\n+                /**\n+                 * Complete a list value by completing each item in the list with the\n+                 * inner type\n+                 */\n+\n+                function completeListValue(exeContext, returnType, fieldNodes, info, path, result) {\n+                    if (!(0, _isIterableObject.isIterableObject)(result)) {\n+                        throw new _GraphQLError.GraphQLError(`Expected Iterable, but did not find one for field \"${info.parentType.name}.${info.fieldName}\".`);\n+                    } // This is specified as a simple map, however we're optimizing the path\n+                    // where the list contains no Promises by avoiding creating another Promise.\n+\n+                    const itemType = returnType.ofType;\n+                    let containsPromise = false;\n+                    const completedResults = Array.from(result, (item, index) => {\n+                        // No need to modify the info object containing the path,\n+                        // since from here on it is not ever accessed by resolver functions.\n+                        const itemPath = (0, _Path.addPath)(path, index, undefined);\n+                        try {\n+                            let completedItem;\n+                            if ((0, _isPromise.isPromise)(item)) {\n+                                completedItem = item.then(resolved => completeValue(exeContext, itemType, fieldNodes, info, itemPath, resolved));\n+                            } else {\n+                                completedItem = completeValue(exeContext, itemType, fieldNodes, info, itemPath, item);\n+                            }\n+                            if ((0, _isPromise.isPromise)(completedItem)) {\n+                                containsPromise = true; // Note: we don't rely on a `catch` method, but we do expect \"thenable\"\n+                                // to take a second callback for the error case.\n+\n+                                return completedItem.then(undefined, rawError => {\n+                                    const error = (0, _locatedError.locatedError)(rawError, fieldNodes, (0, _Path.pathToArray)(itemPath));\n+                                    return handleFieldError(error, itemType, exeContext);\n+                                });\n+                            }\n+                            return completedItem;\n+                        } catch (rawError) {\n+                            const error = (0, _locatedError.locatedError)(rawError, fieldNodes, (0, _Path.pathToArray)(itemPath));\n+                            return handleFieldError(error, itemType, exeContext);\n+                        }\n+                    });\n+                    return containsPromise ? Promise.all(completedResults) : completedResults;\n+                }\n+                /**\n+                 * Complete a Scalar or Enum by serializing to a valid value, returning\n+                 * null if serialization is not possible.\n+                 */\n+\n+                function completeLeafValue(returnType, result) {\n+                    const serializedResult = returnType.serialize(result);\n+                    if (serializedResult == null) {\n+                        throw new Error(`Expected \\`${(0, _inspect.inspect)(returnType)}.serialize(${(0, _inspect.inspect)(result)})\\` to ` + `return non-nullable value, returned: ${(0, _inspect.inspect)(serializedResult)}`);\n+                    }\n+                    return serializedResult;\n+                }\n+                /**\n+                 * Complete a value of an abstract type by determining the runtime object type\n+                 * of that value, then complete the value for that type.\n+                 */\n+\n+                function completeAbstractValue(exeContext, returnType, fieldNodes, info, path, result) {\n+                    var _returnType$resolveTy;\n+                    const resolveTypeFn = (_returnType$resolveTy = returnType.resolveType) !== null && _returnType$resolveTy !== void 0 ? _returnType$resolveTy : exeContext.typeResolver;\n+                    const contextValue = exeContext.contextValue;\n+                    const runtimeType = resolveTypeFn(result, contextValue, info, returnType);\n+                    if ((0, _isPromise.isPromise)(runtimeType)) {\n+                        return runtimeType.then(resolvedRuntimeType => completeObjectValue(exeContext, ensureValidRuntimeType(resolvedRuntimeType, exeContext, returnType, fieldNodes, info, result), fieldNodes, info, path, result));\n+                    }\n+                    return completeObjectValue(exeContext, ensureValidRuntimeType(runtimeType, exeContext, returnType, fieldNodes, info, result), fieldNodes, info, path, result);\n+                }\n+\n+                function ensureValidRuntimeType(runtimeTypeName, exeContext, returnType, fieldNodes, info, result) {\n+                    if (runtimeTypeName == null) {\n+                        throw new _GraphQLError.GraphQLError(`Abstract type \"${returnType.name}\" must resolve to an Object type at runtime for field \"${info.parentType.name}.${info.fieldName}\". Either the \"${returnType.name}\" type should provide a \"resolveType\" function or each possible type should provide an \"isTypeOf\" function.`, fieldNodes);\n+                    } // releases before 16.0.0 supported returning `GraphQLObjectType` from `resolveType`\n+                    // TODO: remove in 17.0.0 release\n+\n+                    if ((0, _definition.isObjectType)(runtimeTypeName)) {\n+                        throw new _GraphQLError.GraphQLError('Support for returning GraphQLObjectType from resolveType was removed in graphql-js@16.0.0 please return type name instead.');\n+                    }\n+                    if (typeof runtimeTypeName !== 'string') {\n+                        throw new _GraphQLError.GraphQLError(`Abstract type \"${returnType.name}\" must resolve to an Object type at runtime for field \"${info.parentType.name}.${info.fieldName}\" with ` + `value ${(0, _inspect.inspect)(result)}, received \"${(0, _inspect.inspect)(runtimeTypeName)}\".`);\n+                    }\n+                    const runtimeType = exeContext.schema.getType(runtimeTypeName);\n+                    if (runtimeType == null) {\n+                        throw new _GraphQLError.GraphQLError(`Abstract type \"${returnType.name}\" was resolved to a type \"${runtimeTypeName}\" that does not exist inside the schema.`, {\n+                            nodes: fieldNodes\n+                        });\n+                    }\n+                    if (!(0, _definition.isObjectType)(runtimeType)) {\n+                        throw new _GraphQLError.GraphQLError(`Abstract type \"${returnType.name}\" was resolved to a non-object type \"${runtimeTypeName}\".`, {\n+                            nodes: fieldNodes\n+                        });\n+                    }\n+                    if (!exeContext.schema.isSubType(returnType, runtimeType)) {\n+                        throw new _GraphQLError.GraphQLError(`Runtime Object type \"${runtimeType.name}\" is not a possible type for \"${returnType.name}\".`, {\n+                            nodes: fieldNodes\n+                        });\n+                    }\n+                    return runtimeType;\n+                }\n+                /**\n+                 * Complete an Object value by executing all sub-selections.\n+                 */\n+\n+                function completeObjectValue(exeContext, returnType, fieldNodes, info, path, result) {\n+                    // Collect sub-fields to execute to complete this value.\n+                    const subFieldNodes = collectSubfields(exeContext, returnType, fieldNodes); // If there is an isTypeOf predicate function, call it with the\n+                    // current result. If isTypeOf returns false, then raise an error rather\n+                    // than continuing execution.\n+\n+                    if (returnType.isTypeOf) {\n+                        const isTypeOf = returnType.isTypeOf(result, exeContext.contextValue, info);\n+                        if ((0, _isPromise.isPromise)(isTypeOf)) {\n+                            return isTypeOf.then(resolvedIsTypeOf => {\n+                                if (!resolvedIsTypeOf) {\n+                                    throw invalidReturnTypeError(returnType, result, fieldNodes);\n+                                }\n+                                return executeFields(exeContext, returnType, result, path, subFieldNodes);\n+                            });\n+                        }\n+                        if (!isTypeOf) {\n+                            throw invalidReturnTypeError(returnType, result, fieldNodes);\n+                        }\n+                    }\n+                    return executeFields(exeContext, returnType, result, path, subFieldNodes);\n+                }\n+\n+                function invalidReturnTypeError(returnType, result, fieldNodes) {\n+                    return new _GraphQLError.GraphQLError(`Expected value of type \"${returnType.name}\" but got: ${(0, _inspect.inspect)(result)}.`, {\n+                        nodes: fieldNodes\n+                    });\n+                }\n+                /**\n+                 * If a resolveType function is not given, then a default resolve behavior is\n+                 * used which attempts two strategies:\n+                 *\n+                 * First, See if the provided value has a `__typename` field defined, if so, use\n+                 * that value as name of the resolved type.\n+                 *\n+                 * Otherwise, test each possible type for the abstract type by calling\n+                 * isTypeOf for the object being coerced, returning the first type that matches.\n+                 */\n+\n+                const defaultTypeResolver = function(value, contextValue, info, abstractType) {\n+                    // First, look for `__typename`.\n+                    if ((0, _isObjectLike.isObjectLike)(value) && typeof value.__typename === 'string') {\n+                        return value.__typename;\n+                    } // Otherwise, test each possible type.\n+\n+                    const possibleTypes = info.schema.getPossibleTypes(abstractType);\n+                    const promisedIsTypeOfResults = [];\n+                    for (let i = 0; i < possibleTypes.length; i++) {\n+                        const type = possibleTypes[i];\n+                        if (type.isTypeOf) {\n+                            const isTypeOfResult = type.isTypeOf(value, contextValue, info);\n+                            if ((0, _isPromise.isPromise)(isTypeOfResult)) {\n+                                promisedIsTypeOfResults[i] = isTypeOfResult;\n+                            } else if (isTypeOfResult) {\n+                                return type.name;\n+                            }\n+                        }\n+                    }\n+                    if (promisedIsTypeOfResults.length) {\n+                        return Promise.all(promisedIsTypeOfResults).then(isTypeOfResults => {\n+                            for (let i = 0; i < isTypeOfResults.length; i++) {\n+                                if (isTypeOfResults[i]) {\n+                                    return possibleTypes[i].name;\n+                                }\n+                            }\n+                        });\n+                    }\n+                };\n+                /**\n+                 * If a resolve function is not given, then a default resolve behavior is used\n+                 * which takes the property of the source object of the same name as the field\n+                 * and returns it as the result, or if it's a function, returns the result\n+                 * of calling that function while passing along args and context value.\n+                 */\n+                exports.defaultTypeResolver = defaultTypeResolver;\n+                const defaultFieldResolver = function(source, args, contextValue, info) {\n+                    // ensure source is a value for which property access is acceptable.\n+                    if ((0, _isObjectLike.isObjectLike)(source) || typeof source === 'function') {\n+                        const property = source[info.fieldName];\n+                        if (typeof property === 'function') {\n+                            return source[info.fieldName](args, contextValue, info);\n+                        }\n+                        return property;\n+                    }\n+                };\n+                /**\n+                 * This method looks up the field on the given type definition.\n+                 * It has special casing for the three introspection fields,\n+                 * __schema, __type and __typename. __typename is special because\n+                 * it can always be queried as a field, even in situations where no\n+                 * other fields are allowed, like on a Union. __schema and __type\n+                 * could get automatically added to the query type, but that would\n+                 * require mutating type definitions, which would cause issues.\n+                 *\n+                 * @internal\n+                 */\n+                exports.defaultFieldResolver = defaultFieldResolver;\n+\n+                function getFieldDef(schema, parentType, fieldNode) {\n+                    const fieldName = fieldNode.name.value;\n+                    if (fieldName === _introspection.SchemaMetaFieldDef.name && schema.getQueryType() === parentType) {\n+                        return _introspection.SchemaMetaFieldDef;\n+                    } else if (fieldName === _introspection.TypeMetaFieldDef.name && schema.getQueryType() === parentType) {\n+                        return _introspection.TypeMetaFieldDef;\n+                    } else if (fieldName === _introspection.TypeNameMetaFieldDef.name) {\n+                        return _introspection.TypeNameMetaFieldDef;\n+                    }\n+                    return parentType.getFields()[fieldName];\n+                }\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/graphql/execution/index.mjs\":\n+            /*!*********************************************************!*\\\n+              !*** ../../../node_modules/graphql/execution/index.mjs ***!\n+              \\*********************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                Object.defineProperty(exports, \"createSourceEventStream\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _subscribe.createSourceEventStream;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"defaultFieldResolver\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _execute.defaultFieldResolver;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"defaultTypeResolver\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _execute.defaultTypeResolver;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"execute\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _execute.execute;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"executeSync\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _execute.executeSync;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"getArgumentValues\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _values.getArgumentValues;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"getDirectiveValues\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _values.getDirectiveValues;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"getVariableValues\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _values.getVariableValues;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"responsePathAsArray\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _Path.pathToArray;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"subscribe\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _subscribe.subscribe;\n+                    }\n+                }));\n+                var _Path = __webpack_require__( /*! ../jsutils/Path.mjs */ \"../../../node_modules/graphql/jsutils/Path.mjs\");\n+                var _execute = __webpack_require__( /*! ./execute.mjs */ \"../../../node_modules/graphql/execution/execute.mjs\");\n+                var _subscribe = __webpack_require__( /*! ./subscribe.mjs */ \"../../../node_modules/graphql/execution/subscribe.mjs\");\n+                var _values = __webpack_require__( /*! ./values.mjs */ \"../../../node_modules/graphql/execution/values.mjs\");\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/graphql/execution/mapAsyncIterator.mjs\":\n+            /*!********************************************************************!*\\\n+              !*** ../../../node_modules/graphql/execution/mapAsyncIterator.mjs ***!\n+              \\********************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.mapAsyncIterator = mapAsyncIterator;\n+                /**\n+                 * Given an AsyncIterable and a callback function, return an AsyncIterator\n+                 * which produces values mapped via calling the callback function.\n+                 */\n+                function mapAsyncIterator(iterable, callback) {\n+                    const iterator = iterable[Symbol.asyncIterator]();\n+                    async function mapResult(result) {\n+                        if (result.done) {\n+                            return result;\n+                        }\n+                        try {\n+                            return {\n+                                value: await callback(result.value),\n+                                done: false\n+                            };\n+                        } catch (error) {\n+                            /* c8 ignore start */\n+                            // FIXME: add test case\n+                            if (typeof iterator.return === 'function') {\n+                                try {\n+                                    await iterator.return();\n+                                } catch (_e) {\n+                                    /* ignore error */\n+                                }\n+                            }\n+                            throw error;\n+                            /* c8 ignore stop */\n+                        }\n+                    }\n+                    return {\n+                        async next() {\n+                            return mapResult(await iterator.next());\n+                        },\n+                        async return () {\n+                            // If iterator.return() does not exist, then type R must be undefined.\n+                            return typeof iterator.return === 'function' ? mapResult(await iterator.return()) : {\n+                                value: undefined,\n+                                done: true\n+                            };\n+                        },\n+                        async throw (error) {\n+                            if (typeof iterator.throw === 'function') {\n+                                return mapResult(await iterator.throw(error));\n+                            }\n+                            throw error;\n+                        },\n+                        [Symbol.asyncIterator]() {\n+                            return this;\n+                        }\n+                    };\n+                }\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/graphql/execution/subscribe.mjs\":\n+            /*!*************************************************************!*\\\n+              !*** ../../../node_modules/graphql/execution/subscribe.mjs ***!\n+              \\*************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.createSourceEventStream = createSourceEventStream;\n+                exports.subscribe = subscribe;\n+                var _devAssert = __webpack_require__( /*! ../jsutils/devAssert.mjs */ \"../../../node_modules/graphql/jsutils/devAssert.mjs\");\n+                var _inspect = __webpack_require__( /*! ../jsutils/inspect.mjs */ \"../../../node_modules/graphql/jsutils/inspect.mjs\");\n+                var _isAsyncIterable = __webpack_require__( /*! ../jsutils/isAsyncIterable.mjs */ \"../../../node_modules/graphql/jsutils/isAsyncIterable.mjs\");\n+                var _Path = __webpack_require__( /*! ../jsutils/Path.mjs */ \"../../../node_modules/graphql/jsutils/Path.mjs\");\n+                var _GraphQLError = __webpack_require__( /*! ../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n+                var _locatedError = __webpack_require__( /*! ../error/locatedError.mjs */ \"../../../node_modules/graphql/error/locatedError.mjs\");\n+                var _collectFields = __webpack_require__( /*! ./collectFields.mjs */ \"../../../node_modules/graphql/execution/collectFields.mjs\");\n+                var _execute = __webpack_require__( /*! ./execute.mjs */ \"../../../node_modules/graphql/execution/execute.mjs\");\n+                var _mapAsyncIterator = __webpack_require__( /*! ./mapAsyncIterator.mjs */ \"../../../node_modules/graphql/execution/mapAsyncIterator.mjs\");\n+                var _values = __webpack_require__( /*! ./values.mjs */ \"../../../node_modules/graphql/execution/values.mjs\");\n+                /**\n+                 * Implements the \"Subscribe\" algorithm described in the GraphQL specification.\n+                 *\n+                 * Returns a Promise which resolves to either an AsyncIterator (if successful)\n+                 * or an ExecutionResult (error). The promise will be rejected if the schema or\n+                 * other arguments to this function are invalid, or if the resolved event stream\n+                 * is not an async iterable.\n+                 *\n+                 * If the client-provided arguments to this function do not result in a\n+                 * compliant subscription, a GraphQL Response (ExecutionResult) with\n+                 * descriptive errors and no data will be returned.\n+                 *\n+                 * If the source stream could not be created due to faulty subscription\n+                 * resolver logic or underlying systems, the promise will resolve to a single\n+                 * ExecutionResult containing `errors` and no `data`.\n+                 *\n+                 * If the operation succeeded, the promise resolves to an AsyncIterator, which\n+                 * yields a stream of ExecutionResults representing the response stream.\n+                 *\n+                 * Accepts either an object with named arguments, or individual arguments.\n+                 */\n+\n+                async function subscribe(args) {\n+                    // Temporary for v15 to v16 migration. Remove in v17\n+                    arguments.length < 2 || (0, _devAssert.devAssert)(false, 'graphql@16 dropped long-deprecated support for positional arguments, please pass an object instead.');\n+                    const resultOrStream = await createSourceEventStream(args);\n+                    if (!(0, _isAsyncIterable.isAsyncIterable)(resultOrStream)) {\n+                        return resultOrStream;\n+                    } // For each payload yielded from a subscription, map it over the normal\n+                    // GraphQL `execute` function, with `payload` as the rootValue.\n+                    // This implements the \"MapSourceToResponseEvent\" algorithm described in\n+                    // the GraphQL specification. The `execute` function provides the\n+                    // \"ExecuteSubscriptionEvent\" algorithm, as it is nearly identical to the\n+                    // \"ExecuteQuery\" algorithm, for which `execute` is also used.\n+\n+                    const mapSourceToResponse = payload => (0, _execute.execute)({\n+                        ...args,\n+                        rootValue: payload\n+                    }); // Map every source value to a ExecutionResult value as described above.\n+\n+                    return (0, _mapAsyncIterator.mapAsyncIterator)(resultOrStream, mapSourceToResponse);\n+                }\n+\n+                function toNormalizedArgs(args) {\n+                    const firstArg = args[0];\n+                    if (firstArg && 'document' in firstArg) {\n+                        return firstArg;\n+                    }\n+                    return {\n+                        schema: firstArg,\n+                        // FIXME: when underlying TS bug fixed, see https://github.com/microsoft/TypeScript/issues/31613\n+                        document: args[1],\n+                        rootValue: args[2],\n+                        contextValue: args[3],\n+                        variableValues: args[4],\n+                        operationName: args[5],\n+                        subscribeFieldResolver: args[6]\n+                    };\n+                }\n+                /**\n+                 * Implements the \"CreateSourceEventStream\" algorithm described in the\n+                 * GraphQL specification, resolving the subscription source event stream.\n+                 *\n+                 * Returns a Promise which resolves to either an AsyncIterable (if successful)\n+                 * or an ExecutionResult (error). The promise will be rejected if the schema or\n+                 * other arguments to this function are invalid, or if the resolved event stream\n+                 * is not an async iterable.\n+                 *\n+                 * If the client-provided arguments to this function do not result in a\n+                 * compliant subscription, a GraphQL Response (ExecutionResult) with\n+                 * descriptive errors and no data will be returned.\n+                 *\n+                 * If the the source stream could not be created due to faulty subscription\n+                 * resolver logic or underlying systems, the promise will resolve to a single\n+                 * ExecutionResult containing `errors` and no `data`.\n+                 *\n+                 * If the operation succeeded, the promise resolves to the AsyncIterable for the\n+                 * event stream returned by the resolver.\n+                 *\n+                 * A Source Event Stream represents a sequence of events, each of which triggers\n+                 * a GraphQL execution for that event.\n+                 *\n+                 * This may be useful when hosting the stateful subscription service in a\n+                 * different process or machine than the stateless GraphQL execution engine,\n+                 * or otherwise separating these two steps. For more on this, see the\n+                 * \"Supporting Subscriptions at Scale\" information in the GraphQL specification.\n+                 */\n+\n+                async function createSourceEventStream(...rawArgs) {\n+                    const args = toNormalizedArgs(rawArgs);\n+                    const {\n+                        schema,\n+                        document,\n+                        variableValues\n+                    } = args; // If arguments are missing or incorrectly typed, this is an internal\n+                    // developer mistake which should throw an early error.\n+\n+                    (0, _execute.assertValidExecutionArguments)(schema, document, variableValues); // If a valid execution context cannot be created due to incorrect arguments,\n+                    // a \"Response\" with only errors is returned.\n+\n+                    const exeContext = (0, _execute.buildExecutionContext)(args); // Return early errors if execution context failed.\n+\n+                    if (!('schema' in exeContext)) {\n+                        return {\n+                            errors: exeContext\n+                        };\n+                    }\n+                    try {\n+                        const eventStream = await executeSubscription(exeContext); // Assert field returned an event stream, otherwise yield an error.\n+\n+                        if (!(0, _isAsyncIterable.isAsyncIterable)(eventStream)) {\n+                            throw new Error('Subscription field must return Async Iterable. ' + `Received: ${(0, _inspect.inspect)(eventStream)}.`);\n+                        }\n+                        return eventStream;\n+                    } catch (error) {\n+                        // If it GraphQLError, report it as an ExecutionResult, containing only errors and no data.\n+                        // Otherwise treat the error as a system-class error and re-throw it.\n+                        if (error instanceof _GraphQLError.GraphQLError) {\n+                            return {\n+                                errors: [error]\n+                            };\n+                        }\n+                        throw error;\n+                    }\n+                }\n+                async function executeSubscription(exeContext) {\n+                    const {\n+                        schema,\n+                        fragments,\n+                        operation,\n+                        variableValues,\n+                        rootValue\n+                    } = exeContext;\n+                    const rootType = schema.getSubscriptionType();\n+                    if (rootType == null) {\n+                        throw new _GraphQLError.GraphQLError('Schema is not configured to execute subscription operation.', {\n+                            nodes: operation\n+                        });\n+                    }\n+                    const rootFields = (0, _collectFields.collectFields)(schema, fragments, variableValues, rootType, operation.selectionSet);\n+                    const [responseName, fieldNodes] = [...rootFields.entries()][0];\n+                    const fieldDef = (0, _execute.getFieldDef)(schema, rootType, fieldNodes[0]);\n+                    if (!fieldDef) {\n+                        const fieldName = fieldNodes[0].name.value;\n+                        throw new _GraphQLError.GraphQLError(`The subscription field \"${fieldName}\" is not defined.`, {\n+                            nodes: fieldNodes\n+                        });\n+                    }\n+                    const path = (0, _Path.addPath)(undefined, responseName, rootType.name);\n+                    const info = (0, _execute.buildResolveInfo)(exeContext, fieldDef, fieldNodes, rootType, path);\n+                    try {\n+                        var _fieldDef$subscribe;\n+\n+                        // Implements the \"ResolveFieldEventStream\" algorithm from GraphQL specification.\n+                        // It differs from \"ResolveFieldValue\" due to providing a different `resolveFn`.\n+                        // Build a JS object of arguments from the field.arguments AST, using the\n+                        // variables scope to fulfill any variable references.\n+                        const args = (0, _values.getArgumentValues)(fieldDef, fieldNodes[0], variableValues); // The resolve function's optional third argument is a context value that\n+                        // is provided to every resolve function within an execution. It is commonly\n+                        // used to represent an authenticated user, or request-specific caches.\n+\n+                        const contextValue = exeContext.contextValue; // Call the `subscribe()` resolver or the default resolver to produce an\n+                        // AsyncIterable yielding raw payloads.\n+\n+                        const resolveFn = (_fieldDef$subscribe = fieldDef.subscribe) !== null && _fieldDef$subscribe !== void 0 ? _fieldDef$subscribe : exeContext.subscribeFieldResolver;\n+                        const eventStream = await resolveFn(rootValue, args, contextValue, info);\n+                        if (eventStream instanceof Error) {\n+                            throw eventStream;\n+                        }\n+                        return eventStream;\n+                    } catch (error) {\n+                        throw (0, _locatedError.locatedError)(error, fieldNodes, (0, _Path.pathToArray)(path));\n+                    }\n+                }\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/graphql/execution/values.mjs\":\n+            /*!**********************************************************!*\\\n+              !*** ../../../node_modules/graphql/execution/values.mjs ***!\n+              \\**********************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.getArgumentValues = getArgumentValues;\n+                exports.getDirectiveValues = getDirectiveValues;\n+                exports.getVariableValues = getVariableValues;\n+                var _inspect = __webpack_require__( /*! ../jsutils/inspect.mjs */ \"../../../node_modules/graphql/jsutils/inspect.mjs\");\n+                var _keyMap = __webpack_require__( /*! ../jsutils/keyMap.mjs */ \"../../../node_modules/graphql/jsutils/keyMap.mjs\");\n+                var _printPathArray = __webpack_require__( /*! ../jsutils/printPathArray.mjs */ \"../../../node_modules/graphql/jsutils/printPathArray.mjs\");\n+                var _GraphQLError = __webpack_require__( /*! ../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n+                var _kinds = __webpack_require__( /*! ../language/kinds.mjs */ \"../../../node_modules/graphql/language/kinds.mjs\");\n+                var _printer = __webpack_require__( /*! ../language/printer.mjs */ \"../../../node_modules/graphql/language/printer.mjs\");\n+                var _definition = __webpack_require__( /*! ../type/definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n+                var _coerceInputValue = __webpack_require__( /*! ../utilities/coerceInputValue.mjs */ \"../../../node_modules/graphql/utilities/coerceInputValue.mjs\");\n+                var _typeFromAST = __webpack_require__( /*! ../utilities/typeFromAST.mjs */ \"../../../node_modules/graphql/utilities/typeFromAST.mjs\");\n+                var _valueFromAST = __webpack_require__( /*! ../utilities/valueFromAST.mjs */ \"../../../node_modules/graphql/utilities/valueFromAST.mjs\");\n+                /**\n+                 * Prepares an object map of variableValues of the correct type based on the\n+                 * provided variable definitions and arbitrary input. If the input cannot be\n+                 * parsed to match the variable definitions, a GraphQLError will be thrown.\n+                 *\n+                 * Note: The returned value is a plain Object with a prototype, since it is\n+                 * exposed to user code. Care should be taken to not pull values from the\n+                 * Object prototype.\n+                 */\n+                function getVariableValues(schema, varDefNodes, inputs, options) {\n+                    const errors = [];\n+                    const maxErrors = options === null || options === void 0 ? void 0 : options.maxErrors;\n+                    try {\n+                        const coerced = coerceVariableValues(schema, varDefNodes, inputs, error => {\n+                            if (maxErrors != null && errors.length >= maxErrors) {\n+                                throw new _GraphQLError.GraphQLError('Too many errors processing variables, error limit reached. Execution aborted.');\n+                            }\n+                            errors.push(error);\n+                        });\n+                        if (errors.length === 0) {\n+                            return {\n+                                coerced\n+                            };\n+                        }\n+                    } catch (error) {\n+                        errors.push(error);\n+                    }\n+                    return {\n+                        errors\n+                    };\n+                }\n+\n+                function coerceVariableValues(schema, varDefNodes, inputs, onError) {\n+                    const coercedValues = {};\n+                    for (const varDefNode of varDefNodes) {\n+                        const varName = varDefNode.variable.name.value;\n+                        const varType = (0, _typeFromAST.typeFromAST)(schema, varDefNode.type);\n+                        if (!(0, _definition.isInputType)(varType)) {\n+                            // Must use input types for variables. This should be caught during\n+                            // validation, however is checked again here for safety.\n+                            const varTypeStr = (0, _printer.print)(varDefNode.type);\n+                            onError(new _GraphQLError.GraphQLError(`Variable \"$${varName}\" expected value of type \"${varTypeStr}\" which cannot be used as an input type.`, {\n+                                nodes: varDefNode.type\n+                            }));\n+                            continue;\n+                        }\n+                        if (!hasOwnProperty(inputs, varName)) {\n+                            if (varDefNode.defaultValue) {\n+                                coercedValues[varName] = (0, _valueFromAST.valueFromAST)(varDefNode.defaultValue, varType);\n+                            } else if ((0, _definition.isNonNullType)(varType)) {\n+                                const varTypeStr = (0, _inspect.inspect)(varType);\n+                                onError(new _GraphQLError.GraphQLError(`Variable \"$${varName}\" of required type \"${varTypeStr}\" was not provided.`, {\n+                                    nodes: varDefNode\n+                                }));\n+                            }\n+                            continue;\n+                        }\n+                        const value = inputs[varName];\n+                        if (value === null && (0, _definition.isNonNullType)(varType)) {\n+                            const varTypeStr = (0, _inspect.inspect)(varType);\n+                            onError(new _GraphQLError.GraphQLError(`Variable \"$${varName}\" of non-null type \"${varTypeStr}\" must not be null.`, {\n+                                nodes: varDefNode\n+                            }));\n+                            continue;\n+                        }\n+                        coercedValues[varName] = (0, _coerceInputValue.coerceInputValue)(value, varType, (path, invalidValue, error) => {\n+                            let prefix = `Variable \"$${varName}\" got invalid value ` + (0, _inspect.inspect)(invalidValue);\n+                            if (path.length > 0) {\n+                                prefix += ` at \"${varName}${(0, _printPathArray.printPathArray)(path)}\"`;\n+                            }\n+                            onError(new _GraphQLError.GraphQLError(prefix + '; ' + error.message, {\n+                                nodes: varDefNode,\n+                                originalError: error\n+                            }));\n+                        });\n+                    }\n+                    return coercedValues;\n+                }\n+                /**\n+                 * Prepares an object map of argument values given a list of argument\n+                 * definitions and list of argument AST nodes.\n+                 *\n+                 * Note: The returned value is a plain Object with a prototype, since it is\n+                 * exposed to user code. Care should be taken to not pull values from the\n+                 * Object prototype.\n+                 */\n+\n+                function getArgumentValues(def, node, variableValues) {\n+                    var _node$arguments;\n+                    const coercedValues = {}; // FIXME: https://github.com/graphql/graphql-js/issues/2203\n+\n+                    /* c8 ignore next */\n+\n+                    const argumentNodes = (_node$arguments = node.arguments) !== null && _node$arguments !== void 0 ? _node$arguments : [];\n+                    const argNodeMap = (0, _keyMap.keyMap)(argumentNodes, arg => arg.name.value);\n+                    for (const argDef of def.args) {\n+                        const name = argDef.name;\n+                        const argType = argDef.type;\n+                        const argumentNode = argNodeMap[name];\n+                        if (!argumentNode) {\n+                            if (argDef.defaultValue !== undefined) {\n+                                coercedValues[name] = argDef.defaultValue;\n+                            } else if ((0, _definition.isNonNullType)(argType)) {\n+                                throw new _GraphQLError.GraphQLError(`Argument \"${name}\" of required type \"${(0, _inspect.inspect)(argType)}\" ` + 'was not provided.', {\n+                                    nodes: node\n+                                });\n+                            }\n+                            continue;\n+                        }\n+                        const valueNode = argumentNode.value;\n+                        let isNull = valueNode.kind === _kinds.Kind.NULL;\n+                        if (valueNode.kind === _kinds.Kind.VARIABLE) {\n+                            const variableName = valueNode.name.value;\n+                            if (variableValues == null || !hasOwnProperty(variableValues, variableName)) {\n+                                if (argDef.defaultValue !== undefined) {\n+                                    coercedValues[name] = argDef.defaultValue;\n+                                } else if ((0, _definition.isNonNullType)(argType)) {\n+                                    throw new _GraphQLError.GraphQLError(`Argument \"${name}\" of required type \"${(0, _inspect.inspect)(argType)}\" ` + `was provided the variable \"$${variableName}\" which was not provided a runtime value.`, {\n+                                        nodes: valueNode\n+                                    });\n+                                }\n+                                continue;\n+                            }\n+                            isNull = variableValues[variableName] == null;\n+                        }\n+                        if (isNull && (0, _definition.isNonNullType)(argType)) {\n+                            throw new _GraphQLError.GraphQLError(`Argument \"${name}\" of non-null type \"${(0, _inspect.inspect)(argType)}\" ` + 'must not be null.', {\n+                                nodes: valueNode\n+                            });\n+                        }\n+                        const coercedValue = (0, _valueFromAST.valueFromAST)(valueNode, argType, variableValues);\n+                        if (coercedValue === undefined) {\n+                            // Note: ValuesOfCorrectTypeRule validation should catch this before\n+                            // execution. This is a runtime check to ensure execution does not\n+                            // continue with an invalid argument value.\n+                            throw new _GraphQLError.GraphQLError(`Argument \"${name}\" has invalid value ${(0, _printer.print)(valueNode)}.`, {\n+                                nodes: valueNode\n+                            });\n+                        }\n+                        coercedValues[name] = coercedValue;\n+                    }\n+                    return coercedValues;\n+                }\n+                /**\n+                 * Prepares an object map of argument values given a directive definition\n+                 * and a AST node which may contain directives. Optionally also accepts a map\n+                 * of variable values.\n+                 *\n+                 * If the directive does not exist on the node, returns undefined.\n+                 *\n+                 * Note: The returned value is a plain Object with a prototype, since it is\n+                 * exposed to user code. Care should be taken to not pull values from the\n+                 * Object prototype.\n+                 */\n+\n+                function getDirectiveValues(directiveDef, node, variableValues) {\n+                    var _node$directives;\n+                    const directiveNode = (_node$directives = node.directives) === null || _node$directives === void 0 ? void 0 : _node$directives.find(directive => directive.name.value === directiveDef.name);\n+                    if (directiveNode) {\n+                        return getArgumentValues(directiveDef, directiveNode, variableValues);\n+                    }\n+                }\n+\n+                function hasOwnProperty(obj, prop) {\n+                    return Object.prototype.hasOwnProperty.call(obj, prop);\n+                }\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/graphql/graphql.mjs\":\n+            /*!*************************************************!*\\\n+              !*** ../../../node_modules/graphql/graphql.mjs ***!\n+              \\*************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.graphql = graphql;\n+                exports.graphqlSync = graphqlSync;\n+                var _devAssert = __webpack_require__( /*! ./jsutils/devAssert.mjs */ \"../../../node_modules/graphql/jsutils/devAssert.mjs\");\n+                var _isPromise = __webpack_require__( /*! ./jsutils/isPromise.mjs */ \"../../../node_modules/graphql/jsutils/isPromise.mjs\");\n+                var _parser = __webpack_require__( /*! ./language/parser.mjs */ \"../../../node_modules/graphql/language/parser.mjs\");\n+                var _validate = __webpack_require__( /*! ./type/validate.mjs */ \"../../../node_modules/graphql/type/validate.mjs\");\n+                var _validate2 = __webpack_require__( /*! ./validation/validate.mjs */ \"../../../node_modules/graphql/validation/validate.mjs\");\n+                var _execute = __webpack_require__( /*! ./execution/execute.mjs */ \"../../../node_modules/graphql/execution/execute.mjs\");\n+                /**\n+                 * This is the primary entry point function for fulfilling GraphQL operations\n+                 * by parsing, validating, and executing a GraphQL document along side a\n+                 * GraphQL schema.\n+                 *\n+                 * More sophisticated GraphQL servers, such as those which persist queries,\n+                 * may wish to separate the validation and execution phases to a static time\n+                 * tooling step, and a server runtime step.\n+                 *\n+                 * Accepts either an object with named arguments, or individual arguments:\n+                 *\n+                 * schema:\n+                 *    The GraphQL type system to use when validating and executing a query.\n+                 * source:\n+                 *    A GraphQL language formatted string representing the requested operation.\n+                 * rootValue:\n+                 *    The value provided as the first argument to resolver functions on the top\n+                 *    level type (e.g. the query object type).\n+                 * contextValue:\n+                 *    The context value is provided as an argument to resolver functions after\n+                 *    field arguments. It is used to pass shared information useful at any point\n+                 *    during executing this query, for example the currently logged in user and\n+                 *    connections to databases or other services.\n+                 * variableValues:\n+                 *    A mapping of variable name to runtime value to use for all variables\n+                 *    defined in the requestString.\n+                 * operationName:\n+                 *    The name of the operation to use if requestString contains multiple\n+                 *    possible operations. Can be omitted if requestString contains only\n+                 *    one operation.\n+                 * fieldResolver:\n+                 *    A resolver function to use when one is not provided by the schema.\n+                 *    If not provided, the default field resolver is used (which looks for a\n+                 *    value or method on the source value with the field's name).\n+                 * typeResolver:\n+                 *    A type resolver function to use when none is provided by the schema.\n+                 *    If not provided, the default type resolver is used (which looks for a\n+                 *    `__typename` field or alternatively calls the `isTypeOf` method).\n+                 */\n+\n+                function graphql(args) {\n+                    // Always return a Promise for a consistent API.\n+                    return new Promise(resolve => resolve(graphqlImpl(args)));\n+                }\n+                /**\n+                 * The graphqlSync function also fulfills GraphQL operations by parsing,\n+                 * validating, and executing a GraphQL document along side a GraphQL schema.\n+                 * However, it guarantees to complete synchronously (or throw an error) assuming\n+                 * that all field resolvers are also synchronous.\n+                 */\n+\n+                function graphqlSync(args) {\n+                    const result = graphqlImpl(args); // Assert that the execution was synchronous.\n+\n+                    if ((0, _isPromise.isPromise)(result)) {\n+                        throw new Error('GraphQL execution failed to complete synchronously.');\n+                    }\n+                    return result;\n+                }\n+\n+                function graphqlImpl(args) {\n+                    // Temporary for v15 to v16 migration. Remove in v17\n+                    arguments.length < 2 || (0, _devAssert.devAssert)(false, 'graphql@16 dropped long-deprecated support for positional arguments, please pass an object instead.');\n+                    const {\n+                        schema,\n+                        source,\n+                        rootValue,\n+                        contextValue,\n+                        variableValues,\n+                        operationName,\n+                        fieldResolver,\n+                        typeResolver\n+                    } = args; // Validate Schema\n+\n+                    const schemaValidationErrors = (0, _validate.validateSchema)(schema);\n+                    if (schemaValidationErrors.length > 0) {\n+                        return {\n+                            errors: schemaValidationErrors\n+                        };\n+                    } // Parse\n+\n+                    let document;\n+                    try {\n+                        document = (0, _parser.parse)(source);\n+                    } catch (syntaxError) {\n+                        return {\n+                            errors: [syntaxError]\n+                        };\n+                    } // Validate\n+\n+                    const validationErrors = (0, _validate2.validate)(schema, document);\n+                    if (validationErrors.length > 0) {\n+                        return {\n+                            errors: validationErrors\n+                        };\n+                    } // Execute\n+\n+                    return (0, _execute.execute)({\n+                        schema,\n+                        document,\n+                        rootValue,\n+                        contextValue,\n+                        variableValues,\n+                        operationName,\n+                        fieldResolver,\n+                        typeResolver\n+                    });\n+                }\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/graphql/index.mjs\":\n+            /*!***********************************************!*\\\n+              !*** ../../../node_modules/graphql/index.mjs ***!\n+              \\***********************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                Object.defineProperty(exports, \"BREAK\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index2.BREAK;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"BreakingChangeType\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index6.BreakingChangeType;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"DEFAULT_DEPRECATION_REASON\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.DEFAULT_DEPRECATION_REASON;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"DangerousChangeType\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index6.DangerousChangeType;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"DirectiveLocation\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index2.DirectiveLocation;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"ExecutableDefinitionsRule\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index4.ExecutableDefinitionsRule;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"FieldsOnCorrectTypeRule\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index4.FieldsOnCorrectTypeRule;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"FragmentsOnCompositeTypesRule\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index4.FragmentsOnCompositeTypesRule;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"GRAPHQL_MAX_INT\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.GRAPHQL_MAX_INT;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"GRAPHQL_MIN_INT\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.GRAPHQL_MIN_INT;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"GraphQLBoolean\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.GraphQLBoolean;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"GraphQLDeprecatedDirective\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.GraphQLDeprecatedDirective;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"GraphQLDirective\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.GraphQLDirective;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"GraphQLEnumType\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.GraphQLEnumType;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"GraphQLError\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index5.GraphQLError;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"GraphQLFloat\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.GraphQLFloat;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"GraphQLID\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.GraphQLID;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"GraphQLIncludeDirective\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.GraphQLIncludeDirective;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"GraphQLInputObjectType\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.GraphQLInputObjectType;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"GraphQLInt\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.GraphQLInt;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"GraphQLInterfaceType\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.GraphQLInterfaceType;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"GraphQLList\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.GraphQLList;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"GraphQLNonNull\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.GraphQLNonNull;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"GraphQLObjectType\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.GraphQLObjectType;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"GraphQLOneOfDirective\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.GraphQLOneOfDirective;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"GraphQLScalarType\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.GraphQLScalarType;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"GraphQLSchema\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.GraphQLSchema;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"GraphQLSkipDirective\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.GraphQLSkipDirective;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"GraphQLSpecifiedByDirective\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.GraphQLSpecifiedByDirective;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"GraphQLString\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.GraphQLString;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"GraphQLUnionType\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.GraphQLUnionType;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"Kind\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index2.Kind;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"KnownArgumentNamesRule\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index4.KnownArgumentNamesRule;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"KnownDirectivesRule\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index4.KnownDirectivesRule;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"KnownFragmentNamesRule\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index4.KnownFragmentNamesRule;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"KnownTypeNamesRule\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index4.KnownTypeNamesRule;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"Lexer\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index2.Lexer;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"Location\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index2.Location;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"LoneAnonymousOperationRule\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index4.LoneAnonymousOperationRule;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"LoneSchemaDefinitionRule\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index4.LoneSchemaDefinitionRule;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"MaxIntrospectionDepthRule\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index4.MaxIntrospectionDepthRule;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"NoDeprecatedCustomRule\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index4.NoDeprecatedCustomRule;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"NoFragmentCyclesRule\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index4.NoFragmentCyclesRule;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"NoSchemaIntrospectionCustomRule\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index4.NoSchemaIntrospectionCustomRule;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"NoUndefinedVariablesRule\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index4.NoUndefinedVariablesRule;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"NoUnusedFragmentsRule\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index4.NoUnusedFragmentsRule;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"NoUnusedVariablesRule\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index4.NoUnusedVariablesRule;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"OperationTypeNode\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index2.OperationTypeNode;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"OverlappingFieldsCanBeMergedRule\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index4.OverlappingFieldsCanBeMergedRule;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"PossibleFragmentSpreadsRule\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index4.PossibleFragmentSpreadsRule;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"PossibleTypeExtensionsRule\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index4.PossibleTypeExtensionsRule;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"ProvidedRequiredArgumentsRule\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index4.ProvidedRequiredArgumentsRule;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"ScalarLeafsRule\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index4.ScalarLeafsRule;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"SchemaMetaFieldDef\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index.SchemaMetaFieldDef;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"SingleFieldSubscriptionsRule\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index4.SingleFieldSubscriptionsRule;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"Source\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index2.Source;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"Token\", ({\n                     enumerable: true,\n                     get: function() {\n                         return _index2.Token;\n                     }\n                 }));\n                 Object.defineProperty(exports, \"TokenKind\", ({\n                     enumerable: true,\n@@ -28148,14 +46238,20 @@\n                 }));\n                 Object.defineProperty(exports, \"printType\", ({\n                     enumerable: true,\n                     get: function() {\n                         return _index6.printType;\n                     }\n                 }));\n+                Object.defineProperty(exports, \"recommendedRules\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _index4.recommendedRules;\n+                    }\n+                }));\n                 Object.defineProperty(exports, \"resolveObjMapThunk\", ({\n                     enumerable: true,\n                     get: function() {\n                         return _index.resolveObjMapThunk;\n                     }\n                 }));\n                 Object.defineProperty(exports, \"resolveReadonlyArrayThunk\", ({\n@@ -28288,14 +46384,15 @@\n         \"../../../node_modules/graphql/jsutils/Path.mjs\":\n             /*!******************************************************!*\\\n               !*** ../../../node_modules/graphql/jsutils/Path.mjs ***!\n               \\******************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.addPath = addPath;\n                 exports.pathToArray = pathToArray;\n@@ -28330,14 +46427,15 @@\n         \"../../../node_modules/graphql/jsutils/devAssert.mjs\":\n             /*!***********************************************************!*\\\n               !*** ../../../node_modules/graphql/jsutils/devAssert.mjs ***!\n               \\***********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.devAssert = devAssert;\n \n@@ -28355,14 +46453,15 @@\n         \"../../../node_modules/graphql/jsutils/didYouMean.mjs\":\n             /*!************************************************************!*\\\n               !*** ../../../node_modules/graphql/jsutils/didYouMean.mjs ***!\n               \\************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.didYouMean = didYouMean;\n                 const MAX_SUGGESTIONS = 5;\n@@ -28397,14 +46496,15 @@\n         \"../../../node_modules/graphql/jsutils/groupBy.mjs\":\n             /*!*********************************************************!*\\\n               !*** ../../../node_modules/graphql/jsutils/groupBy.mjs ***!\n               \\*********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.groupBy = groupBy;\n                 /**\n@@ -28431,14 +46531,15 @@\n         \"../../../node_modules/graphql/jsutils/identityFunc.mjs\":\n             /*!**************************************************************!*\\\n               !*** ../../../node_modules/graphql/jsutils/identityFunc.mjs ***!\n               \\**************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.identityFunc = identityFunc;\n                 /**\n@@ -28455,14 +46556,15 @@\n         \"../../../node_modules/graphql/jsutils/inspect.mjs\":\n             /*!*********************************************************!*\\\n               !*** ../../../node_modules/graphql/jsutils/inspect.mjs ***!\n               \\*********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.inspect = inspect;\n                 const MAX_ARRAY_LENGTH = 10;\n@@ -28516,18 +46618,15 @@\n                     const entries = Object.entries(object);\n                     if (entries.length === 0) {\n                         return '{}';\n                     }\n                     if (seenValues.length > MAX_RECURSIVE_DEPTH) {\n                         return '[' + getObjectTag(object) + ']';\n                     }\n-                    const properties = entries.map(_ref => {\n-                        let [key, value] = _ref;\n-                        return key + ': ' + formatValue(value, seenValues);\n-                    });\n+                    const properties = entries.map(([key, value]) => key + ': ' + formatValue(value, seenValues));\n                     return '{ ' + properties.join(', ') + ' }';\n                 }\n \n                 function formatArray(array, seenValues) {\n                     if (array.length === 0) {\n                         return '[]';\n                     }\n@@ -28566,31 +46665,37 @@\n         \"../../../node_modules/graphql/jsutils/instanceOf.mjs\":\n             /*!************************************************************!*\\\n               !*** ../../../node_modules/graphql/jsutils/instanceOf.mjs ***!\n               \\************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.instanceOf = void 0;\n                 var _inspect = __webpack_require__( /*! ./inspect.mjs */ \"../../../node_modules/graphql/jsutils/inspect.mjs\");\n+                /* c8 ignore next 3 */\n+\n+                const isProduction = globalThis.process &&\n+                    // eslint-disable-next-line no-undef\n+                    \"development\" === 'production';\n                 /**\n                  * A replacement for instanceof which includes an error warning when multi-realm\n                  * constructors are detected.\n                  * See: https://expressjs.com/en/advanced/best-practice-performance.html#set-node_env-to-production\n                  * See: https://webpack.js.org/guides/production/\n                  */\n \n-                const instanceOf = /* c8 ignore next 6 */\n+                const instanceOf = exports.instanceOf = /* c8 ignore next 6 */\n                     // FIXME: https://github.com/graphql/graphql-js/issues/2317\n-                    globalThis.process && globalThis.process.env.NODE_ENV === 'production' ? function instanceOf(value, constructor) {\n+                    isProduction ? function instanceOf(value, constructor) {\n                         return value instanceof constructor;\n                     } : function instanceOf(value, constructor) {\n                         if (value instanceof constructor) {\n                             return true;\n                         }\n                         if (typeof value === 'object' && value !== null) {\n                             var _value$constructor;\n@@ -28616,27 +46721,27 @@\n versions may have different capabilities and behavior. The data from one\n version used in the function from another could produce confusing and\n spurious results.`);\n                             }\n                         }\n                         return false;\n                     };\n-                exports.instanceOf = instanceOf;\n \n                 /***/\n             }),\n \n         /***/\n         \"../../../node_modules/graphql/jsutils/invariant.mjs\":\n             /*!***********************************************************!*\\\n               !*** ../../../node_modules/graphql/jsutils/invariant.mjs ***!\n               \\***********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.invariant = invariant;\n \n@@ -28654,14 +46759,15 @@\n         \"../../../node_modules/graphql/jsutils/isAsyncIterable.mjs\":\n             /*!*****************************************************************!*\\\n               !*** ../../../node_modules/graphql/jsutils/isAsyncIterable.mjs ***!\n               \\*****************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.isAsyncIterable = isAsyncIterable;\n                 /**\n@@ -28679,14 +46785,15 @@\n         \"../../../node_modules/graphql/jsutils/isIterableObject.mjs\":\n             /*!******************************************************************!*\\\n               !*** ../../../node_modules/graphql/jsutils/isIterableObject.mjs ***!\n               \\******************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.isIterableObject = isIterableObject;\n                 /**\n@@ -28717,14 +46824,15 @@\n         \"../../../node_modules/graphql/jsutils/isObjectLike.mjs\":\n             /*!**************************************************************!*\\\n               !*** ../../../node_modules/graphql/jsutils/isObjectLike.mjs ***!\n               \\**************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.isObjectLike = isObjectLike;\n                 /**\n@@ -28742,14 +46850,15 @@\n         \"../../../node_modules/graphql/jsutils/isPromise.mjs\":\n             /*!***********************************************************!*\\\n               !*** ../../../node_modules/graphql/jsutils/isPromise.mjs ***!\n               \\***********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.isPromise = isPromise;\n                 /**\n@@ -28767,14 +46876,15 @@\n         \"../../../node_modules/graphql/jsutils/keyMap.mjs\":\n             /*!********************************************************!*\\\n               !*** ../../../node_modules/graphql/jsutils/keyMap.mjs ***!\n               \\********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.keyMap = keyMap;\n                 /**\n@@ -28819,14 +46929,15 @@\n         \"../../../node_modules/graphql/jsutils/keyValMap.mjs\":\n             /*!***********************************************************!*\\\n               !*** ../../../node_modules/graphql/jsutils/keyValMap.mjs ***!\n               \\***********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.keyValMap = keyValMap;\n                 /**\n@@ -28861,14 +46972,15 @@\n         \"../../../node_modules/graphql/jsutils/mapValue.mjs\":\n             /*!**********************************************************!*\\\n               !*** ../../../node_modules/graphql/jsutils/mapValue.mjs ***!\n               \\**********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.mapValue = mapValue;\n                 /**\n@@ -28890,14 +47002,15 @@\n         \"../../../node_modules/graphql/jsutils/memoize3.mjs\":\n             /*!**********************************************************!*\\\n               !*** ../../../node_modules/graphql/jsutils/memoize3.mjs ***!\n               \\**********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.memoize3 = memoize3;\n                 /**\n@@ -28935,14 +47048,15 @@\n         \"../../../node_modules/graphql/jsutils/naturalCompare.mjs\":\n             /*!****************************************************************!*\\\n               !*** ../../../node_modules/graphql/jsutils/naturalCompare.mjs ***!\n               \\****************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.naturalCompare = naturalCompare;\n                 /**\n@@ -29004,14 +47118,15 @@\n         \"../../../node_modules/graphql/jsutils/printPathArray.mjs\":\n             /*!****************************************************************!*\\\n               !*** ../../../node_modules/graphql/jsutils/printPathArray.mjs ***!\n               \\****************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.printPathArray = printPathArray;\n                 /**\n@@ -29028,14 +47143,15 @@\n         \"../../../node_modules/graphql/jsutils/promiseForObject.mjs\":\n             /*!******************************************************************!*\\\n               !*** ../../../node_modules/graphql/jsutils/promiseForObject.mjs ***!\n               \\******************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.promiseForObject = promiseForObject;\n                 /**\n@@ -29062,14 +47178,15 @@\n         \"../../../node_modules/graphql/jsutils/promiseReduce.mjs\":\n             /*!***************************************************************!*\\\n               !*** ../../../node_modules/graphql/jsutils/promiseReduce.mjs ***!\n               \\***************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.promiseReduce = promiseReduce;\n                 var _isPromise = __webpack_require__( /*! ./isPromise.mjs */ \"../../../node_modules/graphql/jsutils/isPromise.mjs\");\n@@ -29095,14 +47212,15 @@\n         \"../../../node_modules/graphql/jsutils/suggestionList.mjs\":\n             /*!****************************************************************!*\\\n               !*** ../../../node_modules/graphql/jsutils/suggestionList.mjs ***!\n               \\****************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.suggestionList = suggestionList;\n                 var _naturalCompare = __webpack_require__( /*! ./naturalCompare.mjs */ \"../../../node_modules/graphql/jsutils/naturalCompare.mjs\");\n@@ -29181,15 +47299,14 @@\n                                 const cost = a[i - 1] === b[j - 1] ? 0 : 1;\n                                 let currentCell = Math.min(upRow[j] + 1,\n                                     // delete\n                                     currentRow[j - 1] + 1,\n                                     // insert\n                                     upRow[j - 1] + cost // substitute\n                                 );\n-\n                                 if (i > 1 && j > 1 && a[i - 1] === b[j - 2] && a[i - 2] === b[j - 1]) {\n                                     // transposition\n                                     const doubleDiagonalCell = rows[(i - 2) % 3][j - 2];\n                                     currentCell = Math.min(currentCell, doubleDiagonalCell + 1);\n                                 }\n                                 if (currentCell < smallestCell) {\n                                     smallestCell = currentCell;\n@@ -29222,14 +47339,15 @@\n         \"../../../node_modules/graphql/jsutils/toError.mjs\":\n             /*!*********************************************************!*\\\n               !*** ../../../node_modules/graphql/jsutils/toError.mjs ***!\n               \\*********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.toError = toError;\n                 var _inspect = __webpack_require__( /*! ./inspect.mjs */ \"../../../node_modules/graphql/jsutils/inspect.mjs\");\n@@ -29255,14 +47373,15 @@\n         \"../../../node_modules/graphql/jsutils/toObjMap.mjs\":\n             /*!**********************************************************!*\\\n               !*** ../../../node_modules/graphql/jsutils/toObjMap.mjs ***!\n               \\**********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.toObjMap = toObjMap;\n \n@@ -29287,14 +47406,15 @@\n         \"../../../node_modules/graphql/language/ast.mjs\":\n             /*!******************************************************!*\\\n               !*** ../../../node_modules/graphql/language/ast.mjs ***!\n               \\******************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.Token = exports.QueryDocumentKeys = exports.OperationTypeNode = exports.Location = void 0;\n                 exports.isNode = isNode;\n@@ -29404,15 +47524,15 @@\n                  * The list of all possible AST node types.\n                  */\n \n                 /**\n                  * @internal\n                  */\n                 exports.Token = Token;\n-                const QueryDocumentKeys = {\n+                const QueryDocumentKeys = exports.QueryDocumentKeys = {\n                     Name: [],\n                     Document: ['definitions'],\n                     OperationDefinition: ['name', 'variableDefinitions', 'directives', 'selectionSet'],\n                     VariableDefinition: ['variable', 'type', 'defaultValue', 'directives'],\n                     Variable: ['name'],\n                     SelectionSet: ['selections'],\n                     Field: ['alias', 'name', 'arguments', 'directives', 'selectionSet'],\n@@ -29452,28 +47572,26 @@\n                     ScalarTypeExtension: ['name', 'directives'],\n                     ObjectTypeExtension: ['name', 'interfaces', 'directives', 'fields'],\n                     InterfaceTypeExtension: ['name', 'interfaces', 'directives', 'fields'],\n                     UnionTypeExtension: ['name', 'directives', 'types'],\n                     EnumTypeExtension: ['name', 'directives', 'values'],\n                     InputObjectTypeExtension: ['name', 'directives', 'fields']\n                 };\n-                exports.QueryDocumentKeys = QueryDocumentKeys;\n                 const kindValues = new Set(Object.keys(QueryDocumentKeys));\n                 /**\n                  * @internal\n                  */\n \n                 function isNode(maybeNode) {\n                     const maybeKind = maybeNode === null || maybeNode === void 0 ? void 0 : maybeNode.kind;\n                     return typeof maybeKind === 'string' && kindValues.has(maybeKind);\n                 }\n                 /** Name */\n \n                 var OperationTypeNode;\n-                exports.OperationTypeNode = OperationTypeNode;\n                 (function(OperationTypeNode) {\n                     OperationTypeNode['QUERY'] = 'query';\n                     OperationTypeNode['MUTATION'] = 'mutation';\n                     OperationTypeNode['SUBSCRIPTION'] = 'subscription';\n                 })(OperationTypeNode || (exports.OperationTypeNode = OperationTypeNode = {}));\n \n                 /***/\n@@ -29483,14 +47601,15 @@\n         \"../../../node_modules/graphql/language/blockString.mjs\":\n             /*!**************************************************************!*\\\n               !*** ../../../node_modules/graphql/language/blockString.mjs ***!\n               \\**************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.dedentBlockStringLines = dedentBlockStringLines;\n                 exports.isPrintableAsBlockString = isPrintableAsBlockString;\n@@ -29513,15 +47632,14 @@\n                     for (let i = 0; i < lines.length; ++i) {\n                         var _firstNonEmptyLine;\n                         const line = lines[i];\n                         const indent = leadingWhitespace(line);\n                         if (indent === line.length) {\n                             continue; // skip empty lines\n                         }\n-\n                         firstNonEmptyLine = (_firstNonEmptyLine = firstNonEmptyLine) !== null && _firstNonEmptyLine !== void 0 ? _firstNonEmptyLine : i;\n                         lastNonEmptyLine = i;\n                         if (i !== 0 && indent < commonIndent) {\n                             commonIndent = indent;\n                         }\n                     }\n                     return lines // Remove common indentation from all lines but first.\n@@ -29540,15 +47658,14 @@\n                  * @internal\n                  */\n \n                 function isPrintableAsBlockString(value) {\n                     if (value === '') {\n                         return true; // empty string is printable\n                     }\n-\n                     let isEmptyLine = true;\n                     let hasIndent = false;\n                     let hasCommonIndent = true;\n                     let seenNonEmptyLine = false;\n                     for (let i = 0; i < value.length; ++i) {\n                         switch (value.codePointAt(i)) {\n                             case 0x0000:\n@@ -29573,15 +47690,14 @@\n                                 // Has \\r or \\r\\n which will be replaced as \\n\n \n                             case 10:\n                                 //  \\n\n                                 if (isEmptyLine && !seenNonEmptyLine) {\n                                     return false; // Has leading new line\n                                 }\n-\n                                 seenNonEmptyLine = true;\n                                 isEmptyLine = true;\n                                 hasIndent = false;\n                                 break;\n                             case 9: //   \\t\n \n                             case 32:\n@@ -29592,19 +47708,17 @@\n                                 hasCommonIndent && (hasCommonIndent = hasIndent);\n                                 isEmptyLine = false;\n                         }\n                     }\n                     if (isEmptyLine) {\n                         return false; // Has trailing empty lines\n                     }\n-\n                     if (hasCommonIndent && seenNonEmptyLine) {\n                         return false; // Has internal indent\n                     }\n-\n                     return true;\n                 }\n                 /**\n                  * Print a block string in the indented block form by adding a leading and\n                  * trailing blank line. However, if a block string starts with whitespace and is\n                  * a single-line, adding a leading blank line would strip that whitespace.\n                  *\n@@ -29647,14 +47761,15 @@\n         \"../../../node_modules/graphql/language/characterClasses.mjs\":\n             /*!*******************************************************************!*\\\n               !*** ../../../node_modules/graphql/language/characterClasses.mjs ***!\n               \\*******************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.isDigit = isDigit;\n                 exports.isLetter = isLetter;\n@@ -29733,25 +47848,25 @@\n         \"../../../node_modules/graphql/language/directiveLocation.mjs\":\n             /*!********************************************************************!*\\\n               !*** ../../../node_modules/graphql/language/directiveLocation.mjs ***!\n               \\********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.DirectiveLocation = void 0;\n                 /**\n                  * The set of allowed directive location values.\n                  */\n                 var DirectiveLocation;\n-                exports.DirectiveLocation = DirectiveLocation;\n                 (function(DirectiveLocation) {\n                     DirectiveLocation['QUERY'] = 'QUERY';\n                     DirectiveLocation['MUTATION'] = 'MUTATION';\n                     DirectiveLocation['SUBSCRIPTION'] = 'SUBSCRIPTION';\n                     DirectiveLocation['FIELD'] = 'FIELD';\n                     DirectiveLocation['FRAGMENT_DEFINITION'] = 'FRAGMENT_DEFINITION';\n                     DirectiveLocation['FRAGMENT_SPREAD'] = 'FRAGMENT_SPREAD';\n@@ -29783,14 +47898,15 @@\n         \"../../../node_modules/graphql/language/index.mjs\":\n             /*!********************************************************!*\\\n               !*** ../../../node_modules/graphql/language/index.mjs ***!\n               \\********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 Object.defineProperty(exports, \"BREAK\", ({\n                     enumerable: true,\n@@ -29998,25 +48114,25 @@\n         \"../../../node_modules/graphql/language/kinds.mjs\":\n             /*!********************************************************!*\\\n               !*** ../../../node_modules/graphql/language/kinds.mjs ***!\n               \\********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.Kind = void 0;\n                 /**\n                  * The set of allowed kind values for AST nodes.\n                  */\n                 var Kind;\n-                exports.Kind = Kind;\n                 (function(Kind) {\n                     Kind['NAME'] = 'Name';\n                     Kind['DOCUMENT'] = 'Document';\n                     Kind['OPERATION_DEFINITION'] = 'OperationDefinition';\n                     Kind['VARIABLE_DEFINITION'] = 'VariableDefinition';\n                     Kind['SELECTION_SET'] = 'SelectionSet';\n                     Kind['FIELD'] = 'Field';\n@@ -30072,14 +48188,15 @@\n         \"../../../node_modules/graphql/language/lexer.mjs\":\n             /*!********************************************************!*\\\n               !*** ../../../node_modules/graphql/language/lexer.mjs ***!\n               \\********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.Lexer = void 0;\n                 exports.isPunctuatorTokenKind = isPunctuatorTokenKind;\n@@ -30812,14 +48929,15 @@\n         \"../../../node_modules/graphql/language/location.mjs\":\n             /*!***********************************************************!*\\\n               !*** ../../../node_modules/graphql/language/location.mjs ***!\n               \\***********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.getLocation = getLocation;\n                 var _invariant = __webpack_require__( /*! ../jsutils/invariant.mjs */ \"../../../node_modules/graphql/jsutils/invariant.mjs\");\n@@ -30856,14 +48974,15 @@\n         \"../../../node_modules/graphql/language/parser.mjs\":\n             /*!*********************************************************!*\\\n               !*** ../../../node_modules/graphql/language/parser.mjs ***!\n               \\*********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.Parser = void 0;\n                 exports.parse = parse;\n@@ -30946,16 +49065,15 @@\n                  * considered breaking changes. If you still need to support multiple versions of the\n                  * library, please use the `versionInfo` variable for version detection.\n                  *\n                  * @internal\n                  */\n \n                 class Parser {\n-                    constructor(source) {\n-                        let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n+                    constructor(source, options = {}) {\n                         const sourceObj = (0, _source.isSource)(source) ? source : new _source.Source(source);\n                         this._lexer = new _lexer.Lexer(sourceObj);\n                         this._options = options;\n                         this._tokenCounter = 0;\n                     }\n                     /**\n                      * Converts a name lex token into a name parse node.\n@@ -31182,16 +49300,15 @@\n                         const item = isConst ? this.parseConstArgument : this.parseArgument;\n                         return this.optionalMany(_tokenKind.TokenKind.PAREN_L, item, _tokenKind.TokenKind.PAREN_R);\n                     }\n                     /**\n                      * Argument[Const] : Name : Value[?Const]\n                      */\n \n-                    parseArgument() {\n-                        let isConst = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;\n+                    parseArgument(isConst = false) {\n                         const start = this._lexer.token;\n                         const name = this.parseName();\n                         this.expectToken(_tokenKind.TokenKind.COLON);\n                         return this.node(start, {\n                             kind: _kinds.Kind.ARGUMENT,\n                             name,\n                             value: this.parseValueLiteral(isConst)\n@@ -32212,14 +50329,15 @@\n         \"../../../node_modules/graphql/language/predicates.mjs\":\n             /*!*************************************************************!*\\\n               !*** ../../../node_modules/graphql/language/predicates.mjs ***!\n               \\*************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.isConstValueNode = isConstValueNode;\n                 exports.isDefinitionNode = isDefinitionNode;\n@@ -32280,14 +50398,15 @@\n         \"../../../node_modules/graphql/language/printLocation.mjs\":\n             /*!****************************************************************!*\\\n               !*** ../../../node_modules/graphql/language/printLocation.mjs ***!\n               \\****************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.printLocation = printLocation;\n                 exports.printSourceLocation = printSourceLocation;\n@@ -32332,39 +50451,31 @@\n                         [`${lineNum} |`, locationLine],\n                         ['|', '^'.padStart(columnNum)],\n                         [`${lineNum + 1} |`, lines[lineIndex + 1]]\n                     ]);\n                 }\n \n                 function printPrefixedLines(lines) {\n-                    const existingLines = lines.filter(_ref => {\n-                        let [_, line] = _ref;\n-                        return line !== undefined;\n-                    });\n-                    const padLen = Math.max(...existingLines.map(_ref2 => {\n-                        let [prefix] = _ref2;\n-                        return prefix.length;\n-                    }));\n-                    return existingLines.map(_ref3 => {\n-                        let [prefix, line] = _ref3;\n-                        return prefix.padStart(padLen) + (line ? ' ' + line : '');\n-                    }).join('\\n');\n+                    const existingLines = lines.filter(([_, line]) => line !== undefined);\n+                    const padLen = Math.max(...existingLines.map(([prefix]) => prefix.length));\n+                    return existingLines.map(([prefix, line]) => prefix.padStart(padLen) + (line ? ' ' + line : '')).join('\\n');\n                 }\n \n                 /***/\n             }),\n \n         /***/\n         \"../../../node_modules/graphql/language/printString.mjs\":\n             /*!**************************************************************!*\\\n               !*** ../../../node_modules/graphql/language/printString.mjs ***!\n               \\**************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.printString = printString;\n                 /**\n@@ -32401,14 +50512,15 @@\n         \"../../../node_modules/graphql/language/printer.mjs\":\n             /*!**********************************************************!*\\\n               !*** ../../../node_modules/graphql/language/printer.mjs ***!\n               \\**********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.print = print;\n                 var _blockString = __webpack_require__( /*! ./blockString.mjs */ \"../../../node_modules/graphql/language/blockString.mjs\");\n@@ -32440,426 +50552,311 @@\n                             const prefix = join([node.operation, join([node.name, varDefs]), join(node.directives, ' ')], ' '); // Anonymous queries with no directives or variable definitions can use\n                             // the query short form.\n \n                             return (prefix === 'query' ? '' : prefix + ' ') + node.selectionSet;\n                         }\n                     },\n                     VariableDefinition: {\n-                        leave: _ref => {\n-                            let {\n-                                variable,\n-                                type,\n-                                defaultValue,\n-                                directives\n-                            } = _ref;\n-                            return variable + ': ' + type + wrap(' = ', defaultValue) + wrap(' ', join(directives, ' '));\n-                        }\n+                        leave: ({\n+                            variable,\n+                            type,\n+                            defaultValue,\n+                            directives\n+                        }) => variable + ': ' + type + wrap(' = ', defaultValue) + wrap(' ', join(directives, ' '))\n                     },\n                     SelectionSet: {\n-                        leave: _ref2 => {\n-                            let {\n-                                selections\n-                            } = _ref2;\n-                            return block(selections);\n-                        }\n+                        leave: ({\n+                            selections\n+                        }) => block(selections)\n                     },\n                     Field: {\n-                        leave(_ref3) {\n-                            let {\n-                                alias,\n-                                name,\n-                                arguments: args,\n-                                directives,\n-                                selectionSet\n-                            } = _ref3;\n+                        leave({\n+                            alias,\n+                            name,\n+                            arguments: args,\n+                            directives,\n+                            selectionSet\n+                        }) {\n                             const prefix = wrap('', alias, ': ') + name;\n                             let argsLine = prefix + wrap('(', join(args, ', '), ')');\n                             if (argsLine.length > MAX_LINE_LENGTH) {\n                                 argsLine = prefix + wrap('(\\n', indent(join(args, '\\n')), '\\n)');\n                             }\n                             return join([argsLine, join(directives, ' '), selectionSet], ' ');\n                         }\n                     },\n                     Argument: {\n-                        leave: _ref4 => {\n-                            let {\n-                                name,\n-                                value\n-                            } = _ref4;\n-                            return name + ': ' + value;\n-                        }\n+                        leave: ({\n+                            name,\n+                            value\n+                        }) => name + ': ' + value\n                     },\n                     // Fragments\n                     FragmentSpread: {\n-                        leave: _ref5 => {\n-                            let {\n-                                name,\n-                                directives\n-                            } = _ref5;\n-                            return '...' + name + wrap(' ', join(directives, ' '));\n-                        }\n+                        leave: ({\n+                            name,\n+                            directives\n+                        }) => '...' + name + wrap(' ', join(directives, ' '))\n                     },\n                     InlineFragment: {\n-                        leave: _ref6 => {\n-                            let {\n-                                typeCondition,\n-                                directives,\n-                                selectionSet\n-                            } = _ref6;\n-                            return join(['...', wrap('on ', typeCondition), join(directives, ' '), selectionSet], ' ');\n-                        }\n+                        leave: ({\n+                            typeCondition,\n+                            directives,\n+                            selectionSet\n+                        }) => join(['...', wrap('on ', typeCondition), join(directives, ' '), selectionSet], ' ')\n                     },\n                     FragmentDefinition: {\n-                        leave: (_ref7 // Note: fragment variable definitions are experimental and may be changed\n-                        ) => {\n-                            let {\n-                                name,\n-                                typeCondition,\n-                                variableDefinitions,\n-                                directives,\n-                                selectionSet\n-                            } = _ref7;\n-                            return (\n-                                // or removed in the future.\n-                                `fragment ${name}${wrap('(', join(variableDefinitions, ', '), ')')} ` + `on ${typeCondition} ${wrap('', join(directives, ' '), ' ')}` + selectionSet\n-                            );\n-                        }\n+                        leave: ({\n+                                    name,\n+                                    typeCondition,\n+                                    variableDefinitions,\n+                                    directives,\n+                                    selectionSet\n+                                } // Note: fragment variable definitions are experimental and may be changed\n+                            ) =>\n+                            // or removed in the future.\n+                            `fragment ${name}${wrap('(', join(variableDefinitions, ', '), ')')} ` + `on ${typeCondition} ${wrap('', join(directives, ' '), ' ')}` + selectionSet\n                     },\n                     // Value\n                     IntValue: {\n-                        leave: _ref8 => {\n-                            let {\n-                                value\n-                            } = _ref8;\n-                            return value;\n-                        }\n+                        leave: ({\n+                            value\n+                        }) => value\n                     },\n                     FloatValue: {\n-                        leave: _ref9 => {\n-                            let {\n-                                value\n-                            } = _ref9;\n-                            return value;\n-                        }\n+                        leave: ({\n+                            value\n+                        }) => value\n                     },\n                     StringValue: {\n-                        leave: _ref10 => {\n-                            let {\n-                                value,\n-                                block: isBlockString\n-                            } = _ref10;\n-                            return isBlockString ? (0, _blockString.printBlockString)(value) : (0, _printString.printString)(value);\n-                        }\n+                        leave: ({\n+                            value,\n+                            block: isBlockString\n+                        }) => isBlockString ? (0, _blockString.printBlockString)(value) : (0, _printString.printString)(value)\n                     },\n                     BooleanValue: {\n-                        leave: _ref11 => {\n-                            let {\n-                                value\n-                            } = _ref11;\n-                            return value ? 'true' : 'false';\n-                        }\n+                        leave: ({\n+                            value\n+                        }) => value ? 'true' : 'false'\n                     },\n                     NullValue: {\n                         leave: () => 'null'\n                     },\n                     EnumValue: {\n-                        leave: _ref12 => {\n-                            let {\n-                                value\n-                            } = _ref12;\n-                            return value;\n-                        }\n+                        leave: ({\n+                            value\n+                        }) => value\n                     },\n                     ListValue: {\n-                        leave: _ref13 => {\n-                            let {\n-                                values\n-                            } = _ref13;\n-                            return '[' + join(values, ', ') + ']';\n-                        }\n+                        leave: ({\n+                            values\n+                        }) => '[' + join(values, ', ') + ']'\n                     },\n                     ObjectValue: {\n-                        leave: _ref14 => {\n-                            let {\n-                                fields\n-                            } = _ref14;\n-                            return '{' + join(fields, ', ') + '}';\n-                        }\n+                        leave: ({\n+                            fields\n+                        }) => '{' + join(fields, ', ') + '}'\n                     },\n                     ObjectField: {\n-                        leave: _ref15 => {\n-                            let {\n-                                name,\n-                                value\n-                            } = _ref15;\n-                            return name + ': ' + value;\n-                        }\n+                        leave: ({\n+                            name,\n+                            value\n+                        }) => name + ': ' + value\n                     },\n                     // Directive\n                     Directive: {\n-                        leave: _ref16 => {\n-                            let {\n-                                name,\n-                                arguments: args\n-                            } = _ref16;\n-                            return '@' + name + wrap('(', join(args, ', '), ')');\n-                        }\n+                        leave: ({\n+                            name,\n+                            arguments: args\n+                        }) => '@' + name + wrap('(', join(args, ', '), ')')\n                     },\n                     // Type\n                     NamedType: {\n-                        leave: _ref17 => {\n-                            let {\n-                                name\n-                            } = _ref17;\n-                            return name;\n-                        }\n+                        leave: ({\n+                            name\n+                        }) => name\n                     },\n                     ListType: {\n-                        leave: _ref18 => {\n-                            let {\n-                                type\n-                            } = _ref18;\n-                            return '[' + type + ']';\n-                        }\n+                        leave: ({\n+                            type\n+                        }) => '[' + type + ']'\n                     },\n                     NonNullType: {\n-                        leave: _ref19 => {\n-                            let {\n-                                type\n-                            } = _ref19;\n-                            return type + '!';\n-                        }\n+                        leave: ({\n+                            type\n+                        }) => type + '!'\n                     },\n                     // Type System Definitions\n                     SchemaDefinition: {\n-                        leave: _ref20 => {\n-                            let {\n-                                description,\n-                                directives,\n-                                operationTypes\n-                            } = _ref20;\n-                            return wrap('', description, '\\n') + join(['schema', join(directives, ' '), block(operationTypes)], ' ');\n-                        }\n+                        leave: ({\n+                            description,\n+                            directives,\n+                            operationTypes\n+                        }) => wrap('', description, '\\n') + join(['schema', join(directives, ' '), block(operationTypes)], ' ')\n                     },\n                     OperationTypeDefinition: {\n-                        leave: _ref21 => {\n-                            let {\n-                                operation,\n-                                type\n-                            } = _ref21;\n-                            return operation + ': ' + type;\n-                        }\n+                        leave: ({\n+                            operation,\n+                            type\n+                        }) => operation + ': ' + type\n                     },\n                     ScalarTypeDefinition: {\n-                        leave: _ref22 => {\n-                            let {\n-                                description,\n-                                name,\n-                                directives\n-                            } = _ref22;\n-                            return wrap('', description, '\\n') + join(['scalar', name, join(directives, ' ')], ' ');\n-                        }\n+                        leave: ({\n+                            description,\n+                            name,\n+                            directives\n+                        }) => wrap('', description, '\\n') + join(['scalar', name, join(directives, ' ')], ' ')\n                     },\n                     ObjectTypeDefinition: {\n-                        leave: _ref23 => {\n-                            let {\n-                                description,\n-                                name,\n-                                interfaces,\n-                                directives,\n-                                fields\n-                            } = _ref23;\n-                            return wrap('', description, '\\n') + join(['type', name, wrap('implements ', join(interfaces, ' & ')), join(directives, ' '), block(fields)], ' ');\n-                        }\n+                        leave: ({\n+                            description,\n+                            name,\n+                            interfaces,\n+                            directives,\n+                            fields\n+                        }) => wrap('', description, '\\n') + join(['type', name, wrap('implements ', join(interfaces, ' & ')), join(directives, ' '), block(fields)], ' ')\n                     },\n                     FieldDefinition: {\n-                        leave: _ref24 => {\n-                            let {\n-                                description,\n-                                name,\n-                                arguments: args,\n-                                type,\n-                                directives\n-                            } = _ref24;\n-                            return wrap('', description, '\\n') + name + (hasMultilineItems(args) ? wrap('(\\n', indent(join(args, '\\n')), '\\n)') : wrap('(', join(args, ', '), ')')) + ': ' + type + wrap(' ', join(directives, ' '));\n-                        }\n+                        leave: ({\n+                            description,\n+                            name,\n+                            arguments: args,\n+                            type,\n+                            directives\n+                        }) => wrap('', description, '\\n') + name + (hasMultilineItems(args) ? wrap('(\\n', indent(join(args, '\\n')), '\\n)') : wrap('(', join(args, ', '), ')')) + ': ' + type + wrap(' ', join(directives, ' '))\n                     },\n                     InputValueDefinition: {\n-                        leave: _ref25 => {\n-                            let {\n-                                description,\n-                                name,\n-                                type,\n-                                defaultValue,\n-                                directives\n-                            } = _ref25;\n-                            return wrap('', description, '\\n') + join([name + ': ' + type, wrap('= ', defaultValue), join(directives, ' ')], ' ');\n-                        }\n+                        leave: ({\n+                            description,\n+                            name,\n+                            type,\n+                            defaultValue,\n+                            directives\n+                        }) => wrap('', description, '\\n') + join([name + ': ' + type, wrap('= ', defaultValue), join(directives, ' ')], ' ')\n                     },\n                     InterfaceTypeDefinition: {\n-                        leave: _ref26 => {\n-                            let {\n-                                description,\n-                                name,\n-                                interfaces,\n-                                directives,\n-                                fields\n-                            } = _ref26;\n-                            return wrap('', description, '\\n') + join(['interface', name, wrap('implements ', join(interfaces, ' & ')), join(directives, ' '), block(fields)], ' ');\n-                        }\n+                        leave: ({\n+                            description,\n+                            name,\n+                            interfaces,\n+                            directives,\n+                            fields\n+                        }) => wrap('', description, '\\n') + join(['interface', name, wrap('implements ', join(interfaces, ' & ')), join(directives, ' '), block(fields)], ' ')\n                     },\n                     UnionTypeDefinition: {\n-                        leave: _ref27 => {\n-                            let {\n-                                description,\n-                                name,\n-                                directives,\n-                                types\n-                            } = _ref27;\n-                            return wrap('', description, '\\n') + join(['union', name, join(directives, ' '), wrap('= ', join(types, ' | '))], ' ');\n-                        }\n+                        leave: ({\n+                            description,\n+                            name,\n+                            directives,\n+                            types\n+                        }) => wrap('', description, '\\n') + join(['union', name, join(directives, ' '), wrap('= ', join(types, ' | '))], ' ')\n                     },\n                     EnumTypeDefinition: {\n-                        leave: _ref28 => {\n-                            let {\n-                                description,\n-                                name,\n-                                directives,\n-                                values\n-                            } = _ref28;\n-                            return wrap('', description, '\\n') + join(['enum', name, join(directives, ' '), block(values)], ' ');\n-                        }\n+                        leave: ({\n+                            description,\n+                            name,\n+                            directives,\n+                            values\n+                        }) => wrap('', description, '\\n') + join(['enum', name, join(directives, ' '), block(values)], ' ')\n                     },\n                     EnumValueDefinition: {\n-                        leave: _ref29 => {\n-                            let {\n-                                description,\n-                                name,\n-                                directives\n-                            } = _ref29;\n-                            return wrap('', description, '\\n') + join([name, join(directives, ' ')], ' ');\n-                        }\n+                        leave: ({\n+                            description,\n+                            name,\n+                            directives\n+                        }) => wrap('', description, '\\n') + join([name, join(directives, ' ')], ' ')\n                     },\n                     InputObjectTypeDefinition: {\n-                        leave: _ref30 => {\n-                            let {\n-                                description,\n-                                name,\n-                                directives,\n-                                fields\n-                            } = _ref30;\n-                            return wrap('', description, '\\n') + join(['input', name, join(directives, ' '), block(fields)], ' ');\n-                        }\n+                        leave: ({\n+                            description,\n+                            name,\n+                            directives,\n+                            fields\n+                        }) => wrap('', description, '\\n') + join(['input', name, join(directives, ' '), block(fields)], ' ')\n                     },\n                     DirectiveDefinition: {\n-                        leave: _ref31 => {\n-                            let {\n-                                description,\n-                                name,\n-                                arguments: args,\n-                                repeatable,\n-                                locations\n-                            } = _ref31;\n-                            return wrap('', description, '\\n') + 'directive @' + name + (hasMultilineItems(args) ? wrap('(\\n', indent(join(args, '\\n')), '\\n)') : wrap('(', join(args, ', '), ')')) + (repeatable ? ' repeatable' : '') + ' on ' + join(locations, ' | ');\n-                        }\n+                        leave: ({\n+                            description,\n+                            name,\n+                            arguments: args,\n+                            repeatable,\n+                            locations\n+                        }) => wrap('', description, '\\n') + 'directive @' + name + (hasMultilineItems(args) ? wrap('(\\n', indent(join(args, '\\n')), '\\n)') : wrap('(', join(args, ', '), ')')) + (repeatable ? ' repeatable' : '') + ' on ' + join(locations, ' | ')\n                     },\n                     SchemaExtension: {\n-                        leave: _ref32 => {\n-                            let {\n-                                directives,\n-                                operationTypes\n-                            } = _ref32;\n-                            return join(['extend schema', join(directives, ' '), block(operationTypes)], ' ');\n-                        }\n+                        leave: ({\n+                            directives,\n+                            operationTypes\n+                        }) => join(['extend schema', join(directives, ' '), block(operationTypes)], ' ')\n                     },\n                     ScalarTypeExtension: {\n-                        leave: _ref33 => {\n-                            let {\n-                                name,\n-                                directives\n-                            } = _ref33;\n-                            return join(['extend scalar', name, join(directives, ' ')], ' ');\n-                        }\n+                        leave: ({\n+                            name,\n+                            directives\n+                        }) => join(['extend scalar', name, join(directives, ' ')], ' ')\n                     },\n                     ObjectTypeExtension: {\n-                        leave: _ref34 => {\n-                            let {\n-                                name,\n-                                interfaces,\n-                                directives,\n-                                fields\n-                            } = _ref34;\n-                            return join(['extend type', name, wrap('implements ', join(interfaces, ' & ')), join(directives, ' '), block(fields)], ' ');\n-                        }\n+                        leave: ({\n+                            name,\n+                            interfaces,\n+                            directives,\n+                            fields\n+                        }) => join(['extend type', name, wrap('implements ', join(interfaces, ' & ')), join(directives, ' '), block(fields)], ' ')\n                     },\n                     InterfaceTypeExtension: {\n-                        leave: _ref35 => {\n-                            let {\n-                                name,\n-                                interfaces,\n-                                directives,\n-                                fields\n-                            } = _ref35;\n-                            return join(['extend interface', name, wrap('implements ', join(interfaces, ' & ')), join(directives, ' '), block(fields)], ' ');\n-                        }\n+                        leave: ({\n+                            name,\n+                            interfaces,\n+                            directives,\n+                            fields\n+                        }) => join(['extend interface', name, wrap('implements ', join(interfaces, ' & ')), join(directives, ' '), block(fields)], ' ')\n                     },\n                     UnionTypeExtension: {\n-                        leave: _ref36 => {\n-                            let {\n-                                name,\n-                                directives,\n-                                types\n-                            } = _ref36;\n-                            return join(['extend union', name, join(directives, ' '), wrap('= ', join(types, ' | '))], ' ');\n-                        }\n+                        leave: ({\n+                            name,\n+                            directives,\n+                            types\n+                        }) => join(['extend union', name, join(directives, ' '), wrap('= ', join(types, ' | '))], ' ')\n                     },\n                     EnumTypeExtension: {\n-                        leave: _ref37 => {\n-                            let {\n-                                name,\n-                                directives,\n-                                values\n-                            } = _ref37;\n-                            return join(['extend enum', name, join(directives, ' '), block(values)], ' ');\n-                        }\n+                        leave: ({\n+                            name,\n+                            directives,\n+                            values\n+                        }) => join(['extend enum', name, join(directives, ' '), block(values)], ' ')\n                     },\n                     InputObjectTypeExtension: {\n-                        leave: _ref38 => {\n-                            let {\n-                                name,\n-                                directives,\n-                                fields\n-                            } = _ref38;\n-                            return join(['extend input', name, join(directives, ' '), block(fields)], ' ');\n-                        }\n+                        leave: ({\n+                            name,\n+                            directives,\n+                            fields\n+                        }) => join(['extend input', name, join(directives, ' '), block(fields)], ' ')\n                     }\n                 };\n                 /**\n                  * Given maybeArray, print an empty string if it is null or empty, otherwise\n                  * print all items together separated by separator if provided\n                  */\n \n-                function join(maybeArray) {\n-                    let separator = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';\n+                function join(maybeArray, separator = '') {\n                     var _maybeArray$filter$jo;\n                     return (_maybeArray$filter$jo = maybeArray === null || maybeArray === void 0 ? void 0 : maybeArray.filter(x => x).join(separator)) !== null && _maybeArray$filter$jo !== void 0 ? _maybeArray$filter$jo : '';\n                 }\n                 /**\n                  * Given array, print each item on its own line, wrapped in an indented `{ }` block.\n                  */\n \n                 function block(array) {\n                     return wrap('{\\n', indent(join(array, '\\n')), '\\n}');\n                 }\n                 /**\n                  * If maybeString is not null or empty, then wrap with start and end, otherwise print an empty string.\n                  */\n \n-                function wrap(start, maybeString) {\n-                    let end = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : '';\n+                function wrap(start, maybeString, end = '') {\n                     return maybeString != null && maybeString !== '' ? start + maybeString + end : '';\n                 }\n \n                 function indent(str) {\n                     return wrap('  ', str.replace(/\\n/g, '\\n  '));\n                 }\n \n@@ -32879,14 +50876,15 @@\n         \"../../../node_modules/graphql/language/source.mjs\":\n             /*!*********************************************************!*\\\n               !*** ../../../node_modules/graphql/language/source.mjs ***!\n               \\*********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.Source = void 0;\n                 exports.isSource = isSource;\n@@ -32897,20 +50895,18 @@\n                  * A representation of source input to GraphQL. The `name` and `locationOffset` parameters are\n                  * optional, but they are useful for clients who store GraphQL documents in source files.\n                  * For example, if the GraphQL input starts at line 40 in a file named `Foo.graphql`, it might\n                  * be useful for `name` to be `\"Foo.graphql\"` and location to be `{ line: 40, column: 1 }`.\n                  * The `line` and `column` properties in `locationOffset` are 1-indexed.\n                  */\n                 class Source {\n-                    constructor(body) {\n-                        let name = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'GraphQL request';\n-                        let locationOffset = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {\n-                            line: 1,\n-                            column: 1\n-                        };\n+                    constructor(body, name = 'GraphQL request', locationOffset = {\n+                        line: 1,\n+                        column: 1\n+                    }) {\n                         typeof body === 'string' || (0, _devAssert.devAssert)(false, `Body must be a string. Received: ${(0, _inspect.inspect)(body)}.`);\n                         this.body = body;\n                         this.name = name;\n                         this.locationOffset = locationOffset;\n                         this.locationOffset.line > 0 || (0, _devAssert.devAssert)(false, 'line in locationOffset is 1-indexed and must be positive.');\n                         this.locationOffset.column > 0 || (0, _devAssert.devAssert)(false, 'column in locationOffset is 1-indexed and must be positive.');\n                     }\n@@ -32936,26 +50932,26 @@\n         \"../../../node_modules/graphql/language/tokenKind.mjs\":\n             /*!************************************************************!*\\\n               !*** ../../../node_modules/graphql/language/tokenKind.mjs ***!\n               \\************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.TokenKind = void 0;\n                 /**\n                  * An exported enum describing the different kinds of tokens that the\n                  * lexer emits.\n                  */\n                 var TokenKind;\n-                exports.TokenKind = TokenKind;\n                 (function(TokenKind) {\n                     TokenKind['SOF'] = '<SOF>';\n                     TokenKind['EOF'] = '<EOF>';\n                     TokenKind['BANG'] = '!';\n                     TokenKind['DOLLAR'] = '$';\n                     TokenKind['AMP'] = '&';\n                     TokenKind['PAREN_L'] = '(';\n@@ -32990,14 +50986,15 @@\n         \"../../../node_modules/graphql/language/visitor.mjs\":\n             /*!**********************************************************!*\\\n               !*** ../../../node_modules/graphql/language/visitor.mjs ***!\n               \\**********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.BREAK = void 0;\n                 exports.getEnterLeaveForKind = getEnterLeaveForKind;\n@@ -33009,15 +51006,15 @@\n                 var _ast = __webpack_require__( /*! ./ast.mjs */ \"../../../node_modules/graphql/language/ast.mjs\");\n                 var _kinds = __webpack_require__( /*! ./kinds.mjs */ \"../../../node_modules/graphql/language/kinds.mjs\");\n                 /**\n                  * A visitor is provided to visit, it contains the collection of\n                  * relevant functions to be called during the visitor's traversal.\n                  */\n \n-                const BREAK = Object.freeze({});\n+                const BREAK = exports.BREAK = Object.freeze({});\n                 /**\n                  * visit() will walk through an AST using a depth-first traversal, calling\n                  * the visitor's enter function at each node in the traversal, and calling the\n                  * leave function after visiting that node and all of its child nodes.\n                  *\n                  * By returning different values from the enter and leave functions, the\n                  * behavior of the visitor can be altered, including skipping over a sub-tree of\n@@ -33088,18 +51085,16 @@\n                  *   },\n                  *   leave(node) {\n                  *     // leave any node\n                  *   }\n                  * })\n                  * ```\n                  */\n-                exports.BREAK = BREAK;\n \n-                function visit(root, visitor) {\n-                    let visitorKeys = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : _ast.QueryDocumentKeys;\n+                function visit(root, visitor, visitorKeys = _ast.QueryDocumentKeys) {\n                     const enterLeaveMap = new Map();\n                     for (const kind of Object.values(_kinds.Kind)) {\n                         enterLeaveMap.set(kind, getEnterLeaveForKind(visitor, kind));\n                     }\n                     /* eslint-disable no-undef-init */\n \n                     let stack = undefined;\n@@ -33234,18 +51229,15 @@\n                             enterList[i] = enter;\n                             leaveList[i] = leave;\n                         }\n                         if (!hasVisitor) {\n                             continue;\n                         }\n                         const mergedEnterLeave = {\n-                            enter() {\n-                                for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n-                                    args[_key] = arguments[_key];\n-                                }\n+                            enter(...args) {\n                                 const node = args[0];\n                                 for (let i = 0; i < visitors.length; i++) {\n                                     if (skipping[i] === null) {\n                                         var _enterList$i;\n                                         const result = (_enterList$i = enterList[i]) === null || _enterList$i === void 0 ? void 0 : _enterList$i.apply(visitors[i], args);\n                                         if (result === false) {\n                                             skipping[i] = node;\n@@ -33253,18 +51245,15 @@\n                                             skipping[i] = BREAK;\n                                         } else if (result !== undefined) {\n                                             return result;\n                                         }\n                                     }\n                                 }\n                             },\n-                            leave() {\n-                                for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n-                                    args[_key2] = arguments[_key2];\n-                                }\n+                            leave(...args) {\n                                 const node = args[0];\n                                 for (let i = 0; i < visitors.length; i++) {\n                                     if (skipping[i] === null) {\n                                         var _leaveList$i;\n                                         const result = (_leaveList$i = leaveList[i]) === null || _leaveList$i === void 0 ? void 0 : _leaveList$i.apply(visitors[i], args);\n                                         if (result === BREAK) {\n                                             skipping[i] = BREAK;\n@@ -33327,14 +51316,15 @@\n         \"../../../node_modules/graphql/type/assertName.mjs\":\n             /*!*********************************************************!*\\\n               !*** ../../../node_modules/graphql/type/assertName.mjs ***!\n               \\*********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.assertEnumValueName = assertEnumValueName;\n                 exports.assertName = assertName;\n@@ -33381,14 +51371,15 @@\n         \"../../../node_modules/graphql/type/definition.mjs\":\n             /*!*********************************************************!*\\\n               !*** ../../../node_modules/graphql/type/definition.mjs ***!\n               \\*********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.GraphQLUnionType = exports.GraphQLScalarType = exports.GraphQLObjectType = exports.GraphQLNonNull = exports.GraphQLList = exports.GraphQLInterfaceType = exports.GraphQLInputObjectType = exports.GraphQLEnumType = void 0;\n                 exports.argsToArgsConfig = argsToArgsConfig;\n@@ -33965,26 +51956,23 @@\n                             extensions: (0, _toObjMap.toObjMap)(fieldConfig.extensions),\n                             astNode: fieldConfig.astNode\n                         };\n                     });\n                 }\n \n                 function defineArguments(config) {\n-                    return Object.entries(config).map(_ref => {\n-                        let [argName, argConfig] = _ref;\n-                        return {\n-                            name: (0, _assertName.assertName)(argName),\n-                            description: argConfig.description,\n-                            type: argConfig.type,\n-                            defaultValue: argConfig.defaultValue,\n-                            deprecationReason: argConfig.deprecationReason,\n-                            extensions: (0, _toObjMap.toObjMap)(argConfig.extensions),\n-                            astNode: argConfig.astNode\n-                        };\n-                    });\n+                    return Object.entries(config).map(([argName, argConfig]) => ({\n+                        name: (0, _assertName.assertName)(argName),\n+                        description: argConfig.description,\n+                        type: argConfig.type,\n+                        defaultValue: argConfig.defaultValue,\n+                        deprecationReason: argConfig.deprecationReason,\n+                        extensions: (0, _toObjMap.toObjMap)(argConfig.extensions),\n+                        astNode: argConfig.astNode\n+                    }));\n                 }\n \n                 function isPlainObj(obj) {\n                     return (0, _isObjectLike.isObjectLike)(obj) && !Array.isArray(obj);\n                 }\n \n                 function fieldsToFieldsConfig(fields) {\n@@ -34185,28 +52173,37 @@\n                     constructor(config) {\n                         var _config$extensionASTN5;\n                         this.name = (0, _assertName.assertName)(config.name);\n                         this.description = config.description;\n                         this.extensions = (0, _toObjMap.toObjMap)(config.extensions);\n                         this.astNode = config.astNode;\n                         this.extensionASTNodes = (_config$extensionASTN5 = config.extensionASTNodes) !== null && _config$extensionASTN5 !== void 0 ? _config$extensionASTN5 : [];\n-                        this._values = defineEnumValues(this.name, config.values);\n-                        this._valueLookup = new Map(this._values.map(enumValue => [enumValue.value, enumValue]));\n-                        this._nameLookup = (0, _keyMap.keyMap)(this._values, value => value.name);\n+                        this._values = typeof config.values === 'function' ? config.values : defineEnumValues(this.name, config.values);\n+                        this._valueLookup = null;\n+                        this._nameLookup = null;\n                     }\n                     get[Symbol.toStringTag]() {\n                         return 'GraphQLEnumType';\n                     }\n                     getValues() {\n+                        if (typeof this._values === 'function') {\n+                            this._values = defineEnumValues(this.name, this._values());\n+                        }\n                         return this._values;\n                     }\n                     getValue(name) {\n+                        if (this._nameLookup === null) {\n+                            this._nameLookup = (0, _keyMap.keyMap)(this.getValues(), value => value.name);\n+                        }\n                         return this._nameLookup[name];\n                     }\n                     serialize(outputValue) {\n+                        if (this._valueLookup === null) {\n+                            this._valueLookup = new Map(this.getValues().map(enumValue => [enumValue.value, enumValue]));\n+                        }\n                         const enumValue = this._valueLookup.get(outputValue);\n                         if (enumValue === undefined) {\n                             throw new _GraphQLError.GraphQLError(`Enum \"${this.name}\" cannot represent value: ${(0, _inspect.inspect)(outputValue)}`);\n                         }\n                         return enumValue.name;\n                     }\n                     parseValue(inputValue) /* T */ {\n@@ -34267,16 +52264,15 @@\n                     const allNames = enumType.getValues().map(value => value.name);\n                     const suggestedValues = (0, _suggestionList.suggestionList)(unknownValueStr, allNames);\n                     return (0, _didYouMean.didYouMean)('the enum value', suggestedValues);\n                 }\n \n                 function defineEnumValues(typeName, valueMap) {\n                     isPlainObj(valueMap) || (0, _devAssert.devAssert)(false, `${typeName} values must be an object with value names as keys.`);\n-                    return Object.entries(valueMap).map(_ref2 => {\n-                        let [valueName, valueConfig] = _ref2;\n+                    return Object.entries(valueMap).map(([valueName, valueConfig]) => {\n                         isPlainObj(valueConfig) || (0, _devAssert.devAssert)(false, `${typeName}.${valueName} must refer to an object with a \"value\" key ` + `representing an internal value but got: ${(0, _inspect.inspect)(valueConfig)}.`);\n                         return {\n                             name: (0, _assertName.assertEnumValueName)(valueName),\n                             description: valueConfig.description,\n                             value: valueConfig.value !== undefined ? valueConfig.value : valueName,\n                             deprecationReason: valueConfig.deprecationReason,\n                             extensions: (0, _toObjMap.toObjMap)(valueConfig.extensions),\n@@ -34304,20 +52300,21 @@\n                  *     alt: { type: GraphQLFloat, defaultValue: 0 },\n                  *   }\n                  * });\n                  * ```\n                  */\n                 class GraphQLInputObjectType {\n                     constructor(config) {\n-                        var _config$extensionASTN6;\n+                        var _config$extensionASTN6, _config$isOneOf;\n                         this.name = (0, _assertName.assertName)(config.name);\n                         this.description = config.description;\n                         this.extensions = (0, _toObjMap.toObjMap)(config.extensions);\n                         this.astNode = config.astNode;\n                         this.extensionASTNodes = (_config$extensionASTN6 = config.extensionASTNodes) !== null && _config$extensionASTN6 !== void 0 ? _config$extensionASTN6 : [];\n+                        this.isOneOf = (_config$isOneOf = config.isOneOf) !== null && _config$isOneOf !== void 0 ? _config$isOneOf : false;\n                         this._fields = defineInputFieldMap.bind(undefined, config);\n                     }\n                     get[Symbol.toStringTag]() {\n                         return 'GraphQLInputObjectType';\n                     }\n                     getFields() {\n                         if (typeof this._fields === 'function') {\n@@ -34336,15 +52333,16 @@\n                         }));\n                         return {\n                             name: this.name,\n                             description: this.description,\n                             fields,\n                             extensions: this.extensions,\n                             astNode: this.astNode,\n-                            extensionASTNodes: this.extensionASTNodes\n+                            extensionASTNodes: this.extensionASTNodes,\n+                            isOneOf: this.isOneOf\n                         };\n                     }\n                     toString() {\n                         return this.name;\n                     }\n                     toJSON() {\n                         return this.toString();\n@@ -34380,20 +52378,21 @@\n         \"../../../node_modules/graphql/type/directives.mjs\":\n             /*!*********************************************************!*\\\n               !*** ../../../node_modules/graphql/type/directives.mjs ***!\n               \\*********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports.GraphQLSpecifiedByDirective = exports.GraphQLSkipDirective = exports.GraphQLIncludeDirective = exports.GraphQLDirective = exports.GraphQLDeprecatedDirective = exports.DEFAULT_DEPRECATION_REASON = void 0;\n+                exports.GraphQLSpecifiedByDirective = exports.GraphQLSkipDirective = exports.GraphQLOneOfDirective = exports.GraphQLIncludeDirective = exports.GraphQLDirective = exports.GraphQLDeprecatedDirective = exports.DEFAULT_DEPRECATION_REASON = void 0;\n                 exports.assertDirective = assertDirective;\n                 exports.isDirective = isDirective;\n                 exports.isSpecifiedDirective = isSpecifiedDirective;\n                 exports.specifiedDirectives = void 0;\n                 var _devAssert = __webpack_require__( /*! ../jsutils/devAssert.mjs */ \"../../../node_modules/graphql/jsutils/devAssert.mjs\");\n                 var _inspect = __webpack_require__( /*! ../jsutils/inspect.mjs */ \"../../../node_modules/graphql/jsutils/inspect.mjs\");\n                 var _instanceOf = __webpack_require__( /*! ../jsutils/instanceOf.mjs */ \"../../../node_modules/graphql/jsutils/instanceOf.mjs\");\n@@ -34467,103 +52466,110 @@\n                     }\n                 }\n \n                 /**\n                  * Used to conditionally include fields or fragments.\n                  */\n                 exports.GraphQLDirective = GraphQLDirective;\n-                const GraphQLIncludeDirective = new GraphQLDirective({\n+                const GraphQLIncludeDirective = exports.GraphQLIncludeDirective = new GraphQLDirective({\n                     name: 'include',\n                     description: 'Directs the executor to include this field or fragment only when the `if` argument is true.',\n                     locations: [_directiveLocation.DirectiveLocation.FIELD, _directiveLocation.DirectiveLocation.FRAGMENT_SPREAD, _directiveLocation.DirectiveLocation.INLINE_FRAGMENT],\n                     args: {\n                         if: {\n                             type: new _definition.GraphQLNonNull(_scalars.GraphQLBoolean),\n                             description: 'Included when true.'\n                         }\n                     }\n                 });\n                 /**\n                  * Used to conditionally skip (exclude) fields or fragments.\n                  */\n-                exports.GraphQLIncludeDirective = GraphQLIncludeDirective;\n-                const GraphQLSkipDirective = new GraphQLDirective({\n+\n+                const GraphQLSkipDirective = exports.GraphQLSkipDirective = new GraphQLDirective({\n                     name: 'skip',\n                     description: 'Directs the executor to skip this field or fragment when the `if` argument is true.',\n                     locations: [_directiveLocation.DirectiveLocation.FIELD, _directiveLocation.DirectiveLocation.FRAGMENT_SPREAD, _directiveLocation.DirectiveLocation.INLINE_FRAGMENT],\n                     args: {\n                         if: {\n                             type: new _definition.GraphQLNonNull(_scalars.GraphQLBoolean),\n                             description: 'Skipped when true.'\n                         }\n                     }\n                 });\n                 /**\n                  * Constant string used for default reason for a deprecation.\n                  */\n-                exports.GraphQLSkipDirective = GraphQLSkipDirective;\n-                const DEFAULT_DEPRECATION_REASON = 'No longer supported';\n+\n+                const DEFAULT_DEPRECATION_REASON = exports.DEFAULT_DEPRECATION_REASON = 'No longer supported';\n                 /**\n                  * Used to declare element of a GraphQL schema as deprecated.\n                  */\n-                exports.DEFAULT_DEPRECATION_REASON = DEFAULT_DEPRECATION_REASON;\n-                const GraphQLDeprecatedDirective = new GraphQLDirective({\n+\n+                const GraphQLDeprecatedDirective = exports.GraphQLDeprecatedDirective = new GraphQLDirective({\n                     name: 'deprecated',\n                     description: 'Marks an element of a GraphQL schema as no longer supported.',\n                     locations: [_directiveLocation.DirectiveLocation.FIELD_DEFINITION, _directiveLocation.DirectiveLocation.ARGUMENT_DEFINITION, _directiveLocation.DirectiveLocation.INPUT_FIELD_DEFINITION, _directiveLocation.DirectiveLocation.ENUM_VALUE],\n                     args: {\n                         reason: {\n                             type: _scalars.GraphQLString,\n                             description: 'Explains why this element was deprecated, usually also including a suggestion for how to access supported similar data. Formatted using the Markdown syntax, as specified by [CommonMark](https://commonmark.org/).',\n                             defaultValue: DEFAULT_DEPRECATION_REASON\n                         }\n                     }\n                 });\n                 /**\n                  * Used to provide a URL for specifying the behavior of custom scalar definitions.\n                  */\n-                exports.GraphQLDeprecatedDirective = GraphQLDeprecatedDirective;\n-                const GraphQLSpecifiedByDirective = new GraphQLDirective({\n+\n+                const GraphQLSpecifiedByDirective = exports.GraphQLSpecifiedByDirective = new GraphQLDirective({\n                     name: 'specifiedBy',\n                     description: 'Exposes a URL that specifies the behavior of this scalar.',\n                     locations: [_directiveLocation.DirectiveLocation.SCALAR],\n                     args: {\n                         url: {\n                             type: new _definition.GraphQLNonNull(_scalars.GraphQLString),\n                             description: 'The URL that specifies the behavior of this scalar.'\n                         }\n                     }\n                 });\n                 /**\n+                 * Used to indicate an Input Object is a OneOf Input Object.\n+                 */\n+\n+                const GraphQLOneOfDirective = exports.GraphQLOneOfDirective = new GraphQLDirective({\n+                    name: 'oneOf',\n+                    description: 'Indicates exactly one field must be supplied and this field must not be `null`.',\n+                    locations: [_directiveLocation.DirectiveLocation.INPUT_OBJECT],\n+                    args: {}\n+                });\n+                /**\n                  * The full list of specified directives.\n                  */\n-                exports.GraphQLSpecifiedByDirective = GraphQLSpecifiedByDirective;\n-                const specifiedDirectives = Object.freeze([GraphQLIncludeDirective, GraphQLSkipDirective, GraphQLDeprecatedDirective, GraphQLSpecifiedByDirective]);\n-                exports.specifiedDirectives = specifiedDirectives;\n+\n+                const specifiedDirectives = exports.specifiedDirectives = Object.freeze([GraphQLIncludeDirective, GraphQLSkipDirective, GraphQLDeprecatedDirective, GraphQLSpecifiedByDirective, GraphQLOneOfDirective]);\n \n                 function isSpecifiedDirective(directive) {\n-                    return specifiedDirectives.some(_ref => {\n-                        let {\n-                            name\n-                        } = _ref;\n-                        return name === directive.name;\n-                    });\n+                    return specifiedDirectives.some(({\n+                        name\n+                    }) => name === directive.name);\n                 }\n \n                 /***/\n             }),\n \n         /***/\n         \"../../../node_modules/graphql/type/index.mjs\":\n             /*!****************************************************!*\\\n               !*** ../../../node_modules/graphql/type/index.mjs ***!\n               \\****************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 Object.defineProperty(exports, \"DEFAULT_DEPRECATION_REASON\", ({\n                     enumerable: true,\n@@ -34657,14 +52663,20 @@\n                 }));\n                 Object.defineProperty(exports, \"GraphQLObjectType\", ({\n                     enumerable: true,\n                     get: function() {\n                         return _definition.GraphQLObjectType;\n                     }\n                 }));\n+                Object.defineProperty(exports, \"GraphQLOneOfDirective\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _directives.GraphQLOneOfDirective;\n+                    }\n+                }));\n                 Object.defineProperty(exports, \"GraphQLScalarType\", ({\n                     enumerable: true,\n                     get: function() {\n                         return _definition.GraphQLScalarType;\n                     }\n                 }));\n                 Object.defineProperty(exports, \"GraphQLSchema\", ({\n@@ -35108,29 +53120,30 @@\n         \"../../../node_modules/graphql/type/introspection.mjs\":\n             /*!************************************************************!*\\\n               !*** ../../../node_modules/graphql/type/introspection.mjs ***!\n               \\************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.introspectionTypes = exports.__TypeKind = exports.__Type = exports.__Schema = exports.__InputValue = exports.__Field = exports.__EnumValue = exports.__DirectiveLocation = exports.__Directive = exports.TypeNameMetaFieldDef = exports.TypeMetaFieldDef = exports.TypeKind = exports.SchemaMetaFieldDef = void 0;\n                 exports.isIntrospectionType = isIntrospectionType;\n                 var _inspect = __webpack_require__( /*! ../jsutils/inspect.mjs */ \"../../../node_modules/graphql/jsutils/inspect.mjs\");\n                 var _invariant = __webpack_require__( /*! ../jsutils/invariant.mjs */ \"../../../node_modules/graphql/jsutils/invariant.mjs\");\n                 var _directiveLocation = __webpack_require__( /*! ../language/directiveLocation.mjs */ \"../../../node_modules/graphql/language/directiveLocation.mjs\");\n                 var _printer = __webpack_require__( /*! ../language/printer.mjs */ \"../../../node_modules/graphql/language/printer.mjs\");\n                 var _astFromValue = __webpack_require__( /*! ../utilities/astFromValue.mjs */ \"../../../node_modules/graphql/utilities/astFromValue.mjs\");\n                 var _definition = __webpack_require__( /*! ./definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n                 var _scalars = __webpack_require__( /*! ./scalars.mjs */ \"../../../node_modules/graphql/type/scalars.mjs\");\n-                const __Schema = new _definition.GraphQLObjectType({\n+                const __Schema = exports.__Schema = new _definition.GraphQLObjectType({\n                     name: '__Schema',\n                     description: 'A GraphQL Schema defines the capabilities of a GraphQL server. It exposes all available types and directives on the server, as well as the entry points for query, mutation, and subscription operations.',\n                     fields: () => ({\n                         description: {\n                             type: _scalars.GraphQLString,\n                             resolve: schema => schema.description\n                         },\n@@ -35159,16 +53172,15 @@\n                         directives: {\n                             description: 'A list of all directives supported by this server.',\n                             type: new _definition.GraphQLNonNull(new _definition.GraphQLList(new _definition.GraphQLNonNull(__Directive))),\n                             resolve: schema => schema.getDirectives()\n                         }\n                     })\n                 });\n-                exports.__Schema = __Schema;\n-                const __Directive = new _definition.GraphQLObjectType({\n+                const __Directive = exports.__Directive = new _definition.GraphQLObjectType({\n                     name: '__Directive',\n                     description: \"A Directive provides a way to describe alternate runtime execution and type validation behavior in a GraphQL document.\\n\\nIn some cases, you need to provide options to alter GraphQL's execution behavior in ways field arguments will not suffice, such as conditionally including or skipping a field. Directives provide this by describing additional information to the executor.\",\n                     fields: () => ({\n                         name: {\n                             type: new _definition.GraphQLNonNull(_scalars.GraphQLString),\n                             resolve: directive => directive.name\n                         },\n@@ -35188,25 +53200,23 @@\n                             type: new _definition.GraphQLNonNull(new _definition.GraphQLList(new _definition.GraphQLNonNull(__InputValue))),\n                             args: {\n                                 includeDeprecated: {\n                                     type: _scalars.GraphQLBoolean,\n                                     defaultValue: false\n                                 }\n                             },\n-                            resolve(field, _ref) {\n-                                let {\n-                                    includeDeprecated\n-                                } = _ref;\n+                            resolve(field, {\n+                                includeDeprecated\n+                            }) {\n                                 return includeDeprecated ? field.args : field.args.filter(arg => arg.deprecationReason == null);\n                             }\n                         }\n                     })\n                 });\n-                exports.__Directive = __Directive;\n-                const __DirectiveLocation = new _definition.GraphQLEnumType({\n+                const __DirectiveLocation = exports.__DirectiveLocation = new _definition.GraphQLEnumType({\n                     name: '__DirectiveLocation',\n                     description: 'A Directive can be adjacent to many parts of the GraphQL language, a __DirectiveLocation describes one such possible adjacencies.',\n                     values: {\n                         QUERY: {\n                             value: _directiveLocation.DirectiveLocation.QUERY,\n                             description: 'Location adjacent to a query operation.'\n                         },\n@@ -35280,16 +53290,15 @@\n                         },\n                         INPUT_FIELD_DEFINITION: {\n                             value: _directiveLocation.DirectiveLocation.INPUT_FIELD_DEFINITION,\n                             description: 'Location adjacent to an input object field definition.'\n                         }\n                     }\n                 });\n-                exports.__DirectiveLocation = __DirectiveLocation;\n-                const __Type = new _definition.GraphQLObjectType({\n+                const __Type = exports.__Type = new _definition.GraphQLObjectType({\n                     name: '__Type',\n                     description: 'The fundamental unit of any GraphQL Schema is the type. There are many kinds of types in GraphQL as represented by the `__TypeKind` enum.\\n\\nDepending on the kind of a type, certain fields describe information about that type. Scalar types provide no information beyond a name, description and optional `specifiedByURL`, while Enum types provide their values. Object and Interface types provide the fields they describe. Abstract types, Union and Interface, provide the Object types possible at runtime. List and NonNull types compose other types.',\n                     fields: () => ({\n                         kind: {\n                             type: new _definition.GraphQLNonNull(__TypeKind),\n                             resolve(type) {\n                                 if ((0, _definition.isScalarType)(type)) {\n@@ -35340,18 +53349,17 @@\n                             type: new _definition.GraphQLList(new _definition.GraphQLNonNull(__Field)),\n                             args: {\n                                 includeDeprecated: {\n                                     type: _scalars.GraphQLBoolean,\n                                     defaultValue: false\n                                 }\n                             },\n-                            resolve(type, _ref2) {\n-                                let {\n-                                    includeDeprecated\n-                                } = _ref2;\n+                            resolve(type, {\n+                                includeDeprecated\n+                            }) {\n                                 if ((0, _definition.isObjectType)(type) || (0, _definition.isInterfaceType)(type)) {\n                                     const fields = Object.values(type.getFields());\n                                     return includeDeprecated ? fields : fields.filter(field => field.deprecationReason == null);\n                                 }\n                             }\n                         },\n                         interfaces: {\n@@ -35360,67 +53368,71 @@\n                                 if ((0, _definition.isObjectType)(type) || (0, _definition.isInterfaceType)(type)) {\n                                     return type.getInterfaces();\n                                 }\n                             }\n                         },\n                         possibleTypes: {\n                             type: new _definition.GraphQLList(new _definition.GraphQLNonNull(__Type)),\n-                            resolve(type, _args, _context, _ref3) {\n-                                let {\n-                                    schema\n-                                } = _ref3;\n+                            resolve(type, _args, _context, {\n+                                schema\n+                            }) {\n                                 if ((0, _definition.isAbstractType)(type)) {\n                                     return schema.getPossibleTypes(type);\n                                 }\n                             }\n                         },\n                         enumValues: {\n                             type: new _definition.GraphQLList(new _definition.GraphQLNonNull(__EnumValue)),\n                             args: {\n                                 includeDeprecated: {\n                                     type: _scalars.GraphQLBoolean,\n                                     defaultValue: false\n                                 }\n                             },\n-                            resolve(type, _ref4) {\n-                                let {\n-                                    includeDeprecated\n-                                } = _ref4;\n+                            resolve(type, {\n+                                includeDeprecated\n+                            }) {\n                                 if ((0, _definition.isEnumType)(type)) {\n                                     const values = type.getValues();\n                                     return includeDeprecated ? values : values.filter(field => field.deprecationReason == null);\n                                 }\n                             }\n                         },\n                         inputFields: {\n                             type: new _definition.GraphQLList(new _definition.GraphQLNonNull(__InputValue)),\n                             args: {\n                                 includeDeprecated: {\n                                     type: _scalars.GraphQLBoolean,\n                                     defaultValue: false\n                                 }\n                             },\n-                            resolve(type, _ref5) {\n-                                let {\n-                                    includeDeprecated\n-                                } = _ref5;\n+                            resolve(type, {\n+                                includeDeprecated\n+                            }) {\n                                 if ((0, _definition.isInputObjectType)(type)) {\n                                     const values = Object.values(type.getFields());\n                                     return includeDeprecated ? values : values.filter(field => field.deprecationReason == null);\n                                 }\n                             }\n                         },\n                         ofType: {\n                             type: __Type,\n                             resolve: type => 'ofType' in type ? type.ofType : undefined\n+                        },\n+                        isOneOf: {\n+                            type: _scalars.GraphQLBoolean,\n+                            resolve: type => {\n+                                if ((0, _definition.isInputObjectType)(type)) {\n+                                    return type.isOneOf;\n+                                }\n+                            }\n                         }\n                     })\n                 });\n-                exports.__Type = __Type;\n-                const __Field = new _definition.GraphQLObjectType({\n+                const __Field = exports.__Field = new _definition.GraphQLObjectType({\n                     name: '__Field',\n                     description: 'Object and Interface types are described by a list of Fields, each of which has a name, potentially a list of arguments, and a return type.',\n                     fields: () => ({\n                         name: {\n                             type: new _definition.GraphQLNonNull(_scalars.GraphQLString),\n                             resolve: field => field.name\n                         },\n@@ -35432,18 +53444,17 @@\n                             type: new _definition.GraphQLNonNull(new _definition.GraphQLList(new _definition.GraphQLNonNull(__InputValue))),\n                             args: {\n                                 includeDeprecated: {\n                                     type: _scalars.GraphQLBoolean,\n                                     defaultValue: false\n                                 }\n                             },\n-                            resolve(field, _ref6) {\n-                                let {\n-                                    includeDeprecated\n-                                } = _ref6;\n+                            resolve(field, {\n+                                includeDeprecated\n+                            }) {\n                                 return includeDeprecated ? field.args : field.args.filter(arg => arg.deprecationReason == null);\n                             }\n                         },\n                         type: {\n                             type: new _definition.GraphQLNonNull(__Type),\n                             resolve: field => field.type\n                         },\n@@ -35453,16 +53464,15 @@\n                         },\n                         deprecationReason: {\n                             type: _scalars.GraphQLString,\n                             resolve: field => field.deprecationReason\n                         }\n                     })\n                 });\n-                exports.__Field = __Field;\n-                const __InputValue = new _definition.GraphQLObjectType({\n+                const __InputValue = exports.__InputValue = new _definition.GraphQLObjectType({\n                     name: '__InputValue',\n                     description: 'Arguments provided to Fields or Directives and the input fields of an InputObject are represented as Input Values which describe their type and optionally a default value.',\n                     fields: () => ({\n                         name: {\n                             type: new _definition.GraphQLNonNull(_scalars.GraphQLString),\n                             resolve: inputValue => inputValue.name\n                         },\n@@ -35492,16 +53502,15 @@\n                         },\n                         deprecationReason: {\n                             type: _scalars.GraphQLString,\n                             resolve: obj => obj.deprecationReason\n                         }\n                     })\n                 });\n-                exports.__InputValue = __InputValue;\n-                const __EnumValue = new _definition.GraphQLObjectType({\n+                const __EnumValue = exports.__EnumValue = new _definition.GraphQLObjectType({\n                     name: '__EnumValue',\n                     description: 'One possible value for a given Enum. Enum values are unique values, not a placeholder for a string or numeric value. However an Enum value is returned in a JSON response as a string.',\n                     fields: () => ({\n                         name: {\n                             type: new _definition.GraphQLNonNull(_scalars.GraphQLString),\n                             resolve: enumValue => enumValue.name\n                         },\n@@ -35515,28 +53524,26 @@\n                         },\n                         deprecationReason: {\n                             type: _scalars.GraphQLString,\n                             resolve: enumValue => enumValue.deprecationReason\n                         }\n                     })\n                 });\n-                exports.__EnumValue = __EnumValue;\n                 var TypeKind;\n-                exports.TypeKind = TypeKind;\n                 (function(TypeKind) {\n                     TypeKind['SCALAR'] = 'SCALAR';\n                     TypeKind['OBJECT'] = 'OBJECT';\n                     TypeKind['INTERFACE'] = 'INTERFACE';\n                     TypeKind['UNION'] = 'UNION';\n                     TypeKind['ENUM'] = 'ENUM';\n                     TypeKind['INPUT_OBJECT'] = 'INPUT_OBJECT';\n                     TypeKind['LIST'] = 'LIST';\n                     TypeKind['NON_NULL'] = 'NON_NULL';\n                 })(TypeKind || (exports.TypeKind = TypeKind = {}));\n-                const __TypeKind = new _definition.GraphQLEnumType({\n+                const __TypeKind = exports.__TypeKind = new _definition.GraphQLEnumType({\n                     name: '__TypeKind',\n                     description: 'An enum describing what kind of type a given `__Type` is.',\n                     values: {\n                         SCALAR: {\n                             value: TypeKind.SCALAR,\n                             description: 'Indicates this type is a scalar.'\n                         },\n@@ -35570,97 +53577,81 @@\n                         }\n                     }\n                 });\n                 /**\n                  * Note that these are GraphQLField and not GraphQLFieldConfig,\n                  * so the format for args is different.\n                  */\n-                exports.__TypeKind = __TypeKind;\n-                const SchemaMetaFieldDef = {\n+\n+                const SchemaMetaFieldDef = exports.SchemaMetaFieldDef = {\n                     name: '__schema',\n                     type: new _definition.GraphQLNonNull(__Schema),\n                     description: 'Access the current type schema of this server.',\n                     args: [],\n-                    resolve: (_source, _args, _context, _ref7) => {\n-                        let {\n-                            schema\n-                        } = _ref7;\n-                        return schema;\n-                    },\n+                    resolve: (_source, _args, _context, {\n+                        schema\n+                    }) => schema,\n                     deprecationReason: undefined,\n                     extensions: Object.create(null),\n                     astNode: undefined\n                 };\n-                exports.SchemaMetaFieldDef = SchemaMetaFieldDef;\n-                const TypeMetaFieldDef = {\n+                const TypeMetaFieldDef = exports.TypeMetaFieldDef = {\n                     name: '__type',\n                     type: __Type,\n                     description: 'Request the type information of a single type.',\n                     args: [{\n                         name: 'name',\n                         description: undefined,\n                         type: new _definition.GraphQLNonNull(_scalars.GraphQLString),\n                         defaultValue: undefined,\n                         deprecationReason: undefined,\n                         extensions: Object.create(null),\n                         astNode: undefined\n                     }],\n-                    resolve: (_source, _ref8, _context, _ref9) => {\n-                        let {\n-                            name\n-                        } = _ref8;\n-                        let {\n-                            schema\n-                        } = _ref9;\n-                        return schema.getType(name);\n-                    },\n+                    resolve: (_source, {\n+                        name\n+                    }, _context, {\n+                        schema\n+                    }) => schema.getType(name),\n                     deprecationReason: undefined,\n                     extensions: Object.create(null),\n                     astNode: undefined\n                 };\n-                exports.TypeMetaFieldDef = TypeMetaFieldDef;\n-                const TypeNameMetaFieldDef = {\n+                const TypeNameMetaFieldDef = exports.TypeNameMetaFieldDef = {\n                     name: '__typename',\n                     type: new _definition.GraphQLNonNull(_scalars.GraphQLString),\n                     description: 'The name of the current Object type at runtime.',\n                     args: [],\n-                    resolve: (_source, _args, _context, _ref10) => {\n-                        let {\n-                            parentType\n-                        } = _ref10;\n-                        return parentType.name;\n-                    },\n+                    resolve: (_source, _args, _context, {\n+                        parentType\n+                    }) => parentType.name,\n                     deprecationReason: undefined,\n                     extensions: Object.create(null),\n                     astNode: undefined\n                 };\n-                exports.TypeNameMetaFieldDef = TypeNameMetaFieldDef;\n-                const introspectionTypes = Object.freeze([__Schema, __Directive, __DirectiveLocation, __Type, __Field, __InputValue, __EnumValue, __TypeKind]);\n-                exports.introspectionTypes = introspectionTypes;\n+                const introspectionTypes = exports.introspectionTypes = Object.freeze([__Schema, __Directive, __DirectiveLocation, __Type, __Field, __InputValue, __EnumValue, __TypeKind]);\n \n                 function isIntrospectionType(type) {\n-                    return introspectionTypes.some(_ref11 => {\n-                        let {\n-                            name\n-                        } = _ref11;\n-                        return type.name === name;\n-                    });\n+                    return introspectionTypes.some(({\n+                        name\n+                    }) => type.name === name);\n                 }\n \n                 /***/\n             }),\n \n         /***/\n         \"../../../node_modules/graphql/type/scalars.mjs\":\n             /*!******************************************************!*\\\n               !*** ../../../node_modules/graphql/type/scalars.mjs ***!\n               \\******************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.GraphQLString = exports.GraphQLInt = exports.GraphQLID = exports.GraphQLFloat = exports.GraphQLBoolean = exports.GRAPHQL_MIN_INT = exports.GRAPHQL_MAX_INT = void 0;\n                 exports.isSpecifiedScalarType = isSpecifiedScalarType;\n@@ -35672,23 +53663,22 @@\n                 var _printer = __webpack_require__( /*! ../language/printer.mjs */ \"../../../node_modules/graphql/language/printer.mjs\");\n                 var _definition = __webpack_require__( /*! ./definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n                 /**\n                  * Maximum possible Int value as per GraphQL Spec (32-bit signed integer).\n                  * n.b. This differs from JavaScript's numbers that are IEEE 754 doubles safe up-to 2^53 - 1\n                  * */\n \n-                const GRAPHQL_MAX_INT = 2147483647;\n+                const GRAPHQL_MAX_INT = exports.GRAPHQL_MAX_INT = 2147483647;\n                 /**\n                  * Minimum possible Int value as per GraphQL Spec (32-bit signed integer).\n                  * n.b. This differs from JavaScript's numbers that are IEEE 754 doubles safe starting at -(2^53 - 1)\n                  * */\n-                exports.GRAPHQL_MAX_INT = GRAPHQL_MAX_INT;\n-                const GRAPHQL_MIN_INT = -2147483648;\n-                exports.GRAPHQL_MIN_INT = GRAPHQL_MIN_INT;\n-                const GraphQLInt = new _definition.GraphQLScalarType({\n+\n+                const GRAPHQL_MIN_INT = exports.GRAPHQL_MIN_INT = -2147483648;\n+                const GraphQLInt = exports.GraphQLInt = new _definition.GraphQLScalarType({\n                     name: 'Int',\n                     description: 'The `Int` scalar type represents non-fractional signed whole numeric values. Int can represent values between -(2^31) and 2^31 - 1.',\n                     serialize(outputValue) {\n                         const coercedValue = serializeObject(outputValue);\n                         if (typeof coercedValue === 'boolean') {\n                             return coercedValue ? 1 : 0;\n                         }\n@@ -35724,16 +53714,15 @@\n                             throw new _GraphQLError.GraphQLError(`Int cannot represent non 32-bit signed integer value: ${valueNode.value}`, {\n                                 nodes: valueNode\n                             });\n                         }\n                         return num;\n                     }\n                 });\n-                exports.GraphQLInt = GraphQLInt;\n-                const GraphQLFloat = new _definition.GraphQLScalarType({\n+                const GraphQLFloat = exports.GraphQLFloat = new _definition.GraphQLScalarType({\n                     name: 'Float',\n                     description: 'The `Float` scalar type represents signed double-precision fractional values as specified by [IEEE 754](https://en.wikipedia.org/wiki/IEEE_floating_point).',\n                     serialize(outputValue) {\n                         const coercedValue = serializeObject(outputValue);\n                         if (typeof coercedValue === 'boolean') {\n                             return coercedValue ? 1 : 0;\n                         }\n@@ -35755,16 +53744,15 @@\n                     parseLiteral(valueNode) {\n                         if (valueNode.kind !== _kinds.Kind.FLOAT && valueNode.kind !== _kinds.Kind.INT) {\n                             throw new _GraphQLError.GraphQLError(`Float cannot represent non numeric value: ${(0, _printer.print)(valueNode)}`, valueNode);\n                         }\n                         return parseFloat(valueNode.value);\n                     }\n                 });\n-                exports.GraphQLFloat = GraphQLFloat;\n-                const GraphQLString = new _definition.GraphQLScalarType({\n+                const GraphQLString = exports.GraphQLString = new _definition.GraphQLScalarType({\n                     name: 'String',\n                     description: 'The `String` scalar type represents textual data, represented as UTF-8 character sequences. The String type is most often used by GraphQL to represent free-form human-readable text.',\n                     serialize(outputValue) {\n                         const coercedValue = serializeObject(outputValue); // Serialize string, boolean and number values to a string, but do not\n                         // attempt to coerce object, function, symbol, or other types as strings.\n \n                         if (typeof coercedValue === 'string') {\n@@ -35789,16 +53777,15 @@\n                             throw new _GraphQLError.GraphQLError(`String cannot represent a non string value: ${(0, _printer.print)(valueNode)}`, {\n                                 nodes: valueNode\n                             });\n                         }\n                         return valueNode.value;\n                     }\n                 });\n-                exports.GraphQLString = GraphQLString;\n-                const GraphQLBoolean = new _definition.GraphQLScalarType({\n+                const GraphQLBoolean = exports.GraphQLBoolean = new _definition.GraphQLScalarType({\n                     name: 'Boolean',\n                     description: 'The `Boolean` scalar type represents `true` or `false`.',\n                     serialize(outputValue) {\n                         const coercedValue = serializeObject(outputValue);\n                         if (typeof coercedValue === 'boolean') {\n                             return coercedValue;\n                         }\n@@ -35818,16 +53805,15 @@\n                             throw new _GraphQLError.GraphQLError(`Boolean cannot represent a non boolean value: ${(0, _printer.print)(valueNode)}`, {\n                                 nodes: valueNode\n                             });\n                         }\n                         return valueNode.value;\n                     }\n                 });\n-                exports.GraphQLBoolean = GraphQLBoolean;\n-                const GraphQLID = new _definition.GraphQLScalarType({\n+                const GraphQLID = exports.GraphQLID = new _definition.GraphQLScalarType({\n                     name: 'ID',\n                     description: 'The `ID` scalar type represents a unique identifier, often used to refetch an object or as key for a cache. The ID type appears in a JSON response as a String; however, it is not intended to be human-readable. When expected as an input type, any string (such as `\"4\"`) or integer (such as `4`) input value will be accepted as an ID.',\n                     serialize(outputValue) {\n                         const coercedValue = serializeObject(outputValue);\n                         if (typeof coercedValue === 'string') {\n                             return coercedValue;\n                         }\n@@ -35850,25 +53836,20 @@\n                             throw new _GraphQLError.GraphQLError('ID cannot represent a non-string and non-integer value: ' + (0, _printer.print)(valueNode), {\n                                 nodes: valueNode\n                             });\n                         }\n                         return valueNode.value;\n                     }\n                 });\n-                exports.GraphQLID = GraphQLID;\n-                const specifiedScalarTypes = Object.freeze([GraphQLString, GraphQLInt, GraphQLFloat, GraphQLBoolean, GraphQLID]);\n-                exports.specifiedScalarTypes = specifiedScalarTypes;\n+                const specifiedScalarTypes = exports.specifiedScalarTypes = Object.freeze([GraphQLString, GraphQLInt, GraphQLFloat, GraphQLBoolean, GraphQLID]);\n \n                 function isSpecifiedScalarType(type) {\n-                    return specifiedScalarTypes.some(_ref => {\n-                        let {\n-                            name\n-                        } = _ref;\n-                        return type.name === name;\n-                    });\n+                    return specifiedScalarTypes.some(({\n+                        name\n+                    }) => type.name === name);\n                 } // Support serializing objects with custom valueOf() or toJSON() functions -\n                 // a common way to represent a complex value which can be represented as\n                 // a string (ex: MongoDB id objects).\n \n                 function serializeObject(outputValue) {\n                     if ((0, _isObjectLike.isObjectLike)(outputValue)) {\n                         if (typeof outputValue.valueOf === 'function') {\n@@ -35891,14 +53872,15 @@\n         \"../../../node_modules/graphql/type/schema.mjs\":\n             /*!*****************************************************!*\\\n               !*** ../../../node_modules/graphql/type/schema.mjs ***!\n               \\*****************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.GraphQLSchema = void 0;\n                 exports.assertSchema = assertSchema;\n@@ -36216,14 +54198,15 @@\n         \"../../../node_modules/graphql/type/validate.mjs\":\n             /*!*******************************************************!*\\\n               !*** ../../../node_modules/graphql/type/validate.mjs ***!\n               \\*******************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.assertValidSchema = assertValidSchema;\n                 exports.validateSchema = validateSchema;\n@@ -36311,15 +54294,15 @@\n \n                 function getOperationTypeNode(schema, operation) {\n                     var _flatMap$find;\n                     return (_flatMap$find = [schema.astNode, ...schema.extensionASTNodes].flatMap(\n                         // FIXME: https://github.com/graphql/graphql-js/issues/2203\n                         schemaNode => {\n                             var _schemaNode$operation;\n-                            return ( /* c8 ignore next */\n+                            return /* c8 ignore next */ (\n                                 (_schemaNode$operation = schemaNode === null || schemaNode === void 0 ? void 0 : schemaNode.operationTypes) !== null && _schemaNode$operation !== void 0 ? _schemaNode$operation : []\n                             );\n                         }).find(operationNode => operationNode.operation === operation)) === null || _flatMap$find === void 0 ? void 0 : _flatMap$find.type;\n                 }\n \n                 function validateDirectives(context) {\n                     for (const directive of context.schema.getDirectives()) {\n@@ -36542,14 +54525,27 @@\n                             var _field$astNode2;\n                             context.reportError(`The type of ${inputObj.name}.${field.name} must be Input Type ` + `but got: ${(0, _inspect.inspect)(field.type)}.`, (_field$astNode2 = field.astNode) === null || _field$astNode2 === void 0 ? void 0 : _field$astNode2.type);\n                         }\n                         if ((0, _definition.isRequiredInputField)(field) && field.deprecationReason != null) {\n                             var _field$astNode3;\n                             context.reportError(`Required input field ${inputObj.name}.${field.name} cannot be deprecated.`, [getDeprecatedDirectiveNode(field.astNode), (_field$astNode3 = field.astNode) === null || _field$astNode3 === void 0 ? void 0 : _field$astNode3.type]);\n                         }\n+                        if (inputObj.isOneOf) {\n+                            validateOneOfInputObjectField(inputObj, field, context);\n+                        }\n+                    }\n+                }\n+\n+                function validateOneOfInputObjectField(type, field, context) {\n+                    if ((0, _definition.isNonNullType)(field.type)) {\n+                        var _field$astNode4;\n+                        context.reportError(`OneOf input field ${type.name}.${field.name} must be nullable.`, (_field$astNode4 = field.astNode) === null || _field$astNode4 === void 0 ? void 0 : _field$astNode4.type);\n+                    }\n+                    if (field.defaultValue !== undefined) {\n+                        context.reportError(`OneOf input field ${type.name}.${field.name} cannot have a default value.`, field.astNode);\n                     }\n                 }\n \n                 function createInputObjectCircularRefsValidator(context) {\n                     // Modified copy of algorithm from 'src/validation/rules/NoFragmentCycles.js'.\n                     // Tracks already visited types to maintain O(N) and to ensure that cycles\n                     // are not redundantly reported.\n@@ -36593,30 +54589,30 @@\n                         astNode,\n                         extensionASTNodes\n                     } = type;\n                     const nodes = astNode != null ? [astNode, ...extensionASTNodes] : extensionASTNodes; // FIXME: https://github.com/graphql/graphql-js/issues/2203\n \n                     return nodes.flatMap(typeNode => {\n                         var _typeNode$interfaces;\n-                        return ( /* c8 ignore next */\n+                        return /* c8 ignore next */ (\n                             (_typeNode$interfaces = typeNode.interfaces) !== null && _typeNode$interfaces !== void 0 ? _typeNode$interfaces : []\n                         );\n                     }).filter(ifaceNode => ifaceNode.name.value === iface.name);\n                 }\n \n                 function getUnionMemberTypeNodes(union, typeName) {\n                     const {\n                         astNode,\n                         extensionASTNodes\n                     } = union;\n                     const nodes = astNode != null ? [astNode, ...extensionASTNodes] : extensionASTNodes; // FIXME: https://github.com/graphql/graphql-js/issues/2203\n \n                     return nodes.flatMap(unionNode => {\n                         var _unionNode$types;\n-                        return ( /* c8 ignore next */\n+                        return /* c8 ignore next */ (\n                             (_unionNode$types = unionNode.types) !== null && _unionNode$types !== void 0 ? _unionNode$types : []\n                         );\n                     }).filter(typeNode => typeNode.name.value === typeName);\n                 }\n \n                 function getDeprecatedDirectiveNode(definitionNode) {\n                     var _definitionNode$direc;\n@@ -36630,14 +54626,15 @@\n         \"../../../node_modules/graphql/utilities/TypeInfo.mjs\":\n             /*!************************************************************!*\\\n               !*** ../../../node_modules/graphql/utilities/TypeInfo.mjs ***!\n               \\************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.TypeInfo = void 0;\n                 exports.visitWithTypeInfo = visitWithTypeInfo;\n@@ -36817,15 +54814,14 @@\n                                 }\n                                 this._enumValue = enumValue;\n                                 break;\n                             }\n                             default: // Ignore other nodes\n                         }\n                     }\n-\n                     leave(node) {\n                         switch (node.kind) {\n                             case _kinds.Kind.SELECTION_SET:\n                                 this._parentTypeStack.pop();\n                                 break;\n                             case _kinds.Kind.FIELD:\n                                 this._fieldDefStack.pop();\n@@ -36885,36 +54881,30 @@\n                 /**\n                  * Creates a new visitor instance which maintains a provided TypeInfo instance\n                  * along with visiting visitor.\n                  */\n \n                 function visitWithTypeInfo(typeInfo, visitor) {\n                     return {\n-                        enter() {\n-                            for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n-                                args[_key] = arguments[_key];\n-                            }\n+                        enter(...args) {\n                             const node = args[0];\n                             typeInfo.enter(node);\n                             const fn = (0, _visitor.getEnterLeaveForKind)(visitor, node.kind).enter;\n                             if (fn) {\n                                 const result = fn.apply(visitor, args);\n                                 if (result !== undefined) {\n                                     typeInfo.leave(node);\n                                     if ((0, _ast.isNode)(result)) {\n                                         typeInfo.enter(result);\n                                     }\n                                 }\n                                 return result;\n                             }\n                         },\n-                        leave() {\n-                            for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n-                                args[_key2] = arguments[_key2];\n-                            }\n+                        leave(...args) {\n                             const node = args[0];\n                             const fn = (0, _visitor.getEnterLeaveForKind)(visitor, node.kind).leave;\n                             let result;\n                             if (fn) {\n                                 result = fn.apply(visitor, args);\n                             }\n                             typeInfo.leave(node);\n@@ -36930,14 +54920,15 @@\n         \"../../../node_modules/graphql/utilities/assertValidName.mjs\":\n             /*!*******************************************************************!*\\\n               !*** ../../../node_modules/graphql/utilities/assertValidName.mjs ***!\n               \\*******************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.assertValidName = assertValidName;\n                 exports.isValidNameError = isValidNameError;\n@@ -36983,14 +54974,15 @@\n         \"../../../node_modules/graphql/utilities/astFromValue.mjs\":\n             /*!****************************************************************!*\\\n               !*** ../../../node_modules/graphql/utilities/astFromValue.mjs ***!\n               \\****************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.astFromValue = astFromValue;\n                 var _inspect = __webpack_require__( /*! ../jsutils/inspect.mjs */ \"../../../node_modules/graphql/jsutils/inspect.mjs\");\n@@ -37151,14 +55143,15 @@\n         \"../../../node_modules/graphql/utilities/buildASTSchema.mjs\":\n             /*!******************************************************************!*\\\n               !*** ../../../node_modules/graphql/utilities/buildASTSchema.mjs ***!\n               \\******************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.buildASTSchema = buildASTSchema;\n                 exports.buildSchema = buildSchema;\n@@ -37246,14 +55239,15 @@\n         \"../../../node_modules/graphql/utilities/buildClientSchema.mjs\":\n             /*!*********************************************************************!*\\\n               !*** ../../../node_modules/graphql/utilities/buildClientSchema.mjs ***!\n               \\*********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.buildClientSchema = buildClientSchema;\n                 var _devAssert = __webpack_require__( /*! ../jsutils/devAssert.mjs */ \"../../../node_modules/graphql/jsutils/devAssert.mjs\");\n@@ -37445,15 +55439,16 @@\n                         if (!inputObjectIntrospection.inputFields) {\n                             const inputObjectIntrospectionStr = (0, _inspect.inspect)(inputObjectIntrospection);\n                             throw new Error(`Introspection result missing inputFields: ${inputObjectIntrospectionStr}.`);\n                         }\n                         return new _definition.GraphQLInputObjectType({\n                             name: inputObjectIntrospection.name,\n                             description: inputObjectIntrospection.description,\n-                            fields: () => buildInputValueDefMap(inputObjectIntrospection.inputFields)\n+                            fields: () => buildInputValueDefMap(inputObjectIntrospection.inputFields),\n+                            isOneOf: inputObjectIntrospection.isOneOf\n                         });\n                     }\n \n                     function buildFieldDefMap(typeIntrospection) {\n                         if (!typeIntrospection.fields) {\n                             throw new Error(`Introspection result missing fields: ${(0, _inspect.inspect)(typeIntrospection)}.`);\n                         }\n@@ -37523,14 +55518,15 @@\n         \"../../../node_modules/graphql/utilities/coerceInputValue.mjs\":\n             /*!********************************************************************!*\\\n               !*** ../../../node_modules/graphql/utilities/coerceInputValue.mjs ***!\n               \\********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.coerceInputValue = coerceInputValue;\n                 var _didYouMean = __webpack_require__( /*! ../jsutils/didYouMean.mjs */ \"../../../node_modules/graphql/jsutils/didYouMean.mjs\");\n@@ -37542,16 +55538,15 @@\n                 var _printPathArray = __webpack_require__( /*! ../jsutils/printPathArray.mjs */ \"../../../node_modules/graphql/jsutils/printPathArray.mjs\");\n                 var _suggestionList = __webpack_require__( /*! ../jsutils/suggestionList.mjs */ \"../../../node_modules/graphql/jsutils/suggestionList.mjs\");\n                 var _GraphQLError = __webpack_require__( /*! ../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n                 var _definition = __webpack_require__( /*! ../type/definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n                 /**\n                  * Coerces a JavaScript value given a GraphQL Input Type.\n                  */\n-                function coerceInputValue(inputValue, type) {\n-                    let onError = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : defaultOnError;\n+                function coerceInputValue(inputValue, type, onError = defaultOnError) {\n                     return coerceInputValueImpl(inputValue, type, onError, undefined);\n                 }\n \n                 function defaultOnError(path, invalidValue, error) {\n                     let errorPrefix = 'Invalid value ' + (0, _inspect.inspect)(invalidValue);\n                     if (path.length > 0) {\n                         errorPrefix += ` at \"value${(0, _printPathArray.printPathArray)(path)}\"`;\n@@ -37606,14 +55601,25 @@\n \n                         for (const fieldName of Object.keys(inputValue)) {\n                             if (!fieldDefs[fieldName]) {\n                                 const suggestions = (0, _suggestionList.suggestionList)(fieldName, Object.keys(type.getFields()));\n                                 onError((0, _Path.pathToArray)(path), inputValue, new _GraphQLError.GraphQLError(`Field \"${fieldName}\" is not defined by type \"${type.name}\".` + (0, _didYouMean.didYouMean)(suggestions)));\n                             }\n                         }\n+                        if (type.isOneOf) {\n+                            const keys = Object.keys(coercedValue);\n+                            if (keys.length !== 1) {\n+                                onError((0, _Path.pathToArray)(path), inputValue, new _GraphQLError.GraphQLError(`Exactly one key must be specified for OneOf type \"${type.name}\".`));\n+                            }\n+                            const key = keys[0];\n+                            const value = coercedValue[key];\n+                            if (value === null) {\n+                                onError((0, _Path.pathToArray)(path).concat(key), value, new _GraphQLError.GraphQLError(`Field \"${key}\" must be non-null.`));\n+                            }\n+                        }\n                         return coercedValue;\n                     }\n                     if ((0, _definition.isLeafType)(type)) {\n                         let parseResult; // Scalars and Enums determine if a input value is valid via parseValue(),\n                         // which can throw to indicate failure. If it throws, maintain a reference\n                         // to the original error.\n \n@@ -37647,14 +55653,15 @@\n         \"../../../node_modules/graphql/utilities/concatAST.mjs\":\n             /*!*************************************************************!*\\\n               !*** ../../../node_modules/graphql/utilities/concatAST.mjs ***!\n               \\*************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.concatAST = concatAST;\n                 var _kinds = __webpack_require__( /*! ../language/kinds.mjs */ \"../../../node_modules/graphql/language/kinds.mjs\");\n@@ -37682,14 +55689,15 @@\n         \"../../../node_modules/graphql/utilities/extendSchema.mjs\":\n             /*!****************************************************************!*\\\n               !*** ../../../node_modules/graphql/utilities/extendSchema.mjs ***!\n               \\****************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.extendSchema = extendSchema;\n                 exports.extendSchemaImpl = extendSchemaImpl;\n@@ -37998,20 +56006,17 @@\n \n                     function buildDirective(node) {\n                         var _node$description;\n                         return new _directives.GraphQLDirective({\n                             name: node.name.value,\n                             description: (_node$description = node.description) === null || _node$description === void 0 ? void 0 : _node$description.value,\n                             // @ts-expect-error\n-                            locations: node.locations.map(_ref => {\n-                                let {\n-                                    value\n-                                } = _ref;\n-                                return value;\n-                            }),\n+                            locations: node.locations.map(({\n+                                value\n+                            }) => value),\n                             isRepeatable: node.repeatable,\n                             args: buildArgumentMap(node.arguments),\n                             astNode: node\n                         });\n                     }\n \n                     function buildFieldMap(nodes) {\n@@ -38114,30 +56119,30 @@\n                         // values below, that would throw immediately while type system\n                         // validation with validateSchema() will produce more actionable results.\n                         // @ts-expect-error\n                         return nodes.flatMap(\n                             // FIXME: https://github.com/graphql/graphql-js/issues/2203\n                             node => {\n                                 var _node$interfaces$map, _node$interfaces;\n-                                return ( /* c8 ignore next */\n+                                return /* c8 ignore next */ (\n                                     (_node$interfaces$map = (_node$interfaces = node.interfaces) === null || _node$interfaces === void 0 ? void 0 : _node$interfaces.map(getNamedType)) !== null && _node$interfaces$map !== void 0 ? _node$interfaces$map : []\n                                 );\n                             });\n                     }\n \n                     function buildUnionTypes(nodes) {\n                         // Note: While this could make assertions to get the correctly typed\n                         // values below, that would throw immediately while type system\n                         // validation with validateSchema() will produce more actionable results.\n                         // @ts-expect-error\n                         return nodes.flatMap(\n                             // FIXME: https://github.com/graphql/graphql-js/issues/2203\n                             node => {\n                                 var _node$types$map, _node$types;\n-                                return ( /* c8 ignore next */\n+                                return /* c8 ignore next */ (\n                                     (_node$types$map = (_node$types = node.types) === null || _node$types === void 0 ? void 0 : _node$types.map(getNamedType)) !== null && _node$types$map !== void 0 ? _node$types$map : []\n                                 );\n                             });\n                     }\n \n                     function buildType(astNode) {\n                         var _typeExtensionsMap$na;\n@@ -38204,15 +56209,16 @@\n                                 var _astNode$description6;\n                                 const allNodes = [astNode, ...extensionASTNodes];\n                                 return new _definition.GraphQLInputObjectType({\n                                     name,\n                                     description: (_astNode$description6 = astNode.description) === null || _astNode$description6 === void 0 ? void 0 : _astNode$description6.value,\n                                     fields: () => buildInputFieldMap(allNodes),\n                                     astNode,\n-                                    extensionASTNodes\n+                                    extensionASTNodes,\n+                                    isOneOf: isOneOf(astNode)\n                                 });\n                             }\n                         }\n                     }\n                 }\n                 const stdTypeMap = (0, _keyMap.keyMap)([..._scalars.specifiedScalarTypes, ..._introspection.introspectionTypes], type => type.name);\n                 /**\n@@ -38230,26 +56236,34 @@\n                  */\n \n                 function getSpecifiedByURL(node) {\n                     const specifiedBy = (0, _values.getDirectiveValues)(_directives.GraphQLSpecifiedByDirective, node); // @ts-expect-error validated by `getDirectiveValues`\n \n                     return specifiedBy === null || specifiedBy === void 0 ? void 0 : specifiedBy.url;\n                 }\n+                /**\n+                 * Given an input object node, returns if the node should be OneOf.\n+                 */\n+\n+                function isOneOf(node) {\n+                    return Boolean((0, _values.getDirectiveValues)(_directives.GraphQLOneOfDirective, node));\n+                }\n \n                 /***/\n             }),\n \n         /***/\n         \"../../../node_modules/graphql/utilities/findBreakingChanges.mjs\":\n             /*!***********************************************************************!*\\\n               !*** ../../../node_modules/graphql/utilities/findBreakingChanges.mjs ***!\n               \\***********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.DangerousChangeType = exports.BreakingChangeType = void 0;\n                 exports.findBreakingChanges = findBreakingChanges;\n@@ -38259,15 +56273,14 @@\n                 var _keyMap = __webpack_require__( /*! ../jsutils/keyMap.mjs */ \"../../../node_modules/graphql/jsutils/keyMap.mjs\");\n                 var _printer = __webpack_require__( /*! ../language/printer.mjs */ \"../../../node_modules/graphql/language/printer.mjs\");\n                 var _definition = __webpack_require__( /*! ../type/definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n                 var _scalars = __webpack_require__( /*! ../type/scalars.mjs */ \"../../../node_modules/graphql/type/scalars.mjs\");\n                 var _astFromValue = __webpack_require__( /*! ./astFromValue.mjs */ \"../../../node_modules/graphql/utilities/astFromValue.mjs\");\n                 var _sortValueNode = __webpack_require__( /*! ./sortValueNode.mjs */ \"../../../node_modules/graphql/utilities/sortValueNode.mjs\");\n                 var BreakingChangeType;\n-                exports.BreakingChangeType = BreakingChangeType;\n                 (function(BreakingChangeType) {\n                     BreakingChangeType['TYPE_REMOVED'] = 'TYPE_REMOVED';\n                     BreakingChangeType['TYPE_CHANGED_KIND'] = 'TYPE_CHANGED_KIND';\n                     BreakingChangeType['TYPE_REMOVED_FROM_UNION'] = 'TYPE_REMOVED_FROM_UNION';\n                     BreakingChangeType['VALUE_REMOVED_FROM_ENUM'] = 'VALUE_REMOVED_FROM_ENUM';\n                     BreakingChangeType['REQUIRED_INPUT_FIELD_ADDED'] = 'REQUIRED_INPUT_FIELD_ADDED';\n                     BreakingChangeType['IMPLEMENTED_INTERFACE_REMOVED'] = 'IMPLEMENTED_INTERFACE_REMOVED';\n@@ -38279,15 +56292,14 @@\n                     BreakingChangeType['DIRECTIVE_REMOVED'] = 'DIRECTIVE_REMOVED';\n                     BreakingChangeType['DIRECTIVE_ARG_REMOVED'] = 'DIRECTIVE_ARG_REMOVED';\n                     BreakingChangeType['REQUIRED_DIRECTIVE_ARG_ADDED'] = 'REQUIRED_DIRECTIVE_ARG_ADDED';\n                     BreakingChangeType['DIRECTIVE_REPEATABLE_REMOVED'] = 'DIRECTIVE_REPEATABLE_REMOVED';\n                     BreakingChangeType['DIRECTIVE_LOCATION_REMOVED'] = 'DIRECTIVE_LOCATION_REMOVED';\n                 })(BreakingChangeType || (exports.BreakingChangeType = BreakingChangeType = {}));\n                 var DangerousChangeType;\n-                exports.DangerousChangeType = DangerousChangeType;\n                 (function(DangerousChangeType) {\n                     DangerousChangeType['VALUE_ADDED_TO_ENUM'] = 'VALUE_ADDED_TO_ENUM';\n                     DangerousChangeType['TYPE_ADDED_TO_UNION'] = 'TYPE_ADDED_TO_UNION';\n                     DangerousChangeType['OPTIONAL_INPUT_FIELD_ADDED'] = 'OPTIONAL_INPUT_FIELD_ADDED';\n                     DangerousChangeType['OPTIONAL_ARG_ADDED'] = 'OPTIONAL_ARG_ADDED';\n                     DangerousChangeType['IMPLEMENTED_INTERFACE_ADDED'] = 'IMPLEMENTED_INTERFACE_ADDED';\n                     DangerousChangeType['ARG_DEFAULT_VALUE_CHANGE'] = 'ARG_DEFAULT_VALUE_CHANGE';\n@@ -38620,26 +56632,20 @@\n                     return (0, _printer.print)((0, _sortValueNode.sortValueNode)(ast));\n                 }\n \n                 function diff(oldArray, newArray) {\n                     const added = [];\n                     const removed = [];\n                     const persisted = [];\n-                    const oldMap = (0, _keyMap.keyMap)(oldArray, _ref => {\n-                        let {\n-                            name\n-                        } = _ref;\n-                        return name;\n-                    });\n-                    const newMap = (0, _keyMap.keyMap)(newArray, _ref2 => {\n-                        let {\n-                            name\n-                        } = _ref2;\n-                        return name;\n-                    });\n+                    const oldMap = (0, _keyMap.keyMap)(oldArray, ({\n+                        name\n+                    }) => name);\n+                    const newMap = (0, _keyMap.keyMap)(newArray, ({\n+                        name\n+                    }) => name);\n                     for (const oldItem of oldArray) {\n                         const newItem = newMap[oldItem.name];\n                         if (newItem === undefined) {\n                             removed.push(oldItem);\n                         } else {\n                             persisted.push([oldItem, newItem]);\n                         }\n@@ -38663,14 +56669,15 @@\n         \"../../../node_modules/graphql/utilities/getIntrospectionQuery.mjs\":\n             /*!*************************************************************************!*\\\n               !*** ../../../node_modules/graphql/utilities/getIntrospectionQuery.mjs ***!\n               \\*************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.getIntrospectionQuery = getIntrospectionQuery;\n                 /**\n@@ -38680,24 +56687,26 @@\n                 function getIntrospectionQuery(options) {\n                     const optionsWithDefault = {\n                         descriptions: true,\n                         specifiedByUrl: false,\n                         directiveIsRepeatable: false,\n                         schemaDescription: false,\n                         inputValueDeprecation: false,\n+                        oneOf: false,\n                         ...options\n                     };\n                     const descriptions = optionsWithDefault.descriptions ? 'description' : '';\n                     const specifiedByUrl = optionsWithDefault.specifiedByUrl ? 'specifiedByURL' : '';\n                     const directiveIsRepeatable = optionsWithDefault.directiveIsRepeatable ? 'isRepeatable' : '';\n                     const schemaDescription = optionsWithDefault.schemaDescription ? descriptions : '';\n \n                     function inputDeprecation(str) {\n                         return optionsWithDefault.inputValueDeprecation ? str : '';\n                     }\n+                    const oneOf = optionsWithDefault.oneOf ? 'isOneOf' : '';\n                     return `\n     query IntrospectionQuery {\n       __schema {\n         ${schemaDescription}\n         queryType { name }\n         mutationType { name }\n         subscriptionType { name }\n@@ -38717,14 +56726,15 @@\n     }\n \n     fragment FullType on __Type {\n       kind\n       name\n       ${descriptions}\n       ${specifiedByUrl}\n+      ${oneOf}\n       fields(includeDeprecated: true) {\n         name\n         ${descriptions}\n         args${inputDeprecation('(includeDeprecated: true)')} {\n           ...InputValue\n         }\n         type {\n@@ -38809,14 +56819,15 @@\n         \"../../../node_modules/graphql/utilities/getOperationAST.mjs\":\n             /*!*******************************************************************!*\\\n               !*** ../../../node_modules/graphql/utilities/getOperationAST.mjs ***!\n               \\*******************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.getOperationAST = getOperationAST;\n                 var _kinds = __webpack_require__( /*! ../language/kinds.mjs */ \"../../../node_modules/graphql/language/kinds.mjs\");\n@@ -38854,14 +56865,15 @@\n         \"../../../node_modules/graphql/utilities/getOperationRootType.mjs\":\n             /*!************************************************************************!*\\\n               !*** ../../../node_modules/graphql/utilities/getOperationRootType.mjs ***!\n               \\************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.getOperationRootType = getOperationRootType;\n                 var _GraphQLError = __webpack_require__( /*! ../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n@@ -38910,14 +56922,15 @@\n         \"../../../node_modules/graphql/utilities/index.mjs\":\n             /*!*********************************************************!*\\\n               !*** ../../../node_modules/graphql/utilities/index.mjs ***!\n               \\*********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 Object.defineProperty(exports, \"BreakingChangeType\", ({\n                     enumerable: true,\n@@ -39134,14 +57147,15 @@\n         \"../../../node_modules/graphql/utilities/introspectionFromSchema.mjs\":\n             /*!***************************************************************************!*\\\n               !*** ../../../node_modules/graphql/utilities/introspectionFromSchema.mjs ***!\n               \\***************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.introspectionFromSchema = introspectionFromSchema;\n                 var _invariant = __webpack_require__( /*! ../jsutils/invariant.mjs */ \"../../../node_modules/graphql/jsutils/invariant.mjs\");\n@@ -39160,14 +57174,15 @@\n \n                 function introspectionFromSchema(schema, options) {\n                     const optionsWithDefaults = {\n                         specifiedByUrl: true,\n                         directiveIsRepeatable: true,\n                         schemaDescription: true,\n                         inputValueDeprecation: true,\n+                        oneOf: true,\n                         ...options\n                     };\n                     const document = (0, _parser.parse)((0, _getIntrospectionQuery.getIntrospectionQuery)(optionsWithDefaults));\n                     const result = (0, _execute.executeSync)({\n                         schema,\n                         document\n                     });\n@@ -39182,14 +57197,15 @@\n         \"../../../node_modules/graphql/utilities/lexicographicSortSchema.mjs\":\n             /*!***************************************************************************!*\\\n               !*** ../../../node_modules/graphql/utilities/lexicographicSortSchema.mjs ***!\n               \\***************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.lexicographicSortSchema = lexicographicSortSchema;\n                 var _inspect = __webpack_require__( /*! ../jsutils/inspect.mjs */ \"../../../node_modules/graphql/jsutils/inspect.mjs\");\n@@ -39348,14 +57364,15 @@\n         \"../../../node_modules/graphql/utilities/printSchema.mjs\":\n             /*!***************************************************************!*\\\n               !*** ../../../node_modules/graphql/utilities/printSchema.mjs ***!\n               \\***************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.printIntrospectionSchema = printIntrospectionSchema;\n                 exports.printSchema = printSchema;\n@@ -39491,28 +57508,27 @@\n                 function printEnum(type) {\n                     const values = type.getValues().map((value, i) => printDescription(value, '  ', !i) + '  ' + value.name + printDeprecated(value.deprecationReason));\n                     return printDescription(type) + `enum ${type.name}` + printBlock(values);\n                 }\n \n                 function printInputObject(type) {\n                     const fields = Object.values(type.getFields()).map((f, i) => printDescription(f, '  ', !i) + '  ' + printInputValue(f));\n-                    return printDescription(type) + `input ${type.name}` + printBlock(fields);\n+                    return printDescription(type) + `input ${type.name}` + (type.isOneOf ? ' @oneOf' : '') + printBlock(fields);\n                 }\n \n                 function printFields(type) {\n                     const fields = Object.values(type.getFields()).map((f, i) => printDescription(f, '  ', !i) + '  ' + f.name + printArgs(f.args, '  ') + ': ' + String(f.type) + printDeprecated(f.deprecationReason));\n                     return printBlock(fields);\n                 }\n \n                 function printBlock(items) {\n                     return items.length !== 0 ? ' {\\n' + items.join('\\n') + '\\n}' : '';\n                 }\n \n-                function printArgs(args) {\n-                    let indentation = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';\n+                function printArgs(args, indentation = '') {\n                     if (args.length === 0) {\n                         return '';\n                     } // If every arg does not have a description, print them on one line.\n \n                     if (args.every(arg => !arg.description)) {\n                         return '(' + args.map(printInputValue).join(', ') + ')';\n                     }\n@@ -39553,17 +57569,15 @@\n                     const astValue = (0, _printer.print)({\n                         kind: _kinds.Kind.STRING,\n                         value: scalar.specifiedByURL\n                     });\n                     return ` @specifiedBy(url: ${astValue})`;\n                 }\n \n-                function printDescription(def) {\n-                    let indentation = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';\n-                    let firstInBlock = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;\n+                function printDescription(def, indentation = '', firstInBlock = true) {\n                     const {\n                         description\n                     } = def;\n                     if (description == null) {\n                         return '';\n                     }\n                     const blockString = (0, _printer.print)({\n@@ -39582,14 +57596,15 @@\n         \"../../../node_modules/graphql/utilities/separateOperations.mjs\":\n             /*!**********************************************************************!*\\\n               !*** ../../../node_modules/graphql/utilities/separateOperations.mjs ***!\n               \\**********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.separateOperations = separateOperations;\n                 var _kinds = __webpack_require__( /*! ../language/kinds.mjs */ \"../../../node_modules/graphql/language/kinds.mjs\");\n@@ -39667,14 +57682,15 @@\n         \"../../../node_modules/graphql/utilities/sortValueNode.mjs\":\n             /*!*****************************************************************!*\\\n               !*** ../../../node_modules/graphql/utilities/sortValueNode.mjs ***!\n               \\*****************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.sortValueNode = sortValueNode;\n                 var _naturalCompare = __webpack_require__( /*! ../jsutils/naturalCompare.mjs */ \"../../../node_modules/graphql/jsutils/naturalCompare.mjs\");\n@@ -39724,14 +57740,15 @@\n         \"../../../node_modules/graphql/utilities/stripIgnoredCharacters.mjs\":\n             /*!**************************************************************************!*\\\n               !*** ../../../node_modules/graphql/utilities/stripIgnoredCharacters.mjs ***!\n               \\**************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.stripIgnoredCharacters = stripIgnoredCharacters;\n                 var _blockString = __webpack_require__( /*! ../language/blockString.mjs */ \"../../../node_modules/graphql/language/blockString.mjs\");\n@@ -39840,14 +57857,15 @@\n         \"../../../node_modules/graphql/utilities/typeComparators.mjs\":\n             /*!*******************************************************************!*\\\n               !*** ../../../node_modules/graphql/utilities/typeComparators.mjs ***!\n               \\*******************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.doTypesOverlap = doTypesOverlap;\n                 exports.isEqualType = isEqualType;\n@@ -39947,14 +57965,15 @@\n         \"../../../node_modules/graphql/utilities/typeFromAST.mjs\":\n             /*!***************************************************************!*\\\n               !*** ../../../node_modules/graphql/utilities/typeFromAST.mjs ***!\n               \\***************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.typeFromAST = typeFromAST;\n                 var _kinds = __webpack_require__( /*! ../language/kinds.mjs */ \"../../../node_modules/graphql/language/kinds.mjs\");\n@@ -39982,14 +58001,15 @@\n         \"../../../node_modules/graphql/utilities/valueFromAST.mjs\":\n             /*!****************************************************************!*\\\n               !*** ../../../node_modules/graphql/utilities/valueFromAST.mjs ***!\n               \\****************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.valueFromAST = valueFromAST;\n                 var _inspect = __webpack_require__( /*! ../jsutils/inspect.mjs */ \"../../../node_modules/graphql/jsutils/inspect.mjs\");\n@@ -40039,15 +58059,14 @@\n \n                         return variableValue;\n                     }\n                     if ((0, _definition.isNonNullType)(type)) {\n                         if (valueNode.kind === _kinds.Kind.NULL) {\n                             return; // Invalid: intentionally return no value.\n                         }\n-\n                         return valueFromAST(valueNode, type.ofType, variables);\n                     }\n                     if (valueNode.kind === _kinds.Kind.NULL) {\n                         // This is explicitly returning the value null.\n                         return null;\n                     }\n                     if ((0, _definition.isListType)(type)) {\n@@ -40057,76 +58076,77 @@\n                             for (const itemNode of valueNode.values) {\n                                 if (isMissingVariable(itemNode, variables)) {\n                                     // If an array contains a missing variable, it is either coerced to\n                                     // null or if the item type is non-null, it considered invalid.\n                                     if ((0, _definition.isNonNullType)(itemType)) {\n                                         return; // Invalid: intentionally return no value.\n                                     }\n-\n                                     coercedValues.push(null);\n                                 } else {\n                                     const itemValue = valueFromAST(itemNode, itemType, variables);\n                                     if (itemValue === undefined) {\n                                         return; // Invalid: intentionally return no value.\n                                     }\n-\n                                     coercedValues.push(itemValue);\n                                 }\n                             }\n                             return coercedValues;\n                         }\n                         const coercedValue = valueFromAST(valueNode, itemType, variables);\n                         if (coercedValue === undefined) {\n                             return; // Invalid: intentionally return no value.\n                         }\n-\n                         return [coercedValue];\n                     }\n                     if ((0, _definition.isInputObjectType)(type)) {\n                         if (valueNode.kind !== _kinds.Kind.OBJECT) {\n                             return; // Invalid: intentionally return no value.\n                         }\n-\n                         const coercedObj = Object.create(null);\n                         const fieldNodes = (0, _keyMap.keyMap)(valueNode.fields, field => field.name.value);\n                         for (const field of Object.values(type.getFields())) {\n                             const fieldNode = fieldNodes[field.name];\n                             if (!fieldNode || isMissingVariable(fieldNode.value, variables)) {\n                                 if (field.defaultValue !== undefined) {\n                                     coercedObj[field.name] = field.defaultValue;\n                                 } else if ((0, _definition.isNonNullType)(field.type)) {\n                                     return; // Invalid: intentionally return no value.\n                                 }\n-\n                                 continue;\n                             }\n                             const fieldValue = valueFromAST(fieldNode.value, field.type, variables);\n                             if (fieldValue === undefined) {\n                                 return; // Invalid: intentionally return no value.\n                             }\n-\n                             coercedObj[field.name] = fieldValue;\n                         }\n+                        if (type.isOneOf) {\n+                            const keys = Object.keys(coercedObj);\n+                            if (keys.length !== 1) {\n+                                return; // Invalid: not exactly one key, intentionally return no value.\n+                            }\n+                            if (coercedObj[keys[0]] === null) {\n+                                return; // Invalid: value not non-null, intentionally return no value.\n+                            }\n+                        }\n                         return coercedObj;\n                     }\n                     if ((0, _definition.isLeafType)(type)) {\n                         // Scalars and Enums fulfill parsing a literal value via parseLiteral().\n                         // Invalid values represent a failure to parse correctly, in which case\n                         // no value is returned.\n                         let result;\n                         try {\n                             result = type.parseLiteral(valueNode, variables);\n                         } catch (_error) {\n                             return; // Invalid: intentionally return no value.\n                         }\n-\n                         if (result === undefined) {\n                             return; // Invalid: intentionally return no value.\n                         }\n-\n                         return result;\n                     }\n                     /* c8 ignore next 3 */\n                     // Not reachable, all possible input types have been considered.\n \n                     false || (0, _invariant.invariant)(false, 'Unexpected input type: ' + (0, _inspect.inspect)(type));\n                 } // Returns true if the provided valueNode is a variable which is not defined\n@@ -40143,14 +58163,15 @@\n         \"../../../node_modules/graphql/utilities/valueFromASTUntyped.mjs\":\n             /*!***********************************************************************!*\\\n               !*** ../../../node_modules/graphql/utilities/valueFromASTUntyped.mjs ***!\n               \\***********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.valueFromASTUntyped = valueFromASTUntyped;\n                 var _keyValMap = __webpack_require__( /*! ../jsutils/keyValMap.mjs */ \"../../../node_modules/graphql/jsutils/keyValMap.mjs\");\n@@ -40200,14 +58221,15 @@\n         \"../../../node_modules/graphql/validation/ValidationContext.mjs\":\n             /*!**********************************************************************!*\\\n               !*** ../../../node_modules/graphql/validation/ValidationContext.mjs ***!\n               \\**********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.ValidationContext = exports.SDLValidationContext = exports.ASTValidationContext = void 0;\n                 var _kinds = __webpack_require__( /*! ../language/kinds.mjs */ \"../../../node_modules/graphql/language/kinds.mjs\");\n@@ -40387,14 +58409,15 @@\n         \"../../../node_modules/graphql/validation/index.mjs\":\n             /*!**********************************************************!*\\\n               !*** ../../../node_modules/graphql/validation/index.mjs ***!\n               \\**********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 Object.defineProperty(exports, \"ExecutableDefinitionsRule\", ({\n                     enumerable: true,\n@@ -40446,14 +58469,20 @@\n                 }));\n                 Object.defineProperty(exports, \"LoneSchemaDefinitionRule\", ({\n                     enumerable: true,\n                     get: function() {\n                         return _LoneSchemaDefinitionRule.LoneSchemaDefinitionRule;\n                     }\n                 }));\n+                Object.defineProperty(exports, \"MaxIntrospectionDepthRule\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _MaxIntrospectionDepthRule.MaxIntrospectionDepthRule;\n+                    }\n+                }));\n                 Object.defineProperty(exports, \"NoDeprecatedCustomRule\", ({\n                     enumerable: true,\n                     get: function() {\n                         return _NoDeprecatedCustomRule.NoDeprecatedCustomRule;\n                     }\n                 }));\n                 Object.defineProperty(exports, \"NoFragmentCyclesRule\", ({\n@@ -40614,14 +58643,20 @@\n                 }));\n                 Object.defineProperty(exports, \"VariablesInAllowedPositionRule\", ({\n                     enumerable: true,\n                     get: function() {\n                         return _VariablesInAllowedPositionRule.VariablesInAllowedPositionRule;\n                     }\n                 }));\n+                Object.defineProperty(exports, \"recommendedRules\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _specifiedRules.recommendedRules;\n+                    }\n+                }));\n                 Object.defineProperty(exports, \"specifiedRules\", ({\n                     enumerable: true,\n                     get: function() {\n                         return _specifiedRules.specifiedRules;\n                     }\n                 }));\n                 Object.defineProperty(exports, \"validate\", ({\n@@ -40655,14 +58690,15 @@\n                 var _UniqueFragmentNamesRule = __webpack_require__( /*! ./rules/UniqueFragmentNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueFragmentNamesRule.mjs\");\n                 var _UniqueInputFieldNamesRule = __webpack_require__( /*! ./rules/UniqueInputFieldNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueInputFieldNamesRule.mjs\");\n                 var _UniqueOperationNamesRule = __webpack_require__( /*! ./rules/UniqueOperationNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueOperationNamesRule.mjs\");\n                 var _UniqueVariableNamesRule = __webpack_require__( /*! ./rules/UniqueVariableNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueVariableNamesRule.mjs\");\n                 var _ValuesOfCorrectTypeRule = __webpack_require__( /*! ./rules/ValuesOfCorrectTypeRule.mjs */ \"../../../node_modules/graphql/validation/rules/ValuesOfCorrectTypeRule.mjs\");\n                 var _VariablesAreInputTypesRule = __webpack_require__( /*! ./rules/VariablesAreInputTypesRule.mjs */ \"../../../node_modules/graphql/validation/rules/VariablesAreInputTypesRule.mjs\");\n                 var _VariablesInAllowedPositionRule = __webpack_require__( /*! ./rules/VariablesInAllowedPositionRule.mjs */ \"../../../node_modules/graphql/validation/rules/VariablesInAllowedPositionRule.mjs\");\n+                var _MaxIntrospectionDepthRule = __webpack_require__( /*! ./rules/MaxIntrospectionDepthRule.mjs */ \"../../../node_modules/graphql/validation/rules/MaxIntrospectionDepthRule.mjs\");\n                 var _LoneSchemaDefinitionRule = __webpack_require__( /*! ./rules/LoneSchemaDefinitionRule.mjs */ \"../../../node_modules/graphql/validation/rules/LoneSchemaDefinitionRule.mjs\");\n                 var _UniqueOperationTypesRule = __webpack_require__( /*! ./rules/UniqueOperationTypesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueOperationTypesRule.mjs\");\n                 var _UniqueTypeNamesRule = __webpack_require__( /*! ./rules/UniqueTypeNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueTypeNamesRule.mjs\");\n                 var _UniqueEnumValueNamesRule = __webpack_require__( /*! ./rules/UniqueEnumValueNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueEnumValueNamesRule.mjs\");\n                 var _UniqueFieldDefinitionNamesRule = __webpack_require__( /*! ./rules/UniqueFieldDefinitionNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueFieldDefinitionNamesRule.mjs\");\n                 var _UniqueArgumentDefinitionNamesRule = __webpack_require__( /*! ./rules/UniqueArgumentDefinitionNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueArgumentDefinitionNamesRule.mjs\");\n                 var _UniqueDirectiveNamesRule = __webpack_require__( /*! ./rules/UniqueDirectiveNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueDirectiveNamesRule.mjs\");\n@@ -40677,14 +58713,15 @@\n         \"../../../node_modules/graphql/validation/rules/ExecutableDefinitionsRule.mjs\":\n             /*!************************************************************************************!*\\\n               !*** ../../../node_modules/graphql/validation/rules/ExecutableDefinitionsRule.mjs ***!\n               \\************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.ExecutableDefinitionsRule = ExecutableDefinitionsRule;\n                 var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n@@ -40721,14 +58758,15 @@\n         \"../../../node_modules/graphql/validation/rules/FieldsOnCorrectTypeRule.mjs\":\n             /*!**********************************************************************************!*\\\n               !*** ../../../node_modules/graphql/validation/rules/FieldsOnCorrectTypeRule.mjs ***!\n               \\**********************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.FieldsOnCorrectTypeRule = FieldsOnCorrectTypeRule;\n                 var _didYouMean = __webpack_require__( /*! ../../jsutils/didYouMean.mjs */ \"../../../node_modules/graphql/jsutils/didYouMean.mjs\");\n@@ -40836,14 +58874,15 @@\n         \"../../../node_modules/graphql/validation/rules/FragmentsOnCompositeTypesRule.mjs\":\n             /*!****************************************************************************************!*\\\n               !*** ../../../node_modules/graphql/validation/rules/FragmentsOnCompositeTypesRule.mjs ***!\n               \\****************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.FragmentsOnCompositeTypesRule = FragmentsOnCompositeTypesRule;\n                 var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n@@ -40892,14 +58931,15 @@\n         \"../../../node_modules/graphql/validation/rules/KnownArgumentNamesRule.mjs\":\n             /*!*********************************************************************************!*\\\n               !*** ../../../node_modules/graphql/validation/rules/KnownArgumentNamesRule.mjs ***!\n               \\*********************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.KnownArgumentNamesOnDirectivesRule = KnownArgumentNamesOnDirectivesRule;\n                 exports.KnownArgumentNamesRule = KnownArgumentNamesRule;\n@@ -40986,14 +59026,15 @@\n         \"../../../node_modules/graphql/validation/rules/KnownDirectivesRule.mjs\":\n             /*!******************************************************************************!*\\\n               !*** ../../../node_modules/graphql/validation/rules/KnownDirectivesRule.mjs ***!\n               \\******************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.KnownDirectivesRule = KnownDirectivesRule;\n                 var _inspect = __webpack_require__( /*! ../../jsutils/inspect.mjs */ \"../../../node_modules/graphql/jsutils/inspect.mjs\");\n@@ -41117,14 +59158,15 @@\n         \"../../../node_modules/graphql/validation/rules/KnownFragmentNamesRule.mjs\":\n             /*!*********************************************************************************!*\\\n               !*** ../../../node_modules/graphql/validation/rules/KnownFragmentNamesRule.mjs ***!\n               \\*********************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.KnownFragmentNamesRule = KnownFragmentNamesRule;\n                 var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n@@ -41157,14 +59199,15 @@\n         \"../../../node_modules/graphql/validation/rules/KnownTypeNamesRule.mjs\":\n             /*!*****************************************************************************!*\\\n               !*** ../../../node_modules/graphql/validation/rules/KnownTypeNamesRule.mjs ***!\n               \\*****************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.KnownTypeNamesRule = KnownTypeNamesRule;\n                 var _didYouMean = __webpack_require__( /*! ../../jsutils/didYouMean.mjs */ \"../../../node_modules/graphql/jsutils/didYouMean.mjs\");\n@@ -41222,14 +59265,15 @@\n         \"../../../node_modules/graphql/validation/rules/LoneAnonymousOperationRule.mjs\":\n             /*!*************************************************************************************!*\\\n               !*** ../../../node_modules/graphql/validation/rules/LoneAnonymousOperationRule.mjs ***!\n               \\*************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.LoneAnonymousOperationRule = LoneAnonymousOperationRule;\n                 var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n@@ -41265,14 +59309,15 @@\n         \"../../../node_modules/graphql/validation/rules/LoneSchemaDefinitionRule.mjs\":\n             /*!***********************************************************************************!*\\\n               !*** ../../../node_modules/graphql/validation/rules/LoneSchemaDefinitionRule.mjs ***!\n               \\***********************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.LoneSchemaDefinitionRule = LoneSchemaDefinitionRule;\n                 var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n@@ -41304,21 +59349,106 @@\n                     };\n                 }\n \n                 /***/\n             }),\n \n         /***/\n+        \"../../../node_modules/graphql/validation/rules/MaxIntrospectionDepthRule.mjs\":\n+            /*!************************************************************************************!*\\\n+              !*** ../../../node_modules/graphql/validation/rules/MaxIntrospectionDepthRule.mjs ***!\n+              \\************************************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.MaxIntrospectionDepthRule = MaxIntrospectionDepthRule;\n+                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n+                var _kinds = __webpack_require__( /*! ../../language/kinds.mjs */ \"../../../node_modules/graphql/language/kinds.mjs\");\n+                const MAX_LISTS_DEPTH = 3;\n+\n+                function MaxIntrospectionDepthRule(context) {\n+                    /**\n+                     * Counts the depth of list fields in \"__Type\" recursively and\n+                     * returns `true` if the limit has been reached.\n+                     */\n+                    function checkDepth(node, visitedFragments = Object.create(null), depth = 0) {\n+                        if (node.kind === _kinds.Kind.FRAGMENT_SPREAD) {\n+                            const fragmentName = node.name.value;\n+                            if (visitedFragments[fragmentName] === true) {\n+                                // Fragment cycles are handled by `NoFragmentCyclesRule`.\n+                                return false;\n+                            }\n+                            const fragment = context.getFragment(fragmentName);\n+                            if (!fragment) {\n+                                // Missing fragments checks are handled by `KnownFragmentNamesRule`.\n+                                return false;\n+                            } // Rather than following an immutable programming pattern which has\n+                            // significant memory and garbage collection overhead, we've opted to\n+                            // take a mutable approach for efficiency's sake. Importantly visiting a\n+                            // fragment twice is fine, so long as you don't do one visit inside the\n+                            // other.\n+\n+                            try {\n+                                visitedFragments[fragmentName] = true;\n+                                return checkDepth(fragment, visitedFragments, depth);\n+                            } finally {\n+                                visitedFragments[fragmentName] = undefined;\n+                            }\n+                        }\n+                        if (node.kind === _kinds.Kind.FIELD && (\n+                                // check all introspection lists\n+                                node.name.value === 'fields' || node.name.value === 'interfaces' || node.name.value === 'possibleTypes' || node.name.value === 'inputFields')) {\n+                            // eslint-disable-next-line no-param-reassign\n+                            depth++;\n+                            if (depth >= MAX_LISTS_DEPTH) {\n+                                return true;\n+                            }\n+                        } // handles fields and inline fragments\n+\n+                        if ('selectionSet' in node && node.selectionSet) {\n+                            for (const child of node.selectionSet.selections) {\n+                                if (checkDepth(child, visitedFragments, depth)) {\n+                                    return true;\n+                                }\n+                            }\n+                        }\n+                        return false;\n+                    }\n+                    return {\n+                        Field(node) {\n+                            if (node.name.value === '__schema' || node.name.value === '__type') {\n+                                if (checkDepth(node)) {\n+                                    context.reportError(new _GraphQLError.GraphQLError('Maximum introspection depth exceeded', {\n+                                        nodes: [node]\n+                                    }));\n+                                    return false;\n+                                }\n+                            }\n+                        }\n+                    };\n+                }\n+\n+                /***/\n+            }),\n+\n+        /***/\n         \"../../../node_modules/graphql/validation/rules/NoFragmentCyclesRule.mjs\":\n             /*!*******************************************************************************!*\\\n               !*** ../../../node_modules/graphql/validation/rules/NoFragmentCyclesRule.mjs ***!\n               \\*******************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.NoFragmentCyclesRule = NoFragmentCyclesRule;\n                 var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n@@ -41388,14 +59518,15 @@\n         \"../../../node_modules/graphql/validation/rules/NoUndefinedVariablesRule.mjs\":\n             /*!***********************************************************************************!*\\\n               !*** ../../../node_modules/graphql/validation/rules/NoUndefinedVariablesRule.mjs ***!\n               \\***********************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.NoUndefinedVariablesRule = NoUndefinedVariablesRule;\n                 var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n@@ -41442,14 +59573,15 @@\n         \"../../../node_modules/graphql/validation/rules/NoUnusedFragmentsRule.mjs\":\n             /*!********************************************************************************!*\\\n               !*** ../../../node_modules/graphql/validation/rules/NoUnusedFragmentsRule.mjs ***!\n               \\********************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.NoUnusedFragmentsRule = NoUnusedFragmentsRule;\n                 var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n@@ -41501,14 +59633,15 @@\n         \"../../../node_modules/graphql/validation/rules/NoUnusedVariablesRule.mjs\":\n             /*!********************************************************************************!*\\\n               !*** ../../../node_modules/graphql/validation/rules/NoUnusedVariablesRule.mjs ***!\n               \\********************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.NoUnusedVariablesRule = NoUnusedVariablesRule;\n                 var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n@@ -41559,14 +59692,15 @@\n         \"../../../node_modules/graphql/validation/rules/OverlappingFieldsCanBeMergedRule.mjs\":\n             /*!*******************************************************************************************!*\\\n               !*** ../../../node_modules/graphql/validation/rules/OverlappingFieldsCanBeMergedRule.mjs ***!\n               \\*******************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.OverlappingFieldsCanBeMergedRule = OverlappingFieldsCanBeMergedRule;\n                 var _inspect = __webpack_require__( /*! ../../jsutils/inspect.mjs */ \"../../../node_modules/graphql/jsutils/inspect.mjs\");\n@@ -41575,18 +59709,15 @@\n                 var _printer = __webpack_require__( /*! ../../language/printer.mjs */ \"../../../node_modules/graphql/language/printer.mjs\");\n                 var _definition = __webpack_require__( /*! ../../type/definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n                 var _sortValueNode = __webpack_require__( /*! ../../utilities/sortValueNode.mjs */ \"../../../node_modules/graphql/utilities/sortValueNode.mjs\");\n                 var _typeFromAST = __webpack_require__( /*! ../../utilities/typeFromAST.mjs */ \"../../../node_modules/graphql/utilities/typeFromAST.mjs\");\n \n                 function reasonMessage(reason) {\n                     if (Array.isArray(reason)) {\n-                        return reason.map(_ref => {\n-                            let [responseName, subReason] = _ref;\n-                            return `subfields \"${responseName}\" conflict because ` + reasonMessage(subReason);\n-                        }).join(' and ');\n+                        return reason.map(([responseName, subReason]) => `subfields \"${responseName}\" conflict because ` + reasonMessage(subReason)).join(' and ');\n                     }\n                     return reason;\n                 }\n                 /**\n                  * Overlapping fields can be merged\n                  *\n                  * A selection set is only valid if all fields (including spreading any\n@@ -41903,22 +60034,18 @@\n                     /* c8 ignore next */\n \n                     if (args1.length !== args2.length) {\n                         /* c8 ignore next */\n                         return false;\n                         /* c8 ignore next */\n                     }\n-\n-                    const values2 = new Map(args2.map(_ref2 => {\n-                        let {\n-                            name,\n-                            value\n-                        } = _ref2;\n-                        return [name.value, value];\n-                    }));\n+                    const values2 = new Map(args2.map(({\n+                        name,\n+                        value\n+                    }) => [name.value, value]));\n                     return args1.every(arg1 => {\n                         const value1 = arg1.value;\n                         const value2 = values2.get(arg1.name.value);\n                         if (value2 === undefined) {\n                             return false;\n                         }\n                         return stringifyValue(value1) === stringifyValue(value2);\n@@ -42005,26 +60132,17 @@\n                     }\n                 } // Given a series of Conflicts which occurred between two sub-fields, generate\n                 // a single Conflict.\n \n                 function subfieldConflicts(conflicts, responseName, node1, node2) {\n                     if (conflicts.length > 0) {\n                         return [\n-                            [responseName, conflicts.map(_ref3 => {\n-                                let [reason] = _ref3;\n-                                return reason;\n-                            })],\n-                            [node1, ...conflicts.map(_ref4 => {\n-                                let [, fields1] = _ref4;\n-                                return fields1;\n-                            }).flat()],\n-                            [node2, ...conflicts.map(_ref5 => {\n-                                let [, , fields2] = _ref5;\n-                                return fields2;\n-                            }).flat()]\n+                            [responseName, conflicts.map(([reason]) => reason)],\n+                            [node1, ...conflicts.map(([, fields1]) => fields1).flat()],\n+                            [node2, ...conflicts.map(([, , fields2]) => fields2).flat()]\n                         ];\n                     }\n                 }\n                 /**\n                  * A way to keep track of pairs of things when the ordering of the pair does not matter.\n                  */\n \n@@ -42064,14 +60182,15 @@\n         \"../../../node_modules/graphql/validation/rules/PossibleFragmentSpreadsRule.mjs\":\n             /*!**************************************************************************************!*\\\n               !*** ../../../node_modules/graphql/validation/rules/PossibleFragmentSpreadsRule.mjs ***!\n               \\**************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.PossibleFragmentSpreadsRule = PossibleFragmentSpreadsRule;\n                 var _inspect = __webpack_require__( /*! ../../jsutils/inspect.mjs */ \"../../../node_modules/graphql/jsutils/inspect.mjs\");\n@@ -42131,14 +60250,15 @@\n         \"../../../node_modules/graphql/validation/rules/PossibleTypeExtensionsRule.mjs\":\n             /*!*************************************************************************************!*\\\n               !*** ../../../node_modules/graphql/validation/rules/PossibleTypeExtensionsRule.mjs ***!\n               \\*************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.PossibleTypeExtensionsRule = PossibleTypeExtensionsRule;\n                 var _didYouMean = __webpack_require__( /*! ../../jsutils/didYouMean.mjs */ \"../../../node_modules/graphql/jsutils/didYouMean.mjs\");\n@@ -42264,14 +60384,15 @@\n         \"../../../node_modules/graphql/validation/rules/ProvidedRequiredArgumentsRule.mjs\":\n             /*!****************************************************************************************!*\\\n               !*** ../../../node_modules/graphql/validation/rules/ProvidedRequiredArgumentsRule.mjs ***!\n               \\****************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.ProvidedRequiredArgumentsOnDirectivesRule = ProvidedRequiredArgumentsOnDirectivesRule;\n                 exports.ProvidedRequiredArgumentsRule = ProvidedRequiredArgumentsRule;\n@@ -42379,14 +60500,15 @@\n         \"../../../node_modules/graphql/validation/rules/ScalarLeafsRule.mjs\":\n             /*!**************************************************************************!*\\\n               !*** ../../../node_modules/graphql/validation/rules/ScalarLeafsRule.mjs ***!\n               \\**************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.ScalarLeafsRule = ScalarLeafsRule;\n                 var _inspect = __webpack_require__( /*! ../../jsutils/inspect.mjs */ \"../../../node_modules/graphql/jsutils/inspect.mjs\");\n@@ -42431,14 +60553,15 @@\n         \"../../../node_modules/graphql/validation/rules/SingleFieldSubscriptionsRule.mjs\":\n             /*!***************************************************************************************!*\\\n               !*** ../../../node_modules/graphql/validation/rules/SingleFieldSubscriptionsRule.mjs ***!\n               \\***************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.SingleFieldSubscriptionsRule = SingleFieldSubscriptionsRule;\n                 var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n@@ -42499,14 +60622,15 @@\n         \"../../../node_modules/graphql/validation/rules/UniqueArgumentDefinitionNamesRule.mjs\":\n             /*!********************************************************************************************!*\\\n               !*** ../../../node_modules/graphql/validation/rules/UniqueArgumentDefinitionNamesRule.mjs ***!\n               \\********************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.UniqueArgumentDefinitionNamesRule = UniqueArgumentDefinitionNamesRule;\n                 var _groupBy = __webpack_require__( /*! ../../jsutils/groupBy.mjs */ \"../../../node_modules/graphql/jsutils/groupBy.mjs\");\n@@ -42573,14 +60697,15 @@\n         \"../../../node_modules/graphql/validation/rules/UniqueArgumentNamesRule.mjs\":\n             /*!**********************************************************************************!*\\\n               !*** ../../../node_modules/graphql/validation/rules/UniqueArgumentNamesRule.mjs ***!\n               \\**********************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.UniqueArgumentNamesRule = UniqueArgumentNamesRule;\n                 var _groupBy = __webpack_require__( /*! ../../jsutils/groupBy.mjs */ \"../../../node_modules/graphql/jsutils/groupBy.mjs\");\n@@ -42590,35378 +60715,28559 @@\n                  *\n                  * A GraphQL field or directive is only valid if all supplied arguments are\n                  * uniquely named.\n                  *\n                  * See https://spec.graphql.org/draft/#sec-Argument-Names\n                  */\n                 function UniqueArgumentNamesRule(context) {\n-                    return {\n-                        Field: checkArgUniqueness,\n-                        Directive: checkArgUniqueness\n-                    };\n-\n-                    function checkArgUniqueness(parentNode) {\n-                        var _parentNode$arguments;\n-\n-                        // FIXME: https://github.com/graphql/graphql-js/issues/2203\n-\n-                        /* c8 ignore next */\n-                        const argumentNodes = (_parentNode$arguments = parentNode.arguments) !== null && _parentNode$arguments !== void 0 ? _parentNode$arguments : [];\n-                        const seenArgs = (0, _groupBy.groupBy)(argumentNodes, arg => arg.name.value);\n-                        for (const [argName, argNodes] of seenArgs) {\n-                            if (argNodes.length > 1) {\n-                                context.reportError(new _GraphQLError.GraphQLError(`There can be only one argument named \"${argName}\".`, {\n-                                    nodes: argNodes.map(node => node.name)\n-                                }));\n-                            }\n-                        }\n-                    }\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/graphql/validation/rules/UniqueDirectiveNamesRule.mjs\":\n-            /*!***********************************************************************************!*\\\n-              !*** ../../../node_modules/graphql/validation/rules/UniqueDirectiveNamesRule.mjs ***!\n-              \\***********************************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.UniqueDirectiveNamesRule = UniqueDirectiveNamesRule;\n-                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n-                /**\n-                 * Unique directive names\n-                 *\n-                 * A GraphQL document is only valid if all defined directives have unique names.\n-                 */\n-                function UniqueDirectiveNamesRule(context) {\n-                    const knownDirectiveNames = Object.create(null);\n-                    const schema = context.getSchema();\n-                    return {\n-                        DirectiveDefinition(node) {\n-                            const directiveName = node.name.value;\n-                            if (schema !== null && schema !== void 0 && schema.getDirective(directiveName)) {\n-                                context.reportError(new _GraphQLError.GraphQLError(`Directive \"@${directiveName}\" already exists in the schema. It cannot be redefined.`, {\n-                                    nodes: node.name\n-                                }));\n-                                return;\n-                            }\n-                            if (knownDirectiveNames[directiveName]) {\n-                                context.reportError(new _GraphQLError.GraphQLError(`There can be only one directive named \"@${directiveName}\".`, {\n-                                    nodes: [knownDirectiveNames[directiveName], node.name]\n-                                }));\n-                            } else {\n-                                knownDirectiveNames[directiveName] = node.name;\n-                            }\n-                            return false;\n-                        }\n-                    };\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/graphql/validation/rules/UniqueDirectivesPerLocationRule.mjs\":\n-            /*!******************************************************************************************!*\\\n-              !*** ../../../node_modules/graphql/validation/rules/UniqueDirectivesPerLocationRule.mjs ***!\n-              \\******************************************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.UniqueDirectivesPerLocationRule = UniqueDirectivesPerLocationRule;\n-                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n-                var _kinds = __webpack_require__( /*! ../../language/kinds.mjs */ \"../../../node_modules/graphql/language/kinds.mjs\");\n-                var _predicates = __webpack_require__( /*! ../../language/predicates.mjs */ \"../../../node_modules/graphql/language/predicates.mjs\");\n-                var _directives = __webpack_require__( /*! ../../type/directives.mjs */ \"../../../node_modules/graphql/type/directives.mjs\");\n-                /**\n-                 * Unique directive names per location\n-                 *\n-                 * A GraphQL document is only valid if all non-repeatable directives at\n-                 * a given location are uniquely named.\n-                 *\n-                 * See https://spec.graphql.org/draft/#sec-Directives-Are-Unique-Per-Location\n-                 */\n-                function UniqueDirectivesPerLocationRule(context) {\n-                    const uniqueDirectiveMap = Object.create(null);\n-                    const schema = context.getSchema();\n-                    const definedDirectives = schema ? schema.getDirectives() : _directives.specifiedDirectives;\n-                    for (const directive of definedDirectives) {\n-                        uniqueDirectiveMap[directive.name] = !directive.isRepeatable;\n-                    }\n-                    const astDefinitions = context.getDocument().definitions;\n-                    for (const def of astDefinitions) {\n-                        if (def.kind === _kinds.Kind.DIRECTIVE_DEFINITION) {\n-                            uniqueDirectiveMap[def.name.value] = !def.repeatable;\n-                        }\n-                    }\n-                    const schemaDirectives = Object.create(null);\n-                    const typeDirectivesMap = Object.create(null);\n-                    return {\n-                        // Many different AST nodes may contain directives. Rather than listing\n-                        // them all, just listen for entering any node, and check to see if it\n-                        // defines any directives.\n-                        enter(node) {\n-                            if (!('directives' in node) || !node.directives) {\n-                                return;\n-                            }\n-                            let seenDirectives;\n-                            if (node.kind === _kinds.Kind.SCHEMA_DEFINITION || node.kind === _kinds.Kind.SCHEMA_EXTENSION) {\n-                                seenDirectives = schemaDirectives;\n-                            } else if ((0, _predicates.isTypeDefinitionNode)(node) || (0, _predicates.isTypeExtensionNode)(node)) {\n-                                const typeName = node.name.value;\n-                                seenDirectives = typeDirectivesMap[typeName];\n-                                if (seenDirectives === undefined) {\n-                                    typeDirectivesMap[typeName] = seenDirectives = Object.create(null);\n-                                }\n-                            } else {\n-                                seenDirectives = Object.create(null);\n-                            }\n-                            for (const directive of node.directives) {\n-                                const directiveName = directive.name.value;\n-                                if (uniqueDirectiveMap[directiveName]) {\n-                                    if (seenDirectives[directiveName]) {\n-                                        context.reportError(new _GraphQLError.GraphQLError(`The directive \"@${directiveName}\" can only be used once at this location.`, {\n-                                            nodes: [seenDirectives[directiveName], directive]\n-                                        }));\n-                                    } else {\n-                                        seenDirectives[directiveName] = directive;\n-                                    }\n-                                }\n-                            }\n-                        }\n-                    };\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/graphql/validation/rules/UniqueEnumValueNamesRule.mjs\":\n-            /*!***********************************************************************************!*\\\n-              !*** ../../../node_modules/graphql/validation/rules/UniqueEnumValueNamesRule.mjs ***!\n-              \\***********************************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.UniqueEnumValueNamesRule = UniqueEnumValueNamesRule;\n-                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n-                var _definition = __webpack_require__( /*! ../../type/definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n-                /**\n-                 * Unique enum value names\n-                 *\n-                 * A GraphQL enum type is only valid if all its values are uniquely named.\n-                 */\n-                function UniqueEnumValueNamesRule(context) {\n-                    const schema = context.getSchema();\n-                    const existingTypeMap = schema ? schema.getTypeMap() : Object.create(null);\n-                    const knownValueNames = Object.create(null);\n-                    return {\n-                        EnumTypeDefinition: checkValueUniqueness,\n-                        EnumTypeExtension: checkValueUniqueness\n-                    };\n-\n-                    function checkValueUniqueness(node) {\n-                        var _node$values;\n-                        const typeName = node.name.value;\n-                        if (!knownValueNames[typeName]) {\n-                            knownValueNames[typeName] = Object.create(null);\n-                        } // FIXME: https://github.com/graphql/graphql-js/issues/2203\n-\n-                        /* c8 ignore next */\n-\n-                        const valueNodes = (_node$values = node.values) !== null && _node$values !== void 0 ? _node$values : [];\n-                        const valueNames = knownValueNames[typeName];\n-                        for (const valueDef of valueNodes) {\n-                            const valueName = valueDef.name.value;\n-                            const existingType = existingTypeMap[typeName];\n-                            if ((0, _definition.isEnumType)(existingType) && existingType.getValue(valueName)) {\n-                                context.reportError(new _GraphQLError.GraphQLError(`Enum value \"${typeName}.${valueName}\" already exists in the schema. It cannot also be defined in this type extension.`, {\n-                                    nodes: valueDef.name\n-                                }));\n-                            } else if (valueNames[valueName]) {\n-                                context.reportError(new _GraphQLError.GraphQLError(`Enum value \"${typeName}.${valueName}\" can only be defined once.`, {\n-                                    nodes: [valueNames[valueName], valueDef.name]\n-                                }));\n-                            } else {\n-                                valueNames[valueName] = valueDef.name;\n-                            }\n-                        }\n-                        return false;\n-                    }\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/graphql/validation/rules/UniqueFieldDefinitionNamesRule.mjs\":\n-            /*!*****************************************************************************************!*\\\n-              !*** ../../../node_modules/graphql/validation/rules/UniqueFieldDefinitionNamesRule.mjs ***!\n-              \\*****************************************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.UniqueFieldDefinitionNamesRule = UniqueFieldDefinitionNamesRule;\n-                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n-                var _definition = __webpack_require__( /*! ../../type/definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n-                /**\n-                 * Unique field definition names\n-                 *\n-                 * A GraphQL complex type is only valid if all its fields are uniquely named.\n-                 */\n-                function UniqueFieldDefinitionNamesRule(context) {\n-                    const schema = context.getSchema();\n-                    const existingTypeMap = schema ? schema.getTypeMap() : Object.create(null);\n-                    const knownFieldNames = Object.create(null);\n-                    return {\n-                        InputObjectTypeDefinition: checkFieldUniqueness,\n-                        InputObjectTypeExtension: checkFieldUniqueness,\n-                        InterfaceTypeDefinition: checkFieldUniqueness,\n-                        InterfaceTypeExtension: checkFieldUniqueness,\n-                        ObjectTypeDefinition: checkFieldUniqueness,\n-                        ObjectTypeExtension: checkFieldUniqueness\n-                    };\n-\n-                    function checkFieldUniqueness(node) {\n-                        var _node$fields;\n-                        const typeName = node.name.value;\n-                        if (!knownFieldNames[typeName]) {\n-                            knownFieldNames[typeName] = Object.create(null);\n-                        } // FIXME: https://github.com/graphql/graphql-js/issues/2203\n-\n-                        /* c8 ignore next */\n-\n-                        const fieldNodes = (_node$fields = node.fields) !== null && _node$fields !== void 0 ? _node$fields : [];\n-                        const fieldNames = knownFieldNames[typeName];\n-                        for (const fieldDef of fieldNodes) {\n-                            const fieldName = fieldDef.name.value;\n-                            if (hasField(existingTypeMap[typeName], fieldName)) {\n-                                context.reportError(new _GraphQLError.GraphQLError(`Field \"${typeName}.${fieldName}\" already exists in the schema. It cannot also be defined in this type extension.`, {\n-                                    nodes: fieldDef.name\n-                                }));\n-                            } else if (fieldNames[fieldName]) {\n-                                context.reportError(new _GraphQLError.GraphQLError(`Field \"${typeName}.${fieldName}\" can only be defined once.`, {\n-                                    nodes: [fieldNames[fieldName], fieldDef.name]\n-                                }));\n-                            } else {\n-                                fieldNames[fieldName] = fieldDef.name;\n-                            }\n-                        }\n-                        return false;\n-                    }\n-                }\n-\n-                function hasField(type, fieldName) {\n-                    if ((0, _definition.isObjectType)(type) || (0, _definition.isInterfaceType)(type) || (0, _definition.isInputObjectType)(type)) {\n-                        return type.getFields()[fieldName] != null;\n-                    }\n-                    return false;\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/graphql/validation/rules/UniqueFragmentNamesRule.mjs\":\n-            /*!**********************************************************************************!*\\\n-              !*** ../../../node_modules/graphql/validation/rules/UniqueFragmentNamesRule.mjs ***!\n-              \\**********************************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.UniqueFragmentNamesRule = UniqueFragmentNamesRule;\n-                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n-                /**\n-                 * Unique fragment names\n-                 *\n-                 * A GraphQL document is only valid if all defined fragments have unique names.\n-                 *\n-                 * See https://spec.graphql.org/draft/#sec-Fragment-Name-Uniqueness\n-                 */\n-                function UniqueFragmentNamesRule(context) {\n-                    const knownFragmentNames = Object.create(null);\n-                    return {\n-                        OperationDefinition: () => false,\n-                        FragmentDefinition(node) {\n-                            const fragmentName = node.name.value;\n-                            if (knownFragmentNames[fragmentName]) {\n-                                context.reportError(new _GraphQLError.GraphQLError(`There can be only one fragment named \"${fragmentName}\".`, {\n-                                    nodes: [knownFragmentNames[fragmentName], node.name]\n-                                }));\n-                            } else {\n-                                knownFragmentNames[fragmentName] = node.name;\n-                            }\n-                            return false;\n-                        }\n-                    };\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/graphql/validation/rules/UniqueInputFieldNamesRule.mjs\":\n-            /*!************************************************************************************!*\\\n-              !*** ../../../node_modules/graphql/validation/rules/UniqueInputFieldNamesRule.mjs ***!\n-              \\************************************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.UniqueInputFieldNamesRule = UniqueInputFieldNamesRule;\n-                var _invariant = __webpack_require__( /*! ../../jsutils/invariant.mjs */ \"../../../node_modules/graphql/jsutils/invariant.mjs\");\n-                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n-                /**\n-                 * Unique input field names\n-                 *\n-                 * A GraphQL input object value is only valid if all supplied fields are\n-                 * uniquely named.\n-                 *\n-                 * See https://spec.graphql.org/draft/#sec-Input-Object-Field-Uniqueness\n-                 */\n-                function UniqueInputFieldNamesRule(context) {\n-                    const knownNameStack = [];\n-                    let knownNames = Object.create(null);\n-                    return {\n-                        ObjectValue: {\n-                            enter() {\n-                                knownNameStack.push(knownNames);\n-                                knownNames = Object.create(null);\n-                            },\n-                            leave() {\n-                                const prevKnownNames = knownNameStack.pop();\n-                                prevKnownNames || (0, _invariant.invariant)(false);\n-                                knownNames = prevKnownNames;\n-                            }\n-                        },\n-                        ObjectField(node) {\n-                            const fieldName = node.name.value;\n-                            if (knownNames[fieldName]) {\n-                                context.reportError(new _GraphQLError.GraphQLError(`There can be only one input field named \"${fieldName}\".`, {\n-                                    nodes: [knownNames[fieldName], node.name]\n-                                }));\n-                            } else {\n-                                knownNames[fieldName] = node.name;\n-                            }\n-                        }\n-                    };\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/graphql/validation/rules/UniqueOperationNamesRule.mjs\":\n-            /*!***********************************************************************************!*\\\n-              !*** ../../../node_modules/graphql/validation/rules/UniqueOperationNamesRule.mjs ***!\n-              \\***********************************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.UniqueOperationNamesRule = UniqueOperationNamesRule;\n-                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n-                /**\n-                 * Unique operation names\n-                 *\n-                 * A GraphQL document is only valid if all defined operations have unique names.\n-                 *\n-                 * See https://spec.graphql.org/draft/#sec-Operation-Name-Uniqueness\n-                 */\n-                function UniqueOperationNamesRule(context) {\n-                    const knownOperationNames = Object.create(null);\n-                    return {\n-                        OperationDefinition(node) {\n-                            const operationName = node.name;\n-                            if (operationName) {\n-                                if (knownOperationNames[operationName.value]) {\n-                                    context.reportError(new _GraphQLError.GraphQLError(`There can be only one operation named \"${operationName.value}\".`, {\n-                                        nodes: [knownOperationNames[operationName.value], operationName]\n-                                    }));\n-                                } else {\n-                                    knownOperationNames[operationName.value] = operationName;\n-                                }\n-                            }\n-                            return false;\n-                        },\n-                        FragmentDefinition: () => false\n-                    };\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/graphql/validation/rules/UniqueOperationTypesRule.mjs\":\n-            /*!***********************************************************************************!*\\\n-              !*** ../../../node_modules/graphql/validation/rules/UniqueOperationTypesRule.mjs ***!\n-              \\***********************************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.UniqueOperationTypesRule = UniqueOperationTypesRule;\n-                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n-                /**\n-                 * Unique operation types\n-                 *\n-                 * A GraphQL document is only valid if it has only one type per operation.\n-                 */\n-                function UniqueOperationTypesRule(context) {\n-                    const schema = context.getSchema();\n-                    const definedOperationTypes = Object.create(null);\n-                    const existingOperationTypes = schema ? {\n-                        query: schema.getQueryType(),\n-                        mutation: schema.getMutationType(),\n-                        subscription: schema.getSubscriptionType()\n-                    } : {};\n-                    return {\n-                        SchemaDefinition: checkOperationTypes,\n-                        SchemaExtension: checkOperationTypes\n-                    };\n-\n-                    function checkOperationTypes(node) {\n-                        var _node$operationTypes;\n-\n-                        // See: https://github.com/graphql/graphql-js/issues/2203\n-\n-                        /* c8 ignore next */\n-                        const operationTypesNodes = (_node$operationTypes = node.operationTypes) !== null && _node$operationTypes !== void 0 ? _node$operationTypes : [];\n-                        for (const operationType of operationTypesNodes) {\n-                            const operation = operationType.operation;\n-                            const alreadyDefinedOperationType = definedOperationTypes[operation];\n-                            if (existingOperationTypes[operation]) {\n-                                context.reportError(new _GraphQLError.GraphQLError(`Type for ${operation} already defined in the schema. It cannot be redefined.`, {\n-                                    nodes: operationType\n-                                }));\n-                            } else if (alreadyDefinedOperationType) {\n-                                context.reportError(new _GraphQLError.GraphQLError(`There can be only one ${operation} type in schema.`, {\n-                                    nodes: [alreadyDefinedOperationType, operationType]\n-                                }));\n-                            } else {\n-                                definedOperationTypes[operation] = operationType;\n-                            }\n-                        }\n-                        return false;\n-                    }\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/graphql/validation/rules/UniqueTypeNamesRule.mjs\":\n-            /*!******************************************************************************!*\\\n-              !*** ../../../node_modules/graphql/validation/rules/UniqueTypeNamesRule.mjs ***!\n-              \\******************************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.UniqueTypeNamesRule = UniqueTypeNamesRule;\n-                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n-                /**\n-                 * Unique type names\n-                 *\n-                 * A GraphQL document is only valid if all defined types have unique names.\n-                 */\n-                function UniqueTypeNamesRule(context) {\n-                    const knownTypeNames = Object.create(null);\n-                    const schema = context.getSchema();\n-                    return {\n-                        ScalarTypeDefinition: checkTypeName,\n-                        ObjectTypeDefinition: checkTypeName,\n-                        InterfaceTypeDefinition: checkTypeName,\n-                        UnionTypeDefinition: checkTypeName,\n-                        EnumTypeDefinition: checkTypeName,\n-                        InputObjectTypeDefinition: checkTypeName\n-                    };\n-\n-                    function checkTypeName(node) {\n-                        const typeName = node.name.value;\n-                        if (schema !== null && schema !== void 0 && schema.getType(typeName)) {\n-                            context.reportError(new _GraphQLError.GraphQLError(`Type \"${typeName}\" already exists in the schema. It cannot also be defined in this type definition.`, {\n-                                nodes: node.name\n-                            }));\n-                            return;\n-                        }\n-                        if (knownTypeNames[typeName]) {\n-                            context.reportError(new _GraphQLError.GraphQLError(`There can be only one type named \"${typeName}\".`, {\n-                                nodes: [knownTypeNames[typeName], node.name]\n-                            }));\n-                        } else {\n-                            knownTypeNames[typeName] = node.name;\n-                        }\n-                        return false;\n-                    }\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/graphql/validation/rules/UniqueVariableNamesRule.mjs\":\n-            /*!**********************************************************************************!*\\\n-              !*** ../../../node_modules/graphql/validation/rules/UniqueVariableNamesRule.mjs ***!\n-              \\**********************************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.UniqueVariableNamesRule = UniqueVariableNamesRule;\n-                var _groupBy = __webpack_require__( /*! ../../jsutils/groupBy.mjs */ \"../../../node_modules/graphql/jsutils/groupBy.mjs\");\n-                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n-                /**\n-                 * Unique variable names\n-                 *\n-                 * A GraphQL operation is only valid if all its variables are uniquely named.\n-                 */\n-                function UniqueVariableNamesRule(context) {\n-                    return {\n-                        OperationDefinition(operationNode) {\n-                            var _operationNode$variab;\n-\n-                            // See: https://github.com/graphql/graphql-js/issues/2203\n-\n-                            /* c8 ignore next */\n-                            const variableDefinitions = (_operationNode$variab = operationNode.variableDefinitions) !== null && _operationNode$variab !== void 0 ? _operationNode$variab : [];\n-                            const seenVariableDefinitions = (0, _groupBy.groupBy)(variableDefinitions, node => node.variable.name.value);\n-                            for (const [variableName, variableNodes] of seenVariableDefinitions) {\n-                                if (variableNodes.length > 1) {\n-                                    context.reportError(new _GraphQLError.GraphQLError(`There can be only one variable named \"$${variableName}\".`, {\n-                                        nodes: variableNodes.map(node => node.variable.name)\n-                                    }));\n-                                }\n-                            }\n-                        }\n-                    };\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/graphql/validation/rules/ValuesOfCorrectTypeRule.mjs\":\n-            /*!**********************************************************************************!*\\\n-              !*** ../../../node_modules/graphql/validation/rules/ValuesOfCorrectTypeRule.mjs ***!\n-              \\**********************************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.ValuesOfCorrectTypeRule = ValuesOfCorrectTypeRule;\n-                var _didYouMean = __webpack_require__( /*! ../../jsutils/didYouMean.mjs */ \"../../../node_modules/graphql/jsutils/didYouMean.mjs\");\n-                var _inspect = __webpack_require__( /*! ../../jsutils/inspect.mjs */ \"../../../node_modules/graphql/jsutils/inspect.mjs\");\n-                var _keyMap = __webpack_require__( /*! ../../jsutils/keyMap.mjs */ \"../../../node_modules/graphql/jsutils/keyMap.mjs\");\n-                var _suggestionList = __webpack_require__( /*! ../../jsutils/suggestionList.mjs */ \"../../../node_modules/graphql/jsutils/suggestionList.mjs\");\n-                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n-                var _printer = __webpack_require__( /*! ../../language/printer.mjs */ \"../../../node_modules/graphql/language/printer.mjs\");\n-                var _definition = __webpack_require__( /*! ../../type/definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n-                /**\n-                 * Value literals of correct type\n-                 *\n-                 * A GraphQL document is only valid if all value literals are of the type\n-                 * expected at their position.\n-                 *\n-                 * See https://spec.graphql.org/draft/#sec-Values-of-Correct-Type\n-                 */\n-                function ValuesOfCorrectTypeRule(context) {\n-                    return {\n-                        ListValue(node) {\n-                            // Note: TypeInfo will traverse into a list's item type, so look to the\n-                            // parent input type to check if it is a list.\n-                            const type = (0, _definition.getNullableType)(context.getParentInputType());\n-                            if (!(0, _definition.isListType)(type)) {\n-                                isValidValueNode(context, node);\n-                                return false; // Don't traverse further.\n-                            }\n-                        },\n-\n-                        ObjectValue(node) {\n-                            const type = (0, _definition.getNamedType)(context.getInputType());\n-                            if (!(0, _definition.isInputObjectType)(type)) {\n-                                isValidValueNode(context, node);\n-                                return false; // Don't traverse further.\n-                            } // Ensure every required field exists.\n-\n-                            const fieldNodeMap = (0, _keyMap.keyMap)(node.fields, field => field.name.value);\n-                            for (const fieldDef of Object.values(type.getFields())) {\n-                                const fieldNode = fieldNodeMap[fieldDef.name];\n-                                if (!fieldNode && (0, _definition.isRequiredInputField)(fieldDef)) {\n-                                    const typeStr = (0, _inspect.inspect)(fieldDef.type);\n-                                    context.reportError(new _GraphQLError.GraphQLError(`Field \"${type.name}.${fieldDef.name}\" of required type \"${typeStr}\" was not provided.`, {\n-                                        nodes: node\n-                                    }));\n-                                }\n-                            }\n-                        },\n-                        ObjectField(node) {\n-                            const parentType = (0, _definition.getNamedType)(context.getParentInputType());\n-                            const fieldType = context.getInputType();\n-                            if (!fieldType && (0, _definition.isInputObjectType)(parentType)) {\n-                                const suggestions = (0, _suggestionList.suggestionList)(node.name.value, Object.keys(parentType.getFields()));\n-                                context.reportError(new _GraphQLError.GraphQLError(`Field \"${node.name.value}\" is not defined by type \"${parentType.name}\".` + (0, _didYouMean.didYouMean)(suggestions), {\n-                                    nodes: node\n-                                }));\n-                            }\n-                        },\n-                        NullValue(node) {\n-                            const type = context.getInputType();\n-                            if ((0, _definition.isNonNullType)(type)) {\n-                                context.reportError(new _GraphQLError.GraphQLError(`Expected value of type \"${(0, _inspect.inspect)(type)}\", found ${(0, _printer.print)(node)}.`, {\n-                                    nodes: node\n-                                }));\n-                            }\n-                        },\n-                        EnumValue: node => isValidValueNode(context, node),\n-                        IntValue: node => isValidValueNode(context, node),\n-                        FloatValue: node => isValidValueNode(context, node),\n-                        StringValue: node => isValidValueNode(context, node),\n-                        BooleanValue: node => isValidValueNode(context, node)\n-                    };\n-                }\n-                /**\n-                 * Any value literal may be a valid representation of a Scalar, depending on\n-                 * that scalar type.\n-                 */\n-\n-                function isValidValueNode(context, node) {\n-                    // Report any error at the full type expected by the location.\n-                    const locationType = context.getInputType();\n-                    if (!locationType) {\n-                        return;\n-                    }\n-                    const type = (0, _definition.getNamedType)(locationType);\n-                    if (!(0, _definition.isLeafType)(type)) {\n-                        const typeStr = (0, _inspect.inspect)(locationType);\n-                        context.reportError(new _GraphQLError.GraphQLError(`Expected value of type \"${typeStr}\", found ${(0, _printer.print)(node)}.`, {\n-                            nodes: node\n-                        }));\n-                        return;\n-                    } // Scalars and Enums determine if a literal value is valid via parseLiteral(),\n-                    // which may throw or return an invalid value to indicate failure.\n-\n-                    try {\n-                        const parseResult = type.parseLiteral(node, undefined\n-                            /* variables */\n-                        );\n-\n-                        if (parseResult === undefined) {\n-                            const typeStr = (0, _inspect.inspect)(locationType);\n-                            context.reportError(new _GraphQLError.GraphQLError(`Expected value of type \"${typeStr}\", found ${(0, _printer.print)(node)}.`, {\n-                                nodes: node\n-                            }));\n-                        }\n-                    } catch (error) {\n-                        const typeStr = (0, _inspect.inspect)(locationType);\n-                        if (error instanceof _GraphQLError.GraphQLError) {\n-                            context.reportError(error);\n-                        } else {\n-                            context.reportError(new _GraphQLError.GraphQLError(`Expected value of type \"${typeStr}\", found ${(0, _printer.print)(node)}; ` + error.message, {\n-                                nodes: node,\n-                                originalError: error\n-                            }));\n-                        }\n-                    }\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/graphql/validation/rules/VariablesAreInputTypesRule.mjs\":\n-            /*!*************************************************************************************!*\\\n-              !*** ../../../node_modules/graphql/validation/rules/VariablesAreInputTypesRule.mjs ***!\n-              \\*************************************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.VariablesAreInputTypesRule = VariablesAreInputTypesRule;\n-                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n-                var _printer = __webpack_require__( /*! ../../language/printer.mjs */ \"../../../node_modules/graphql/language/printer.mjs\");\n-                var _definition = __webpack_require__( /*! ../../type/definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n-                var _typeFromAST = __webpack_require__( /*! ../../utilities/typeFromAST.mjs */ \"../../../node_modules/graphql/utilities/typeFromAST.mjs\");\n-                /**\n-                 * Variables are input types\n-                 *\n-                 * A GraphQL operation is only valid if all the variables it defines are of\n-                 * input types (scalar, enum, or input object).\n-                 *\n-                 * See https://spec.graphql.org/draft/#sec-Variables-Are-Input-Types\n-                 */\n-                function VariablesAreInputTypesRule(context) {\n-                    return {\n-                        VariableDefinition(node) {\n-                            const type = (0, _typeFromAST.typeFromAST)(context.getSchema(), node.type);\n-                            if (type !== undefined && !(0, _definition.isInputType)(type)) {\n-                                const variableName = node.variable.name.value;\n-                                const typeName = (0, _printer.print)(node.type);\n-                                context.reportError(new _GraphQLError.GraphQLError(`Variable \"$${variableName}\" cannot be non-input type \"${typeName}\".`, {\n-                                    nodes: node.type\n-                                }));\n-                            }\n-                        }\n-                    };\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/graphql/validation/rules/VariablesInAllowedPositionRule.mjs\":\n-            /*!*****************************************************************************************!*\\\n-              !*** ../../../node_modules/graphql/validation/rules/VariablesInAllowedPositionRule.mjs ***!\n-              \\*****************************************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.VariablesInAllowedPositionRule = VariablesInAllowedPositionRule;\n-                var _inspect = __webpack_require__( /*! ../../jsutils/inspect.mjs */ \"../../../node_modules/graphql/jsutils/inspect.mjs\");\n-                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n-                var _kinds = __webpack_require__( /*! ../../language/kinds.mjs */ \"../../../node_modules/graphql/language/kinds.mjs\");\n-                var _definition = __webpack_require__( /*! ../../type/definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n-                var _typeComparators = __webpack_require__( /*! ../../utilities/typeComparators.mjs */ \"../../../node_modules/graphql/utilities/typeComparators.mjs\");\n-                var _typeFromAST = __webpack_require__( /*! ../../utilities/typeFromAST.mjs */ \"../../../node_modules/graphql/utilities/typeFromAST.mjs\");\n-                /**\n-                 * Variables in allowed position\n-                 *\n-                 * Variable usages must be compatible with the arguments they are passed to.\n-                 *\n-                 * See https://spec.graphql.org/draft/#sec-All-Variable-Usages-are-Allowed\n-                 */\n-                function VariablesInAllowedPositionRule(context) {\n-                    let varDefMap = Object.create(null);\n-                    return {\n-                        OperationDefinition: {\n-                            enter() {\n-                                varDefMap = Object.create(null);\n-                            },\n-                            leave(operation) {\n-                                const usages = context.getRecursiveVariableUsages(operation);\n-                                for (const {\n-                                        node,\n-                                        type,\n-                                        defaultValue\n-                                    }\n-                                    of usages) {\n-                                    const varName = node.name.value;\n-                                    const varDef = varDefMap[varName];\n-                                    if (varDef && type) {\n-                                        // A var type is allowed if it is the same or more strict (e.g. is\n-                                        // a subtype of) than the expected type. It can be more strict if\n-                                        // the variable type is non-null when the expected type is nullable.\n-                                        // If both are list types, the variable item type can be more strict\n-                                        // than the expected item type (contravariant).\n-                                        const schema = context.getSchema();\n-                                        const varType = (0, _typeFromAST.typeFromAST)(schema, varDef.type);\n-                                        if (varType && !allowedVariableUsage(schema, varType, varDef.defaultValue, type, defaultValue)) {\n-                                            const varTypeStr = (0, _inspect.inspect)(varType);\n-                                            const typeStr = (0, _inspect.inspect)(type);\n-                                            context.reportError(new _GraphQLError.GraphQLError(`Variable \"$${varName}\" of type \"${varTypeStr}\" used in position expecting type \"${typeStr}\".`, {\n-                                                nodes: [varDef, node]\n-                                            }));\n-                                        }\n-                                    }\n-                                }\n-                            }\n-                        },\n-                        VariableDefinition(node) {\n-                            varDefMap[node.variable.name.value] = node;\n-                        }\n-                    };\n-                }\n-                /**\n-                 * Returns true if the variable is allowed in the location it was found,\n-                 * which includes considering if default values exist for either the variable\n-                 * or the location at which it is located.\n-                 */\n-\n-                function allowedVariableUsage(schema, varType, varDefaultValue, locationType, locationDefaultValue) {\n-                    if ((0, _definition.isNonNullType)(locationType) && !(0, _definition.isNonNullType)(varType)) {\n-                        const hasNonNullVariableDefaultValue = varDefaultValue != null && varDefaultValue.kind !== _kinds.Kind.NULL;\n-                        const hasLocationDefaultValue = locationDefaultValue !== undefined;\n-                        if (!hasNonNullVariableDefaultValue && !hasLocationDefaultValue) {\n-                            return false;\n-                        }\n-                        const nullableLocationType = locationType.ofType;\n-                        return (0, _typeComparators.isTypeSubTypeOf)(schema, varType, nullableLocationType);\n-                    }\n-                    return (0, _typeComparators.isTypeSubTypeOf)(schema, varType, locationType);\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/graphql/validation/rules/custom/NoDeprecatedCustomRule.mjs\":\n-            /*!****************************************************************************************!*\\\n-              !*** ../../../node_modules/graphql/validation/rules/custom/NoDeprecatedCustomRule.mjs ***!\n-              \\****************************************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.NoDeprecatedCustomRule = NoDeprecatedCustomRule;\n-                var _invariant = __webpack_require__( /*! ../../../jsutils/invariant.mjs */ \"../../../node_modules/graphql/jsutils/invariant.mjs\");\n-                var _GraphQLError = __webpack_require__( /*! ../../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n-                var _definition = __webpack_require__( /*! ../../../type/definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n-                /**\n-                 * No deprecated\n-                 *\n-                 * A GraphQL document is only valid if all selected fields and all used enum values have not been\n-                 * deprecated.\n-                 *\n-                 * Note: This rule is optional and is not part of the Validation section of the GraphQL\n-                 * Specification. The main purpose of this rule is detection of deprecated usages and not\n-                 * necessarily to forbid their use when querying a service.\n-                 */\n-                function NoDeprecatedCustomRule(context) {\n-                    return {\n-                        Field(node) {\n-                            const fieldDef = context.getFieldDef();\n-                            const deprecationReason = fieldDef === null || fieldDef === void 0 ? void 0 : fieldDef.deprecationReason;\n-                            if (fieldDef && deprecationReason != null) {\n-                                const parentType = context.getParentType();\n-                                parentType != null || (0, _invariant.invariant)(false);\n-                                context.reportError(new _GraphQLError.GraphQLError(`The field ${parentType.name}.${fieldDef.name} is deprecated. ${deprecationReason}`, {\n-                                    nodes: node\n-                                }));\n-                            }\n-                        },\n-                        Argument(node) {\n-                            const argDef = context.getArgument();\n-                            const deprecationReason = argDef === null || argDef === void 0 ? void 0 : argDef.deprecationReason;\n-                            if (argDef && deprecationReason != null) {\n-                                const directiveDef = context.getDirective();\n-                                if (directiveDef != null) {\n-                                    context.reportError(new _GraphQLError.GraphQLError(`Directive \"@${directiveDef.name}\" argument \"${argDef.name}\" is deprecated. ${deprecationReason}`, {\n-                                        nodes: node\n-                                    }));\n-                                } else {\n-                                    const parentType = context.getParentType();\n-                                    const fieldDef = context.getFieldDef();\n-                                    parentType != null && fieldDef != null || (0, _invariant.invariant)(false);\n-                                    context.reportError(new _GraphQLError.GraphQLError(`Field \"${parentType.name}.${fieldDef.name}\" argument \"${argDef.name}\" is deprecated. ${deprecationReason}`, {\n-                                        nodes: node\n-                                    }));\n-                                }\n-                            }\n-                        },\n-                        ObjectField(node) {\n-                            const inputObjectDef = (0, _definition.getNamedType)(context.getParentInputType());\n-                            if ((0, _definition.isInputObjectType)(inputObjectDef)) {\n-                                const inputFieldDef = inputObjectDef.getFields()[node.name.value];\n-                                const deprecationReason = inputFieldDef === null || inputFieldDef === void 0 ? void 0 : inputFieldDef.deprecationReason;\n-                                if (deprecationReason != null) {\n-                                    context.reportError(new _GraphQLError.GraphQLError(`The input field ${inputObjectDef.name}.${inputFieldDef.name} is deprecated. ${deprecationReason}`, {\n-                                        nodes: node\n-                                    }));\n-                                }\n-                            }\n-                        },\n-                        EnumValue(node) {\n-                            const enumValueDef = context.getEnumValue();\n-                            const deprecationReason = enumValueDef === null || enumValueDef === void 0 ? void 0 : enumValueDef.deprecationReason;\n-                            if (enumValueDef && deprecationReason != null) {\n-                                const enumTypeDef = (0, _definition.getNamedType)(context.getInputType());\n-                                enumTypeDef != null || (0, _invariant.invariant)(false);\n-                                context.reportError(new _GraphQLError.GraphQLError(`The enum value \"${enumTypeDef.name}.${enumValueDef.name}\" is deprecated. ${deprecationReason}`, {\n-                                    nodes: node\n-                                }));\n-                            }\n-                        }\n-                    };\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/graphql/validation/rules/custom/NoSchemaIntrospectionCustomRule.mjs\":\n-            /*!*************************************************************************************************!*\\\n-              !*** ../../../node_modules/graphql/validation/rules/custom/NoSchemaIntrospectionCustomRule.mjs ***!\n-              \\*************************************************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.NoSchemaIntrospectionCustomRule = NoSchemaIntrospectionCustomRule;\n-                var _GraphQLError = __webpack_require__( /*! ../../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n-                var _definition = __webpack_require__( /*! ../../../type/definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n-                var _introspection = __webpack_require__( /*! ../../../type/introspection.mjs */ \"../../../node_modules/graphql/type/introspection.mjs\");\n-                /**\n-                 * Prohibit introspection queries\n-                 *\n-                 * A GraphQL document is only valid if all fields selected are not fields that\n-                 * return an introspection type.\n-                 *\n-                 * Note: This rule is optional and is not part of the Validation section of the\n-                 * GraphQL Specification. This rule effectively disables introspection, which\n-                 * does not reflect best practices and should only be done if absolutely necessary.\n-                 */\n-                function NoSchemaIntrospectionCustomRule(context) {\n-                    return {\n-                        Field(node) {\n-                            const type = (0, _definition.getNamedType)(context.getType());\n-                            if (type && (0, _introspection.isIntrospectionType)(type)) {\n-                                context.reportError(new _GraphQLError.GraphQLError(`GraphQL introspection has been disabled, but the requested query contained the field \"${node.name.value}\".`, {\n-                                    nodes: node\n-                                }));\n-                            }\n-                        }\n-                    };\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/graphql/validation/specifiedRules.mjs\":\n-            /*!*******************************************************************!*\\\n-              !*** ../../../node_modules/graphql/validation/specifiedRules.mjs ***!\n-              \\*******************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.specifiedSDLRules = exports.specifiedRules = void 0;\n-                var _ExecutableDefinitionsRule = __webpack_require__( /*! ./rules/ExecutableDefinitionsRule.mjs */ \"../../../node_modules/graphql/validation/rules/ExecutableDefinitionsRule.mjs\");\n-                var _FieldsOnCorrectTypeRule = __webpack_require__( /*! ./rules/FieldsOnCorrectTypeRule.mjs */ \"../../../node_modules/graphql/validation/rules/FieldsOnCorrectTypeRule.mjs\");\n-                var _FragmentsOnCompositeTypesRule = __webpack_require__( /*! ./rules/FragmentsOnCompositeTypesRule.mjs */ \"../../../node_modules/graphql/validation/rules/FragmentsOnCompositeTypesRule.mjs\");\n-                var _KnownArgumentNamesRule = __webpack_require__( /*! ./rules/KnownArgumentNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/KnownArgumentNamesRule.mjs\");\n-                var _KnownDirectivesRule = __webpack_require__( /*! ./rules/KnownDirectivesRule.mjs */ \"../../../node_modules/graphql/validation/rules/KnownDirectivesRule.mjs\");\n-                var _KnownFragmentNamesRule = __webpack_require__( /*! ./rules/KnownFragmentNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/KnownFragmentNamesRule.mjs\");\n-                var _KnownTypeNamesRule = __webpack_require__( /*! ./rules/KnownTypeNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/KnownTypeNamesRule.mjs\");\n-                var _LoneAnonymousOperationRule = __webpack_require__( /*! ./rules/LoneAnonymousOperationRule.mjs */ \"../../../node_modules/graphql/validation/rules/LoneAnonymousOperationRule.mjs\");\n-                var _LoneSchemaDefinitionRule = __webpack_require__( /*! ./rules/LoneSchemaDefinitionRule.mjs */ \"../../../node_modules/graphql/validation/rules/LoneSchemaDefinitionRule.mjs\");\n-                var _NoFragmentCyclesRule = __webpack_require__( /*! ./rules/NoFragmentCyclesRule.mjs */ \"../../../node_modules/graphql/validation/rules/NoFragmentCyclesRule.mjs\");\n-                var _NoUndefinedVariablesRule = __webpack_require__( /*! ./rules/NoUndefinedVariablesRule.mjs */ \"../../../node_modules/graphql/validation/rules/NoUndefinedVariablesRule.mjs\");\n-                var _NoUnusedFragmentsRule = __webpack_require__( /*! ./rules/NoUnusedFragmentsRule.mjs */ \"../../../node_modules/graphql/validation/rules/NoUnusedFragmentsRule.mjs\");\n-                var _NoUnusedVariablesRule = __webpack_require__( /*! ./rules/NoUnusedVariablesRule.mjs */ \"../../../node_modules/graphql/validation/rules/NoUnusedVariablesRule.mjs\");\n-                var _OverlappingFieldsCanBeMergedRule = __webpack_require__( /*! ./rules/OverlappingFieldsCanBeMergedRule.mjs */ \"../../../node_modules/graphql/validation/rules/OverlappingFieldsCanBeMergedRule.mjs\");\n-                var _PossibleFragmentSpreadsRule = __webpack_require__( /*! ./rules/PossibleFragmentSpreadsRule.mjs */ \"../../../node_modules/graphql/validation/rules/PossibleFragmentSpreadsRule.mjs\");\n-                var _PossibleTypeExtensionsRule = __webpack_require__( /*! ./rules/PossibleTypeExtensionsRule.mjs */ \"../../../node_modules/graphql/validation/rules/PossibleTypeExtensionsRule.mjs\");\n-                var _ProvidedRequiredArgumentsRule = __webpack_require__( /*! ./rules/ProvidedRequiredArgumentsRule.mjs */ \"../../../node_modules/graphql/validation/rules/ProvidedRequiredArgumentsRule.mjs\");\n-                var _ScalarLeafsRule = __webpack_require__( /*! ./rules/ScalarLeafsRule.mjs */ \"../../../node_modules/graphql/validation/rules/ScalarLeafsRule.mjs\");\n-                var _SingleFieldSubscriptionsRule = __webpack_require__( /*! ./rules/SingleFieldSubscriptionsRule.mjs */ \"../../../node_modules/graphql/validation/rules/SingleFieldSubscriptionsRule.mjs\");\n-                var _UniqueArgumentDefinitionNamesRule = __webpack_require__( /*! ./rules/UniqueArgumentDefinitionNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueArgumentDefinitionNamesRule.mjs\");\n-                var _UniqueArgumentNamesRule = __webpack_require__( /*! ./rules/UniqueArgumentNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueArgumentNamesRule.mjs\");\n-                var _UniqueDirectiveNamesRule = __webpack_require__( /*! ./rules/UniqueDirectiveNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueDirectiveNamesRule.mjs\");\n-                var _UniqueDirectivesPerLocationRule = __webpack_require__( /*! ./rules/UniqueDirectivesPerLocationRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueDirectivesPerLocationRule.mjs\");\n-                var _UniqueEnumValueNamesRule = __webpack_require__( /*! ./rules/UniqueEnumValueNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueEnumValueNamesRule.mjs\");\n-                var _UniqueFieldDefinitionNamesRule = __webpack_require__( /*! ./rules/UniqueFieldDefinitionNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueFieldDefinitionNamesRule.mjs\");\n-                var _UniqueFragmentNamesRule = __webpack_require__( /*! ./rules/UniqueFragmentNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueFragmentNamesRule.mjs\");\n-                var _UniqueInputFieldNamesRule = __webpack_require__( /*! ./rules/UniqueInputFieldNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueInputFieldNamesRule.mjs\");\n-                var _UniqueOperationNamesRule = __webpack_require__( /*! ./rules/UniqueOperationNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueOperationNamesRule.mjs\");\n-                var _UniqueOperationTypesRule = __webpack_require__( /*! ./rules/UniqueOperationTypesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueOperationTypesRule.mjs\");\n-                var _UniqueTypeNamesRule = __webpack_require__( /*! ./rules/UniqueTypeNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueTypeNamesRule.mjs\");\n-                var _UniqueVariableNamesRule = __webpack_require__( /*! ./rules/UniqueVariableNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueVariableNamesRule.mjs\");\n-                var _ValuesOfCorrectTypeRule = __webpack_require__( /*! ./rules/ValuesOfCorrectTypeRule.mjs */ \"../../../node_modules/graphql/validation/rules/ValuesOfCorrectTypeRule.mjs\");\n-                var _VariablesAreInputTypesRule = __webpack_require__( /*! ./rules/VariablesAreInputTypesRule.mjs */ \"../../../node_modules/graphql/validation/rules/VariablesAreInputTypesRule.mjs\");\n-                var _VariablesInAllowedPositionRule = __webpack_require__( /*! ./rules/VariablesInAllowedPositionRule.mjs */ \"../../../node_modules/graphql/validation/rules/VariablesInAllowedPositionRule.mjs\");\n-                // Spec Section: \"Executable Definitions\"\n-                // Spec Section: \"Field Selections on Objects, Interfaces, and Unions Types\"\n-\n-                // Spec Section: \"Fragments on Composite Types\"\n-\n-                // Spec Section: \"Argument Names\"\n-\n-                // Spec Section: \"Directives Are Defined\"\n-\n-                // Spec Section: \"Fragment spread target defined\"\n-\n-                // Spec Section: \"Fragment Spread Type Existence\"\n-\n-                // Spec Section: \"Lone Anonymous Operation\"\n-\n-                // SDL-specific validation rules\n-\n-                // Spec Section: \"Fragments must not form cycles\"\n-\n-                // Spec Section: \"All Variable Used Defined\"\n-\n-                // Spec Section: \"Fragments must be used\"\n-\n-                // Spec Section: \"All Variables Used\"\n-\n-                // Spec Section: \"Field Selection Merging\"\n-\n-                // Spec Section: \"Fragment spread is possible\"\n-\n-                // Spec Section: \"Argument Optionality\"\n-\n-                // Spec Section: \"Leaf Field Selections\"\n-\n-                // Spec Section: \"Subscriptions with Single Root Field\"\n-\n-                // Spec Section: \"Argument Uniqueness\"\n-\n-                // Spec Section: \"Directives Are Unique Per Location\"\n-\n-                // Spec Section: \"Fragment Name Uniqueness\"\n-\n-                // Spec Section: \"Input Object Field Uniqueness\"\n-\n-                // Spec Section: \"Operation Name Uniqueness\"\n-\n-                // Spec Section: \"Variable Uniqueness\"\n-\n-                // Spec Section: \"Value Type Correctness\"\n-\n-                // Spec Section: \"Variables are Input Types\"\n-\n-                // Spec Section: \"All Variable Usages Are Allowed\"\n-\n-                /**\n-                 * This set includes all validation rules defined by the GraphQL spec.\n-                 *\n-                 * The order of the rules in this list has been adjusted to lead to the\n-                 * most clear output when encountering multiple validation errors.\n-                 */\n-                const specifiedRules = Object.freeze([_ExecutableDefinitionsRule.ExecutableDefinitionsRule, _UniqueOperationNamesRule.UniqueOperationNamesRule, _LoneAnonymousOperationRule.LoneAnonymousOperationRule, _SingleFieldSubscriptionsRule.SingleFieldSubscriptionsRule, _KnownTypeNamesRule.KnownTypeNamesRule, _FragmentsOnCompositeTypesRule.FragmentsOnCompositeTypesRule, _VariablesAreInputTypesRule.VariablesAreInputTypesRule, _ScalarLeafsRule.ScalarLeafsRule, _FieldsOnCorrectTypeRule.FieldsOnCorrectTypeRule, _UniqueFragmentNamesRule.UniqueFragmentNamesRule, _KnownFragmentNamesRule.KnownFragmentNamesRule, _NoUnusedFragmentsRule.NoUnusedFragmentsRule, _PossibleFragmentSpreadsRule.PossibleFragmentSpreadsRule, _NoFragmentCyclesRule.NoFragmentCyclesRule, _UniqueVariableNamesRule.UniqueVariableNamesRule, _NoUndefinedVariablesRule.NoUndefinedVariablesRule, _NoUnusedVariablesRule.NoUnusedVariablesRule, _KnownDirectivesRule.KnownDirectivesRule, _UniqueDirectivesPerLocationRule.UniqueDirectivesPerLocationRule, _KnownArgumentNamesRule.KnownArgumentNamesRule, _UniqueArgumentNamesRule.UniqueArgumentNamesRule, _ValuesOfCorrectTypeRule.ValuesOfCorrectTypeRule, _ProvidedRequiredArgumentsRule.ProvidedRequiredArgumentsRule, _VariablesInAllowedPositionRule.VariablesInAllowedPositionRule, _OverlappingFieldsCanBeMergedRule.OverlappingFieldsCanBeMergedRule, _UniqueInputFieldNamesRule.UniqueInputFieldNamesRule]);\n-                /**\n-                 * @internal\n-                 */\n-                exports.specifiedRules = specifiedRules;\n-                const specifiedSDLRules = Object.freeze([_LoneSchemaDefinitionRule.LoneSchemaDefinitionRule, _UniqueOperationTypesRule.UniqueOperationTypesRule, _UniqueTypeNamesRule.UniqueTypeNamesRule, _UniqueEnumValueNamesRule.UniqueEnumValueNamesRule, _UniqueFieldDefinitionNamesRule.UniqueFieldDefinitionNamesRule, _UniqueArgumentDefinitionNamesRule.UniqueArgumentDefinitionNamesRule, _UniqueDirectiveNamesRule.UniqueDirectiveNamesRule, _KnownTypeNamesRule.KnownTypeNamesRule, _KnownDirectivesRule.KnownDirectivesRule, _UniqueDirectivesPerLocationRule.UniqueDirectivesPerLocationRule, _PossibleTypeExtensionsRule.PossibleTypeExtensionsRule, _KnownArgumentNamesRule.KnownArgumentNamesOnDirectivesRule, _UniqueArgumentNamesRule.UniqueArgumentNamesRule, _UniqueInputFieldNamesRule.UniqueInputFieldNamesRule, _ProvidedRequiredArgumentsRule.ProvidedRequiredArgumentsOnDirectivesRule]);\n-                exports.specifiedSDLRules = specifiedSDLRules;\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/graphql/validation/validate.mjs\":\n-            /*!*************************************************************!*\\\n-              !*** ../../../node_modules/graphql/validation/validate.mjs ***!\n-              \\*************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.assertValidSDL = assertValidSDL;\n-                exports.assertValidSDLExtension = assertValidSDLExtension;\n-                exports.validate = validate;\n-                exports.validateSDL = validateSDL;\n-                var _devAssert = __webpack_require__( /*! ../jsutils/devAssert.mjs */ \"../../../node_modules/graphql/jsutils/devAssert.mjs\");\n-                var _GraphQLError = __webpack_require__( /*! ../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n-                var _visitor = __webpack_require__( /*! ../language/visitor.mjs */ \"../../../node_modules/graphql/language/visitor.mjs\");\n-                var _validate = __webpack_require__( /*! ../type/validate.mjs */ \"../../../node_modules/graphql/type/validate.mjs\");\n-                var _TypeInfo = __webpack_require__( /*! ../utilities/TypeInfo.mjs */ \"../../../node_modules/graphql/utilities/TypeInfo.mjs\");\n-                var _specifiedRules = __webpack_require__( /*! ./specifiedRules.mjs */ \"../../../node_modules/graphql/validation/specifiedRules.mjs\");\n-                var _ValidationContext = __webpack_require__( /*! ./ValidationContext.mjs */ \"../../../node_modules/graphql/validation/ValidationContext.mjs\");\n-                /**\n-                 * Implements the \"Validation\" section of the spec.\n-                 *\n-                 * Validation runs synchronously, returning an array of encountered errors, or\n-                 * an empty array if no errors were encountered and the document is valid.\n-                 *\n-                 * A list of specific validation rules may be provided. If not provided, the\n-                 * default list of rules defined by the GraphQL specification will be used.\n-                 *\n-                 * Each validation rules is a function which returns a visitor\n-                 * (see the language/visitor API). Visitor methods are expected to return\n-                 * GraphQLErrors, or Arrays of GraphQLErrors when invalid.\n-                 *\n-                 * Validate will stop validation after a `maxErrors` limit has been reached.\n-                 * Attackers can send pathologically invalid queries to induce a DoS attack,\n-                 * so by default `maxErrors` set to 100 errors.\n-                 *\n-                 * Optionally a custom TypeInfo instance may be provided. If not provided, one\n-                 * will be created from the provided schema.\n-                 */\n-\n-                function validate(schema, documentAST) {\n-                    let rules = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : _specifiedRules.specifiedRules;\n-                    let options = arguments.length > 3 ? arguments[3] : undefined;\n-                    let typeInfo = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : new _TypeInfo.TypeInfo(schema);\n-                    var _options$maxErrors;\n-                    const maxErrors = (_options$maxErrors = options === null || options === void 0 ? void 0 : options.maxErrors) !== null && _options$maxErrors !== void 0 ? _options$maxErrors : 100;\n-                    documentAST || (0, _devAssert.devAssert)(false, 'Must provide document.'); // If the schema used for validation is invalid, throw an error.\n-\n-                    (0, _validate.assertValidSchema)(schema);\n-                    const abortObj = Object.freeze({});\n-                    const errors = [];\n-                    const context = new _ValidationContext.ValidationContext(schema, documentAST, typeInfo, error => {\n-                        if (errors.length >= maxErrors) {\n-                            errors.push(new _GraphQLError.GraphQLError('Too many validation errors, error limit reached. Validation aborted.')); // eslint-disable-next-line @typescript-eslint/no-throw-literal\n-\n-                            throw abortObj;\n-                        }\n-                        errors.push(error);\n-                    }); // This uses a specialized visitor which runs multiple visitors in parallel,\n-                    // while maintaining the visitor skip and break API.\n-\n-                    const visitor = (0, _visitor.visitInParallel)(rules.map(rule => rule(context))); // Visit the whole document with each instance of all provided rules.\n-\n-                    try {\n-                        (0, _visitor.visit)(documentAST, (0, _TypeInfo.visitWithTypeInfo)(typeInfo, visitor));\n-                    } catch (e) {\n-                        if (e !== abortObj) {\n-                            throw e;\n-                        }\n-                    }\n-                    return errors;\n-                }\n-                /**\n-                 * @internal\n-                 */\n-\n-                function validateSDL(documentAST, schemaToExtend) {\n-                    let rules = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : _specifiedRules.specifiedSDLRules;\n-                    const errors = [];\n-                    const context = new _ValidationContext.SDLValidationContext(documentAST, schemaToExtend, error => {\n-                        errors.push(error);\n-                    });\n-                    const visitors = rules.map(rule => rule(context));\n-                    (0, _visitor.visit)(documentAST, (0, _visitor.visitInParallel)(visitors));\n-                    return errors;\n-                }\n-                /**\n-                 * Utility function which asserts a SDL document is valid by throwing an error\n-                 * if it is invalid.\n-                 *\n-                 * @internal\n-                 */\n-\n-                function assertValidSDL(documentAST) {\n-                    const errors = validateSDL(documentAST);\n-                    if (errors.length !== 0) {\n-                        throw new Error(errors.map(error => error.message).join('\\n\\n'));\n-                    }\n-                }\n-                /**\n-                 * Utility function which asserts a SDL document is valid by throwing an error\n-                 * if it is invalid.\n-                 *\n-                 * @internal\n-                 */\n-\n-                function assertValidSDLExtension(documentAST, schema) {\n-                    const errors = validateSDL(documentAST, schema);\n-                    if (errors.length !== 0) {\n-                        throw new Error(errors.map(error => error.message).join('\\n\\n'));\n-                    }\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/graphql/version.mjs\":\n-            /*!*************************************************!*\\\n-              !*** ../../../node_modules/graphql/version.mjs ***!\n-              \\*************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.versionInfo = exports.version = void 0;\n-                // Note: This file is autogenerated using \"resources/gen-version.js\" script and\n-                // automatically updated by \"npm version\" command.\n-\n-                /**\n-                 * A string containing the version of the GraphQL.js library\n-                 */\n-                const version = '16.8.1';\n-                /**\n-                 * An object containing the components of the GraphQL.js version string\n-                 */\n-                exports.version = version;\n-                const versionInfo = Object.freeze({\n-                    major: 16,\n-                    minor: 8,\n-                    patch: 1,\n-                    preReleaseTag: null\n-                });\n-                exports.versionInfo = versionInfo;\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/hey-listen/dist/hey-listen.es.js\":\n-            /*!**************************************************************!*\\\n-              !*** ../../../node_modules/hey-listen/dist/hey-listen.es.js ***!\n-              \\**************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.warning = exports.invariant = void 0;\n-                var warning = function() {};\n-                exports.warning = warning;\n-                var invariant = function() {};\n-                exports.invariant = invariant;\n-                if (true) {\n-                    exports.warning = warning = function(check, message) {\n-                        if (!check && typeof console !== 'undefined') {\n-                            console.warn(message);\n-                        }\n-                    };\n-                    exports.invariant = invariant = function(check, message) {\n-                        if (!check) {\n-                            throw new Error(message);\n-                        }\n-                    };\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/is-plain-object/index.js\":\n-            /*!******************************************************!*\\\n-              !*** ../../../node_modules/is-plain-object/index.js ***!\n-              \\******************************************************/\n-            /***/\n-            (function(module, __unused_webpack_exports, __webpack_require__) {\n-\n-                /*!\n-                 * is-plain-object <https://github.com/jonschlinkert/is-plain-object>\n-                 *\n-                 * Copyright (c) 2014-2017, Jon Schlinkert.\n-                 * Released under the MIT License.\n-                 */\n-\n-\n-\n-                var isObject = __webpack_require__( /*! isobject */ \"../../../node_modules/isobject/index.js\");\n-\n-                function isObjectObject(o) {\n-                    return isObject(o) === true && Object.prototype.toString.call(o) === '[object Object]';\n-                }\n-                module.exports = function isPlainObject(o) {\n-                    var ctor, prot;\n-                    if (isObjectObject(o) === false) return false;\n-\n-                    // If has modified constructor\n-                    ctor = o.constructor;\n-                    if (typeof ctor !== 'function') return false;\n-\n-                    // If has modified prototype\n-                    prot = ctor.prototype;\n-                    if (isObjectObject(prot) === false) return false;\n-\n-                    // If constructor does not have an Object-specific method\n-                    if (prot.hasOwnProperty('isPrototypeOf') === false) {\n-                        return false;\n-                    }\n-\n-                    // Most likely a plain Object\n-                    return true;\n-                };\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/is-primitive/index.js\":\n-            /*!***************************************************!*\\\n-              !*** ../../../node_modules/is-primitive/index.js ***!\n-              \\***************************************************/\n-            /***/\n-            (function(module) {\n-\n-                /*!\n-                 * is-primitive <https://github.com/jonschlinkert/is-primitive>\n-                 *\n-                 * Copyright (c) 2014-present, Jon Schlinkert.\n-                 * Released under the MIT License.\n-                 */\n-\n-\n-\n-                module.exports = function isPrimitive(val) {\n-                    if (typeof val === 'object') {\n-                        return val === null;\n-                    }\n-                    return typeof val !== 'function';\n-                };\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/isarray/index.js\":\n-            /*!**********************************************!*\\\n-              !*** ../../../node_modules/isarray/index.js ***!\n-              \\**********************************************/\n-            /***/\n-            (function(module) {\n-\n-\n-\n-                var toString = {}.toString;\n-                module.exports = Array.isArray || function(arr) {\n-                    return toString.call(arr) == '[object Array]';\n-                };\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/isobject/index.js\":\n-            /*!***********************************************!*\\\n-              !*** ../../../node_modules/isobject/index.js ***!\n-              \\***********************************************/\n-            /***/\n-            (function(module, __unused_webpack_exports, __webpack_require__) {\n-\n-                /*!\n-                 * isobject <https://github.com/jonschlinkert/isobject>\n-                 *\n-                 * Copyright (c) 2014-2015, Jon Schlinkert.\n-                 * Licensed under the MIT License.\n-                 */\n-\n-\n-\n-                var isArray = __webpack_require__( /*! isarray */ \"../../../node_modules/isarray/index.js\");\n-                module.exports = function isObject(val) {\n-                    return val != null && typeof val === 'object' && isArray(val) === false;\n-                };\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/meros/browser/index.mjs\":\n-            /*!*****************************************************!*\\\n-              !*** ../../../node_modules/meros/browser/index.mjs ***!\n-              \\*****************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.meros = meros;\n-                const separator = '\\r\\n\\r\\n';\n-                const decoder = new TextDecoder();\n-                async function* generate(stream, boundary, options) {\n-                    const reader = stream.getReader(),\n-                        is_eager = !options || !options.multiple;\n-                    let buffer = '',\n-                        is_preamble = true,\n-                        payloads = [];\n-                    try {\n-                        let result;\n-                        outer: while (!(result = await reader.read()).done) {\n-                            const chunk = decoder.decode(result.value);\n-                            const idx_chunk = chunk.indexOf(boundary);\n-                            let idx_boundary = buffer.length;\n-                            buffer += chunk;\n-                            if (!!~idx_chunk) {\n-                                // chunk itself had `boundary` marker\n-                                idx_boundary += idx_chunk;\n-                            } else {\n-                                // search combined (boundary can be across chunks)\n-                                idx_boundary = buffer.indexOf(boundary);\n-                            }\n-                            payloads = [];\n-                            while (!!~idx_boundary) {\n-                                const current = buffer.substring(0, idx_boundary);\n-                                const next = buffer.substring(idx_boundary + boundary.length);\n-                                if (is_preamble) {\n-                                    is_preamble = false;\n-                                } else {\n-                                    const headers = {};\n-                                    const idx_headers = current.indexOf(separator);\n-                                    const arr_headers = buffer.slice(0, idx_headers).toString().trim().split(/\\r\\n/);\n-                                    // parse headers\n-                                    let tmp;\n-                                    while (tmp = arr_headers.shift()) {\n-                                        tmp = tmp.split(': ');\n-                                        headers[tmp.shift().toLowerCase()] = tmp.join(': ');\n-                                    }\n-                                    let body = current.substring(idx_headers + separator.length, current.lastIndexOf('\\r\\n'));\n-                                    let is_json = false;\n-                                    tmp = headers['content-type'];\n-                                    if (tmp && !!~tmp.indexOf('application/json')) {\n-                                        try {\n-                                            body = JSON.parse(body);\n-                                            is_json = true;\n-                                        } catch (_) {}\n-                                    }\n-                                    tmp = {\n-                                        headers,\n-                                        body,\n-                                        json: is_json\n-                                    };\n-                                    is_eager ? yield tmp: payloads.push(tmp);\n-                                    // hit a tail boundary, break\n-                                    if (next.substring(0, 2) === '--') break outer;\n-                                }\n-                                buffer = next;\n-                                idx_boundary = buffer.indexOf(boundary);\n-                            }\n-                            if (payloads.length) yield payloads;\n-                        }\n-                    } finally {\n-                        if (payloads.length) yield payloads;\n-                        reader.releaseLock();\n-                    }\n-                }\n-\n-                /**\n-                 * Yield immediately for every part made available on the response. If the `content-type` of the response isn't a\n-                 * multipart body, then we'll resolve with {@link Response}.\n-                 *\n-                 * @example\n-                 *\n-                 * ```js\n-                 * const parts = await fetch('/fetch-multipart')\n-                 *      .then(meros);\n-                 *\n-                 * for await (const part of parts) {\n-                 *     // do something with this part\n-                 * }\n-                 * ```\n-                 */\n-                async function meros(response, options) {\n-                    if (!response.ok || !response.body || response.bodyUsed) return response;\n-                    const ctype = response.headers.get('content-type');\n-                    if (!ctype || !~ctype.indexOf('multipart/mixed')) return response;\n-                    const idx_boundary = ctype.indexOf('boundary=');\n-                    return generate(response.body, `--${!!~idx_boundary ?\n-  // +9 for 'boundary='.length\n-  ctype.substring(idx_boundary + 9).trim().replace(/['\"]/g, '') : '-'}`, options);\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/nullthrows/nullthrows.js\":\n-            /*!******************************************************!*\\\n-              !*** ../../../node_modules/nullthrows/nullthrows.js ***!\n-              \\******************************************************/\n-            /***/\n-            (function(module) {\n-\n-\n-\n-                function nullthrows(x, message) {\n-                    if (x != null) {\n-                        return x;\n-                    }\n-                    var error = new Error(message !== undefined ? message : 'Got unexpected ' + x);\n-                    error.framesToPop = 1; // Skip nullthrows's own stack frame.\n-                    throw error;\n-                }\n-                module.exports = nullthrows;\n-                module.exports[\"default\"] = nullthrows;\n-                Object.defineProperty(module.exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/popmotion/dist/popmotion.cjs.js\":\n-            /*!*************************************************************!*\\\n-              !*** ../../../node_modules/popmotion/dist/popmotion.cjs.js ***!\n-              \\*************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                var tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.js\");\n-                var heyListen = __webpack_require__( /*! hey-listen */ \"../../../node_modules/hey-listen/dist/hey-listen.es.js\");\n-                var styleValueTypes = __webpack_require__( /*! style-value-types */ \"../../../node_modules/style-value-types/dist/valueTypes.cjs.js\");\n-                var sync = __webpack_require__( /*! framesync */ \"../../../node_modules/framesync/dist/framesync.cjs.js\");\n-\n-                function _interopDefaultLegacy(e) {\n-                    return e && typeof e === 'object' && 'default' in e ? e : {\n-                        'default': e\n-                    };\n-                }\n-                var sync__default = /*#__PURE__*/ _interopDefaultLegacy(sync);\n-                const clamp = (min, max, v) => Math.min(Math.max(v, min), max);\n-                const safeMin = 0.001;\n-                const minDuration = 0.01;\n-                const maxDuration = 10.0;\n-                const minDamping = 0.05;\n-                const maxDamping = 1;\n-\n-                function findSpring(_ref) {\n-                    let {\n-                        duration = 800,\n-                            bounce = 0.25,\n-                            velocity = 0,\n-                            mass = 1\n-                    } = _ref;\n-                    let envelope;\n-                    let derivative;\n-                    heyListen.warning(duration <= maxDuration * 1000, \"Spring duration must be 10 seconds or less\");\n-                    let dampingRatio = 1 - bounce;\n-                    dampingRatio = clamp(minDamping, maxDamping, dampingRatio);\n-                    duration = clamp(minDuration, maxDuration, duration / 1000);\n-                    if (dampingRatio < 1) {\n-                        envelope = undampedFreq => {\n-                            const exponentialDecay = undampedFreq * dampingRatio;\n-                            const delta = exponentialDecay * duration;\n-                            const a = exponentialDecay - velocity;\n-                            const b = calcAngularFreq(undampedFreq, dampingRatio);\n-                            const c = Math.exp(-delta);\n-                            return safeMin - a / b * c;\n-                        };\n-                        derivative = undampedFreq => {\n-                            const exponentialDecay = undampedFreq * dampingRatio;\n-                            const delta = exponentialDecay * duration;\n-                            const d = delta * velocity + velocity;\n-                            const e = Math.pow(dampingRatio, 2) * Math.pow(undampedFreq, 2) * duration;\n-                            const f = Math.exp(-delta);\n-                            const g = calcAngularFreq(Math.pow(undampedFreq, 2), dampingRatio);\n-                            const factor = -envelope(undampedFreq) + safeMin > 0 ? -1 : 1;\n-                            return factor * ((d - e) * f) / g;\n-                        };\n-                    } else {\n-                        envelope = undampedFreq => {\n-                            const a = Math.exp(-undampedFreq * duration);\n-                            const b = (undampedFreq - velocity) * duration + 1;\n-                            return -safeMin + a * b;\n-                        };\n-                        derivative = undampedFreq => {\n-                            const a = Math.exp(-undampedFreq * duration);\n-                            const b = (velocity - undampedFreq) * (duration * duration);\n-                            return a * b;\n-                        };\n-                    }\n-                    const initialGuess = 5 / duration;\n-                    const undampedFreq = approximateRoot(envelope, derivative, initialGuess);\n-                    duration = duration * 1000;\n-                    if (isNaN(undampedFreq)) {\n-                        return {\n-                            stiffness: 100,\n-                            damping: 10,\n-                            duration\n-                        };\n-                    } else {\n-                        const stiffness = Math.pow(undampedFreq, 2) * mass;\n-                        return {\n-                            stiffness,\n-                            damping: dampingRatio * 2 * Math.sqrt(mass * stiffness),\n-                            duration\n-                        };\n-                    }\n-                }\n-                const rootIterations = 12;\n-\n-                function approximateRoot(envelope, derivative, initialGuess) {\n-                    let result = initialGuess;\n-                    for (let i = 1; i < rootIterations; i++) {\n-                        result = result - envelope(result) / derivative(result);\n-                    }\n-                    return result;\n-                }\n-\n-                function calcAngularFreq(undampedFreq, dampingRatio) {\n-                    return undampedFreq * Math.sqrt(1 - dampingRatio * dampingRatio);\n-                }\n-                const durationKeys = [\"duration\", \"bounce\"];\n-                const physicsKeys = [\"stiffness\", \"damping\", \"mass\"];\n-\n-                function isSpringType(options, keys) {\n-                    return keys.some(key => options[key] !== undefined);\n-                }\n-\n-                function getSpringOptions(options) {\n-                    let springOptions = Object.assign({\n-                        velocity: 0.0,\n-                        stiffness: 100,\n-                        damping: 10,\n-                        mass: 1.0,\n-                        isResolvedFromDuration: false\n-                    }, options);\n-                    if (!isSpringType(options, physicsKeys) && isSpringType(options, durationKeys)) {\n-                        const derived = findSpring(options);\n-                        springOptions = Object.assign(Object.assign(Object.assign({}, springOptions), derived), {\n-                            velocity: 0.0,\n-                            mass: 1.0\n-                        });\n-                        springOptions.isResolvedFromDuration = true;\n-                    }\n-                    return springOptions;\n-                }\n-\n-                function spring(_a) {\n-                    var {\n-                        from = 0.0,\n-                            to = 1.0,\n-                            restSpeed = 2,\n-                            restDelta\n-                    } = _a,\n-                    options = tslib.__rest(_a, [\"from\", \"to\", \"restSpeed\", \"restDelta\"]);\n-                    const state = {\n-                        done: false,\n-                        value: from\n-                    };\n-                    let {\n-                        stiffness,\n-                        damping,\n-                        mass,\n-                        velocity,\n-                        duration,\n-                        isResolvedFromDuration\n-                    } = getSpringOptions(options);\n-                    let resolveSpring = zero;\n-                    let resolveVelocity = zero;\n-\n-                    function createSpring() {\n-                        const initialVelocity = velocity ? -(velocity / 1000) : 0.0;\n-                        const initialDelta = to - from;\n-                        const dampingRatio = damping / (2 * Math.sqrt(stiffness * mass));\n-                        const undampedAngularFreq = Math.sqrt(stiffness / mass) / 1000;\n-                        if (restDelta === undefined) {\n-                            restDelta = Math.min(Math.abs(to - from) / 100, 0.4);\n-                        }\n-                        if (dampingRatio < 1) {\n-                            const angularFreq = calcAngularFreq(undampedAngularFreq, dampingRatio);\n-                            resolveSpring = t => {\n-                                const envelope = Math.exp(-dampingRatio * undampedAngularFreq * t);\n-                                return to - envelope * ((initialVelocity + dampingRatio * undampedAngularFreq * initialDelta) / angularFreq * Math.sin(angularFreq * t) + initialDelta * Math.cos(angularFreq * t));\n-                            };\n-                            resolveVelocity = t => {\n-                                const envelope = Math.exp(-dampingRatio * undampedAngularFreq * t);\n-                                return dampingRatio * undampedAngularFreq * envelope * (Math.sin(angularFreq * t) * (initialVelocity + dampingRatio * undampedAngularFreq * initialDelta) / angularFreq + initialDelta * Math.cos(angularFreq * t)) - envelope * (Math.cos(angularFreq * t) * (initialVelocity + dampingRatio * undampedAngularFreq * initialDelta) - angularFreq * initialDelta * Math.sin(angularFreq * t));\n-                            };\n-                        } else if (dampingRatio === 1) {\n-                            resolveSpring = t => to - Math.exp(-undampedAngularFreq * t) * (initialDelta + (initialVelocity + undampedAngularFreq * initialDelta) * t);\n-                        } else {\n-                            const dampedAngularFreq = undampedAngularFreq * Math.sqrt(dampingRatio * dampingRatio - 1);\n-                            resolveSpring = t => {\n-                                const envelope = Math.exp(-dampingRatio * undampedAngularFreq * t);\n-                                const freqForT = Math.min(dampedAngularFreq * t, 300);\n-                                return to - envelope * ((initialVelocity + dampingRatio * undampedAngularFreq * initialDelta) * Math.sinh(freqForT) + dampedAngularFreq * initialDelta * Math.cosh(freqForT)) / dampedAngularFreq;\n-                            };\n-                        }\n-                    }\n-                    createSpring();\n-                    return {\n-                        next: t => {\n-                            const current = resolveSpring(t);\n-                            if (!isResolvedFromDuration) {\n-                                const currentVelocity = resolveVelocity(t) * 1000;\n-                                const isBelowVelocityThreshold = Math.abs(currentVelocity) <= restSpeed;\n-                                const isBelowDisplacementThreshold = Math.abs(to - current) <= restDelta;\n-                                state.done = isBelowVelocityThreshold && isBelowDisplacementThreshold;\n-                            } else {\n-                                state.done = t >= duration;\n-                            }\n-                            state.value = state.done ? to : current;\n-                            return state;\n-                        },\n-                        flipTarget: () => {\n-                            velocity = -velocity;\n-                            [from, to] = [to, from];\n-                            createSpring();\n-                        }\n-                    };\n-                }\n-                spring.needsInterpolation = (a, b) => typeof a === \"string\" || typeof b === \"string\";\n-                const zero = _t => 0;\n-                const progress = (from, to, value) => {\n-                    const toFromDifference = to - from;\n-                    return toFromDifference === 0 ? 1 : (value - from) / toFromDifference;\n-                };\n-                const mix = (from, to, progress) => -progress * from + progress * to + from;\n-\n-                function hueToRgb(p, q, t) {\n-                    if (t < 0) t += 1;\n-                    if (t > 1) t -= 1;\n-                    if (t < 1 / 6) return p + (q - p) * 6 * t;\n-                    if (t < 1 / 2) return q;\n-                    if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6;\n-                    return p;\n-                }\n-\n-                function hslaToRgba(_ref2) {\n-                    let {\n-                        hue,\n-                        saturation,\n-                        lightness,\n-                        alpha\n-                    } = _ref2;\n-                    hue /= 360;\n-                    saturation /= 100;\n-                    lightness /= 100;\n-                    let red = 0;\n-                    let green = 0;\n-                    let blue = 0;\n-                    if (!saturation) {\n-                        red = green = blue = lightness;\n-                    } else {\n-                        const q = lightness < 0.5 ? lightness * (1 + saturation) : lightness + saturation - lightness * saturation;\n-                        const p = 2 * lightness - q;\n-                        red = hueToRgb(p, q, hue + 1 / 3);\n-                        green = hueToRgb(p, q, hue);\n-                        blue = hueToRgb(p, q, hue - 1 / 3);\n-                    }\n-                    return {\n-                        red: Math.round(red * 255),\n-                        green: Math.round(green * 255),\n-                        blue: Math.round(blue * 255),\n-                        alpha\n-                    };\n-                }\n-                const mixLinearColor = (from, to, v) => {\n-                    const fromExpo = from * from;\n-                    const toExpo = to * to;\n-                    return Math.sqrt(Math.max(0, v * (toExpo - fromExpo) + fromExpo));\n-                };\n-                const colorTypes = [styleValueTypes.hex, styleValueTypes.rgba, styleValueTypes.hsla];\n-                const getColorType = v => colorTypes.find(type => type.test(v));\n-                const notAnimatable = color => `'${color}' is not an animatable color. Use the equivalent color code instead.`;\n-                const mixColor = (from, to) => {\n-                    let fromColorType = getColorType(from);\n-                    let toColorType = getColorType(to);\n-                    heyListen.invariant(!!fromColorType, notAnimatable(from));\n-                    heyListen.invariant(!!toColorType, notAnimatable(to));\n-                    let fromColor = fromColorType.parse(from);\n-                    let toColor = toColorType.parse(to);\n-                    if (fromColorType === styleValueTypes.hsla) {\n-                        fromColor = hslaToRgba(fromColor);\n-                        fromColorType = styleValueTypes.rgba;\n-                    }\n-                    if (toColorType === styleValueTypes.hsla) {\n-                        toColor = hslaToRgba(toColor);\n-                        toColorType = styleValueTypes.rgba;\n-                    }\n-                    const blended = Object.assign({}, fromColor);\n-                    return v => {\n-                        for (const key in blended) {\n-                            if (key !== \"alpha\") {\n-                                blended[key] = mixLinearColor(fromColor[key], toColor[key], v);\n-                            }\n-                        }\n-                        blended.alpha = mix(fromColor.alpha, toColor.alpha, v);\n-                        return fromColorType.transform(blended);\n-                    };\n-                };\n-                const zeroPoint = {\n-                    x: 0,\n-                    y: 0,\n-                    z: 0\n-                };\n-                const isNum = v => typeof v === 'number';\n-                const combineFunctions = (a, b) => v => b(a(v));\n-                const pipe = function() {\n-                    for (var _len = arguments.length, transformers = new Array(_len), _key = 0; _key < _len; _key++) {\n-                        transformers[_key] = arguments[_key];\n-                    }\n-                    return transformers.reduce(combineFunctions);\n-                };\n-\n-                function getMixer(origin, target) {\n-                    if (isNum(origin)) {\n-                        return v => mix(origin, target, v);\n-                    } else if (styleValueTypes.color.test(origin)) {\n-                        return mixColor(origin, target);\n-                    } else {\n-                        return mixComplex(origin, target);\n-                    }\n-                }\n-                const mixArray = (from, to) => {\n-                    const output = [...from];\n-                    const numValues = output.length;\n-                    const blendValue = from.map((fromThis, i) => getMixer(fromThis, to[i]));\n-                    return v => {\n-                        for (let i = 0; i < numValues; i++) {\n-                            output[i] = blendValue[i](v);\n-                        }\n-                        return output;\n-                    };\n-                };\n-                const mixObject = (origin, target) => {\n-                    const output = Object.assign(Object.assign({}, origin), target);\n-                    const blendValue = {};\n-                    for (const key in output) {\n-                        if (origin[key] !== undefined && target[key] !== undefined) {\n-                            blendValue[key] = getMixer(origin[key], target[key]);\n-                        }\n-                    }\n-                    return v => {\n-                        for (const key in blendValue) {\n-                            output[key] = blendValue[key](v);\n-                        }\n-                        return output;\n-                    };\n-                };\n-\n-                function analyse(value) {\n-                    const parsed = styleValueTypes.complex.parse(value);\n-                    const numValues = parsed.length;\n-                    let numNumbers = 0;\n-                    let numRGB = 0;\n-                    let numHSL = 0;\n-                    for (let i = 0; i < numValues; i++) {\n-                        if (numNumbers || typeof parsed[i] === \"number\") {\n-                            numNumbers++;\n-                        } else {\n-                            if (parsed[i].hue !== undefined) {\n-                                numHSL++;\n-                            } else {\n-                                numRGB++;\n-                            }\n-                        }\n-                    }\n-                    return {\n-                        parsed,\n-                        numNumbers,\n-                        numRGB,\n-                        numHSL\n-                    };\n-                }\n-                const mixComplex = (origin, target) => {\n-                    const template = styleValueTypes.complex.createTransformer(target);\n-                    const originStats = analyse(origin);\n-                    const targetStats = analyse(target);\n-                    const canInterpolate = originStats.numHSL === targetStats.numHSL && originStats.numRGB === targetStats.numRGB && originStats.numNumbers >= targetStats.numNumbers;\n-                    if (canInterpolate) {\n-                        return pipe(mixArray(originStats.parsed, targetStats.parsed), template);\n-                    } else {\n-                        heyListen.warning(true, `Complex values '${origin}' and '${target}' too different to mix. Ensure all colors are of the same type, and that each contains the same quantity of number and color values. Falling back to instant transition.`);\n-                        return p => `${p > 0 ? target : origin}`;\n-                    }\n-                };\n-                const mixNumber = (from, to) => p => mix(from, to, p);\n-\n-                function detectMixerFactory(v) {\n-                    if (typeof v === 'number') {\n-                        return mixNumber;\n-                    } else if (typeof v === 'string') {\n-                        if (styleValueTypes.color.test(v)) {\n-                            return mixColor;\n-                        } else {\n-                            return mixComplex;\n-                        }\n-                    } else if (Array.isArray(v)) {\n-                        return mixArray;\n-                    } else if (typeof v === 'object') {\n-                        return mixObject;\n-                    }\n-                }\n-\n-                function createMixers(output, ease, customMixer) {\n-                    const mixers = [];\n-                    const mixerFactory = customMixer || detectMixerFactory(output[0]);\n-                    const numMixers = output.length - 1;\n-                    for (let i = 0; i < numMixers; i++) {\n-                        let mixer = mixerFactory(output[i], output[i + 1]);\n-                        if (ease) {\n-                            const easingFunction = Array.isArray(ease) ? ease[i] : ease;\n-                            mixer = pipe(easingFunction, mixer);\n-                        }\n-                        mixers.push(mixer);\n-                    }\n-                    return mixers;\n-                }\n-\n-                function fastInterpolate(_ref3, _ref4) {\n-                    let [from, to] = _ref3;\n-                    let [mixer] = _ref4;\n-                    return v => mixer(progress(from, to, v));\n-                }\n-\n-                function slowInterpolate(input, mixers) {\n-                    const inputLength = input.length;\n-                    const lastInputIndex = inputLength - 1;\n-                    return v => {\n-                        let mixerIndex = 0;\n-                        let foundMixerIndex = false;\n-                        if (v <= input[0]) {\n-                            foundMixerIndex = true;\n-                        } else if (v >= input[lastInputIndex]) {\n-                            mixerIndex = lastInputIndex - 1;\n-                            foundMixerIndex = true;\n-                        }\n-                        if (!foundMixerIndex) {\n-                            let i = 1;\n-                            for (; i < inputLength; i++) {\n-                                if (input[i] > v || i === lastInputIndex) {\n-                                    break;\n-                                }\n-                            }\n-                            mixerIndex = i - 1;\n-                        }\n-                        const progressInRange = progress(input[mixerIndex], input[mixerIndex + 1], v);\n-                        return mixers[mixerIndex](progressInRange);\n-                    };\n-                }\n-\n-                function interpolate(input, output) {\n-                    let {\n-                        clamp: isClamp = true,\n-                        ease,\n-                        mixer\n-                    } = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n-                    const inputLength = input.length;\n-                    heyListen.invariant(inputLength === output.length, 'Both input and output ranges must be the same length');\n-                    heyListen.invariant(!ease || !Array.isArray(ease) || ease.length === inputLength - 1, 'Array of easing functions must be of length `input.length - 1`, as it applies to the transitions **between** the defined values.');\n-                    if (input[0] > input[inputLength - 1]) {\n-                        input = [].concat(input);\n-                        output = [].concat(output);\n-                        input.reverse();\n-                        output.reverse();\n-                    }\n-                    const mixers = createMixers(output, ease, mixer);\n-                    const interpolator = inputLength === 2 ? fastInterpolate(input, mixers) : slowInterpolate(input, mixers);\n-                    return isClamp ? v => interpolator(clamp(input[0], input[inputLength - 1], v)) : interpolator;\n-                }\n-                const reverseEasing = easing => p => 1 - easing(1 - p);\n-                const mirrorEasing = easing => p => p <= 0.5 ? easing(2 * p) / 2 : (2 - easing(2 * (1 - p))) / 2;\n-                const createExpoIn = power => p => Math.pow(p, power);\n-                const createBackIn = power => p => p * p * ((power + 1) * p - power);\n-                const createAnticipate = power => {\n-                    const backEasing = createBackIn(power);\n-                    return p => (p *= 2) < 1 ? 0.5 * backEasing(p) : 0.5 * (2 - Math.pow(2, -10 * (p - 1)));\n-                };\n-                const DEFAULT_OVERSHOOT_STRENGTH = 1.525;\n-                const BOUNCE_FIRST_THRESHOLD = 4.0 / 11.0;\n-                const BOUNCE_SECOND_THRESHOLD = 8.0 / 11.0;\n-                const BOUNCE_THIRD_THRESHOLD = 9.0 / 10.0;\n-                const linear = p => p;\n-                const easeIn = createExpoIn(2);\n-                const easeOut = reverseEasing(easeIn);\n-                const easeInOut = mirrorEasing(easeIn);\n-                const circIn = p => 1 - Math.sin(Math.acos(p));\n-                const circOut = reverseEasing(circIn);\n-                const circInOut = mirrorEasing(circOut);\n-                const backIn = createBackIn(DEFAULT_OVERSHOOT_STRENGTH);\n-                const backOut = reverseEasing(backIn);\n-                const backInOut = mirrorEasing(backIn);\n-                const anticipate = createAnticipate(DEFAULT_OVERSHOOT_STRENGTH);\n-                const ca = 4356.0 / 361.0;\n-                const cb = 35442.0 / 1805.0;\n-                const cc = 16061.0 / 1805.0;\n-                const bounceOut = p => {\n-                    if (p === 1 || p === 0) return p;\n-                    const p2 = p * p;\n-                    return p < BOUNCE_FIRST_THRESHOLD ? 7.5625 * p2 : p < BOUNCE_SECOND_THRESHOLD ? 9.075 * p2 - 9.9 * p + 3.4 : p < BOUNCE_THIRD_THRESHOLD ? ca * p2 - cb * p + cc : 10.8 * p * p - 20.52 * p + 10.72;\n-                };\n-                const bounceIn = reverseEasing(bounceOut);\n-                const bounceInOut = p => p < 0.5 ? 0.5 * (1.0 - bounceOut(1.0 - p * 2.0)) : 0.5 * bounceOut(p * 2.0 - 1.0) + 0.5;\n-\n-                function defaultEasing(values, easing) {\n-                    return values.map(() => easing || easeInOut).splice(0, values.length - 1);\n-                }\n-\n-                function defaultOffset(values) {\n-                    const numValues = values.length;\n-                    return values.map((_value, i) => i !== 0 ? i / (numValues - 1) : 0);\n-                }\n-\n-                function convertOffsetToTimes(offset, duration) {\n-                    return offset.map(o => o * duration);\n-                }\n-\n-                function keyframes(_ref5) {\n-                    let {\n-                        from = 0,\n-                            to = 1,\n-                            ease,\n-                            offset,\n-                            duration = 300\n-                    } = _ref5;\n-                    const state = {\n-                        done: false,\n-                        value: from\n-                    };\n-                    const values = Array.isArray(to) ? to : [from, to];\n-                    const times = convertOffsetToTimes(offset && offset.length === values.length ? offset : defaultOffset(values), duration);\n-\n-                    function createInterpolator() {\n-                        return interpolate(times, values, {\n-                            ease: Array.isArray(ease) ? ease : defaultEasing(values, ease)\n-                        });\n-                    }\n-                    let interpolator = createInterpolator();\n-                    return {\n-                        next: t => {\n-                            state.value = interpolator(t);\n-                            state.done = t >= duration;\n-                            return state;\n-                        },\n-                        flipTarget: () => {\n-                            values.reverse();\n-                            interpolator = createInterpolator();\n-                        }\n-                    };\n-                }\n-\n-                function decay(_ref6) {\n-                    let {\n-                        velocity = 0,\n-                            from = 0,\n-                            power = 0.8,\n-                            timeConstant = 350,\n-                            restDelta = 0.5,\n-                            modifyTarget\n-                    } = _ref6;\n-                    const state = {\n-                        done: false,\n-                        value: from\n-                    };\n-                    let amplitude = power * velocity;\n-                    const ideal = from + amplitude;\n-                    const target = modifyTarget === undefined ? ideal : modifyTarget(ideal);\n-                    if (target !== ideal) amplitude = target - from;\n-                    return {\n-                        next: t => {\n-                            const delta = -amplitude * Math.exp(-t / timeConstant);\n-                            state.done = !(delta > restDelta || delta < -restDelta);\n-                            state.value = state.done ? target : target + delta;\n-                            return state;\n-                        },\n-                        flipTarget: () => {}\n-                    };\n-                }\n-                const types = {\n-                    keyframes,\n-                    spring,\n-                    decay\n-                };\n-\n-                function detectAnimationFromOptions(config) {\n-                    if (Array.isArray(config.to)) {\n-                        return keyframes;\n-                    } else if (types[config.type]) {\n-                        return types[config.type];\n-                    }\n-                    const keys = new Set(Object.keys(config));\n-                    if (keys.has(\"ease\") || keys.has(\"duration\") && !keys.has(\"dampingRatio\")) {\n-                        return keyframes;\n-                    } else if (keys.has(\"dampingRatio\") || keys.has(\"stiffness\") || keys.has(\"mass\") || keys.has(\"damping\") || keys.has(\"restSpeed\") || keys.has(\"restDelta\")) {\n-                        return spring;\n-                    }\n-                    return keyframes;\n-                }\n-\n-                function loopElapsed(elapsed, duration) {\n-                    let delay = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0;\n-                    return elapsed - duration - delay;\n-                }\n-\n-                function reverseElapsed(elapsed, duration) {\n-                    let delay = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0;\n-                    let isForwardPlayback = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : true;\n-                    return isForwardPlayback ? loopElapsed(duration + -elapsed, duration, delay) : duration - (elapsed - duration) + delay;\n-                }\n-\n-                function hasRepeatDelayElapsed(elapsed, duration, delay, isForwardPlayback) {\n-                    return isForwardPlayback ? elapsed >= duration + delay : elapsed <= -delay;\n-                }\n-                const framesync = update => {\n-                    const passTimestamp = _ref7 => {\n-                        let {\n-                            delta\n-                        } = _ref7;\n-                        return update(delta);\n-                    };\n-                    return {\n-                        start: () => sync__default[\"default\"].update(passTimestamp, true),\n-                        stop: () => sync.cancelSync.update(passTimestamp)\n-                    };\n-                };\n-\n-                function animate(_a) {\n-                    var _b, _c;\n-                    var {\n-                        from,\n-                        autoplay = true,\n-                        driver = framesync,\n-                        elapsed = 0,\n-                        repeat: repeatMax = 0,\n-                        repeatType = \"loop\",\n-                        repeatDelay = 0,\n-                        onPlay,\n-                        onStop,\n-                        onComplete,\n-                        onRepeat,\n-                        onUpdate\n-                    } = _a,\n-                    options = tslib.__rest(_a, [\"from\", \"autoplay\", \"driver\", \"elapsed\", \"repeat\", \"repeatType\", \"repeatDelay\", \"onPlay\", \"onStop\", \"onComplete\", \"onRepeat\", \"onUpdate\"]);\n-                    let {\n-                        to\n-                    } = options;\n-                    let driverControls;\n-                    let repeatCount = 0;\n-                    let computedDuration = options.duration;\n-                    let latest;\n-                    let isComplete = false;\n-                    let isForwardPlayback = true;\n-                    let interpolateFromNumber;\n-                    const animator = detectAnimationFromOptions(options);\n-                    if ((_c = (_b = animator).needsInterpolation) === null || _c === void 0 ? void 0 : _c.call(_b, from, to)) {\n-                        interpolateFromNumber = interpolate([0, 100], [from, to], {\n-                            clamp: false\n-                        });\n-                        from = 0;\n-                        to = 100;\n-                    }\n-                    const animation = animator(Object.assign(Object.assign({}, options), {\n-                        from,\n-                        to\n-                    }));\n-\n-                    function repeat() {\n-                        repeatCount++;\n-                        if (repeatType === \"reverse\") {\n-                            isForwardPlayback = repeatCount % 2 === 0;\n-                            elapsed = reverseElapsed(elapsed, computedDuration, repeatDelay, isForwardPlayback);\n-                        } else {\n-                            elapsed = loopElapsed(elapsed, computedDuration, repeatDelay);\n-                            if (repeatType === \"mirror\") animation.flipTarget();\n-                        }\n-                        isComplete = false;\n-                        onRepeat && onRepeat();\n-                    }\n-\n-                    function complete() {\n-                        driverControls.stop();\n-                        onComplete && onComplete();\n-                    }\n-\n-                    function update(delta) {\n-                        if (!isForwardPlayback) delta = -delta;\n-                        elapsed += delta;\n-                        if (!isComplete) {\n-                            const state = animation.next(Math.max(0, elapsed));\n-                            latest = state.value;\n-                            if (interpolateFromNumber) latest = interpolateFromNumber(latest);\n-                            isComplete = isForwardPlayback ? state.done : elapsed <= 0;\n-                        }\n-                        onUpdate === null || onUpdate === void 0 ? void 0 : onUpdate(latest);\n-                        if (isComplete) {\n-                            if (repeatCount === 0) computedDuration !== null && computedDuration !== void 0 ? computedDuration : computedDuration = elapsed;\n-                            if (repeatCount < repeatMax) {\n-                                hasRepeatDelayElapsed(elapsed, computedDuration, repeatDelay, isForwardPlayback) && repeat();\n-                            } else {\n-                                complete();\n-                            }\n-                        }\n-                    }\n-\n-                    function play() {\n-                        onPlay === null || onPlay === void 0 ? void 0 : onPlay();\n-                        driverControls = driver(update);\n-                        driverControls.start();\n-                    }\n-                    autoplay && play();\n-                    return {\n-                        stop: () => {\n-                            onStop === null || onStop === void 0 ? void 0 : onStop();\n-                            driverControls.stop();\n-                        }\n-                    };\n-                }\n-\n-                function velocityPerSecond(velocity, frameDuration) {\n-                    return frameDuration ? velocity * (1000 / frameDuration) : 0;\n-                }\n-\n-                function inertia(_ref8) {\n-                    let {\n-                        from = 0,\n-                            velocity = 0,\n-                            min,\n-                            max,\n-                            power = 0.8,\n-                            timeConstant = 750,\n-                            bounceStiffness = 500,\n-                            bounceDamping = 10,\n-                            restDelta = 1,\n-                            modifyTarget,\n-                            driver,\n-                            onUpdate,\n-                            onComplete,\n-                            onStop\n-                    } = _ref8;\n-                    let currentAnimation;\n-\n-                    function isOutOfBounds(v) {\n-                        return min !== undefined && v < min || max !== undefined && v > max;\n-                    }\n-\n-                    function boundaryNearest(v) {\n-                        if (min === undefined) return max;\n-                        if (max === undefined) return min;\n-                        return Math.abs(min - v) < Math.abs(max - v) ? min : max;\n-                    }\n-\n-                    function startAnimation(options) {\n-                        currentAnimation === null || currentAnimation === void 0 ? void 0 : currentAnimation.stop();\n-                        currentAnimation = animate(Object.assign(Object.assign({}, options), {\n-                            driver,\n-                            onUpdate: v => {\n-                                var _a;\n-                                onUpdate === null || onUpdate === void 0 ? void 0 : onUpdate(v);\n-                                (_a = options.onUpdate) === null || _a === void 0 ? void 0 : _a.call(options, v);\n-                            },\n-                            onComplete,\n-                            onStop\n-                        }));\n-                    }\n-\n-                    function startSpring(options) {\n-                        startAnimation(Object.assign({\n-                            type: \"spring\",\n-                            stiffness: bounceStiffness,\n-                            damping: bounceDamping,\n-                            restDelta\n-                        }, options));\n-                    }\n-                    if (isOutOfBounds(from)) {\n-                        startSpring({\n-                            from,\n-                            velocity,\n-                            to: boundaryNearest(from)\n-                        });\n-                    } else {\n-                        let target = power * velocity + from;\n-                        if (typeof modifyTarget !== \"undefined\") target = modifyTarget(target);\n-                        const boundary = boundaryNearest(target);\n-                        const heading = boundary === min ? -1 : 1;\n-                        let prev;\n-                        let current;\n-                        const checkBoundary = v => {\n-                            prev = current;\n-                            current = v;\n-                            velocity = velocityPerSecond(v - prev, sync.getFrameData().delta);\n-                            if (heading === 1 && v > boundary || heading === -1 && v < boundary) {\n-                                startSpring({\n-                                    from: v,\n-                                    to: boundary,\n-                                    velocity\n-                                });\n-                            }\n-                        };\n-                        startAnimation({\n-                            type: \"decay\",\n-                            from,\n-                            velocity,\n-                            timeConstant,\n-                            power,\n-                            restDelta,\n-                            modifyTarget,\n-                            onUpdate: isOutOfBounds(target) ? checkBoundary : undefined\n-                        });\n-                    }\n-                    return {\n-                        stop: () => currentAnimation === null || currentAnimation === void 0 ? void 0 : currentAnimation.stop()\n-                    };\n-                }\n-                const radiansToDegrees = radians => radians * 180 / Math.PI;\n-                const angle = function(a) {\n-                    let b = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : zeroPoint;\n-                    return radiansToDegrees(Math.atan2(b.y - a.y, b.x - a.x));\n-                };\n-                const applyOffset = (from, to) => {\n-                    let hasReceivedFrom = true;\n-                    if (to === undefined) {\n-                        to = from;\n-                        hasReceivedFrom = false;\n-                    }\n-                    return v => {\n-                        if (hasReceivedFrom) {\n-                            return v - from + to;\n-                        } else {\n-                            from = v;\n-                            hasReceivedFrom = true;\n-                            return to;\n-                        }\n-                    };\n-                };\n-                const identity = v => v;\n-                const createAttractor = function() {\n-                    let alterDisplacement = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : identity;\n-                    return (constant, origin, v) => {\n-                        const displacement = origin - v;\n-                        const springModifiedDisplacement = -(0 - constant + 1) * (0 - alterDisplacement(Math.abs(displacement)));\n-                        return displacement <= 0 ? origin + springModifiedDisplacement : origin - springModifiedDisplacement;\n-                    };\n-                };\n-                const attract = createAttractor();\n-                const attractExpo = createAttractor(Math.sqrt);\n-                const degreesToRadians = degrees => degrees * Math.PI / 180;\n-                const isPoint = point => point.hasOwnProperty('x') && point.hasOwnProperty('y');\n-                const isPoint3D = point => isPoint(point) && point.hasOwnProperty('z');\n-                const distance1D = (a, b) => Math.abs(a - b);\n-\n-                function distance(a, b) {\n-                    if (isNum(a) && isNum(b)) {\n-                        return distance1D(a, b);\n-                    } else if (isPoint(a) && isPoint(b)) {\n-                        const xDelta = distance1D(a.x, b.x);\n-                        const yDelta = distance1D(a.y, b.y);\n-                        const zDelta = isPoint3D(a) && isPoint3D(b) ? distance1D(a.z, b.z) : 0;\n-                        return Math.sqrt(Math.pow(xDelta, 2) + Math.pow(yDelta, 2) + Math.pow(zDelta, 2));\n-                    }\n-                }\n-                const pointFromVector = (origin, angle, distance) => {\n-                    angle = degreesToRadians(angle);\n-                    return {\n-                        x: distance * Math.cos(angle) + origin.x,\n-                        y: distance * Math.sin(angle) + origin.y\n-                    };\n-                };\n-                const toDecimal = function(num) {\n-                    let precision = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 2;\n-                    precision = Math.pow(10, precision);\n-                    return Math.round(num * precision) / precision;\n-                };\n-                const smoothFrame = function(prevValue, nextValue, duration) {\n-                    let smoothing = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0;\n-                    return toDecimal(prevValue + duration * (nextValue - prevValue) / Math.max(smoothing, duration));\n-                };\n-                const smooth = function() {\n-                    let strength = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 50;\n-                    let previousValue = 0;\n-                    let lastUpdated = 0;\n-                    return v => {\n-                        const currentFramestamp = sync.getFrameData().timestamp;\n-                        const timeDelta = currentFramestamp !== lastUpdated ? currentFramestamp - lastUpdated : 0;\n-                        const newValue = timeDelta ? smoothFrame(previousValue, v, timeDelta, strength) : previousValue;\n-                        lastUpdated = currentFramestamp;\n-                        previousValue = newValue;\n-                        return newValue;\n-                    };\n-                };\n-                const snap = points => {\n-                    if (typeof points === 'number') {\n-                        return v => Math.round(v / points) * points;\n-                    } else {\n-                        let i = 0;\n-                        const numPoints = points.length;\n-                        return v => {\n-                            let lastDistance = Math.abs(points[0] - v);\n-                            for (i = 1; i < numPoints; i++) {\n-                                const point = points[i];\n-                                const distance = Math.abs(point - v);\n-                                if (distance === 0) return point;\n-                                if (distance > lastDistance) return points[i - 1];\n-                                if (i === numPoints - 1) return point;\n-                                lastDistance = distance;\n-                            }\n-                        };\n-                    }\n-                };\n-\n-                function velocityPerFrame(xps, frameDuration) {\n-                    return xps / (1000 / frameDuration);\n-                }\n-                const wrap = (min, max, v) => {\n-                    const rangeSize = max - min;\n-                    return ((v - min) % rangeSize + rangeSize) % rangeSize + min;\n-                };\n-                const a = (a1, a2) => 1.0 - 3.0 * a2 + 3.0 * a1;\n-                const b = (a1, a2) => 3.0 * a2 - 6.0 * a1;\n-                const c = a1 => 3.0 * a1;\n-                const calcBezier = (t, a1, a2) => ((a(a1, a2) * t + b(a1, a2)) * t + c(a1)) * t;\n-                const getSlope = (t, a1, a2) => 3.0 * a(a1, a2) * t * t + 2.0 * b(a1, a2) * t + c(a1);\n-                const subdivisionPrecision = 0.0000001;\n-                const subdivisionMaxIterations = 10;\n-\n-                function binarySubdivide(aX, aA, aB, mX1, mX2) {\n-                    let currentX;\n-                    let currentT;\n-                    let i = 0;\n-                    do {\n-                        currentT = aA + (aB - aA) / 2.0;\n-                        currentX = calcBezier(currentT, mX1, mX2) - aX;\n-                        if (currentX > 0.0) {\n-                            aB = currentT;\n-                        } else {\n-                            aA = currentT;\n-                        }\n-                    } while (Math.abs(currentX) > subdivisionPrecision && ++i < subdivisionMaxIterations);\n-                    return currentT;\n-                }\n-                const newtonIterations = 8;\n-                const newtonMinSlope = 0.001;\n-\n-                function newtonRaphsonIterate(aX, aGuessT, mX1, mX2) {\n-                    for (let i = 0; i < newtonIterations; ++i) {\n-                        const currentSlope = getSlope(aGuessT, mX1, mX2);\n-                        if (currentSlope === 0.0) {\n-                            return aGuessT;\n-                        }\n-                        const currentX = calcBezier(aGuessT, mX1, mX2) - aX;\n-                        aGuessT -= currentX / currentSlope;\n-                    }\n-                    return aGuessT;\n-                }\n-                const kSplineTableSize = 11;\n-                const kSampleStepSize = 1.0 / (kSplineTableSize - 1.0);\n-\n-                function cubicBezier(mX1, mY1, mX2, mY2) {\n-                    if (mX1 === mY1 && mX2 === mY2) return linear;\n-                    const sampleValues = new Float32Array(kSplineTableSize);\n-                    for (let i = 0; i < kSplineTableSize; ++i) {\n-                        sampleValues[i] = calcBezier(i * kSampleStepSize, mX1, mX2);\n-                    }\n-\n-                    function getTForX(aX) {\n-                        let intervalStart = 0.0;\n-                        let currentSample = 1;\n-                        const lastSample = kSplineTableSize - 1;\n-                        for (; currentSample !== lastSample && sampleValues[currentSample] <= aX; ++currentSample) {\n-                            intervalStart += kSampleStepSize;\n-                        }\n-                        --currentSample;\n-                        const dist = (aX - sampleValues[currentSample]) / (sampleValues[currentSample + 1] - sampleValues[currentSample]);\n-                        const guessForT = intervalStart + dist * kSampleStepSize;\n-                        const initialSlope = getSlope(guessForT, mX1, mX2);\n-                        if (initialSlope >= newtonMinSlope) {\n-                            return newtonRaphsonIterate(aX, guessForT, mX1, mX2);\n-                        } else if (initialSlope === 0.0) {\n-                            return guessForT;\n-                        } else {\n-                            return binarySubdivide(aX, intervalStart, intervalStart + kSampleStepSize, mX1, mX2);\n-                        }\n-                    }\n-                    return t => t === 0 || t === 1 ? t : calcBezier(getTForX(t), mY1, mY2);\n-                }\n-                const steps = function(steps) {\n-                    let direction = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'end';\n-                    return progress => {\n-                        progress = direction === 'end' ? Math.min(progress, 0.999) : Math.max(progress, 0.001);\n-                        const expanded = progress * steps;\n-                        const rounded = direction === 'end' ? Math.floor(expanded) : Math.ceil(expanded);\n-                        return clamp(0, 1, rounded / steps);\n-                    };\n-                };\n-                exports.angle = angle;\n-                exports.animate = animate;\n-                exports.anticipate = anticipate;\n-                exports.applyOffset = applyOffset;\n-                exports.attract = attract;\n-                exports.attractExpo = attractExpo;\n-                exports.backIn = backIn;\n-                exports.backInOut = backInOut;\n-                exports.backOut = backOut;\n-                exports.bounceIn = bounceIn;\n-                exports.bounceInOut = bounceInOut;\n-                exports.bounceOut = bounceOut;\n-                exports.circIn = circIn;\n-                exports.circInOut = circInOut;\n-                exports.circOut = circOut;\n-                exports.clamp = clamp;\n-                exports.createAnticipate = createAnticipate;\n-                exports.createAttractor = createAttractor;\n-                exports.createBackIn = createBackIn;\n-                exports.createExpoIn = createExpoIn;\n-                exports.cubicBezier = cubicBezier;\n-                exports.decay = decay;\n-                exports.degreesToRadians = degreesToRadians;\n-                exports.distance = distance;\n-                exports.easeIn = easeIn;\n-                exports.easeInOut = easeInOut;\n-                exports.easeOut = easeOut;\n-                exports.inertia = inertia;\n-                exports.interpolate = interpolate;\n-                exports.isPoint = isPoint;\n-                exports.isPoint3D = isPoint3D;\n-                exports.keyframes = keyframes;\n-                exports.linear = linear;\n-                exports.mirrorEasing = mirrorEasing;\n-                exports.mix = mix;\n-                exports.mixColor = mixColor;\n-                exports.mixComplex = mixComplex;\n-                exports.pipe = pipe;\n-                exports.pointFromVector = pointFromVector;\n-                exports.progress = progress;\n-                exports.radiansToDegrees = radiansToDegrees;\n-                exports.reverseEasing = reverseEasing;\n-                exports.smooth = smooth;\n-                exports.smoothFrame = smoothFrame;\n-                exports.snap = snap;\n-                exports.spring = spring;\n-                exports.steps = steps;\n-                exports.toDecimal = toDecimal;\n-                exports.velocityPerFrame = velocityPerFrame;\n-                exports.velocityPerSecond = velocityPerSecond;\n-                exports.wrap = wrap;\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/punycode.js/punycode.es6.js\":\n-            /*!*********************************************************!*\\\n-              !*** ../../../node_modules/punycode.js/punycode.es6.js ***!\n-              \\*********************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports) {\n-\n-\n-\n-                /** Highest positive signed 32-bit float value */\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.toUnicode = exports.toASCII = exports.encode = exports[\"default\"] = exports.decode = void 0;\n-                exports.ucs2decode = ucs2decode;\n-                exports.ucs2encode = void 0;\n-                const maxInt = 2147483647; // aka. 0x7FFFFFFF or 2^31-1\n-\n-                /** Bootstring parameters */\n-                const base = 36;\n-                const tMin = 1;\n-                const tMax = 26;\n-                const skew = 38;\n-                const damp = 700;\n-                const initialBias = 72;\n-                const initialN = 128; // 0x80\n-                const delimiter = '-'; // '\\x2D'\n-\n-                /** Regular expressions */\n-                const regexPunycode = /^xn--/;\n-                const regexNonASCII = /[^\\0-\\x7F]/; // Note: U+007F DEL is excluded too.\n-                const regexSeparators = /[\\x2E\\u3002\\uFF0E\\uFF61]/g; // RFC 3490 separators\n-\n-                /** Error messages */\n-                const errors = {\n-                    'overflow': 'Overflow: input needs wider integers to process',\n-                    'not-basic': 'Illegal input >= 0x80 (not a basic code point)',\n-                    'invalid-input': 'Invalid input'\n-                };\n-\n-                /** Convenience shortcuts */\n-                const baseMinusTMin = base - tMin;\n-                const floor = Math.floor;\n-                const stringFromCharCode = String.fromCharCode;\n-\n-                /*--------------------------------------------------------------------------*/\n-\n-                /**\n-                 * A generic error utility function.\n-                 * @private\n-                 * @param {String} type The error type.\n-                 * @returns {Error} Throws a `RangeError` with the applicable error message.\n-                 */\n-                function error(type) {\n-                    throw new RangeError(errors[type]);\n-                }\n-\n-                /**\n-                 * A generic `Array#map` utility function.\n-                 * @private\n-                 * @param {Array} array The array to iterate over.\n-                 * @param {Function} callback The function that gets called for every array\n-                 * item.\n-                 * @returns {Array} A new array of values returned by the callback function.\n-                 */\n-                function map(array, callback) {\n-                    const result = [];\n-                    let length = array.length;\n-                    while (length--) {\n-                        result[length] = callback(array[length]);\n-                    }\n-                    return result;\n-                }\n-\n-                /**\n-                 * A simple `Array#map`-like wrapper to work with domain name strings or email\n-                 * addresses.\n-                 * @private\n-                 * @param {String} domain The domain name or email address.\n-                 * @param {Function} callback The function that gets called for every\n-                 * character.\n-                 * @returns {String} A new string of characters returned by the callback\n-                 * function.\n-                 */\n-                function mapDomain(domain, callback) {\n-                    const parts = domain.split('@');\n-                    let result = '';\n-                    if (parts.length > 1) {\n-                        // In email addresses, only the domain name should be punycoded. Leave\n-                        // the local part (i.e. everything up to `@`) intact.\n-                        result = parts[0] + '@';\n-                        domain = parts[1];\n-                    }\n-                    // Avoid `split(regex)` for IE8 compatibility. See #17.\n-                    domain = domain.replace(regexSeparators, '\\x2E');\n-                    const labels = domain.split('.');\n-                    const encoded = map(labels, callback).join('.');\n-                    return result + encoded;\n-                }\n-\n-                /**\n-                 * Creates an array containing the numeric code points of each Unicode\n-                 * character in the string. While JavaScript uses UCS-2 internally,\n-                 * this function will convert a pair of surrogate halves (each of which\n-                 * UCS-2 exposes as separate characters) into a single code point,\n-                 * matching UTF-16.\n-                 * @see `punycode.ucs2.encode`\n-                 * @see <https://mathiasbynens.be/notes/javascript-encoding>\n-                 * @memberOf punycode.ucs2\n-                 * @name decode\n-                 * @param {String} string The Unicode input string (UCS-2).\n-                 * @returns {Array} The new array of code points.\n-                 */\n-                function ucs2decode(string) {\n-                    const output = [];\n-                    let counter = 0;\n-                    const length = string.length;\n-                    while (counter < length) {\n-                        const value = string.charCodeAt(counter++);\n-                        if (value >= 0xD800 && value <= 0xDBFF && counter < length) {\n-                            // It's a high surrogate, and there is a next character.\n-                            const extra = string.charCodeAt(counter++);\n-                            if ((extra & 0xFC00) == 0xDC00) {\n-                                // Low surrogate.\n-                                output.push(((value & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000);\n-                            } else {\n-                                // It's an unmatched surrogate; only append this code unit, in case the\n-                                // next code unit is the high surrogate of a surrogate pair.\n-                                output.push(value);\n-                                counter--;\n-                            }\n-                        } else {\n-                            output.push(value);\n-                        }\n-                    }\n-                    return output;\n-                }\n-\n-                /**\n-                 * Creates a string based on an array of numeric code points.\n-                 * @see `punycode.ucs2.decode`\n-                 * @memberOf punycode.ucs2\n-                 * @name encode\n-                 * @param {Array} codePoints The array of numeric code points.\n-                 * @returns {String} The new Unicode string (UCS-2).\n-                 */\n-                const ucs2encode = codePoints => String.fromCodePoint(...codePoints);\n-\n-                /**\n-                 * Converts a basic code point into a digit/integer.\n-                 * @see `digitToBasic()`\n-                 * @private\n-                 * @param {Number} codePoint The basic numeric code point value.\n-                 * @returns {Number} The numeric value of a basic code point (for use in\n-                 * representing integers) in the range `0` to `base - 1`, or `base` if\n-                 * the code point does not represent a value.\n-                 */\n-                exports.ucs2encode = ucs2encode;\n-                const basicToDigit = function(codePoint) {\n-                    if (codePoint >= 0x30 && codePoint < 0x3A) {\n-                        return 26 + (codePoint - 0x30);\n-                    }\n-                    if (codePoint >= 0x41 && codePoint < 0x5B) {\n-                        return codePoint - 0x41;\n-                    }\n-                    if (codePoint >= 0x61 && codePoint < 0x7B) {\n-                        return codePoint - 0x61;\n-                    }\n-                    return base;\n-                };\n-\n-                /**\n-                 * Converts a digit/integer into a basic code point.\n-                 * @see `basicToDigit()`\n-                 * @private\n-                 * @param {Number} digit The numeric value of a basic code point.\n-                 * @returns {Number} The basic code point whose value (when used for\n-                 * representing integers) is `digit`, which needs to be in the range\n-                 * `0` to `base - 1`. If `flag` is non-zero, the uppercase form is\n-                 * used; else, the lowercase form is used. The behavior is undefined\n-                 * if `flag` is non-zero and `digit` has no uppercase form.\n-                 */\n-                const digitToBasic = function(digit, flag) {\n-                    //  0..25 map to ASCII a..z or A..Z\n-                    // 26..35 map to ASCII 0..9\n-                    return digit + 22 + 75 * (digit < 26) - ((flag != 0) << 5);\n-                };\n-\n-                /**\n-                 * Bias adaptation function as per section 3.4 of RFC 3492.\n-                 * https://tools.ietf.org/html/rfc3492#section-3.4\n-                 * @private\n-                 */\n-                const adapt = function(delta, numPoints, firstTime) {\n-                    let k = 0;\n-                    delta = firstTime ? floor(delta / damp) : delta >> 1;\n-                    delta += floor(delta / numPoints);\n-                    for /* no initialization */ (; delta > baseMinusTMin * tMax >> 1; k += base) {\n-                        delta = floor(delta / baseMinusTMin);\n-                    }\n-                    return floor(k + (baseMinusTMin + 1) * delta / (delta + skew));\n-                };\n-\n-                /**\n-                 * Converts a Punycode string of ASCII-only symbols to a string of Unicode\n-                 * symbols.\n-                 * @memberOf punycode\n-                 * @param {String} input The Punycode string of ASCII-only symbols.\n-                 * @returns {String} The resulting string of Unicode symbols.\n-                 */\n-                const decode = function(input) {\n-                    // Don't use UCS-2.\n-                    const output = [];\n-                    const inputLength = input.length;\n-                    let i = 0;\n-                    let n = initialN;\n-                    let bias = initialBias;\n-\n-                    // Handle the basic code points: let `basic` be the number of input code\n-                    // points before the last delimiter, or `0` if there is none, then copy\n-                    // the first basic code points to the output.\n-\n-                    let basic = input.lastIndexOf(delimiter);\n-                    if (basic < 0) {\n-                        basic = 0;\n-                    }\n-                    for (let j = 0; j < basic; ++j) {\n-                        // if it's not a basic code point\n-                        if (input.charCodeAt(j) >= 0x80) {\n-                            error('not-basic');\n-                        }\n-                        output.push(input.charCodeAt(j));\n-                    }\n-\n-                    // Main decoding loop: start just after the last delimiter if any basic code\n-                    // points were copied; start at the beginning otherwise.\n-\n-                    for /* no final expression */ (let index = basic > 0 ? basic + 1 : 0; index < inputLength;) {\n-                        // `index` is the index of the next character to be consumed.\n-                        // Decode a generalized variable-length integer into `delta`,\n-                        // which gets added to `i`. The overflow checking is easier\n-                        // if we increase `i` as we go, then subtract off its starting\n-                        // value at the end to obtain `delta`.\n-                        const oldi = i;\n-                        for /* no condition */ (let w = 1, k = base;; k += base) {\n-                            if (index >= inputLength) {\n-                                error('invalid-input');\n-                            }\n-                            const digit = basicToDigit(input.charCodeAt(index++));\n-                            if (digit >= base) {\n-                                error('invalid-input');\n-                            }\n-                            if (digit > floor((maxInt - i) / w)) {\n-                                error('overflow');\n-                            }\n-                            i += digit * w;\n-                            const t = k <= bias ? tMin : k >= bias + tMax ? tMax : k - bias;\n-                            if (digit < t) {\n-                                break;\n-                            }\n-                            const baseMinusT = base - t;\n-                            if (w > floor(maxInt / baseMinusT)) {\n-                                error('overflow');\n-                            }\n-                            w *= baseMinusT;\n-                        }\n-                        const out = output.length + 1;\n-                        bias = adapt(i - oldi, out, oldi == 0);\n-\n-                        // `i` was supposed to wrap around from `out` to `0`,\n-                        // incrementing `n` each time, so we'll fix that now:\n-                        if (floor(i / out) > maxInt - n) {\n-                            error('overflow');\n-                        }\n-                        n += floor(i / out);\n-                        i %= out;\n-\n-                        // Insert `n` at position `i` of the output.\n-                        output.splice(i++, 0, n);\n-                    }\n-                    return String.fromCodePoint(...output);\n-                };\n-\n-                /**\n-                 * Converts a string of Unicode symbols (e.g. a domain name label) to a\n-                 * Punycode string of ASCII-only symbols.\n-                 * @memberOf punycode\n-                 * @param {String} input The string of Unicode symbols.\n-                 * @returns {String} The resulting Punycode string of ASCII-only symbols.\n-                 */\n-                exports.decode = decode;\n-                const encode = function(input) {\n-                    const output = [];\n-\n-                    // Convert the input in UCS-2 to an array of Unicode code points.\n-                    input = ucs2decode(input);\n-\n-                    // Cache the length.\n-                    const inputLength = input.length;\n-\n-                    // Initialize the state.\n-                    let n = initialN;\n-                    let delta = 0;\n-                    let bias = initialBias;\n-\n-                    // Handle the basic code points.\n-                    for (const currentValue of input) {\n-                        if (currentValue < 0x80) {\n-                            output.push(stringFromCharCode(currentValue));\n-                        }\n-                    }\n-                    const basicLength = output.length;\n-                    let handledCPCount = basicLength;\n-\n-                    // `handledCPCount` is the number of code points that have been handled;\n-                    // `basicLength` is the number of basic code points.\n-\n-                    // Finish the basic string with a delimiter unless it's empty.\n-                    if (basicLength) {\n-                        output.push(delimiter);\n-                    }\n-\n-                    // Main encoding loop:\n-                    while (handledCPCount < inputLength) {\n-                        // All non-basic code points < n have been handled already. Find the next\n-                        // larger one:\n-                        let m = maxInt;\n-                        for (const currentValue of input) {\n-                            if (currentValue >= n && currentValue < m) {\n-                                m = currentValue;\n-                            }\n-                        }\n-\n-                        // Increase `delta` enough to advance the decoder's <n,i> state to <m,0>,\n-                        // but guard against overflow.\n-                        const handledCPCountPlusOne = handledCPCount + 1;\n-                        if (m - n > floor((maxInt - delta) / handledCPCountPlusOne)) {\n-                            error('overflow');\n-                        }\n-                        delta += (m - n) * handledCPCountPlusOne;\n-                        n = m;\n-                        for (const currentValue of input) {\n-                            if (currentValue < n && ++delta > maxInt) {\n-                                error('overflow');\n-                            }\n-                            if (currentValue === n) {\n-                                // Represent delta as a generalized variable-length integer.\n-                                let q = delta;\n-                                for /* no condition */ (let k = base;; k += base) {\n-                                    const t = k <= bias ? tMin : k >= bias + tMax ? tMax : k - bias;\n-                                    if (q < t) {\n-                                        break;\n-                                    }\n-                                    const qMinusT = q - t;\n-                                    const baseMinusT = base - t;\n-                                    output.push(stringFromCharCode(digitToBasic(t + qMinusT % baseMinusT, 0)));\n-                                    q = floor(qMinusT / baseMinusT);\n-                                }\n-                                output.push(stringFromCharCode(digitToBasic(q, 0)));\n-                                bias = adapt(delta, handledCPCountPlusOne, handledCPCount === basicLength);\n-                                delta = 0;\n-                                ++handledCPCount;\n-                            }\n-                        }\n-                        ++delta;\n-                        ++n;\n-                    }\n-                    return output.join('');\n-                };\n-\n-                /**\n-                 * Converts a Punycode string representing a domain name or an email address\n-                 * to Unicode. Only the Punycoded parts of the input will be converted, i.e.\n-                 * it doesn't matter if you call it on a string that has already been\n-                 * converted to Unicode.\n-                 * @memberOf punycode\n-                 * @param {String} input The Punycoded domain name or email address to\n-                 * convert to Unicode.\n-                 * @returns {String} The Unicode representation of the given Punycode\n-                 * string.\n-                 */\n-                exports.encode = encode;\n-                const toUnicode = function(input) {\n-                    return mapDomain(input, function(string) {\n-                        return regexPunycode.test(string) ? decode(string.slice(4).toLowerCase()) : string;\n-                    });\n-                };\n-\n-                /**\n-                 * Converts a Unicode string representing a domain name or an email address to\n-                 * Punycode. Only the non-ASCII parts of the domain name will be converted,\n-                 * i.e. it doesn't matter if you call it with a domain that's already in\n-                 * ASCII.\n-                 * @memberOf punycode\n-                 * @param {String} input The domain name or email address to convert, as a\n-                 * Unicode string.\n-                 * @returns {String} The Punycode representation of the given domain name or\n-                 * email address.\n-                 */\n-                exports.toUnicode = toUnicode;\n-                const toASCII = function(input) {\n-                    return mapDomain(input, function(string) {\n-                        return regexNonASCII.test(string) ? 'xn--' + encode(string) : string;\n-                    });\n-                };\n-\n-                /*--------------------------------------------------------------------------*/\n-\n-                /** Define the public API */\n-                exports.toASCII = toASCII;\n-                const punycode = {\n-                    /**\n-                     * A string representing the current Punycode.js version number.\n-                     * @memberOf punycode\n-                     * @type String\n-                     */\n-                    'version': '2.3.1',\n-                    /**\n-                     * An object of methods to convert from JavaScript's internal character\n-                     * representation (UCS-2) to Unicode code points, and back.\n-                     * @see <https://mathiasbynens.be/notes/javascript-encoding>\n-                     * @memberOf punycode\n-                     * @type Object\n-                     */\n-                    'ucs2': {\n-                        'decode': ucs2decode,\n-                        'encode': ucs2encode\n-                    },\n-                    'decode': decode,\n-                    'encode': encode,\n-                    'toASCII': toASCII,\n-                    'toUnicode': toUnicode\n-                };\n-                var _default = punycode;\n-                exports[\"default\"] = _default;\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/react-remove-scroll-bar/dist/es2015/component.js\":\n-            /*!******************************************************************************!*\\\n-              !*** ../../../node_modules/react-remove-scroll-bar/dist/es2015/component.js ***!\n-              \\******************************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.RemoveScrollBar = void 0;\n-                var React = _interopRequireWildcard(__webpack_require__( /*! react */ \"react\"));\n-                var _reactStyleSingleton = __webpack_require__( /*! react-style-singleton */ \"../../../node_modules/react-style-singleton/dist/es2015/index.js\");\n-                var _constants = __webpack_require__( /*! ./constants */ \"../../../node_modules/react-remove-scroll-bar/dist/es2015/constants.js\");\n-                var _utils = __webpack_require__( /*! ./utils */ \"../../../node_modules/react-remove-scroll-bar/dist/es2015/utils.js\");\n-\n-                function _getRequireWildcardCache(nodeInterop) {\n-                    if (typeof WeakMap !== \"function\") return null;\n-                    var cacheBabelInterop = new WeakMap();\n-                    var cacheNodeInterop = new WeakMap();\n-                    return (_getRequireWildcardCache = function(nodeInterop) {\n-                        return nodeInterop ? cacheNodeInterop : cacheBabelInterop;\n-                    })(nodeInterop);\n-                }\n-\n-                function _interopRequireWildcard(obj, nodeInterop) {\n-                    if (!nodeInterop && obj && obj.__esModule) {\n-                        return obj;\n-                    }\n-                    if (obj === null || typeof obj !== \"object\" && typeof obj !== \"function\") {\n-                        return {\n-                            default: obj\n-                        };\n-                    }\n-                    var cache = _getRequireWildcardCache(nodeInterop);\n-                    if (cache && cache.has(obj)) {\n-                        return cache.get(obj);\n-                    }\n-                    var newObj = {};\n-                    var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;\n-                    for (var key in obj) {\n-                        if (key !== \"default\" && Object.prototype.hasOwnProperty.call(obj, key)) {\n-                            var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;\n-                            if (desc && (desc.get || desc.set)) {\n-                                Object.defineProperty(newObj, key, desc);\n-                            } else {\n-                                newObj[key] = obj[key];\n-                            }\n-                        }\n-                    }\n-                    newObj.default = obj;\n-                    if (cache) {\n-                        cache.set(obj, newObj);\n-                    }\n-                    return newObj;\n-                }\n-                var Style = (0, _reactStyleSingleton.styleSingleton)();\n-                // important tip - once we measure scrollBar width and remove them\n-                // we could not repeat this operation\n-                // thus we are using style-singleton - only the first \"yet correct\" style will be applied.\n-                var getStyles = function(_a, allowRelative, gapMode, important) {\n-                    var left = _a.left,\n-                        top = _a.top,\n-                        right = _a.right,\n-                        gap = _a.gap;\n-                    if (gapMode === void 0) {\n-                        gapMode = 'margin';\n-                    }\n-                    return \"\\n  .\".concat(_constants.noScrollbarsClassName, \" {\\n   overflow: hidden \").concat(important, \";\\n   padding-right: \").concat(gap, \"px \").concat(important, \";\\n  }\\n  body {\\n    overflow: hidden \").concat(important, \";\\n    overscroll-behavior: contain;\\n    \").concat([allowRelative && \"position: relative \".concat(important, \";\"), gapMode === 'margin' && \"\\n    padding-left: \".concat(left, \"px;\\n    padding-top: \").concat(top, \"px;\\n    padding-right: \").concat(right, \"px;\\n    margin-left:0;\\n    margin-top:0;\\n    margin-right: \").concat(gap, \"px \").concat(important, \";\\n    \"), gapMode === 'padding' && \"padding-right: \".concat(gap, \"px \").concat(important, \";\")].filter(Boolean).join(''), \"\\n  }\\n  \\n  .\").concat(_constants.zeroRightClassName, \" {\\n    right: \").concat(gap, \"px \").concat(important, \";\\n  }\\n  \\n  .\").concat(_constants.fullWidthClassName, \" {\\n    margin-right: \").concat(gap, \"px \").concat(important, \";\\n  }\\n  \\n  .\").concat(_constants.zeroRightClassName, \" .\").concat(_constants.zeroRightClassName, \" {\\n    right: 0 \").concat(important, \";\\n  }\\n  \\n  .\").concat(_constants.fullWidthClassName, \" .\").concat(_constants.fullWidthClassName, \" {\\n    margin-right: 0 \").concat(important, \";\\n  }\\n  \\n  body {\\n    \").concat(_constants.removedBarSizeVariable, \": \").concat(gap, \"px;\\n  }\\n\");\n-                };\n-                /**\n-                 * Removes page scrollbar and blocks page scroll when mounted\n-                 */\n-                var RemoveScrollBar = function(props) {\n-                    var noRelative = props.noRelative,\n-                        noImportant = props.noImportant,\n-                        _a = props.gapMode,\n-                        gapMode = _a === void 0 ? 'margin' : _a;\n-                    var gap = React.useMemo(function() {\n-                        return (0, _utils.getGapWidth)(gapMode);\n-                    }, [gapMode]);\n-                    return /*#__PURE__*/ React.createElement(Style, {\n-                        styles: getStyles(gap, !noRelative, gapMode, !noImportant ? '!important' : '')\n-                    });\n-                };\n-                exports.RemoveScrollBar = RemoveScrollBar;\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/react-remove-scroll-bar/dist/es2015/constants.js\":\n-            /*!******************************************************************************!*\\\n-              !*** ../../../node_modules/react-remove-scroll-bar/dist/es2015/constants.js ***!\n-              \\******************************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.zeroRightClassName = exports.removedBarSizeVariable = exports.noScrollbarsClassName = exports.fullWidthClassName = void 0;\n-                var zeroRightClassName = 'right-scroll-bar-position';\n-                exports.zeroRightClassName = zeroRightClassName;\n-                var fullWidthClassName = 'width-before-scroll-bar';\n-                exports.fullWidthClassName = fullWidthClassName;\n-                var noScrollbarsClassName = 'with-scroll-bars-hidden';\n-                /**\n-                 * Name of a CSS variable containing the amount of \"hidden\" scrollbar\n-                 * ! might be undefined ! use will fallback!\n-                 */\n-                exports.noScrollbarsClassName = noScrollbarsClassName;\n-                var removedBarSizeVariable = '--removed-body-scroll-bar-size';\n-                exports.removedBarSizeVariable = removedBarSizeVariable;\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/react-remove-scroll-bar/dist/es2015/index.js\":\n-            /*!**************************************************************************!*\\\n-              !*** ../../../node_modules/react-remove-scroll-bar/dist/es2015/index.js ***!\n-              \\**************************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                Object.defineProperty(exports, \"RemoveScrollBar\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _component.RemoveScrollBar;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"fullWidthClassName\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _constants.fullWidthClassName;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"getGapWidth\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _utils.getGapWidth;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"noScrollbarsClassName\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _constants.noScrollbarsClassName;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"removedBarSizeVariable\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _constants.removedBarSizeVariable;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"zeroRightClassName\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _constants.zeroRightClassName;\n+                    return {\n+                        Field: checkArgUniqueness,\n+                        Directive: checkArgUniqueness\n+                    };\n+\n+                    function checkArgUniqueness(parentNode) {\n+                        var _parentNode$arguments;\n+\n+                        // FIXME: https://github.com/graphql/graphql-js/issues/2203\n+\n+                        /* c8 ignore next */\n+                        const argumentNodes = (_parentNode$arguments = parentNode.arguments) !== null && _parentNode$arguments !== void 0 ? _parentNode$arguments : [];\n+                        const seenArgs = (0, _groupBy.groupBy)(argumentNodes, arg => arg.name.value);\n+                        for (const [argName, argNodes] of seenArgs) {\n+                            if (argNodes.length > 1) {\n+                                context.reportError(new _GraphQLError.GraphQLError(`There can be only one argument named \"${argName}\".`, {\n+                                    nodes: argNodes.map(node => node.name)\n+                                }));\n+                            }\n+                        }\n                     }\n-                }));\n-                var _component = __webpack_require__( /*! ./component */ \"../../../node_modules/react-remove-scroll-bar/dist/es2015/component.js\");\n-                var _constants = __webpack_require__( /*! ./constants */ \"../../../node_modules/react-remove-scroll-bar/dist/es2015/constants.js\");\n-                var _utils = __webpack_require__( /*! ./utils */ \"../../../node_modules/react-remove-scroll-bar/dist/es2015/utils.js\");\n+                }\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/react-remove-scroll-bar/dist/es2015/utils.js\":\n-            /*!**************************************************************************!*\\\n-              !*** ../../../node_modules/react-remove-scroll-bar/dist/es2015/utils.js ***!\n-              \\**************************************************************************/\n+        \"../../../node_modules/graphql/validation/rules/UniqueDirectiveNamesRule.mjs\":\n+            /*!***********************************************************************************!*\\\n+              !*** ../../../node_modules/graphql/validation/rules/UniqueDirectiveNamesRule.mjs ***!\n+              \\***********************************************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports) {\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports.zeroGap = exports.getGapWidth = void 0;\n-                var zeroGap = {\n-                    left: 0,\n-                    top: 0,\n-                    right: 0,\n-                    gap: 0\n-                };\n-                exports.zeroGap = zeroGap;\n-                var parse = function(x) {\n-                    return parseInt(x || '', 10) || 0;\n-                };\n-                var getOffset = function(gapMode) {\n-                    var cs = window.getComputedStyle(document.body);\n-                    if (true) {\n-                        if (cs.overflowY === 'hidden') {\n-                            console.error('react-remove-scroll-bar: cannot calculate scrollbar size because it is removed (overflow:hidden on body');\n-                        }\n-                    }\n-                    var left = cs[gapMode === 'padding' ? 'paddingLeft' : 'marginLeft'];\n-                    var top = cs[gapMode === 'padding' ? 'paddingTop' : 'marginTop'];\n-                    var right = cs[gapMode === 'padding' ? 'paddingRight' : 'marginRight'];\n-                    return [parse(left), parse(top), parse(right)];\n-                };\n-                var getGapWidth = function(gapMode) {\n-                    if (gapMode === void 0) {\n-                        gapMode = 'margin';\n-                    }\n-                    if (typeof window === 'undefined') {\n-                        return zeroGap;\n-                    }\n-                    var offsets = getOffset(gapMode);\n-                    var documentWidth = document.documentElement.clientWidth;\n-                    var windowWidth = window.innerWidth;\n+                exports.UniqueDirectiveNamesRule = UniqueDirectiveNamesRule;\n+                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n+                /**\n+                 * Unique directive names\n+                 *\n+                 * A GraphQL document is only valid if all defined directives have unique names.\n+                 */\n+                function UniqueDirectiveNamesRule(context) {\n+                    const knownDirectiveNames = Object.create(null);\n+                    const schema = context.getSchema();\n                     return {\n-                        left: offsets[0],\n-                        top: offsets[1],\n-                        right: offsets[2],\n-                        gap: Math.max(0, windowWidth - documentWidth + offsets[2] - offsets[0])\n+                        DirectiveDefinition(node) {\n+                            const directiveName = node.name.value;\n+                            if (schema !== null && schema !== void 0 && schema.getDirective(directiveName)) {\n+                                context.reportError(new _GraphQLError.GraphQLError(`Directive \"@${directiveName}\" already exists in the schema. It cannot be redefined.`, {\n+                                    nodes: node.name\n+                                }));\n+                                return;\n+                            }\n+                            if (knownDirectiveNames[directiveName]) {\n+                                context.reportError(new _GraphQLError.GraphQLError(`There can be only one directive named \"@${directiveName}\".`, {\n+                                    nodes: [knownDirectiveNames[directiveName], node.name]\n+                                }));\n+                            } else {\n+                                knownDirectiveNames[directiveName] = node.name;\n+                            }\n+                            return false;\n+                        }\n                     };\n-                };\n-                exports.getGapWidth = getGapWidth;\n+                }\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/react-remove-scroll/dist/es2015/Combination.js\":\n-            /*!****************************************************************************!*\\\n-              !*** ../../../node_modules/react-remove-scroll/dist/es2015/Combination.js ***!\n-              \\****************************************************************************/\n+        \"../../../node_modules/graphql/validation/rules/UniqueDirectivesPerLocationRule.mjs\":\n+            /*!******************************************************************************************!*\\\n+              !*** ../../../node_modules/graphql/validation/rules/UniqueDirectivesPerLocationRule.mjs ***!\n+              \\******************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports[\"default\"] = void 0;\n-                var _tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.js\");\n-                var React = _interopRequireWildcard(__webpack_require__( /*! react */ \"react\"));\n-                var _UI = __webpack_require__( /*! ./UI */ \"../../../node_modules/react-remove-scroll/dist/es2015/UI.js\");\n-                var _sidecar = _interopRequireDefault(__webpack_require__( /*! ./sidecar */ \"../../../node_modules/react-remove-scroll/dist/es2015/sidecar.js\"));\n-\n-                function _interopRequireDefault(obj) {\n-                    return obj && obj.__esModule ? obj : {\n-                        default: obj\n-                    };\n-                }\n-\n-                function _getRequireWildcardCache(nodeInterop) {\n-                    if (typeof WeakMap !== \"function\") return null;\n-                    var cacheBabelInterop = new WeakMap();\n-                    var cacheNodeInterop = new WeakMap();\n-                    return (_getRequireWildcardCache = function(nodeInterop) {\n-                        return nodeInterop ? cacheNodeInterop : cacheBabelInterop;\n-                    })(nodeInterop);\n-                }\n-\n-                function _interopRequireWildcard(obj, nodeInterop) {\n-                    if (!nodeInterop && obj && obj.__esModule) {\n-                        return obj;\n+                exports.UniqueDirectivesPerLocationRule = UniqueDirectivesPerLocationRule;\n+                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n+                var _kinds = __webpack_require__( /*! ../../language/kinds.mjs */ \"../../../node_modules/graphql/language/kinds.mjs\");\n+                var _predicates = __webpack_require__( /*! ../../language/predicates.mjs */ \"../../../node_modules/graphql/language/predicates.mjs\");\n+                var _directives = __webpack_require__( /*! ../../type/directives.mjs */ \"../../../node_modules/graphql/type/directives.mjs\");\n+                /**\n+                 * Unique directive names per location\n+                 *\n+                 * A GraphQL document is only valid if all non-repeatable directives at\n+                 * a given location are uniquely named.\n+                 *\n+                 * See https://spec.graphql.org/draft/#sec-Directives-Are-Unique-Per-Location\n+                 */\n+                function UniqueDirectivesPerLocationRule(context) {\n+                    const uniqueDirectiveMap = Object.create(null);\n+                    const schema = context.getSchema();\n+                    const definedDirectives = schema ? schema.getDirectives() : _directives.specifiedDirectives;\n+                    for (const directive of definedDirectives) {\n+                        uniqueDirectiveMap[directive.name] = !directive.isRepeatable;\n                     }\n-                    if (obj === null || typeof obj !== \"object\" && typeof obj !== \"function\") {\n-                        return {\n-                            default: obj\n-                        };\n+                    const astDefinitions = context.getDocument().definitions;\n+                    for (const def of astDefinitions) {\n+                        if (def.kind === _kinds.Kind.DIRECTIVE_DEFINITION) {\n+                            uniqueDirectiveMap[def.name.value] = !def.repeatable;\n+                        }\n                     }\n-                    var cache = _getRequireWildcardCache(nodeInterop);\n-                    if (cache && cache.has(obj)) {\n-                        return cache.get(obj);\n-                    }\n-                    var newObj = {};\n-                    var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;\n-                    for (var key in obj) {\n-                        if (key !== \"default\" && Object.prototype.hasOwnProperty.call(obj, key)) {\n-                            var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;\n-                            if (desc && (desc.get || desc.set)) {\n-                                Object.defineProperty(newObj, key, desc);\n+                    const schemaDirectives = Object.create(null);\n+                    const typeDirectivesMap = Object.create(null);\n+                    return {\n+                        // Many different AST nodes may contain directives. Rather than listing\n+                        // them all, just listen for entering any node, and check to see if it\n+                        // defines any directives.\n+                        enter(node) {\n+                            if (!('directives' in node) || !node.directives) {\n+                                return;\n+                            }\n+                            let seenDirectives;\n+                            if (node.kind === _kinds.Kind.SCHEMA_DEFINITION || node.kind === _kinds.Kind.SCHEMA_EXTENSION) {\n+                                seenDirectives = schemaDirectives;\n+                            } else if ((0, _predicates.isTypeDefinitionNode)(node) || (0, _predicates.isTypeExtensionNode)(node)) {\n+                                const typeName = node.name.value;\n+                                seenDirectives = typeDirectivesMap[typeName];\n+                                if (seenDirectives === undefined) {\n+                                    typeDirectivesMap[typeName] = seenDirectives = Object.create(null);\n+                                }\n                             } else {\n-                                newObj[key] = obj[key];\n+                                seenDirectives = Object.create(null);\n+                            }\n+                            for (const directive of node.directives) {\n+                                const directiveName = directive.name.value;\n+                                if (uniqueDirectiveMap[directiveName]) {\n+                                    if (seenDirectives[directiveName]) {\n+                                        context.reportError(new _GraphQLError.GraphQLError(`The directive \"@${directiveName}\" can only be used once at this location.`, {\n+                                            nodes: [seenDirectives[directiveName], directive]\n+                                        }));\n+                                    } else {\n+                                        seenDirectives[directiveName] = directive;\n+                                    }\n+                                }\n                             }\n                         }\n-                    }\n-                    newObj.default = obj;\n-                    if (cache) {\n-                        cache.set(obj, newObj);\n-                    }\n-                    return newObj;\n+                    };\n                 }\n-                var ReactRemoveScroll = /*#__PURE__*/ React.forwardRef(function(props, ref) {\n-                    return /*#__PURE__*/ React.createElement(_UI.RemoveScroll, (0, _tslib.__assign)({}, props, {\n-                        ref: ref,\n-                        sideCar: _sidecar.default\n-                    }));\n-                });\n-                ReactRemoveScroll.classNames = _UI.RemoveScroll.classNames;\n-                var _default = ReactRemoveScroll;\n-                exports[\"default\"] = _default;\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/react-remove-scroll/dist/es2015/SideEffect.js\":\n-            /*!***************************************************************************!*\\\n-              !*** ../../../node_modules/react-remove-scroll/dist/es2015/SideEffect.js ***!\n-              \\***************************************************************************/\n+        \"../../../node_modules/graphql/validation/rules/UniqueEnumValueNamesRule.mjs\":\n+            /*!***********************************************************************************!*\\\n+              !*** ../../../node_modules/graphql/validation/rules/UniqueEnumValueNamesRule.mjs ***!\n+              \\***********************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports.RemoveScrollSideCar = RemoveScrollSideCar;\n-                exports.getTouchXY = exports.getDeltaXY = void 0;\n-                var _tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.js\");\n-                var React = _interopRequireWildcard(__webpack_require__( /*! react */ \"react\"));\n-                var _reactRemoveScrollBar = __webpack_require__( /*! react-remove-scroll-bar */ \"../../../node_modules/react-remove-scroll-bar/dist/es2015/index.js\");\n-                var _reactStyleSingleton = __webpack_require__( /*! react-style-singleton */ \"../../../node_modules/react-style-singleton/dist/es2015/index.js\");\n-                var _aggresiveCapture = __webpack_require__( /*! ./aggresiveCapture */ \"../../../node_modules/react-remove-scroll/dist/es2015/aggresiveCapture.js\");\n-                var _handleScroll = __webpack_require__( /*! ./handleScroll */ \"../../../node_modules/react-remove-scroll/dist/es2015/handleScroll.js\");\n+                exports.UniqueEnumValueNamesRule = UniqueEnumValueNamesRule;\n+                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n+                var _definition = __webpack_require__( /*! ../../type/definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n+                /**\n+                 * Unique enum value names\n+                 *\n+                 * A GraphQL enum type is only valid if all its values are uniquely named.\n+                 */\n+                function UniqueEnumValueNamesRule(context) {\n+                    const schema = context.getSchema();\n+                    const existingTypeMap = schema ? schema.getTypeMap() : Object.create(null);\n+                    const knownValueNames = Object.create(null);\n+                    return {\n+                        EnumTypeDefinition: checkValueUniqueness,\n+                        EnumTypeExtension: checkValueUniqueness\n+                    };\n \n-                function _getRequireWildcardCache(nodeInterop) {\n-                    if (typeof WeakMap !== \"function\") return null;\n-                    var cacheBabelInterop = new WeakMap();\n-                    var cacheNodeInterop = new WeakMap();\n-                    return (_getRequireWildcardCache = function(nodeInterop) {\n-                        return nodeInterop ? cacheNodeInterop : cacheBabelInterop;\n-                    })(nodeInterop);\n-                }\n+                    function checkValueUniqueness(node) {\n+                        var _node$values;\n+                        const typeName = node.name.value;\n+                        if (!knownValueNames[typeName]) {\n+                            knownValueNames[typeName] = Object.create(null);\n+                        } // FIXME: https://github.com/graphql/graphql-js/issues/2203\n \n-                function _interopRequireWildcard(obj, nodeInterop) {\n-                    if (!nodeInterop && obj && obj.__esModule) {\n-                        return obj;\n-                    }\n-                    if (obj === null || typeof obj !== \"object\" && typeof obj !== \"function\") {\n-                        return {\n-                            default: obj\n-                        };\n-                    }\n-                    var cache = _getRequireWildcardCache(nodeInterop);\n-                    if (cache && cache.has(obj)) {\n-                        return cache.get(obj);\n-                    }\n-                    var newObj = {};\n-                    var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;\n-                    for (var key in obj) {\n-                        if (key !== \"default\" && Object.prototype.hasOwnProperty.call(obj, key)) {\n-                            var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;\n-                            if (desc && (desc.get || desc.set)) {\n-                                Object.defineProperty(newObj, key, desc);\n+                        /* c8 ignore next */\n+\n+                        const valueNodes = (_node$values = node.values) !== null && _node$values !== void 0 ? _node$values : [];\n+                        const valueNames = knownValueNames[typeName];\n+                        for (const valueDef of valueNodes) {\n+                            const valueName = valueDef.name.value;\n+                            const existingType = existingTypeMap[typeName];\n+                            if ((0, _definition.isEnumType)(existingType) && existingType.getValue(valueName)) {\n+                                context.reportError(new _GraphQLError.GraphQLError(`Enum value \"${typeName}.${valueName}\" already exists in the schema. It cannot also be defined in this type extension.`, {\n+                                    nodes: valueDef.name\n+                                }));\n+                            } else if (valueNames[valueName]) {\n+                                context.reportError(new _GraphQLError.GraphQLError(`Enum value \"${typeName}.${valueName}\" can only be defined once.`, {\n+                                    nodes: [valueNames[valueName], valueDef.name]\n+                                }));\n                             } else {\n-                                newObj[key] = obj[key];\n+                                valueNames[valueName] = valueDef.name;\n                             }\n                         }\n+                        return false;\n                     }\n-                    newObj.default = obj;\n-                    if (cache) {\n-                        cache.set(obj, newObj);\n-                    }\n-                    return newObj;\n-                }\n-                var getTouchXY = function(event) {\n-                    return 'changedTouches' in event ? [event.changedTouches[0].clientX, event.changedTouches[0].clientY] : [0, 0];\n-                };\n-                exports.getTouchXY = getTouchXY;\n-                var getDeltaXY = function(event) {\n-                    return [event.deltaX, event.deltaY];\n-                };\n-                exports.getDeltaXY = getDeltaXY;\n-                var extractRef = function(ref) {\n-                    return ref && 'current' in ref ? ref.current : ref;\n-                };\n-                var deltaCompare = function(x, y) {\n-                    return x[0] === y[0] && x[1] === y[1];\n-                };\n-                var generateStyle = function(id) {\n-                    return \"\\n  .block-interactivity-\".concat(id, \" {pointer-events: none;}\\n  .allow-interactivity-\").concat(id, \" {pointer-events: all;}\\n\");\n-                };\n-                var idCounter = 0;\n-                var lockStack = [];\n-\n-                function RemoveScrollSideCar(props) {\n-                    var shouldPreventQueue = React.useRef([]);\n-                    var touchStartRef = React.useRef([0, 0]);\n-                    var activeAxis = React.useRef();\n-                    var id = React.useState(idCounter++)[0];\n-                    var Style = React.useState(function() {\n-                        return (0, _reactStyleSingleton.styleSingleton)();\n-                    })[0];\n-                    var lastProps = React.useRef(props);\n-                    React.useEffect(function() {\n-                        lastProps.current = props;\n-                    }, [props]);\n-                    React.useEffect(function() {\n-                        if (props.inert) {\n-                            document.body.classList.add(\"block-interactivity-\".concat(id));\n-                            var allow_1 = (0, _tslib.__spreadArray)([props.lockRef.current], (props.shards || []).map(extractRef), true).filter(Boolean);\n-                            allow_1.forEach(function(el) {\n-                                return el.classList.add(\"allow-interactivity-\".concat(id));\n-                            });\n-                            return function() {\n-                                document.body.classList.remove(\"block-interactivity-\".concat(id));\n-                                allow_1.forEach(function(el) {\n-                                    return el.classList.remove(\"allow-interactivity-\".concat(id));\n-                                });\n-                            };\n-                        }\n-                        return;\n-                    }, [props.inert, props.lockRef.current, props.shards]);\n-                    var shouldCancelEvent = React.useCallback(function(event, parent) {\n-                        if ('touches' in event && event.touches.length === 2) {\n-                            return !lastProps.current.allowPinchZoom;\n-                        }\n-                        var touch = getTouchXY(event);\n-                        var touchStart = touchStartRef.current;\n-                        var deltaX = 'deltaX' in event ? event.deltaX : touchStart[0] - touch[0];\n-                        var deltaY = 'deltaY' in event ? event.deltaY : touchStart[1] - touch[1];\n-                        var currentAxis;\n-                        var target = event.target;\n-                        var moveDirection = Math.abs(deltaX) > Math.abs(deltaY) ? 'h' : 'v';\n-                        // allow horizontal touch move on Range inputs. They will not cause any scroll\n-                        if ('touches' in event && moveDirection === 'h' && target.type === 'range') {\n-                            return false;\n-                        }\n-                        var canBeScrolledInMainDirection = (0, _handleScroll.locationCouldBeScrolled)(moveDirection, target);\n-                        if (!canBeScrolledInMainDirection) {\n-                            return true;\n-                        }\n-                        if (canBeScrolledInMainDirection) {\n-                            currentAxis = moveDirection;\n-                        } else {\n-                            currentAxis = moveDirection === 'v' ? 'h' : 'v';\n-                            canBeScrolledInMainDirection = (0, _handleScroll.locationCouldBeScrolled)(moveDirection, target);\n-                            // other axis might be not scrollable\n-                        }\n-\n-                        if (!canBeScrolledInMainDirection) {\n-                            return false;\n-                        }\n-                        if (!activeAxis.current && 'changedTouches' in event && (deltaX || deltaY)) {\n-                            activeAxis.current = currentAxis;\n-                        }\n-                        if (!currentAxis) {\n-                            return true;\n-                        }\n-                        var cancelingAxis = activeAxis.current || currentAxis;\n-                        return (0, _handleScroll.handleScroll)(cancelingAxis, parent, event, cancelingAxis === 'h' ? deltaX : deltaY, true);\n-                    }, []);\n-                    var shouldPrevent = React.useCallback(function(_event) {\n-                        var event = _event;\n-                        if (!lockStack.length || lockStack[lockStack.length - 1] !== Style) {\n-                            // not the last active\n-                            return;\n-                        }\n-                        var delta = 'deltaY' in event ? getDeltaXY(event) : getTouchXY(event);\n-                        var sourceEvent = shouldPreventQueue.current.filter(function(e) {\n-                            return e.name === event.type && e.target === event.target && deltaCompare(e.delta, delta);\n-                        })[0];\n-                        // self event, and should be canceled\n-                        if (sourceEvent && sourceEvent.should) {\n-                            if (event.cancelable) {\n-                                event.preventDefault();\n-                            }\n-                            return;\n-                        }\n-                        // outside or shard event\n-                        if (!sourceEvent) {\n-                            var shardNodes = (lastProps.current.shards || []).map(extractRef).filter(Boolean).filter(function(node) {\n-                                return node.contains(event.target);\n-                            });\n-                            var shouldStop = shardNodes.length > 0 ? shouldCancelEvent(event, shardNodes[0]) : !lastProps.current.noIsolation;\n-                            if (shouldStop) {\n-                                if (event.cancelable) {\n-                                    event.preventDefault();\n-                                }\n-                            }\n-                        }\n-                    }, []);\n-                    var shouldCancel = React.useCallback(function(name, delta, target, should) {\n-                        var event = {\n-                            name: name,\n-                            delta: delta,\n-                            target: target,\n-                            should: should\n-                        };\n-                        shouldPreventQueue.current.push(event);\n-                        setTimeout(function() {\n-                            shouldPreventQueue.current = shouldPreventQueue.current.filter(function(e) {\n-                                return e !== event;\n-                            });\n-                        }, 1);\n-                    }, []);\n-                    var scrollTouchStart = React.useCallback(function(event) {\n-                        touchStartRef.current = getTouchXY(event);\n-                        activeAxis.current = undefined;\n-                    }, []);\n-                    var scrollWheel = React.useCallback(function(event) {\n-                        shouldCancel(event.type, getDeltaXY(event), event.target, shouldCancelEvent(event, props.lockRef.current));\n-                    }, []);\n-                    var scrollTouchMove = React.useCallback(function(event) {\n-                        shouldCancel(event.type, getTouchXY(event), event.target, shouldCancelEvent(event, props.lockRef.current));\n-                    }, []);\n-                    React.useEffect(function() {\n-                        lockStack.push(Style);\n-                        props.setCallbacks({\n-                            onScrollCapture: scrollWheel,\n-                            onWheelCapture: scrollWheel,\n-                            onTouchMoveCapture: scrollTouchMove\n-                        });\n-                        document.addEventListener('wheel', shouldPrevent, _aggresiveCapture.nonPassive);\n-                        document.addEventListener('touchmove', shouldPrevent, _aggresiveCapture.nonPassive);\n-                        document.addEventListener('touchstart', scrollTouchStart, _aggresiveCapture.nonPassive);\n-                        return function() {\n-                            lockStack = lockStack.filter(function(inst) {\n-                                return inst !== Style;\n-                            });\n-                            document.removeEventListener('wheel', shouldPrevent, _aggresiveCapture.nonPassive);\n-                            document.removeEventListener('touchmove', shouldPrevent, _aggresiveCapture.nonPassive);\n-                            document.removeEventListener('touchstart', scrollTouchStart, _aggresiveCapture.nonPassive);\n-                        };\n-                    }, []);\n-                    var removeScrollBar = props.removeScrollBar,\n-                        inert = props.inert;\n-                    return /*#__PURE__*/ React.createElement(React.Fragment, null, inert ? /*#__PURE__*/ React.createElement(Style, {\n-                        styles: generateStyle(id)\n-                    }) : null, removeScrollBar ? /*#__PURE__*/ React.createElement(_reactRemoveScrollBar.RemoveScrollBar, {\n-                        gapMode: \"margin\"\n-                    }) : null);\n                 }\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/react-remove-scroll/dist/es2015/UI.js\":\n-            /*!*******************************************************************!*\\\n-              !*** ../../../node_modules/react-remove-scroll/dist/es2015/UI.js ***!\n-              \\*******************************************************************/\n+        \"../../../node_modules/graphql/validation/rules/UniqueFieldDefinitionNamesRule.mjs\":\n+            /*!*****************************************************************************************!*\\\n+              !*** ../../../node_modules/graphql/validation/rules/UniqueFieldDefinitionNamesRule.mjs ***!\n+              \\*****************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports.RemoveScroll = void 0;\n-                var _tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.js\");\n-                var React = _interopRequireWildcard(__webpack_require__( /*! react */ \"react\"));\n-                var _constants = __webpack_require__( /*! react-remove-scroll-bar/constants */ \"../../../node_modules/react-remove-scroll-bar/dist/es2015/constants.js\");\n-                var _useCallbackRef = __webpack_require__( /*! use-callback-ref */ \"../../../node_modules/use-callback-ref/dist/es2015/index.js\");\n-                var _medium = __webpack_require__( /*! ./medium */ \"../../../node_modules/react-remove-scroll/dist/es2015/medium.js\");\n+                exports.UniqueFieldDefinitionNamesRule = UniqueFieldDefinitionNamesRule;\n+                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n+                var _definition = __webpack_require__( /*! ../../type/definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n+                /**\n+                 * Unique field definition names\n+                 *\n+                 * A GraphQL complex type is only valid if all its fields are uniquely named.\n+                 */\n+                function UniqueFieldDefinitionNamesRule(context) {\n+                    const schema = context.getSchema();\n+                    const existingTypeMap = schema ? schema.getTypeMap() : Object.create(null);\n+                    const knownFieldNames = Object.create(null);\n+                    return {\n+                        InputObjectTypeDefinition: checkFieldUniqueness,\n+                        InputObjectTypeExtension: checkFieldUniqueness,\n+                        InterfaceTypeDefinition: checkFieldUniqueness,\n+                        InterfaceTypeExtension: checkFieldUniqueness,\n+                        ObjectTypeDefinition: checkFieldUniqueness,\n+                        ObjectTypeExtension: checkFieldUniqueness\n+                    };\n \n-                function _getRequireWildcardCache(nodeInterop) {\n-                    if (typeof WeakMap !== \"function\") return null;\n-                    var cacheBabelInterop = new WeakMap();\n-                    var cacheNodeInterop = new WeakMap();\n-                    return (_getRequireWildcardCache = function(nodeInterop) {\n-                        return nodeInterop ? cacheNodeInterop : cacheBabelInterop;\n-                    })(nodeInterop);\n-                }\n+                    function checkFieldUniqueness(node) {\n+                        var _node$fields;\n+                        const typeName = node.name.value;\n+                        if (!knownFieldNames[typeName]) {\n+                            knownFieldNames[typeName] = Object.create(null);\n+                        } // FIXME: https://github.com/graphql/graphql-js/issues/2203\n \n-                function _interopRequireWildcard(obj, nodeInterop) {\n-                    if (!nodeInterop && obj && obj.__esModule) {\n-                        return obj;\n-                    }\n-                    if (obj === null || typeof obj !== \"object\" && typeof obj !== \"function\") {\n-                        return {\n-                            default: obj\n-                        };\n-                    }\n-                    var cache = _getRequireWildcardCache(nodeInterop);\n-                    if (cache && cache.has(obj)) {\n-                        return cache.get(obj);\n-                    }\n-                    var newObj = {};\n-                    var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;\n-                    for (var key in obj) {\n-                        if (key !== \"default\" && Object.prototype.hasOwnProperty.call(obj, key)) {\n-                            var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;\n-                            if (desc && (desc.get || desc.set)) {\n-                                Object.defineProperty(newObj, key, desc);\n+                        /* c8 ignore next */\n+\n+                        const fieldNodes = (_node$fields = node.fields) !== null && _node$fields !== void 0 ? _node$fields : [];\n+                        const fieldNames = knownFieldNames[typeName];\n+                        for (const fieldDef of fieldNodes) {\n+                            const fieldName = fieldDef.name.value;\n+                            if (hasField(existingTypeMap[typeName], fieldName)) {\n+                                context.reportError(new _GraphQLError.GraphQLError(`Field \"${typeName}.${fieldName}\" already exists in the schema. It cannot also be defined in this type extension.`, {\n+                                    nodes: fieldDef.name\n+                                }));\n+                            } else if (fieldNames[fieldName]) {\n+                                context.reportError(new _GraphQLError.GraphQLError(`Field \"${typeName}.${fieldName}\" can only be defined once.`, {\n+                                    nodes: [fieldNames[fieldName], fieldDef.name]\n+                                }));\n                             } else {\n-                                newObj[key] = obj[key];\n+                                fieldNames[fieldName] = fieldDef.name;\n                             }\n                         }\n+                        return false;\n                     }\n-                    newObj.default = obj;\n-                    if (cache) {\n-                        cache.set(obj, newObj);\n+                }\n+\n+                function hasField(type, fieldName) {\n+                    if ((0, _definition.isObjectType)(type) || (0, _definition.isInterfaceType)(type) || (0, _definition.isInputObjectType)(type)) {\n+                        return type.getFields()[fieldName] != null;\n                     }\n-                    return newObj;\n+                    return false;\n                 }\n-                var nothing = function() {\n-                    return;\n-                };\n-                /**\n-                 * Removes scrollbar from the page and contain the scroll within the Lock\n-                 */\n-                var RemoveScroll = /*#__PURE__*/ React.forwardRef(function(props, parentRef) {\n-                    var ref = React.useRef(null);\n-                    var _a = React.useState({\n-                            onScrollCapture: nothing,\n-                            onWheelCapture: nothing,\n-                            onTouchMoveCapture: nothing\n-                        }),\n-                        callbacks = _a[0],\n-                        setCallbacks = _a[1];\n-                    var forwardProps = props.forwardProps,\n-                        children = props.children,\n-                        className = props.className,\n-                        removeScrollBar = props.removeScrollBar,\n-                        enabled = props.enabled,\n-                        shards = props.shards,\n-                        sideCar = props.sideCar,\n-                        noIsolation = props.noIsolation,\n-                        inert = props.inert,\n-                        allowPinchZoom = props.allowPinchZoom,\n-                        _b = props.as,\n-                        Container = _b === void 0 ? 'div' : _b,\n-                        rest = (0, _tslib.__rest)(props, [\"forwardProps\", \"children\", \"className\", \"removeScrollBar\", \"enabled\", \"shards\", \"sideCar\", \"noIsolation\", \"inert\", \"allowPinchZoom\", \"as\"]);\n-                    var SideCar = sideCar;\n-                    var containerRef = (0, _useCallbackRef.useMergeRefs)([ref, parentRef]);\n-                    var containerProps = (0, _tslib.__assign)((0, _tslib.__assign)({}, rest), callbacks);\n-                    return /*#__PURE__*/ React.createElement(React.Fragment, null, enabled && /*#__PURE__*/ React.createElement(SideCar, {\n-                        sideCar: _medium.effectCar,\n-                        removeScrollBar: removeScrollBar,\n-                        shards: shards,\n-                        noIsolation: noIsolation,\n-                        inert: inert,\n-                        setCallbacks: setCallbacks,\n-                        allowPinchZoom: !!allowPinchZoom,\n-                        lockRef: ref\n-                    }), forwardProps ? /*#__PURE__*/ React.cloneElement(React.Children.only(children), (0, _tslib.__assign)((0, _tslib.__assign)({}, containerProps), {\n-                        ref: containerRef\n-                    })) : /*#__PURE__*/ React.createElement(Container, (0, _tslib.__assign)({}, containerProps, {\n-                        className: className,\n-                        ref: containerRef\n-                    }), children));\n-                });\n-                exports.RemoveScroll = RemoveScroll;\n-                RemoveScroll.defaultProps = {\n-                    enabled: true,\n-                    removeScrollBar: true,\n-                    inert: false\n-                };\n-                RemoveScroll.classNames = {\n-                    fullWidth: _constants.fullWidthClassName,\n-                    zeroRight: _constants.zeroRightClassName\n-                };\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/react-remove-scroll/dist/es2015/aggresiveCapture.js\":\n-            /*!*********************************************************************************!*\\\n-              !*** ../../../node_modules/react-remove-scroll/dist/es2015/aggresiveCapture.js ***!\n-              \\*********************************************************************************/\n+        \"../../../node_modules/graphql/validation/rules/UniqueFragmentNamesRule.mjs\":\n+            /*!**********************************************************************************!*\\\n+              !*** ../../../node_modules/graphql/validation/rules/UniqueFragmentNamesRule.mjs ***!\n+              \\**********************************************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports) {\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports.nonPassive = void 0;\n-                var passiveSupported = false;\n-                if (typeof window !== 'undefined') {\n-                    try {\n-                        var options = Object.defineProperty({}, 'passive', {\n-                            get: function() {\n-                                passiveSupported = true;\n-                                return true;\n+                exports.UniqueFragmentNamesRule = UniqueFragmentNamesRule;\n+                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n+                /**\n+                 * Unique fragment names\n+                 *\n+                 * A GraphQL document is only valid if all defined fragments have unique names.\n+                 *\n+                 * See https://spec.graphql.org/draft/#sec-Fragment-Name-Uniqueness\n+                 */\n+                function UniqueFragmentNamesRule(context) {\n+                    const knownFragmentNames = Object.create(null);\n+                    return {\n+                        OperationDefinition: () => false,\n+                        FragmentDefinition(node) {\n+                            const fragmentName = node.name.value;\n+                            if (knownFragmentNames[fragmentName]) {\n+                                context.reportError(new _GraphQLError.GraphQLError(`There can be only one fragment named \"${fragmentName}\".`, {\n+                                    nodes: [knownFragmentNames[fragmentName], node.name]\n+                                }));\n+                            } else {\n+                                knownFragmentNames[fragmentName] = node.name;\n                             }\n-                        });\n-                        // @ts-ignore\n-                        window.addEventListener('test', options, options);\n-                        // @ts-ignore\n-                        window.removeEventListener('test', options, options);\n-                    } catch (err) {\n-                        passiveSupported = false;\n-                    }\n+                            return false;\n+                        }\n+                    };\n                 }\n-                var nonPassive = passiveSupported ? {\n-                    passive: false\n-                } : false;\n-                exports.nonPassive = nonPassive;\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/react-remove-scroll/dist/es2015/handleScroll.js\":\n-            /*!*****************************************************************************!*\\\n-              !*** ../../../node_modules/react-remove-scroll/dist/es2015/handleScroll.js ***!\n-              \\*****************************************************************************/\n+        \"../../../node_modules/graphql/validation/rules/UniqueInputFieldNamesRule.mjs\":\n+            /*!************************************************************************************!*\\\n+              !*** ../../../node_modules/graphql/validation/rules/UniqueInputFieldNamesRule.mjs ***!\n+              \\************************************************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports) {\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports.locationCouldBeScrolled = exports.handleScroll = void 0;\n-                var alwaysContainsScroll = function(node) {\n-                    // textarea will always _contain_ scroll inside self. It only can be hidden\n-                    return node.tagName === 'TEXTAREA';\n-                };\n-                var elementCanBeScrolled = function(node, overflow) {\n-                    var styles = window.getComputedStyle(node);\n-                    return (\n-                        // not-not-scrollable\n-                        styles[overflow] !== 'hidden' &&\n-                        // contains scroll inside self\n-                        !(styles.overflowY === styles.overflowX && !alwaysContainsScroll(node) && styles[overflow] === 'visible')\n-                    );\n-                };\n-                var elementCouldBeVScrolled = function(node) {\n-                    return elementCanBeScrolled(node, 'overflowY');\n-                };\n-                var elementCouldBeHScrolled = function(node) {\n-                    return elementCanBeScrolled(node, 'overflowX');\n-                };\n-                var locationCouldBeScrolled = function(axis, node) {\n-                    var current = node;\n-                    do {\n-                        // Skip over shadow root\n-                        if (typeof ShadowRoot !== 'undefined' && current instanceof ShadowRoot) {\n-                            current = current.host;\n-                        }\n-                        var isScrollable = elementCouldBeScrolled(axis, current);\n-                        if (isScrollable) {\n-                            var _a = getScrollVariables(axis, current),\n-                                s = _a[1],\n-                                d = _a[2];\n-                            if (s > d) {\n-                                return true;\n+                exports.UniqueInputFieldNamesRule = UniqueInputFieldNamesRule;\n+                var _invariant = __webpack_require__( /*! ../../jsutils/invariant.mjs */ \"../../../node_modules/graphql/jsutils/invariant.mjs\");\n+                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n+                /**\n+                 * Unique input field names\n+                 *\n+                 * A GraphQL input object value is only valid if all supplied fields are\n+                 * uniquely named.\n+                 *\n+                 * See https://spec.graphql.org/draft/#sec-Input-Object-Field-Uniqueness\n+                 */\n+                function UniqueInputFieldNamesRule(context) {\n+                    const knownNameStack = [];\n+                    let knownNames = Object.create(null);\n+                    return {\n+                        ObjectValue: {\n+                            enter() {\n+                                knownNameStack.push(knownNames);\n+                                knownNames = Object.create(null);\n+                            },\n+                            leave() {\n+                                const prevKnownNames = knownNameStack.pop();\n+                                prevKnownNames || (0, _invariant.invariant)(false);\n+                                knownNames = prevKnownNames;\n                             }\n-                        }\n-                        current = current.parentNode;\n-                    } while (current && current !== document.body);\n-                    return false;\n-                };\n-                exports.locationCouldBeScrolled = locationCouldBeScrolled;\n-                var getVScrollVariables = function(_a) {\n-                    var scrollTop = _a.scrollTop,\n-                        scrollHeight = _a.scrollHeight,\n-                        clientHeight = _a.clientHeight;\n-                    return [scrollTop, scrollHeight, clientHeight];\n-                };\n-                var getHScrollVariables = function(_a) {\n-                    var scrollLeft = _a.scrollLeft,\n-                        scrollWidth = _a.scrollWidth,\n-                        clientWidth = _a.clientWidth;\n-                    return [scrollLeft, scrollWidth, clientWidth];\n-                };\n-                var elementCouldBeScrolled = function(axis, node) {\n-                    return axis === 'v' ? elementCouldBeVScrolled(node) : elementCouldBeHScrolled(node);\n-                };\n-                var getScrollVariables = function(axis, node) {\n-                    return axis === 'v' ? getVScrollVariables(node) : getHScrollVariables(node);\n-                };\n-                var getDirectionFactor = function(axis, direction) {\n-                    /**\n-                     * If the element's direction is rtl (right-to-left), then scrollLeft is 0 when the scrollbar is at its rightmost position,\n-                     * and then increasingly negative as you scroll towards the end of the content.\n-                     * @see https://developer.mozilla.org/en-US/docs/Web/API/Element/scrollLeft\n-                     */\n-                    return axis === 'h' && direction === 'rtl' ? -1 : 1;\n-                };\n-                var handleScroll = function(axis, endTarget, event, sourceDelta, noOverscroll) {\n-                    var directionFactor = getDirectionFactor(axis, window.getComputedStyle(endTarget).direction);\n-                    var delta = directionFactor * sourceDelta;\n-                    // find scrollable target\n-                    var target = event.target;\n-                    var targetInLock = endTarget.contains(target);\n-                    var shouldCancelScroll = false;\n-                    var isDeltaPositive = delta > 0;\n-                    var availableScroll = 0;\n-                    var availableScrollTop = 0;\n-                    do {\n-                        var _a = getScrollVariables(axis, target),\n-                            position = _a[0],\n-                            scroll_1 = _a[1],\n-                            capacity = _a[2];\n-                        var elementScroll = scroll_1 - capacity - directionFactor * position;\n-                        if (position || elementScroll) {\n-                            if (elementCouldBeScrolled(axis, target)) {\n-                                availableScroll += elementScroll;\n-                                availableScrollTop += position;\n+                        },\n+                        ObjectField(node) {\n+                            const fieldName = node.name.value;\n+                            if (knownNames[fieldName]) {\n+                                context.reportError(new _GraphQLError.GraphQLError(`There can be only one input field named \"${fieldName}\".`, {\n+                                    nodes: [knownNames[fieldName], node.name]\n+                                }));\n+                            } else {\n+                                knownNames[fieldName] = node.name;\n                             }\n                         }\n-                        target = target.parentNode;\n-                    } while (\n-                        // portaled content\n-                        !targetInLock && target !== document.body ||\n-                        // self content\n-                        targetInLock && (endTarget.contains(target) || endTarget === target));\n-                    if (isDeltaPositive && (noOverscroll && availableScroll === 0 || !noOverscroll && delta > availableScroll)) {\n-                        shouldCancelScroll = true;\n-                    } else if (!isDeltaPositive && (noOverscroll && availableScrollTop === 0 || !noOverscroll && -delta > availableScrollTop)) {\n-                        shouldCancelScroll = true;\n-                    }\n-                    return shouldCancelScroll;\n-                };\n-                exports.handleScroll = handleScroll;\n+                    };\n+                }\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/react-remove-scroll/dist/es2015/index.js\":\n-            /*!**********************************************************************!*\\\n-              !*** ../../../node_modules/react-remove-scroll/dist/es2015/index.js ***!\n-              \\**********************************************************************/\n+        \"../../../node_modules/graphql/validation/rules/UniqueOperationNamesRule.mjs\":\n+            /*!***********************************************************************************!*\\\n+              !*** ../../../node_modules/graphql/validation/rules/UniqueOperationNamesRule.mjs ***!\n+              \\***********************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                Object.defineProperty(exports, \"RemoveScroll\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _Combination.default;\n-                    }\n-                }));\n-                var _Combination = _interopRequireDefault(__webpack_require__( /*! ./Combination */ \"../../../node_modules/react-remove-scroll/dist/es2015/Combination.js\"));\n-\n-                function _interopRequireDefault(obj) {\n-                    return obj && obj.__esModule ? obj : {\n-                        default: obj\n+                exports.UniqueOperationNamesRule = UniqueOperationNamesRule;\n+                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n+                /**\n+                 * Unique operation names\n+                 *\n+                 * A GraphQL document is only valid if all defined operations have unique names.\n+                 *\n+                 * See https://spec.graphql.org/draft/#sec-Operation-Name-Uniqueness\n+                 */\n+                function UniqueOperationNamesRule(context) {\n+                    const knownOperationNames = Object.create(null);\n+                    return {\n+                        OperationDefinition(node) {\n+                            const operationName = node.name;\n+                            if (operationName) {\n+                                if (knownOperationNames[operationName.value]) {\n+                                    context.reportError(new _GraphQLError.GraphQLError(`There can be only one operation named \"${operationName.value}\".`, {\n+                                        nodes: [knownOperationNames[operationName.value], operationName]\n+                                    }));\n+                                } else {\n+                                    knownOperationNames[operationName.value] = operationName;\n+                                }\n+                            }\n+                            return false;\n+                        },\n+                        FragmentDefinition: () => false\n                     };\n                 }\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/react-remove-scroll/dist/es2015/medium.js\":\n-            /*!***********************************************************************!*\\\n-              !*** ../../../node_modules/react-remove-scroll/dist/es2015/medium.js ***!\n-              \\***********************************************************************/\n+        \"../../../node_modules/graphql/validation/rules/UniqueOperationTypesRule.mjs\":\n+            /*!***********************************************************************************!*\\\n+              !*** ../../../node_modules/graphql/validation/rules/UniqueOperationTypesRule.mjs ***!\n+              \\***********************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports.effectCar = void 0;\n-                var _useSidecar = __webpack_require__( /*! use-sidecar */ \"../../../node_modules/use-sidecar/dist/es2015/index.js\");\n-                var effectCar = (0, _useSidecar.createSidecarMedium)();\n-                exports.effectCar = effectCar;\n+                exports.UniqueOperationTypesRule = UniqueOperationTypesRule;\n+                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n+                /**\n+                 * Unique operation types\n+                 *\n+                 * A GraphQL document is only valid if it has only one type per operation.\n+                 */\n+                function UniqueOperationTypesRule(context) {\n+                    const schema = context.getSchema();\n+                    const definedOperationTypes = Object.create(null);\n+                    const existingOperationTypes = schema ? {\n+                        query: schema.getQueryType(),\n+                        mutation: schema.getMutationType(),\n+                        subscription: schema.getSubscriptionType()\n+                    } : {};\n+                    return {\n+                        SchemaDefinition: checkOperationTypes,\n+                        SchemaExtension: checkOperationTypes\n+                    };\n+\n+                    function checkOperationTypes(node) {\n+                        var _node$operationTypes;\n+\n+                        // See: https://github.com/graphql/graphql-js/issues/2203\n+\n+                        /* c8 ignore next */\n+                        const operationTypesNodes = (_node$operationTypes = node.operationTypes) !== null && _node$operationTypes !== void 0 ? _node$operationTypes : [];\n+                        for (const operationType of operationTypesNodes) {\n+                            const operation = operationType.operation;\n+                            const alreadyDefinedOperationType = definedOperationTypes[operation];\n+                            if (existingOperationTypes[operation]) {\n+                                context.reportError(new _GraphQLError.GraphQLError(`Type for ${operation} already defined in the schema. It cannot be redefined.`, {\n+                                    nodes: operationType\n+                                }));\n+                            } else if (alreadyDefinedOperationType) {\n+                                context.reportError(new _GraphQLError.GraphQLError(`There can be only one ${operation} type in schema.`, {\n+                                    nodes: [alreadyDefinedOperationType, operationType]\n+                                }));\n+                            } else {\n+                                definedOperationTypes[operation] = operationType;\n+                            }\n+                        }\n+                        return false;\n+                    }\n+                }\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/react-remove-scroll/dist/es2015/sidecar.js\":\n-            /*!************************************************************************!*\\\n-              !*** ../../../node_modules/react-remove-scroll/dist/es2015/sidecar.js ***!\n-              \\************************************************************************/\n+        \"../../../node_modules/graphql/validation/rules/UniqueTypeNamesRule.mjs\":\n+            /*!******************************************************************************!*\\\n+              !*** ../../../node_modules/graphql/validation/rules/UniqueTypeNamesRule.mjs ***!\n+              \\******************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports[\"default\"] = void 0;\n-                var _useSidecar = __webpack_require__( /*! use-sidecar */ \"../../../node_modules/use-sidecar/dist/es2015/index.js\");\n-                var _SideEffect = __webpack_require__( /*! ./SideEffect */ \"../../../node_modules/react-remove-scroll/dist/es2015/SideEffect.js\");\n-                var _medium = __webpack_require__( /*! ./medium */ \"../../../node_modules/react-remove-scroll/dist/es2015/medium.js\");\n-                var _default = (0, _useSidecar.exportSidecar)(_medium.effectCar, _SideEffect.RemoveScrollSideCar);\n-                exports[\"default\"] = _default;\n+                exports.UniqueTypeNamesRule = UniqueTypeNamesRule;\n+                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n+                /**\n+                 * Unique type names\n+                 *\n+                 * A GraphQL document is only valid if all defined types have unique names.\n+                 */\n+                function UniqueTypeNamesRule(context) {\n+                    const knownTypeNames = Object.create(null);\n+                    const schema = context.getSchema();\n+                    return {\n+                        ScalarTypeDefinition: checkTypeName,\n+                        ObjectTypeDefinition: checkTypeName,\n+                        InterfaceTypeDefinition: checkTypeName,\n+                        UnionTypeDefinition: checkTypeName,\n+                        EnumTypeDefinition: checkTypeName,\n+                        InputObjectTypeDefinition: checkTypeName\n+                    };\n+\n+                    function checkTypeName(node) {\n+                        const typeName = node.name.value;\n+                        if (schema !== null && schema !== void 0 && schema.getType(typeName)) {\n+                            context.reportError(new _GraphQLError.GraphQLError(`Type \"${typeName}\" already exists in the schema. It cannot also be defined in this type definition.`, {\n+                                nodes: node.name\n+                            }));\n+                            return;\n+                        }\n+                        if (knownTypeNames[typeName]) {\n+                            context.reportError(new _GraphQLError.GraphQLError(`There can be only one type named \"${typeName}\".`, {\n+                                nodes: [knownTypeNames[typeName], node.name]\n+                            }));\n+                        } else {\n+                            knownTypeNames[typeName] = node.name;\n+                        }\n+                        return false;\n+                    }\n+                }\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/react-style-singleton/dist/es2015/component.js\":\n-            /*!****************************************************************************!*\\\n-              !*** ../../../node_modules/react-style-singleton/dist/es2015/component.js ***!\n-              \\****************************************************************************/\n+        \"../../../node_modules/graphql/validation/rules/UniqueVariableNamesRule.mjs\":\n+            /*!**********************************************************************************!*\\\n+              !*** ../../../node_modules/graphql/validation/rules/UniqueVariableNamesRule.mjs ***!\n+              \\**********************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports.styleSingleton = void 0;\n-                var _hook = __webpack_require__( /*! ./hook */ \"../../../node_modules/react-style-singleton/dist/es2015/hook.js\");\n+                exports.UniqueVariableNamesRule = UniqueVariableNamesRule;\n+                var _groupBy = __webpack_require__( /*! ../../jsutils/groupBy.mjs */ \"../../../node_modules/graphql/jsutils/groupBy.mjs\");\n+                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n                 /**\n-                 * create a Component to add styles on demand\n-                 * - styles are added when first instance is mounted\n-                 * - styles are removed when the last instance is unmounted\n-                 * - changing styles in runtime does nothing unless dynamic is set. But with multiple components that can lead to the undefined behavior\n+                 * Unique variable names\n+                 *\n+                 * A GraphQL operation is only valid if all its variables are uniquely named.\n                  */\n-                var styleSingleton = function() {\n-                    var useStyle = (0, _hook.styleHookSingleton)();\n-                    var Sheet = function(_a) {\n-                        var styles = _a.styles,\n-                            dynamic = _a.dynamic;\n-                        useStyle(styles, dynamic);\n-                        return null;\n+                function UniqueVariableNamesRule(context) {\n+                    return {\n+                        OperationDefinition(operationNode) {\n+                            var _operationNode$variab;\n+\n+                            // See: https://github.com/graphql/graphql-js/issues/2203\n+\n+                            /* c8 ignore next */\n+                            const variableDefinitions = (_operationNode$variab = operationNode.variableDefinitions) !== null && _operationNode$variab !== void 0 ? _operationNode$variab : [];\n+                            const seenVariableDefinitions = (0, _groupBy.groupBy)(variableDefinitions, node => node.variable.name.value);\n+                            for (const [variableName, variableNodes] of seenVariableDefinitions) {\n+                                if (variableNodes.length > 1) {\n+                                    context.reportError(new _GraphQLError.GraphQLError(`There can be only one variable named \"$${variableName}\".`, {\n+                                        nodes: variableNodes.map(node => node.variable.name)\n+                                    }));\n+                                }\n+                            }\n+                        }\n                     };\n-                    return Sheet;\n-                };\n-                exports.styleSingleton = styleSingleton;\n+                }\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/react-style-singleton/dist/es2015/hook.js\":\n-            /*!***********************************************************************!*\\\n-              !*** ../../../node_modules/react-style-singleton/dist/es2015/hook.js ***!\n-              \\***********************************************************************/\n+        \"../../../node_modules/graphql/validation/rules/ValuesOfCorrectTypeRule.mjs\":\n+            /*!**********************************************************************************!*\\\n+              !*** ../../../node_modules/graphql/validation/rules/ValuesOfCorrectTypeRule.mjs ***!\n+              \\**********************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports.styleHookSingleton = void 0;\n-                var React = _interopRequireWildcard(__webpack_require__( /*! react */ \"react\"));\n-                var _singleton = __webpack_require__( /*! ./singleton */ \"../../../node_modules/react-style-singleton/dist/es2015/singleton.js\");\n+                exports.ValuesOfCorrectTypeRule = ValuesOfCorrectTypeRule;\n+                var _didYouMean = __webpack_require__( /*! ../../jsutils/didYouMean.mjs */ \"../../../node_modules/graphql/jsutils/didYouMean.mjs\");\n+                var _inspect = __webpack_require__( /*! ../../jsutils/inspect.mjs */ \"../../../node_modules/graphql/jsutils/inspect.mjs\");\n+                var _keyMap = __webpack_require__( /*! ../../jsutils/keyMap.mjs */ \"../../../node_modules/graphql/jsutils/keyMap.mjs\");\n+                var _suggestionList = __webpack_require__( /*! ../../jsutils/suggestionList.mjs */ \"../../../node_modules/graphql/jsutils/suggestionList.mjs\");\n+                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n+                var _kinds = __webpack_require__( /*! ../../language/kinds.mjs */ \"../../../node_modules/graphql/language/kinds.mjs\");\n+                var _printer = __webpack_require__( /*! ../../language/printer.mjs */ \"../../../node_modules/graphql/language/printer.mjs\");\n+                var _definition = __webpack_require__( /*! ../../type/definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n+                /**\n+                 * Value literals of correct type\n+                 *\n+                 * A GraphQL document is only valid if all value literals are of the type\n+                 * expected at their position.\n+                 *\n+                 * See https://spec.graphql.org/draft/#sec-Values-of-Correct-Type\n+                 */\n+                function ValuesOfCorrectTypeRule(context) {\n+                    let variableDefinitions = {};\n+                    return {\n+                        OperationDefinition: {\n+                            enter() {\n+                                variableDefinitions = {};\n+                            }\n+                        },\n+                        VariableDefinition(definition) {\n+                            variableDefinitions[definition.variable.name.value] = definition;\n+                        },\n+                        ListValue(node) {\n+                            // Note: TypeInfo will traverse into a list's item type, so look to the\n+                            // parent input type to check if it is a list.\n+                            const type = (0, _definition.getNullableType)(context.getParentInputType());\n+                            if (!(0, _definition.isListType)(type)) {\n+                                isValidValueNode(context, node);\n+                                return false; // Don't traverse further.\n+                            }\n+                        },\n+                        ObjectValue(node) {\n+                            const type = (0, _definition.getNamedType)(context.getInputType());\n+                            if (!(0, _definition.isInputObjectType)(type)) {\n+                                isValidValueNode(context, node);\n+                                return false; // Don't traverse further.\n+                            } // Ensure every required field exists.\n+\n+                            const fieldNodeMap = (0, _keyMap.keyMap)(node.fields, field => field.name.value);\n+                            for (const fieldDef of Object.values(type.getFields())) {\n+                                const fieldNode = fieldNodeMap[fieldDef.name];\n+                                if (!fieldNode && (0, _definition.isRequiredInputField)(fieldDef)) {\n+                                    const typeStr = (0, _inspect.inspect)(fieldDef.type);\n+                                    context.reportError(new _GraphQLError.GraphQLError(`Field \"${type.name}.${fieldDef.name}\" of required type \"${typeStr}\" was not provided.`, {\n+                                        nodes: node\n+                                    }));\n+                                }\n+                            }\n+                            if (type.isOneOf) {\n+                                validateOneOfInputObject(context, node, type, fieldNodeMap, variableDefinitions);\n+                            }\n+                        },\n+                        ObjectField(node) {\n+                            const parentType = (0, _definition.getNamedType)(context.getParentInputType());\n+                            const fieldType = context.getInputType();\n+                            if (!fieldType && (0, _definition.isInputObjectType)(parentType)) {\n+                                const suggestions = (0, _suggestionList.suggestionList)(node.name.value, Object.keys(parentType.getFields()));\n+                                context.reportError(new _GraphQLError.GraphQLError(`Field \"${node.name.value}\" is not defined by type \"${parentType.name}\".` + (0, _didYouMean.didYouMean)(suggestions), {\n+                                    nodes: node\n+                                }));\n+                            }\n+                        },\n+                        NullValue(node) {\n+                            const type = context.getInputType();\n+                            if ((0, _definition.isNonNullType)(type)) {\n+                                context.reportError(new _GraphQLError.GraphQLError(`Expected value of type \"${(0, _inspect.inspect)(type)}\", found ${(0, _printer.print)(node)}.`, {\n+                                    nodes: node\n+                                }));\n+                            }\n+                        },\n+                        EnumValue: node => isValidValueNode(context, node),\n+                        IntValue: node => isValidValueNode(context, node),\n+                        FloatValue: node => isValidValueNode(context, node),\n+                        StringValue: node => isValidValueNode(context, node),\n+                        BooleanValue: node => isValidValueNode(context, node)\n+                    };\n+                }\n+                /**\n+                 * Any value literal may be a valid representation of a Scalar, depending on\n+                 * that scalar type.\n+                 */\n+\n+                function isValidValueNode(context, node) {\n+                    // Report any error at the full type expected by the location.\n+                    const locationType = context.getInputType();\n+                    if (!locationType) {\n+                        return;\n+                    }\n+                    const type = (0, _definition.getNamedType)(locationType);\n+                    if (!(0, _definition.isLeafType)(type)) {\n+                        const typeStr = (0, _inspect.inspect)(locationType);\n+                        context.reportError(new _GraphQLError.GraphQLError(`Expected value of type \"${typeStr}\", found ${(0, _printer.print)(node)}.`, {\n+                            nodes: node\n+                        }));\n+                        return;\n+                    } // Scalars and Enums determine if a literal value is valid via parseLiteral(),\n+                    // which may throw or return an invalid value to indicate failure.\n \n-                function _getRequireWildcardCache(nodeInterop) {\n-                    if (typeof WeakMap !== \"function\") return null;\n-                    var cacheBabelInterop = new WeakMap();\n-                    var cacheNodeInterop = new WeakMap();\n-                    return (_getRequireWildcardCache = function(nodeInterop) {\n-                        return nodeInterop ? cacheNodeInterop : cacheBabelInterop;\n-                    })(nodeInterop);\n+                    try {\n+                        const parseResult = type.parseLiteral(node, undefined\n+                            /* variables */\n+                        );\n+                        if (parseResult === undefined) {\n+                            const typeStr = (0, _inspect.inspect)(locationType);\n+                            context.reportError(new _GraphQLError.GraphQLError(`Expected value of type \"${typeStr}\", found ${(0, _printer.print)(node)}.`, {\n+                                nodes: node\n+                            }));\n+                        }\n+                    } catch (error) {\n+                        const typeStr = (0, _inspect.inspect)(locationType);\n+                        if (error instanceof _GraphQLError.GraphQLError) {\n+                            context.reportError(error);\n+                        } else {\n+                            context.reportError(new _GraphQLError.GraphQLError(`Expected value of type \"${typeStr}\", found ${(0, _printer.print)(node)}; ` + error.message, {\n+                                nodes: node,\n+                                originalError: error\n+                            }));\n+                        }\n+                    }\n                 }\n \n-                function _interopRequireWildcard(obj, nodeInterop) {\n-                    if (!nodeInterop && obj && obj.__esModule) {\n-                        return obj;\n+                function validateOneOfInputObject(context, node, type, fieldNodeMap, variableDefinitions) {\n+                    var _fieldNodeMap$keys$;\n+                    const keys = Object.keys(fieldNodeMap);\n+                    const isNotExactlyOneField = keys.length !== 1;\n+                    if (isNotExactlyOneField) {\n+                        context.reportError(new _GraphQLError.GraphQLError(`OneOf Input Object \"${type.name}\" must specify exactly one key.`, {\n+                            nodes: [node]\n+                        }));\n+                        return;\n                     }\n-                    if (obj === null || typeof obj !== \"object\" && typeof obj !== \"function\") {\n-                        return {\n-                            default: obj\n-                        };\n+                    const value = (_fieldNodeMap$keys$ = fieldNodeMap[keys[0]]) === null || _fieldNodeMap$keys$ === void 0 ? void 0 : _fieldNodeMap$keys$.value;\n+                    const isNullLiteral = !value || value.kind === _kinds.Kind.NULL;\n+                    const isVariable = (value === null || value === void 0 ? void 0 : value.kind) === _kinds.Kind.VARIABLE;\n+                    if (isNullLiteral) {\n+                        context.reportError(new _GraphQLError.GraphQLError(`Field \"${type.name}.${keys[0]}\" must be non-null.`, {\n+                            nodes: [node]\n+                        }));\n+                        return;\n                     }\n-                    var cache = _getRequireWildcardCache(nodeInterop);\n-                    if (cache && cache.has(obj)) {\n-                        return cache.get(obj);\n-                    }\n-                    var newObj = {};\n-                    var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;\n-                    for (var key in obj) {\n-                        if (key !== \"default\" && Object.prototype.hasOwnProperty.call(obj, key)) {\n-                            var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;\n-                            if (desc && (desc.get || desc.set)) {\n-                                Object.defineProperty(newObj, key, desc);\n-                            } else {\n-                                newObj[key] = obj[key];\n-                            }\n+                    if (isVariable) {\n+                        const variableName = value.name.value;\n+                        const definition = variableDefinitions[variableName];\n+                        const isNullableVariable = definition.type.kind !== _kinds.Kind.NON_NULL_TYPE;\n+                        if (isNullableVariable) {\n+                            context.reportError(new _GraphQLError.GraphQLError(`Variable \"${variableName}\" must be non-nullable to be used for OneOf Input Object \"${type.name}\".`, {\n+                                nodes: [node]\n+                            }));\n                         }\n                     }\n-                    newObj.default = obj;\n-                    if (cache) {\n-                        cache.set(obj, newObj);\n-                    }\n-                    return newObj;\n                 }\n-                /**\n-                 * creates a hook to control style singleton\n-                 * @see {@link styleSingleton} for a safer component version\n-                 * @example\n-                 * ```tsx\n-                 * const useStyle = styleHookSingleton();\n-                 * ///\n-                 * useStyle('body { overflow: hidden}');\n-                 */\n-                var styleHookSingleton = function() {\n-                    var sheet = (0, _singleton.stylesheetSingleton)();\n-                    return function(styles, isDynamic) {\n-                        React.useEffect(function() {\n-                            sheet.add(styles);\n-                            return function() {\n-                                sheet.remove();\n-                            };\n-                        }, [styles && isDynamic]);\n-                    };\n-                };\n-                exports.styleHookSingleton = styleHookSingleton;\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/react-style-singleton/dist/es2015/index.js\":\n-            /*!************************************************************************!*\\\n-              !*** ../../../node_modules/react-style-singleton/dist/es2015/index.js ***!\n-              \\************************************************************************/\n+        \"../../../node_modules/graphql/validation/rules/VariablesAreInputTypesRule.mjs\":\n+            /*!*************************************************************************************!*\\\n+              !*** ../../../node_modules/graphql/validation/rules/VariablesAreInputTypesRule.mjs ***!\n+              \\*************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                Object.defineProperty(exports, \"styleHookSingleton\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _hook.styleHookSingleton;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"styleSingleton\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _component.styleSingleton;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"stylesheetSingleton\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _singleton.stylesheetSingleton;\n-                    }\n-                }));\n-                var _component = __webpack_require__( /*! ./component */ \"../../../node_modules/react-style-singleton/dist/es2015/component.js\");\n-                var _singleton = __webpack_require__( /*! ./singleton */ \"../../../node_modules/react-style-singleton/dist/es2015/singleton.js\");\n-                var _hook = __webpack_require__( /*! ./hook */ \"../../../node_modules/react-style-singleton/dist/es2015/hook.js\");\n+                exports.VariablesAreInputTypesRule = VariablesAreInputTypesRule;\n+                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n+                var _printer = __webpack_require__( /*! ../../language/printer.mjs */ \"../../../node_modules/graphql/language/printer.mjs\");\n+                var _definition = __webpack_require__( /*! ../../type/definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n+                var _typeFromAST = __webpack_require__( /*! ../../utilities/typeFromAST.mjs */ \"../../../node_modules/graphql/utilities/typeFromAST.mjs\");\n+                /**\n+                 * Variables are input types\n+                 *\n+                 * A GraphQL operation is only valid if all the variables it defines are of\n+                 * input types (scalar, enum, or input object).\n+                 *\n+                 * See https://spec.graphql.org/draft/#sec-Variables-Are-Input-Types\n+                 */\n+                function VariablesAreInputTypesRule(context) {\n+                    return {\n+                        VariableDefinition(node) {\n+                            const type = (0, _typeFromAST.typeFromAST)(context.getSchema(), node.type);\n+                            if (type !== undefined && !(0, _definition.isInputType)(type)) {\n+                                const variableName = node.variable.name.value;\n+                                const typeName = (0, _printer.print)(node.type);\n+                                context.reportError(new _GraphQLError.GraphQLError(`Variable \"$${variableName}\" cannot be non-input type \"${typeName}\".`, {\n+                                    nodes: node.type\n+                                }));\n+                            }\n+                        }\n+                    };\n+                }\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/react-style-singleton/dist/es2015/singleton.js\":\n-            /*!****************************************************************************!*\\\n-              !*** ../../../node_modules/react-style-singleton/dist/es2015/singleton.js ***!\n-              \\****************************************************************************/\n+        \"../../../node_modules/graphql/validation/rules/VariablesInAllowedPositionRule.mjs\":\n+            /*!*****************************************************************************************!*\\\n+              !*** ../../../node_modules/graphql/validation/rules/VariablesInAllowedPositionRule.mjs ***!\n+              \\*****************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports.stylesheetSingleton = void 0;\n-                var _getNonce = __webpack_require__( /*! get-nonce */ \"../../../node_modules/get-nonce/dist/es2015/index.js\");\n-\n-                function makeStyleTag() {\n-                    if (!document) return null;\n-                    var tag = document.createElement('style');\n-                    tag.type = 'text/css';\n-                    var nonce = (0, _getNonce.getNonce)();\n-                    if (nonce) {\n-                        tag.setAttribute('nonce', nonce);\n-                    }\n-                    return tag;\n-                }\n-\n-                function injectStyles(tag, css) {\n-                    // @ts-ignore\n-                    if (tag.styleSheet) {\n-                        // @ts-ignore\n-                        tag.styleSheet.cssText = css;\n-                    } else {\n-                        tag.appendChild(document.createTextNode(css));\n-                    }\n-                }\n-\n-                function insertStyleTag(tag) {\n-                    var head = document.head || document.getElementsByTagName('head')[0];\n-                    head.appendChild(tag);\n-                }\n-                var stylesheetSingleton = function() {\n-                    var counter = 0;\n-                    var stylesheet = null;\n+                exports.VariablesInAllowedPositionRule = VariablesInAllowedPositionRule;\n+                var _inspect = __webpack_require__( /*! ../../jsutils/inspect.mjs */ \"../../../node_modules/graphql/jsutils/inspect.mjs\");\n+                var _GraphQLError = __webpack_require__( /*! ../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n+                var _kinds = __webpack_require__( /*! ../../language/kinds.mjs */ \"../../../node_modules/graphql/language/kinds.mjs\");\n+                var _definition = __webpack_require__( /*! ../../type/definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n+                var _typeComparators = __webpack_require__( /*! ../../utilities/typeComparators.mjs */ \"../../../node_modules/graphql/utilities/typeComparators.mjs\");\n+                var _typeFromAST = __webpack_require__( /*! ../../utilities/typeFromAST.mjs */ \"../../../node_modules/graphql/utilities/typeFromAST.mjs\");\n+                /**\n+                 * Variables in allowed position\n+                 *\n+                 * Variable usages must be compatible with the arguments they are passed to.\n+                 *\n+                 * See https://spec.graphql.org/draft/#sec-All-Variable-Usages-are-Allowed\n+                 */\n+                function VariablesInAllowedPositionRule(context) {\n+                    let varDefMap = Object.create(null);\n                     return {\n-                        add: function(style) {\n-                            if (counter == 0) {\n-                                if (stylesheet = makeStyleTag()) {\n-                                    injectStyles(stylesheet, style);\n-                                    insertStyleTag(stylesheet);\n+                        OperationDefinition: {\n+                            enter() {\n+                                varDefMap = Object.create(null);\n+                            },\n+                            leave(operation) {\n+                                const usages = context.getRecursiveVariableUsages(operation);\n+                                for (const {\n+                                        node,\n+                                        type,\n+                                        defaultValue\n+                                    }\n+                                    of usages) {\n+                                    const varName = node.name.value;\n+                                    const varDef = varDefMap[varName];\n+                                    if (varDef && type) {\n+                                        // A var type is allowed if it is the same or more strict (e.g. is\n+                                        // a subtype of) than the expected type. It can be more strict if\n+                                        // the variable type is non-null when the expected type is nullable.\n+                                        // If both are list types, the variable item type can be more strict\n+                                        // than the expected item type (contravariant).\n+                                        const schema = context.getSchema();\n+                                        const varType = (0, _typeFromAST.typeFromAST)(schema, varDef.type);\n+                                        if (varType && !allowedVariableUsage(schema, varType, varDef.defaultValue, type, defaultValue)) {\n+                                            const varTypeStr = (0, _inspect.inspect)(varType);\n+                                            const typeStr = (0, _inspect.inspect)(type);\n+                                            context.reportError(new _GraphQLError.GraphQLError(`Variable \"$${varName}\" of type \"${varTypeStr}\" used in position expecting type \"${typeStr}\".`, {\n+                                                nodes: [varDef, node]\n+                                            }));\n+                                        }\n+                                    }\n                                 }\n                             }\n-                            counter++;\n                         },\n-                        remove: function() {\n-                            counter--;\n-                            if (!counter && stylesheet) {\n-                                stylesheet.parentNode && stylesheet.parentNode.removeChild(stylesheet);\n-                                stylesheet = null;\n-                            }\n+                        VariableDefinition(node) {\n+                            varDefMap[node.variable.name.value] = node;\n                         }\n                     };\n-                };\n-                exports.stylesheetSingleton = stylesheetSingleton;\n+                }\n+                /**\n+                 * Returns true if the variable is allowed in the location it was found,\n+                 * which includes considering if default values exist for either the variable\n+                 * or the location at which it is located.\n+                 */\n+\n+                function allowedVariableUsage(schema, varType, varDefaultValue, locationType, locationDefaultValue) {\n+                    if ((0, _definition.isNonNullType)(locationType) && !(0, _definition.isNonNullType)(varType)) {\n+                        const hasNonNullVariableDefaultValue = varDefaultValue != null && varDefaultValue.kind !== _kinds.Kind.NULL;\n+                        const hasLocationDefaultValue = locationDefaultValue !== undefined;\n+                        if (!hasNonNullVariableDefaultValue && !hasLocationDefaultValue) {\n+                            return false;\n+                        }\n+                        const nullableLocationType = locationType.ofType;\n+                        return (0, _typeComparators.isTypeSubTypeOf)(schema, varType, nullableLocationType);\n+                    }\n+                    return (0, _typeComparators.isTypeSubTypeOf)(schema, varType, locationType);\n+                }\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/react/cjs/react-jsx-runtime.development.js\":\n-            /*!************************************************************************!*\\\n-              !*** ../../../node_modules/react/cjs/react-jsx-runtime.development.js ***!\n-              \\************************************************************************/\n+        \"../../../node_modules/graphql/validation/rules/custom/NoDeprecatedCustomRule.mjs\":\n+            /*!****************************************************************************************!*\\\n+              !*** ../../../node_modules/graphql/validation/rules/custom/NoDeprecatedCustomRule.mjs ***!\n+              \\****************************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.NoDeprecatedCustomRule = NoDeprecatedCustomRule;\n+                var _invariant = __webpack_require__( /*! ../../../jsutils/invariant.mjs */ \"../../../node_modules/graphql/jsutils/invariant.mjs\");\n+                var _GraphQLError = __webpack_require__( /*! ../../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n+                var _definition = __webpack_require__( /*! ../../../type/definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n                 /**\n-                 * @license React\n-                 * react-jsx-runtime.development.js\n+                 * No deprecated\n                  *\n-                 * Copyright (c) Facebook, Inc. and its affiliates.\n+                 * A GraphQL document is only valid if all selected fields and all used enum values have not been\n+                 * deprecated.\n                  *\n-                 * This source code is licensed under the MIT license found in the\n-                 * LICENSE file in the root directory of this source tree.\n+                 * Note: This rule is optional and is not part of the Validation section of the GraphQL\n+                 * Specification. The main purpose of this rule is detection of deprecated usages and not\n+                 * necessarily to forbid their use when querying a service.\n                  */\n-\n-\n-\n-                if (true) {\n-                    (function() {\n-                        'use strict';\n-\n-                        var React = __webpack_require__( /*! react */ \"react\");\n-\n-                        // ATTENTION\n-                        // When adding new symbols to this file,\n-                        // Please consider also adding to 'react-devtools-shared/src/backend/ReactSymbols'\n-                        // The Symbol used to tag the ReactElement-like types.\n-                        var REACT_ELEMENT_TYPE = Symbol.for('react.element');\n-                        var REACT_PORTAL_TYPE = Symbol.for('react.portal');\n-                        var REACT_FRAGMENT_TYPE = Symbol.for('react.fragment');\n-                        var REACT_STRICT_MODE_TYPE = Symbol.for('react.strict_mode');\n-                        var REACT_PROFILER_TYPE = Symbol.for('react.profiler');\n-                        var REACT_PROVIDER_TYPE = Symbol.for('react.provider');\n-                        var REACT_CONTEXT_TYPE = Symbol.for('react.context');\n-                        var REACT_FORWARD_REF_TYPE = Symbol.for('react.forward_ref');\n-                        var REACT_SUSPENSE_TYPE = Symbol.for('react.suspense');\n-                        var REACT_SUSPENSE_LIST_TYPE = Symbol.for('react.suspense_list');\n-                        var REACT_MEMO_TYPE = Symbol.for('react.memo');\n-                        var REACT_LAZY_TYPE = Symbol.for('react.lazy');\n-                        var REACT_OFFSCREEN_TYPE = Symbol.for('react.offscreen');\n-                        var MAYBE_ITERATOR_SYMBOL = Symbol.iterator;\n-                        var FAUX_ITERATOR_SYMBOL = '@@iterator';\n-\n-                        function getIteratorFn(maybeIterable) {\n-                            if (maybeIterable === null || typeof maybeIterable !== 'object') {\n-                                return null;\n+                function NoDeprecatedCustomRule(context) {\n+                    return {\n+                        Field(node) {\n+                            const fieldDef = context.getFieldDef();\n+                            const deprecationReason = fieldDef === null || fieldDef === void 0 ? void 0 : fieldDef.deprecationReason;\n+                            if (fieldDef && deprecationReason != null) {\n+                                const parentType = context.getParentType();\n+                                parentType != null || (0, _invariant.invariant)(false);\n+                                context.reportError(new _GraphQLError.GraphQLError(`The field ${parentType.name}.${fieldDef.name} is deprecated. ${deprecationReason}`, {\n+                                    nodes: node\n+                                }));\n                             }\n-                            var maybeIterator = MAYBE_ITERATOR_SYMBOL && maybeIterable[MAYBE_ITERATOR_SYMBOL] || maybeIterable[FAUX_ITERATOR_SYMBOL];\n-                            if (typeof maybeIterator === 'function') {\n-                                return maybeIterator;\n+                        },\n+                        Argument(node) {\n+                            const argDef = context.getArgument();\n+                            const deprecationReason = argDef === null || argDef === void 0 ? void 0 : argDef.deprecationReason;\n+                            if (argDef && deprecationReason != null) {\n+                                const directiveDef = context.getDirective();\n+                                if (directiveDef != null) {\n+                                    context.reportError(new _GraphQLError.GraphQLError(`Directive \"@${directiveDef.name}\" argument \"${argDef.name}\" is deprecated. ${deprecationReason}`, {\n+                                        nodes: node\n+                                    }));\n+                                } else {\n+                                    const parentType = context.getParentType();\n+                                    const fieldDef = context.getFieldDef();\n+                                    parentType != null && fieldDef != null || (0, _invariant.invariant)(false);\n+                                    context.reportError(new _GraphQLError.GraphQLError(`Field \"${parentType.name}.${fieldDef.name}\" argument \"${argDef.name}\" is deprecated. ${deprecationReason}`, {\n+                                        nodes: node\n+                                    }));\n+                                }\n                             }\n-                            return null;\n-                        }\n-                        var ReactSharedInternals = React.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;\n-\n-                        function error(format) {\n-                            {\n-                                {\n-                                    for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {\n-                                        args[_key2 - 1] = arguments[_key2];\n-                                    }\n-                                    printWarning('error', format, args);\n+                        },\n+                        ObjectField(node) {\n+                            const inputObjectDef = (0, _definition.getNamedType)(context.getParentInputType());\n+                            if ((0, _definition.isInputObjectType)(inputObjectDef)) {\n+                                const inputFieldDef = inputObjectDef.getFields()[node.name.value];\n+                                const deprecationReason = inputFieldDef === null || inputFieldDef === void 0 ? void 0 : inputFieldDef.deprecationReason;\n+                                if (deprecationReason != null) {\n+                                    context.reportError(new _GraphQLError.GraphQLError(`The input field ${inputObjectDef.name}.${inputFieldDef.name} is deprecated. ${deprecationReason}`, {\n+                                        nodes: node\n+                                    }));\n                                 }\n                             }\n+                        },\n+                        EnumValue(node) {\n+                            const enumValueDef = context.getEnumValue();\n+                            const deprecationReason = enumValueDef === null || enumValueDef === void 0 ? void 0 : enumValueDef.deprecationReason;\n+                            if (enumValueDef && deprecationReason != null) {\n+                                const enumTypeDef = (0, _definition.getNamedType)(context.getInputType());\n+                                enumTypeDef != null || (0, _invariant.invariant)(false);\n+                                context.reportError(new _GraphQLError.GraphQLError(`The enum value \"${enumTypeDef.name}.${enumValueDef.name}\" is deprecated. ${deprecationReason}`, {\n+                                    nodes: node\n+                                }));\n+                            }\n                         }\n+                    };\n+                }\n \n-                        function printWarning(level, format, args) {\n-                            // When changing this logic, you might want to also\n-                            // update consoleWithStackDev.www.js as well.\n-                            {\n-                                var ReactDebugCurrentFrame = ReactSharedInternals.ReactDebugCurrentFrame;\n-                                var stack = ReactDebugCurrentFrame.getStackAddendum();\n-                                if (stack !== '') {\n-                                    format += '%s';\n-                                    args = args.concat([stack]);\n-                                } // eslint-disable-next-line react-internal/safe-string-coercion\n+                /***/\n+            }),\n \n-                                var argsWithFormat = args.map(function(item) {\n-                                    return String(item);\n-                                }); // Careful: RN currently depends on this prefix\n+        /***/\n+        \"../../../node_modules/graphql/validation/rules/custom/NoSchemaIntrospectionCustomRule.mjs\":\n+            /*!*************************************************************************************************!*\\\n+              !*** ../../../node_modules/graphql/validation/rules/custom/NoSchemaIntrospectionCustomRule.mjs ***!\n+              \\*************************************************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                                argsWithFormat.unshift('Warning: ' + format); // We intentionally don't use spread (or .apply) directly because it\n-                                // breaks IE9: https://github.com/facebook/react/issues/13610\n-                                // eslint-disable-next-line react-internal/no-production-logging\n+                \"use strict\";\n \n-                                Function.prototype.apply.call(console[level], console, argsWithFormat);\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.NoSchemaIntrospectionCustomRule = NoSchemaIntrospectionCustomRule;\n+                var _GraphQLError = __webpack_require__( /*! ../../../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n+                var _definition = __webpack_require__( /*! ../../../type/definition.mjs */ \"../../../node_modules/graphql/type/definition.mjs\");\n+                var _introspection = __webpack_require__( /*! ../../../type/introspection.mjs */ \"../../../node_modules/graphql/type/introspection.mjs\");\n+                /**\n+                 * Prohibit introspection queries\n+                 *\n+                 * A GraphQL document is only valid if all fields selected are not fields that\n+                 * return an introspection type.\n+                 *\n+                 * Note: This rule is optional and is not part of the Validation section of the\n+                 * GraphQL Specification. This rule effectively disables introspection, which\n+                 * does not reflect best practices and should only be done if absolutely necessary.\n+                 */\n+                function NoSchemaIntrospectionCustomRule(context) {\n+                    return {\n+                        Field(node) {\n+                            const type = (0, _definition.getNamedType)(context.getType());\n+                            if (type && (0, _introspection.isIntrospectionType)(type)) {\n+                                context.reportError(new _GraphQLError.GraphQLError(`GraphQL introspection has been disabled, but the requested query contained the field \"${node.name.value}\".`, {\n+                                    nodes: node\n+                                }));\n                             }\n                         }\n+                    };\n+                }\n \n-                        // -----------------------------------------------------------------------------\n+                /***/\n+            }),\n \n-                        var enableScopeAPI = false; // Experimental Create Event Handle API.\n-                        var enableCacheElement = false;\n-                        var enableTransitionTracing = false; // No known bugs, but needs performance testing\n+        /***/\n+        \"../../../node_modules/graphql/validation/specifiedRules.mjs\":\n+            /*!*******************************************************************!*\\\n+              !*** ../../../node_modules/graphql/validation/specifiedRules.mjs ***!\n+              \\*******************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                        var enableLegacyHidden = false; // Enables unstable_avoidThisFallback feature in Fiber\n-                        // stuff. Intended to enable React core members to more easily debug scheduling\n-                        // issues in DEV builds.\n+                \"use strict\";\n \n-                        var enableDebugTracing = false; // Track which Fiber(s) schedule render work.\n \n-                        var REACT_MODULE_REFERENCE;\n-                        {\n-                            REACT_MODULE_REFERENCE = Symbol.for('react.module.reference');\n-                        }\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.specifiedSDLRules = exports.specifiedRules = exports.recommendedRules = void 0;\n+                var _ExecutableDefinitionsRule = __webpack_require__( /*! ./rules/ExecutableDefinitionsRule.mjs */ \"../../../node_modules/graphql/validation/rules/ExecutableDefinitionsRule.mjs\");\n+                var _FieldsOnCorrectTypeRule = __webpack_require__( /*! ./rules/FieldsOnCorrectTypeRule.mjs */ \"../../../node_modules/graphql/validation/rules/FieldsOnCorrectTypeRule.mjs\");\n+                var _FragmentsOnCompositeTypesRule = __webpack_require__( /*! ./rules/FragmentsOnCompositeTypesRule.mjs */ \"../../../node_modules/graphql/validation/rules/FragmentsOnCompositeTypesRule.mjs\");\n+                var _KnownArgumentNamesRule = __webpack_require__( /*! ./rules/KnownArgumentNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/KnownArgumentNamesRule.mjs\");\n+                var _KnownDirectivesRule = __webpack_require__( /*! ./rules/KnownDirectivesRule.mjs */ \"../../../node_modules/graphql/validation/rules/KnownDirectivesRule.mjs\");\n+                var _KnownFragmentNamesRule = __webpack_require__( /*! ./rules/KnownFragmentNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/KnownFragmentNamesRule.mjs\");\n+                var _KnownTypeNamesRule = __webpack_require__( /*! ./rules/KnownTypeNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/KnownTypeNamesRule.mjs\");\n+                var _LoneAnonymousOperationRule = __webpack_require__( /*! ./rules/LoneAnonymousOperationRule.mjs */ \"../../../node_modules/graphql/validation/rules/LoneAnonymousOperationRule.mjs\");\n+                var _LoneSchemaDefinitionRule = __webpack_require__( /*! ./rules/LoneSchemaDefinitionRule.mjs */ \"../../../node_modules/graphql/validation/rules/LoneSchemaDefinitionRule.mjs\");\n+                var _MaxIntrospectionDepthRule = __webpack_require__( /*! ./rules/MaxIntrospectionDepthRule.mjs */ \"../../../node_modules/graphql/validation/rules/MaxIntrospectionDepthRule.mjs\");\n+                var _NoFragmentCyclesRule = __webpack_require__( /*! ./rules/NoFragmentCyclesRule.mjs */ \"../../../node_modules/graphql/validation/rules/NoFragmentCyclesRule.mjs\");\n+                var _NoUndefinedVariablesRule = __webpack_require__( /*! ./rules/NoUndefinedVariablesRule.mjs */ \"../../../node_modules/graphql/validation/rules/NoUndefinedVariablesRule.mjs\");\n+                var _NoUnusedFragmentsRule = __webpack_require__( /*! ./rules/NoUnusedFragmentsRule.mjs */ \"../../../node_modules/graphql/validation/rules/NoUnusedFragmentsRule.mjs\");\n+                var _NoUnusedVariablesRule = __webpack_require__( /*! ./rules/NoUnusedVariablesRule.mjs */ \"../../../node_modules/graphql/validation/rules/NoUnusedVariablesRule.mjs\");\n+                var _OverlappingFieldsCanBeMergedRule = __webpack_require__( /*! ./rules/OverlappingFieldsCanBeMergedRule.mjs */ \"../../../node_modules/graphql/validation/rules/OverlappingFieldsCanBeMergedRule.mjs\");\n+                var _PossibleFragmentSpreadsRule = __webpack_require__( /*! ./rules/PossibleFragmentSpreadsRule.mjs */ \"../../../node_modules/graphql/validation/rules/PossibleFragmentSpreadsRule.mjs\");\n+                var _PossibleTypeExtensionsRule = __webpack_require__( /*! ./rules/PossibleTypeExtensionsRule.mjs */ \"../../../node_modules/graphql/validation/rules/PossibleTypeExtensionsRule.mjs\");\n+                var _ProvidedRequiredArgumentsRule = __webpack_require__( /*! ./rules/ProvidedRequiredArgumentsRule.mjs */ \"../../../node_modules/graphql/validation/rules/ProvidedRequiredArgumentsRule.mjs\");\n+                var _ScalarLeafsRule = __webpack_require__( /*! ./rules/ScalarLeafsRule.mjs */ \"../../../node_modules/graphql/validation/rules/ScalarLeafsRule.mjs\");\n+                var _SingleFieldSubscriptionsRule = __webpack_require__( /*! ./rules/SingleFieldSubscriptionsRule.mjs */ \"../../../node_modules/graphql/validation/rules/SingleFieldSubscriptionsRule.mjs\");\n+                var _UniqueArgumentDefinitionNamesRule = __webpack_require__( /*! ./rules/UniqueArgumentDefinitionNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueArgumentDefinitionNamesRule.mjs\");\n+                var _UniqueArgumentNamesRule = __webpack_require__( /*! ./rules/UniqueArgumentNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueArgumentNamesRule.mjs\");\n+                var _UniqueDirectiveNamesRule = __webpack_require__( /*! ./rules/UniqueDirectiveNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueDirectiveNamesRule.mjs\");\n+                var _UniqueDirectivesPerLocationRule = __webpack_require__( /*! ./rules/UniqueDirectivesPerLocationRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueDirectivesPerLocationRule.mjs\");\n+                var _UniqueEnumValueNamesRule = __webpack_require__( /*! ./rules/UniqueEnumValueNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueEnumValueNamesRule.mjs\");\n+                var _UniqueFieldDefinitionNamesRule = __webpack_require__( /*! ./rules/UniqueFieldDefinitionNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueFieldDefinitionNamesRule.mjs\");\n+                var _UniqueFragmentNamesRule = __webpack_require__( /*! ./rules/UniqueFragmentNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueFragmentNamesRule.mjs\");\n+                var _UniqueInputFieldNamesRule = __webpack_require__( /*! ./rules/UniqueInputFieldNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueInputFieldNamesRule.mjs\");\n+                var _UniqueOperationNamesRule = __webpack_require__( /*! ./rules/UniqueOperationNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueOperationNamesRule.mjs\");\n+                var _UniqueOperationTypesRule = __webpack_require__( /*! ./rules/UniqueOperationTypesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueOperationTypesRule.mjs\");\n+                var _UniqueTypeNamesRule = __webpack_require__( /*! ./rules/UniqueTypeNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueTypeNamesRule.mjs\");\n+                var _UniqueVariableNamesRule = __webpack_require__( /*! ./rules/UniqueVariableNamesRule.mjs */ \"../../../node_modules/graphql/validation/rules/UniqueVariableNamesRule.mjs\");\n+                var _ValuesOfCorrectTypeRule = __webpack_require__( /*! ./rules/ValuesOfCorrectTypeRule.mjs */ \"../../../node_modules/graphql/validation/rules/ValuesOfCorrectTypeRule.mjs\");\n+                var _VariablesAreInputTypesRule = __webpack_require__( /*! ./rules/VariablesAreInputTypesRule.mjs */ \"../../../node_modules/graphql/validation/rules/VariablesAreInputTypesRule.mjs\");\n+                var _VariablesInAllowedPositionRule = __webpack_require__( /*! ./rules/VariablesInAllowedPositionRule.mjs */ \"../../../node_modules/graphql/validation/rules/VariablesInAllowedPositionRule.mjs\");\n+                // Spec Section: \"Executable Definitions\"\n+                // Spec Section: \"Field Selections on Objects, Interfaces, and Unions Types\"\n \n-                        function isValidElementType(type) {\n-                            if (typeof type === 'string' || typeof type === 'function') {\n-                                return true;\n-                            } // Note: typeof might be other than 'symbol' or 'number' (e.g. if it's a polyfill).\n+                // Spec Section: \"Fragments on Composite Types\"\n \n-                            if (type === REACT_FRAGMENT_TYPE || type === REACT_PROFILER_TYPE || enableDebugTracing || type === REACT_STRICT_MODE_TYPE || type === REACT_SUSPENSE_TYPE || type === REACT_SUSPENSE_LIST_TYPE || enableLegacyHidden || type === REACT_OFFSCREEN_TYPE || enableScopeAPI || enableCacheElement || enableTransitionTracing) {\n-                                return true;\n-                            }\n-                            if (typeof type === 'object' && type !== null) {\n-                                if (type.$$typeof === REACT_LAZY_TYPE || type.$$typeof === REACT_MEMO_TYPE || type.$$typeof === REACT_PROVIDER_TYPE || type.$$typeof === REACT_CONTEXT_TYPE || type.$$typeof === REACT_FORWARD_REF_TYPE ||\n-                                    // This needs to include all possible module reference object\n-                                    // types supported by any Flight configuration anywhere since\n-                                    // we don't know which Flight build this will end up being used\n-                                    // with.\n-                                    type.$$typeof === REACT_MODULE_REFERENCE || type.getModuleId !== undefined) {\n-                                    return true;\n-                                }\n-                            }\n-                            return false;\n-                        }\n+                // Spec Section: \"Argument Names\"\n \n-                        function getWrappedName(outerType, innerType, wrapperName) {\n-                            var displayName = outerType.displayName;\n-                            if (displayName) {\n-                                return displayName;\n-                            }\n-                            var functionName = innerType.displayName || innerType.name || '';\n-                            return functionName !== '' ? wrapperName + \"(\" + functionName + \")\" : wrapperName;\n-                        } // Keep in sync with react-reconciler/getComponentNameFromFiber\n+                // Spec Section: \"Directives Are Defined\"\n \n-                        function getContextName(type) {\n-                            return type.displayName || 'Context';\n-                        } // Note that the reconciler package should generally prefer to use getComponentNameFromFiber() instead.\n+                // Spec Section: \"Fragment spread target defined\"\n \n-                        function getComponentNameFromType(type) {\n-                            if (type == null) {\n-                                // Host root, text node or just invalid type.\n-                                return null;\n-                            } {\n-                                if (typeof type.tag === 'number') {\n-                                    error('Received an unexpected object in getComponentNameFromType(). ' + 'This is likely a bug in React. Please file an issue.');\n-                                }\n-                            }\n-                            if (typeof type === 'function') {\n-                                return type.displayName || type.name || null;\n-                            }\n-                            if (typeof type === 'string') {\n-                                return type;\n-                            }\n-                            switch (type) {\n-                                case REACT_FRAGMENT_TYPE:\n-                                    return 'Fragment';\n-                                case REACT_PORTAL_TYPE:\n-                                    return 'Portal';\n-                                case REACT_PROFILER_TYPE:\n-                                    return 'Profiler';\n-                                case REACT_STRICT_MODE_TYPE:\n-                                    return 'StrictMode';\n-                                case REACT_SUSPENSE_TYPE:\n-                                    return 'Suspense';\n-                                case REACT_SUSPENSE_LIST_TYPE:\n-                                    return 'SuspenseList';\n-                            }\n-                            if (typeof type === 'object') {\n-                                switch (type.$$typeof) {\n-                                    case REACT_CONTEXT_TYPE:\n-                                        var context = type;\n-                                        return getContextName(context) + '.Consumer';\n-                                    case REACT_PROVIDER_TYPE:\n-                                        var provider = type;\n-                                        return getContextName(provider._context) + '.Provider';\n-                                    case REACT_FORWARD_REF_TYPE:\n-                                        return getWrappedName(type, type.render, 'ForwardRef');\n-                                    case REACT_MEMO_TYPE:\n-                                        var outerName = type.displayName || null;\n-                                        if (outerName !== null) {\n-                                            return outerName;\n-                                        }\n-                                        return getComponentNameFromType(type.type) || 'Memo';\n-                                    case REACT_LAZY_TYPE: {\n-                                        var lazyComponent = type;\n-                                        var payload = lazyComponent._payload;\n-                                        var init = lazyComponent._init;\n-                                        try {\n-                                            return getComponentNameFromType(init(payload));\n-                                        } catch (x) {\n-                                            return null;\n-                                        }\n-                                    }\n+                // Spec Section: \"Fragment Spread Type Existence\"\n \n-                                    // eslint-disable-next-line no-fallthrough\n-                                }\n-                            }\n+                // Spec Section: \"Lone Anonymous Operation\"\n \n-                            return null;\n-                        }\n-                        var assign = Object.assign;\n+                // SDL-specific validation rules\n \n-                        // Helpers to patch console.logs to avoid logging during side-effect free\n-                        // replaying on render function. This currently only patches the object\n-                        // lazily which won't cover if the log function was extracted eagerly.\n-                        // We could also eagerly patch the method.\n-                        var disabledDepth = 0;\n-                        var prevLog;\n-                        var prevInfo;\n-                        var prevWarn;\n-                        var prevError;\n-                        var prevGroup;\n-                        var prevGroupCollapsed;\n-                        var prevGroupEnd;\n+                // TODO: Spec Section\n \n-                        function disabledLog() {}\n-                        disabledLog.__reactDisabledLog = true;\n+                // Spec Section: \"Fragments must not form cycles\"\n \n-                        function disableLogs() {\n-                            {\n-                                if (disabledDepth === 0) {\n-                                    /* eslint-disable react-internal/no-production-logging */\n-                                    prevLog = console.log;\n-                                    prevInfo = console.info;\n-                                    prevWarn = console.warn;\n-                                    prevError = console.error;\n-                                    prevGroup = console.group;\n-                                    prevGroupCollapsed = console.groupCollapsed;\n-                                    prevGroupEnd = console.groupEnd; // https://github.com/facebook/react/issues/19099\n+                // Spec Section: \"All Variable Used Defined\"\n \n-                                    var props = {\n-                                        configurable: true,\n-                                        enumerable: true,\n-                                        value: disabledLog,\n-                                        writable: true\n-                                    }; // $FlowFixMe Flow thinks console is immutable.\n+                // Spec Section: \"Fragments must be used\"\n \n-                                    Object.defineProperties(console, {\n-                                        info: props,\n-                                        log: props,\n-                                        warn: props,\n-                                        error: props,\n-                                        group: props,\n-                                        groupCollapsed: props,\n-                                        groupEnd: props\n-                                    });\n-                                    /* eslint-enable react-internal/no-production-logging */\n-                                }\n+                // Spec Section: \"All Variables Used\"\n \n-                                disabledDepth++;\n-                            }\n-                        }\n+                // Spec Section: \"Field Selection Merging\"\n \n-                        function reenableLogs() {\n-                            {\n-                                disabledDepth--;\n-                                if (disabledDepth === 0) {\n-                                    /* eslint-disable react-internal/no-production-logging */\n-                                    var props = {\n-                                        configurable: true,\n-                                        enumerable: true,\n-                                        writable: true\n-                                    }; // $FlowFixMe Flow thinks console is immutable.\n+                // Spec Section: \"Fragment spread is possible\"\n \n-                                    Object.defineProperties(console, {\n-                                        log: assign({}, props, {\n-                                            value: prevLog\n-                                        }),\n-                                        info: assign({}, props, {\n-                                            value: prevInfo\n-                                        }),\n-                                        warn: assign({}, props, {\n-                                            value: prevWarn\n-                                        }),\n-                                        error: assign({}, props, {\n-                                            value: prevError\n-                                        }),\n-                                        group: assign({}, props, {\n-                                            value: prevGroup\n-                                        }),\n-                                        groupCollapsed: assign({}, props, {\n-                                            value: prevGroupCollapsed\n-                                        }),\n-                                        groupEnd: assign({}, props, {\n-                                            value: prevGroupEnd\n-                                        })\n-                                    });\n-                                    /* eslint-enable react-internal/no-production-logging */\n-                                }\n+                // Spec Section: \"Argument Optionality\"\n \n-                                if (disabledDepth < 0) {\n-                                    error('disabledDepth fell below zero. ' + 'This is a bug in React. Please file an issue.');\n-                                }\n-                            }\n-                        }\n-                        var ReactCurrentDispatcher = ReactSharedInternals.ReactCurrentDispatcher;\n-                        var prefix;\n+                // Spec Section: \"Leaf Field Selections\"\n \n-                        function describeBuiltInComponentFrame(name, source, ownerFn) {\n-                            {\n-                                if (prefix === undefined) {\n-                                    // Extract the VM specific prefix used by each line.\n-                                    try {\n-                                        throw Error();\n-                                    } catch (x) {\n-                                        var match = x.stack.trim().match(/\\n( *(at )?)/);\n-                                        prefix = match && match[1] || '';\n-                                    }\n-                                } // We use the prefix to ensure our stacks line up with native stack frames.\n+                // Spec Section: \"Subscriptions with Single Root Field\"\n \n-                                return '\\n' + prefix + name;\n-                            }\n-                        }\n-                        var reentry = false;\n-                        var componentFrameCache;\n-                        {\n-                            var PossiblyWeakMap = typeof WeakMap === 'function' ? WeakMap : Map;\n-                            componentFrameCache = new PossiblyWeakMap();\n-                        }\n+                // Spec Section: \"Argument Uniqueness\"\n \n-                        function describeNativeComponentFrame(fn, construct) {\n-                            // If something asked for a stack inside a fake render, it should get ignored.\n-                            if (!fn || reentry) {\n-                                return '';\n-                            } {\n-                                var frame = componentFrameCache.get(fn);\n-                                if (frame !== undefined) {\n-                                    return frame;\n-                                }\n-                            }\n-                            var control;\n-                            reentry = true;\n-                            var previousPrepareStackTrace = Error.prepareStackTrace; // $FlowFixMe It does accept undefined.\n+                // Spec Section: \"Directives Are Unique Per Location\"\n \n-                            Error.prepareStackTrace = undefined;\n-                            var previousDispatcher;\n-                            {\n-                                previousDispatcher = ReactCurrentDispatcher.current; // Set the dispatcher in DEV because this might be call in the render function\n-                                // for warnings.\n+                // Spec Section: \"Fragment Name Uniqueness\"\n \n-                                ReactCurrentDispatcher.current = null;\n-                                disableLogs();\n-                            }\n-                            try {\n-                                // This should throw.\n-                                if (construct) {\n-                                    // Something should be setting the props in the constructor.\n-                                    var Fake = function() {\n-                                        throw Error();\n-                                    }; // $FlowFixMe\n+                // Spec Section: \"Input Object Field Uniqueness\"\n \n-                                    Object.defineProperty(Fake.prototype, 'props', {\n-                                        set: function() {\n-                                            // We use a throwing setter instead of frozen or non-writable props\n-                                            // because that won't throw in a non-strict mode function.\n-                                            throw Error();\n-                                        }\n-                                    });\n-                                    if (typeof Reflect === 'object' && Reflect.construct) {\n-                                        // We construct a different control for this case to include any extra\n-                                        // frames added by the construct call.\n-                                        try {\n-                                            Reflect.construct(Fake, []);\n-                                        } catch (x) {\n-                                            control = x;\n-                                        }\n-                                        Reflect.construct(fn, [], Fake);\n-                                    } else {\n-                                        try {\n-                                            Fake.call();\n-                                        } catch (x) {\n-                                            control = x;\n-                                        }\n-                                        fn.call(Fake.prototype);\n-                                    }\n-                                } else {\n-                                    try {\n-                                        throw Error();\n-                                    } catch (x) {\n-                                        control = x;\n-                                    }\n-                                    fn();\n-                                }\n-                            } catch (sample) {\n-                                // This is inlined manually because closure doesn't do it for us.\n-                                if (sample && control && typeof sample.stack === 'string') {\n-                                    // This extracts the first frame from the sample that isn't also in the control.\n-                                    // Skipping one frame that we assume is the frame that calls the two.\n-                                    var sampleLines = sample.stack.split('\\n');\n-                                    var controlLines = control.stack.split('\\n');\n-                                    var s = sampleLines.length - 1;\n-                                    var c = controlLines.length - 1;\n-                                    while (s >= 1 && c >= 0 && sampleLines[s] !== controlLines[c]) {\n-                                        // We expect at least one stack frame to be shared.\n-                                        // Typically this will be the root most one. However, stack frames may be\n-                                        // cut off due to maximum stack limits. In this case, one maybe cut off\n-                                        // earlier than the other. We assume that the sample is longer or the same\n-                                        // and there for cut off earlier. So we should find the root most frame in\n-                                        // the sample somewhere in the control.\n-                                        c--;\n-                                    }\n-                                    for (; s >= 1 && c >= 0; s--, c--) {\n-                                        // Next we find the first one that isn't the same which should be the\n-                                        // frame that called our sample function and the control.\n-                                        if (sampleLines[s] !== controlLines[c]) {\n-                                            // In V8, the first line is describing the message but other VMs don't.\n-                                            // If we're about to return the first line, and the control is also on the same\n-                                            // line, that's a pretty good indicator that our sample threw at same line as\n-                                            // the control. I.e. before we entered the sample frame. So we ignore this result.\n-                                            // This can happen if you passed a class to function component, or non-function.\n-                                            if (s !== 1 || c !== 1) {\n-                                                do {\n-                                                    s--;\n-                                                    c--; // We may still have similar intermediate frames from the construct call.\n-                                                    // The next one that isn't the same should be our match though.\n+                // Spec Section: \"Operation Name Uniqueness\"\n \n-                                                    if (c < 0 || sampleLines[s] !== controlLines[c]) {\n-                                                        // V8 adds a \"new\" prefix for native classes. Let's remove it to make it prettier.\n-                                                        var _frame = '\\n' + sampleLines[s].replace(' at new ', ' at '); // If our component frame is labeled \"<anonymous>\"\n-                                                        // but we have a user-provided \"displayName\"\n-                                                        // splice it in to make the stack more readable.\n+                // Spec Section: \"Variable Uniqueness\"\n \n-                                                        if (fn.displayName && _frame.includes('<anonymous>')) {\n-                                                            _frame = _frame.replace('<anonymous>', fn.displayName);\n-                                                        } {\n-                                                            if (typeof fn === 'function') {\n-                                                                componentFrameCache.set(fn, _frame);\n-                                                            }\n-                                                        } // Return the line we found.\n+                // Spec Section: \"Value Type Correctness\"\n \n-                                                        return _frame;\n-                                                    }\n-                                                } while (s >= 1 && c >= 0);\n-                                            }\n-                                            break;\n-                                        }\n-                                    }\n-                                }\n-                            } finally {\n-                                reentry = false;\n-                                {\n-                                    ReactCurrentDispatcher.current = previousDispatcher;\n-                                    reenableLogs();\n-                                }\n-                                Error.prepareStackTrace = previousPrepareStackTrace;\n-                            } // Fallback to just using the name if we couldn't make it throw.\n+                // Spec Section: \"Variables are Input Types\"\n \n-                            var name = fn ? fn.displayName || fn.name : '';\n-                            var syntheticFrame = name ? describeBuiltInComponentFrame(name) : '';\n-                            {\n-                                if (typeof fn === 'function') {\n-                                    componentFrameCache.set(fn, syntheticFrame);\n-                                }\n-                            }\n-                            return syntheticFrame;\n-                        }\n+                // Spec Section: \"All Variable Usages Are Allowed\"\n \n-                        function describeFunctionComponentFrame(fn, source, ownerFn) {\n-                            {\n-                                return describeNativeComponentFrame(fn, false);\n-                            }\n-                        }\n+                /**\n+                 * Technically these aren't part of the spec but they are strongly encouraged\n+                 * validation rules.\n+                 */\n+                const recommendedRules = exports.recommendedRules = Object.freeze([_MaxIntrospectionDepthRule.MaxIntrospectionDepthRule]);\n+                /**\n+                 * This set includes all validation rules defined by the GraphQL spec.\n+                 *\n+                 * The order of the rules in this list has been adjusted to lead to the\n+                 * most clear output when encountering multiple validation errors.\n+                 */\n \n-                        function shouldConstruct(Component) {\n-                            var prototype = Component.prototype;\n-                            return !!(prototype && prototype.isReactComponent);\n-                        }\n+                const specifiedRules = exports.specifiedRules = Object.freeze([_ExecutableDefinitionsRule.ExecutableDefinitionsRule, _UniqueOperationNamesRule.UniqueOperationNamesRule, _LoneAnonymousOperationRule.LoneAnonymousOperationRule, _SingleFieldSubscriptionsRule.SingleFieldSubscriptionsRule, _KnownTypeNamesRule.KnownTypeNamesRule, _FragmentsOnCompositeTypesRule.FragmentsOnCompositeTypesRule, _VariablesAreInputTypesRule.VariablesAreInputTypesRule, _ScalarLeafsRule.ScalarLeafsRule, _FieldsOnCorrectTypeRule.FieldsOnCorrectTypeRule, _UniqueFragmentNamesRule.UniqueFragmentNamesRule, _KnownFragmentNamesRule.KnownFragmentNamesRule, _NoUnusedFragmentsRule.NoUnusedFragmentsRule, _PossibleFragmentSpreadsRule.PossibleFragmentSpreadsRule, _NoFragmentCyclesRule.NoFragmentCyclesRule, _UniqueVariableNamesRule.UniqueVariableNamesRule, _NoUndefinedVariablesRule.NoUndefinedVariablesRule, _NoUnusedVariablesRule.NoUnusedVariablesRule, _KnownDirectivesRule.KnownDirectivesRule, _UniqueDirectivesPerLocationRule.UniqueDirectivesPerLocationRule, _KnownArgumentNamesRule.KnownArgumentNamesRule, _UniqueArgumentNamesRule.UniqueArgumentNamesRule, _ValuesOfCorrectTypeRule.ValuesOfCorrectTypeRule, _ProvidedRequiredArgumentsRule.ProvidedRequiredArgumentsRule, _VariablesInAllowedPositionRule.VariablesInAllowedPositionRule, _OverlappingFieldsCanBeMergedRule.OverlappingFieldsCanBeMergedRule, _UniqueInputFieldNamesRule.UniqueInputFieldNamesRule, ...recommendedRules]);\n+                /**\n+                 * @internal\n+                 */\n \n-                        function describeUnknownElementTypeFrameInDEV(type, source, ownerFn) {\n-                            if (type == null) {\n-                                return '';\n-                            }\n-                            if (typeof type === 'function') {\n-                                {\n-                                    return describeNativeComponentFrame(type, shouldConstruct(type));\n-                                }\n-                            }\n-                            if (typeof type === 'string') {\n-                                return describeBuiltInComponentFrame(type);\n-                            }\n-                            switch (type) {\n-                                case REACT_SUSPENSE_TYPE:\n-                                    return describeBuiltInComponentFrame('Suspense');\n-                                case REACT_SUSPENSE_LIST_TYPE:\n-                                    return describeBuiltInComponentFrame('SuspenseList');\n-                            }\n-                            if (typeof type === 'object') {\n-                                switch (type.$$typeof) {\n-                                    case REACT_FORWARD_REF_TYPE:\n-                                        return describeFunctionComponentFrame(type.render);\n-                                    case REACT_MEMO_TYPE:\n-                                        // Memo may contain any component type so we recursively resolve it.\n-                                        return describeUnknownElementTypeFrameInDEV(type.type, source, ownerFn);\n-                                    case REACT_LAZY_TYPE: {\n-                                        var lazyComponent = type;\n-                                        var payload = lazyComponent._payload;\n-                                        var init = lazyComponent._init;\n-                                        try {\n-                                            // Lazy may contain any component type so we recursively resolve it.\n-                                            return describeUnknownElementTypeFrameInDEV(init(payload), source, ownerFn);\n-                                        } catch (x) {}\n-                                    }\n-                                }\n-                            }\n-                            return '';\n-                        }\n-                        var hasOwnProperty = Object.prototype.hasOwnProperty;\n-                        var loggedTypeFailures = {};\n-                        var ReactDebugCurrentFrame = ReactSharedInternals.ReactDebugCurrentFrame;\n+                const specifiedSDLRules = exports.specifiedSDLRules = Object.freeze([_LoneSchemaDefinitionRule.LoneSchemaDefinitionRule, _UniqueOperationTypesRule.UniqueOperationTypesRule, _UniqueTypeNamesRule.UniqueTypeNamesRule, _UniqueEnumValueNamesRule.UniqueEnumValueNamesRule, _UniqueFieldDefinitionNamesRule.UniqueFieldDefinitionNamesRule, _UniqueArgumentDefinitionNamesRule.UniqueArgumentDefinitionNamesRule, _UniqueDirectiveNamesRule.UniqueDirectiveNamesRule, _KnownTypeNamesRule.KnownTypeNamesRule, _KnownDirectivesRule.KnownDirectivesRule, _UniqueDirectivesPerLocationRule.UniqueDirectivesPerLocationRule, _PossibleTypeExtensionsRule.PossibleTypeExtensionsRule, _KnownArgumentNamesRule.KnownArgumentNamesOnDirectivesRule, _UniqueArgumentNamesRule.UniqueArgumentNamesRule, _UniqueInputFieldNamesRule.UniqueInputFieldNamesRule, _ProvidedRequiredArgumentsRule.ProvidedRequiredArgumentsOnDirectivesRule]);\n \n-                        function setCurrentlyValidatingElement(element) {\n-                            {\n-                                if (element) {\n-                                    var owner = element._owner;\n-                                    var stack = describeUnknownElementTypeFrameInDEV(element.type, element._source, owner ? owner.type : null);\n-                                    ReactDebugCurrentFrame.setExtraStackFrame(stack);\n-                                } else {\n-                                    ReactDebugCurrentFrame.setExtraStackFrame(null);\n-                                }\n-                            }\n-                        }\n+                /***/\n+            }),\n \n-                        function checkPropTypes(typeSpecs, values, location, componentName, element) {\n-                            {\n-                                // $FlowFixMe This is okay but Flow doesn't know it.\n-                                var has = Function.call.bind(hasOwnProperty);\n-                                for (var typeSpecName in typeSpecs) {\n-                                    if (has(typeSpecs, typeSpecName)) {\n-                                        var error$1 = void 0; // Prop type validation may throw. In case they do, we don't want to\n-                                        // fail the render phase where it didn't fail before. So we log it.\n-                                        // After these have been cleaned up, we'll let them throw.\n+        /***/\n+        \"../../../node_modules/graphql/validation/validate.mjs\":\n+            /*!*************************************************************!*\\\n+              !*** ../../../node_modules/graphql/validation/validate.mjs ***!\n+              \\*************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                                        try {\n-                                            // This is intentionally an invariant that gets caught. It's the same\n-                                            // behavior as without this statement except with a better message.\n-                                            if (typeof typeSpecs[typeSpecName] !== 'function') {\n-                                                // eslint-disable-next-line react-internal/prod-error-codes\n-                                                var err = Error((componentName || 'React class') + ': ' + location + ' type `' + typeSpecName + '` is invalid; ' + 'it must be a function, usually from the `prop-types` package, but received `' + typeof typeSpecs[typeSpecName] + '`.' + 'This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.');\n-                                                err.name = 'Invariant Violation';\n-                                                throw err;\n-                                            }\n-                                            error$1 = typeSpecs[typeSpecName](values, typeSpecName, componentName, location, null, 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED');\n-                                        } catch (ex) {\n-                                            error$1 = ex;\n-                                        }\n-                                        if (error$1 && !(error$1 instanceof Error)) {\n-                                            setCurrentlyValidatingElement(element);\n-                                            error('%s: type specification of %s' + ' `%s` is invalid; the type checker ' + 'function must return `null` or an `Error` but returned a %s. ' + 'You may have forgotten to pass an argument to the type checker ' + 'creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and ' + 'shape all require an argument).', componentName || 'React class', location, typeSpecName, typeof error$1);\n-                                            setCurrentlyValidatingElement(null);\n-                                        }\n-                                        if (error$1 instanceof Error && !(error$1.message in loggedTypeFailures)) {\n-                                            // Only monitor this failure once because there tends to be a lot of the\n-                                            // same error.\n-                                            loggedTypeFailures[error$1.message] = true;\n-                                            setCurrentlyValidatingElement(element);\n-                                            error('Failed %s type: %s', location, error$1.message);\n-                                            setCurrentlyValidatingElement(null);\n-                                        }\n-                                    }\n-                                }\n-                            }\n-                        }\n-                        var isArrayImpl = Array.isArray; // eslint-disable-next-line no-redeclare\n+                \"use strict\";\n \n-                        function isArray(a) {\n-                            return isArrayImpl(a);\n-                        }\n \n-                        /*\n-                         * The `'' + value` pattern (used in in perf-sensitive code) throws for Symbol\n-                         * and Temporal.* types. See https://github.com/facebook/react/pull/22064.\n-                         *\n-                         * The functions in this module will throw an easier-to-understand,\n-                         * easier-to-debug exception with a clear errors message message explaining the\n-                         * problem. (Instead of a confusing exception thrown inside the implementation\n-                         * of the `value` object).\n-                         */\n-                        // $FlowFixMe only called in DEV, so void return is not possible.\n-                        function typeName(value) {\n-                            {\n-                                // toStringTag is needed for namespaced types like Temporal.Instant\n-                                var hasToStringTag = typeof Symbol === 'function' && Symbol.toStringTag;\n-                                var type = hasToStringTag && value[Symbol.toStringTag] || value.constructor.name || 'Object';\n-                                return type;\n-                            }\n-                        } // $FlowFixMe only called in DEV, so void return is not possible.\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.assertValidSDL = assertValidSDL;\n+                exports.assertValidSDLExtension = assertValidSDLExtension;\n+                exports.validate = validate;\n+                exports.validateSDL = validateSDL;\n+                var _devAssert = __webpack_require__( /*! ../jsutils/devAssert.mjs */ \"../../../node_modules/graphql/jsutils/devAssert.mjs\");\n+                var _GraphQLError = __webpack_require__( /*! ../error/GraphQLError.mjs */ \"../../../node_modules/graphql/error/GraphQLError.mjs\");\n+                var _visitor = __webpack_require__( /*! ../language/visitor.mjs */ \"../../../node_modules/graphql/language/visitor.mjs\");\n+                var _validate = __webpack_require__( /*! ../type/validate.mjs */ \"../../../node_modules/graphql/type/validate.mjs\");\n+                var _TypeInfo = __webpack_require__( /*! ../utilities/TypeInfo.mjs */ \"../../../node_modules/graphql/utilities/TypeInfo.mjs\");\n+                var _specifiedRules = __webpack_require__( /*! ./specifiedRules.mjs */ \"../../../node_modules/graphql/validation/specifiedRules.mjs\");\n+                var _ValidationContext = __webpack_require__( /*! ./ValidationContext.mjs */ \"../../../node_modules/graphql/validation/ValidationContext.mjs\");\n+                /**\n+                 * Implements the \"Validation\" section of the spec.\n+                 *\n+                 * Validation runs synchronously, returning an array of encountered errors, or\n+                 * an empty array if no errors were encountered and the document is valid.\n+                 *\n+                 * A list of specific validation rules may be provided. If not provided, the\n+                 * default list of rules defined by the GraphQL specification will be used.\n+                 *\n+                 * Each validation rules is a function which returns a visitor\n+                 * (see the language/visitor API). Visitor methods are expected to return\n+                 * GraphQLErrors, or Arrays of GraphQLErrors when invalid.\n+                 *\n+                 * Validate will stop validation after a `maxErrors` limit has been reached.\n+                 * Attackers can send pathologically invalid queries to induce a DoS attack,\n+                 * so by default `maxErrors` set to 100 errors.\n+                 *\n+                 * Optionally a custom TypeInfo instance may be provided. If not provided, one\n+                 * will be created from the provided schema.\n+                 */\n \n-                        function willCoercionThrow(value) {\n-                            {\n-                                try {\n-                                    testStringCoercion(value);\n-                                    return false;\n-                                } catch (e) {\n-                                    return true;\n-                                }\n-                            }\n-                        }\n+                function validate(schema, documentAST, rules = _specifiedRules.specifiedRules, options, /** @deprecated will be removed in 17.0.0 */\n+                    typeInfo = new _TypeInfo.TypeInfo(schema)) {\n+                    var _options$maxErrors;\n+                    const maxErrors = (_options$maxErrors = options === null || options === void 0 ? void 0 : options.maxErrors) !== null && _options$maxErrors !== void 0 ? _options$maxErrors : 100;\n+                    documentAST || (0, _devAssert.devAssert)(false, 'Must provide document.'); // If the schema used for validation is invalid, throw an error.\n \n-                        function testStringCoercion(value) {\n-                            // If you ended up here by following an exception call stack, here's what's\n-                            // happened: you supplied an object or symbol value to React (as a prop, key,\n-                            // DOM attribute, CSS property, string ref, etc.) and when React tried to\n-                            // coerce it to a string using `'' + value`, an exception was thrown.\n-                            //\n-                            // The most common types that will cause this exception are `Symbol` instances\n-                            // and Temporal objects like `Temporal.Instant`. But any object that has a\n-                            // `valueOf` or `[Symbol.toPrimitive]` method that throws will also cause this\n-                            // exception. (Library authors do this to prevent users from using built-in\n-                            // numeric operators like `+` or comparison operators like `>=` because custom\n-                            // methods are needed to perform accurate arithmetic or comparison.)\n-                            //\n-                            // To fix the problem, coerce this object or symbol value to a string before\n-                            // passing it to React. The most reliable way is usually `String(value)`.\n-                            //\n-                            // To find which value is throwing, check the browser or debugger console.\n-                            // Before this exception was thrown, there should be `console.error` output\n-                            // that shows the type (Symbol, Temporal.PlainDate, etc.) that caused the\n-                            // problem and how that type was used: key, atrribute, input value prop, etc.\n-                            // In most cases, this console output also shows the component and its\n-                            // ancestor components where the exception happened.\n-                            //\n-                            // eslint-disable-next-line react-internal/safe-string-coercion\n-                            return '' + value;\n-                        }\n+                    (0, _validate.assertValidSchema)(schema);\n+                    const abortObj = Object.freeze({});\n+                    const errors = [];\n+                    const context = new _ValidationContext.ValidationContext(schema, documentAST, typeInfo, error => {\n+                        if (errors.length >= maxErrors) {\n+                            errors.push(new _GraphQLError.GraphQLError('Too many validation errors, error limit reached. Validation aborted.')); // eslint-disable-next-line @typescript-eslint/no-throw-literal\n \n-                        function checkKeyStringCoercion(value) {\n-                            {\n-                                if (willCoercionThrow(value)) {\n-                                    error('The provided key is an unsupported type %s.' + ' This value must be coerced to a string before before using it here.', typeName(value));\n-                                    return testStringCoercion(value); // throw (to help callers find troubleshooting comments)\n-                                }\n-                            }\n+                            throw abortObj;\n                         }\n+                        errors.push(error);\n+                    }); // This uses a specialized visitor which runs multiple visitors in parallel,\n+                    // while maintaining the visitor skip and break API.\n \n-                        var ReactCurrentOwner = ReactSharedInternals.ReactCurrentOwner;\n-                        var RESERVED_PROPS = {\n-                            key: true,\n-                            ref: true,\n-                            __self: true,\n-                            __source: true\n-                        };\n-                        var specialPropKeyWarningShown;\n-                        var specialPropRefWarningShown;\n-                        var didWarnAboutStringRefs;\n-                        {\n-                            didWarnAboutStringRefs = {};\n-                        }\n+                    const visitor = (0, _visitor.visitInParallel)(rules.map(rule => rule(context))); // Visit the whole document with each instance of all provided rules.\n \n-                        function hasValidRef(config) {\n-                            {\n-                                if (hasOwnProperty.call(config, 'ref')) {\n-                                    var getter = Object.getOwnPropertyDescriptor(config, 'ref').get;\n-                                    if (getter && getter.isReactWarning) {\n-                                        return false;\n-                                    }\n-                                }\n-                            }\n-                            return config.ref !== undefined;\n+                    try {\n+                        (0, _visitor.visit)(documentAST, (0, _TypeInfo.visitWithTypeInfo)(typeInfo, visitor));\n+                    } catch (e) {\n+                        if (e !== abortObj) {\n+                            throw e;\n                         }\n+                    }\n+                    return errors;\n+                }\n+                /**\n+                 * @internal\n+                 */\n \n-                        function hasValidKey(config) {\n-                            {\n-                                if (hasOwnProperty.call(config, 'key')) {\n-                                    var getter = Object.getOwnPropertyDescriptor(config, 'key').get;\n-                                    if (getter && getter.isReactWarning) {\n-                                        return false;\n-                                    }\n-                                }\n-                            }\n-                            return config.key !== undefined;\n-                        }\n+                function validateSDL(documentAST, schemaToExtend, rules = _specifiedRules.specifiedSDLRules) {\n+                    const errors = [];\n+                    const context = new _ValidationContext.SDLValidationContext(documentAST, schemaToExtend, error => {\n+                        errors.push(error);\n+                    });\n+                    const visitors = rules.map(rule => rule(context));\n+                    (0, _visitor.visit)(documentAST, (0, _visitor.visitInParallel)(visitors));\n+                    return errors;\n+                }\n+                /**\n+                 * Utility function which asserts a SDL document is valid by throwing an error\n+                 * if it is invalid.\n+                 *\n+                 * @internal\n+                 */\n \n-                        function warnIfStringRefCannotBeAutoConverted(config, self) {\n-                            {\n-                                if (typeof config.ref === 'string' && ReactCurrentOwner.current && self && ReactCurrentOwner.current.stateNode !== self) {\n-                                    var componentName = getComponentNameFromType(ReactCurrentOwner.current.type);\n-                                    if (!didWarnAboutStringRefs[componentName]) {\n-                                        error('Component \"%s\" contains the string ref \"%s\". ' + 'Support for string refs will be removed in a future major release. ' + 'This case cannot be automatically converted to an arrow function. ' + 'We ask you to manually fix this case by using useRef() or createRef() instead. ' + 'Learn more about using refs safely here: ' + 'https://reactjs.org/link/strict-mode-string-ref', getComponentNameFromType(ReactCurrentOwner.current.type), config.ref);\n-                                        didWarnAboutStringRefs[componentName] = true;\n-                                    }\n-                                }\n-                            }\n-                        }\n+                function assertValidSDL(documentAST) {\n+                    const errors = validateSDL(documentAST);\n+                    if (errors.length !== 0) {\n+                        throw new Error(errors.map(error => error.message).join('\\n\\n'));\n+                    }\n+                }\n+                /**\n+                 * Utility function which asserts a SDL document is valid by throwing an error\n+                 * if it is invalid.\n+                 *\n+                 * @internal\n+                 */\n \n-                        function defineKeyPropWarningGetter(props, displayName) {\n-                            {\n-                                var warnAboutAccessingKey = function() {\n-                                    if (!specialPropKeyWarningShown) {\n-                                        specialPropKeyWarningShown = true;\n-                                        error('%s: `key` is not a prop. Trying to access it will result ' + 'in `undefined` being returned. If you need to access the same ' + 'value within the child component, you should pass it as a different ' + 'prop. (https://reactjs.org/link/special-props)', displayName);\n-                                    }\n-                                };\n-                                warnAboutAccessingKey.isReactWarning = true;\n-                                Object.defineProperty(props, 'key', {\n-                                    get: warnAboutAccessingKey,\n-                                    configurable: true\n-                                });\n-                            }\n-                        }\n+                function assertValidSDLExtension(documentAST, schema) {\n+                    const errors = validateSDL(documentAST, schema);\n+                    if (errors.length !== 0) {\n+                        throw new Error(errors.map(error => error.message).join('\\n\\n'));\n+                    }\n+                }\n \n-                        function defineRefPropWarningGetter(props, displayName) {\n-                            {\n-                                var warnAboutAccessingRef = function() {\n-                                    if (!specialPropRefWarningShown) {\n-                                        specialPropRefWarningShown = true;\n-                                        error('%s: `ref` is not a prop. Trying to access it will result ' + 'in `undefined` being returned. If you need to access the same ' + 'value within the child component, you should pass it as a different ' + 'prop. (https://reactjs.org/link/special-props)', displayName);\n-                                    }\n-                                };\n-                                warnAboutAccessingRef.isReactWarning = true;\n-                                Object.defineProperty(props, 'ref', {\n-                                    get: warnAboutAccessingRef,\n-                                    configurable: true\n-                                });\n-                            }\n-                        }\n-                        /**\n-                         * Factory method to create a new React element. This no longer adheres to\n-                         * the class pattern, so do not use new to call it. Also, instanceof check\n-                         * will not work. Instead test $$typeof field against Symbol.for('react.element') to check\n-                         * if something is a React Element.\n-                         *\n-                         * @param {*} type\n-                         * @param {*} props\n-                         * @param {*} key\n-                         * @param {string|object} ref\n-                         * @param {*} owner\n-                         * @param {*} self A *temporary* helper to detect places where `this` is\n-                         * different from the `owner` when React.createElement is called, so that we\n-                         * can warn. We want to get rid of owner and replace string `ref`s with arrow\n-                         * functions, and as long as `this` and owner are the same, there will be no\n-                         * change in behavior.\n-                         * @param {*} source An annotation object (added by a transpiler or otherwise)\n-                         * indicating filename, line number, and/or other information.\n-                         * @internal\n-                         */\n+                /***/\n+            }),\n \n-                        var ReactElement = function(type, key, ref, self, source, owner, props) {\n-                            var element = {\n-                                // This tag allows us to uniquely identify this as a React Element\n-                                $$typeof: REACT_ELEMENT_TYPE,\n-                                // Built-in properties that belong on the element\n-                                type: type,\n-                                key: key,\n-                                ref: ref,\n-                                props: props,\n-                                // Record the component responsible for creating this element.\n-                                _owner: owner\n-                            };\n-                            {\n-                                // The validation flag is currently mutative. We put it on\n-                                // an external backing store so that we can freeze the whole object.\n-                                // This can be replaced with a WeakMap once they are implemented in\n-                                // commonly used development environments.\n-                                element._store = {}; // To make comparing ReactElements easier for testing purposes, we make\n-                                // the validation flag non-enumerable (where possible, which should\n-                                // include every environment we run tests in), so the test framework\n-                                // ignores it.\n+        /***/\n+        \"../../../node_modules/graphql/version.mjs\":\n+            /*!*************************************************!*\\\n+              !*** ../../../node_modules/graphql/version.mjs ***!\n+              \\*************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports) {\n \n-                                Object.defineProperty(element._store, 'validated', {\n-                                    configurable: false,\n-                                    enumerable: false,\n-                                    writable: true,\n-                                    value: false\n-                                }); // self and source are DEV only properties.\n+                \"use strict\";\n \n-                                Object.defineProperty(element, '_self', {\n-                                    configurable: false,\n-                                    enumerable: false,\n-                                    writable: false,\n-                                    value: self\n-                                }); // Two elements created in two different places should be considered\n-                                // equal for testing purposes and therefore we hide it from enumeration.\n \n-                                Object.defineProperty(element, '_source', {\n-                                    configurable: false,\n-                                    enumerable: false,\n-                                    writable: false,\n-                                    value: source\n-                                });\n-                                if (Object.freeze) {\n-                                    Object.freeze(element.props);\n-                                    Object.freeze(element);\n-                                }\n-                            }\n-                            return element;\n-                        };\n-                        /**\n-                         * https://github.com/reactjs/rfcs/pull/107\n-                         * @param {*} type\n-                         * @param {object} props\n-                         * @param {string} key\n-                         */\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.versionInfo = exports.version = void 0;\n+                // Note: This file is autogenerated using \"resources/gen-version.js\" script and\n+                // automatically updated by \"npm version\" command.\n \n-                        function jsxDEV(type, config, maybeKey, source, self) {\n-                            {\n-                                var propName; // Reserved names are extracted\n+                /**\n+                 * A string containing the version of the GraphQL.js library\n+                 */\n+                const version = exports.version = '16.9.0';\n+                /**\n+                 * An object containing the components of the GraphQL.js version string\n+                 */\n \n-                                var props = {};\n-                                var key = null;\n-                                var ref = null; // Currently, key can be spread in as a prop. This causes a potential\n-                                // issue if key is also explicitly declared (ie. <div {...props} key=\"Hi\" />\n-                                // or <div key=\"Hi\" {...props} /> ). We want to deprecate key spread,\n-                                // but as an intermediary step, we will use jsxDEV for everything except\n-                                // <div {...props} key=\"Hi\" />, because we aren't currently able to tell if\n-                                // key is explicitly declared to be undefined or not.\n+                const versionInfo = exports.versionInfo = Object.freeze({\n+                    major: 16,\n+                    minor: 9,\n+                    patch: 0,\n+                    preReleaseTag: null\n+                });\n \n-                                if (maybeKey !== undefined) {\n-                                    {\n-                                        checkKeyStringCoercion(maybeKey);\n-                                    }\n-                                    key = '' + maybeKey;\n-                                }\n-                                if (hasValidKey(config)) {\n-                                    {\n-                                        checkKeyStringCoercion(config.key);\n-                                    }\n-                                    key = '' + config.key;\n-                                }\n-                                if (hasValidRef(config)) {\n-                                    ref = config.ref;\n-                                    warnIfStringRefCannotBeAutoConverted(config, self);\n-                                } // Remaining properties are added to a new props object\n+                /***/\n+            }),\n \n-                                for (propName in config) {\n-                                    if (hasOwnProperty.call(config, propName) && !RESERVED_PROPS.hasOwnProperty(propName)) {\n-                                        props[propName] = config[propName];\n-                                    }\n-                                } // Resolve default props\n+        /***/\n+        \"../../../node_modules/hey-listen/dist/hey-listen.es.js\":\n+            /*!**************************************************************!*\\\n+              !*** ../../../node_modules/hey-listen/dist/hey-listen.es.js ***!\n+              \\**************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports) {\n \n-                                if (type && type.defaultProps) {\n-                                    var defaultProps = type.defaultProps;\n-                                    for (propName in defaultProps) {\n-                                        if (props[propName] === undefined) {\n-                                            props[propName] = defaultProps[propName];\n-                                        }\n-                                    }\n-                                }\n-                                if (key || ref) {\n-                                    var displayName = typeof type === 'function' ? type.displayName || type.name || 'Unknown' : type;\n-                                    if (key) {\n-                                        defineKeyPropWarningGetter(props, displayName);\n-                                    }\n-                                    if (ref) {\n-                                        defineRefPropWarningGetter(props, displayName);\n-                                    }\n-                                }\n-                                return ReactElement(type, key, ref, self, source, ReactCurrentOwner.current, props);\n-                            }\n-                        }\n-                        var ReactCurrentOwner$1 = ReactSharedInternals.ReactCurrentOwner;\n-                        var ReactDebugCurrentFrame$1 = ReactSharedInternals.ReactDebugCurrentFrame;\n+                \"use strict\";\n \n-                        function setCurrentlyValidatingElement$1(element) {\n-                            {\n-                                if (element) {\n-                                    var owner = element._owner;\n-                                    var stack = describeUnknownElementTypeFrameInDEV(element.type, element._source, owner ? owner.type : null);\n-                                    ReactDebugCurrentFrame$1.setExtraStackFrame(stack);\n-                                } else {\n-                                    ReactDebugCurrentFrame$1.setExtraStackFrame(null);\n-                                }\n-                            }\n-                        }\n-                        var propTypesMisspellWarningShown;\n-                        {\n-                            propTypesMisspellWarningShown = false;\n-                        }\n-                        /**\n-                         * Verifies the object is a ReactElement.\n-                         * See https://reactjs.org/docs/react-api.html#isvalidelement\n-                         * @param {?object} object\n-                         * @return {boolean} True if `object` is a ReactElement.\n-                         * @final\n-                         */\n \n-                        function isValidElement(object) {\n-                            {\n-                                return typeof object === 'object' && object !== null && object.$$typeof === REACT_ELEMENT_TYPE;\n-                            }\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.warning = exports.invariant = void 0;\n+                var warning = function() {};\n+                exports.warning = warning;\n+                var invariant = function() {};\n+                exports.invariant = invariant;\n+                if (true) {\n+                    exports.warning = warning = function(check, message) {\n+                        if (!check && typeof console !== 'undefined') {\n+                            console.warn(message);\n                         }\n-\n-                        function getDeclarationErrorAddendum() {\n-                            {\n-                                if (ReactCurrentOwner$1.current) {\n-                                    var name = getComponentNameFromType(ReactCurrentOwner$1.current.type);\n-                                    if (name) {\n-                                        return '\\n\\nCheck the render method of `' + name + '`.';\n-                                    }\n-                                }\n-                                return '';\n-                            }\n+                    };\n+                    exports.invariant = invariant = function(check, message) {\n+                        if (!check) {\n+                            throw new Error(message);\n                         }\n+                    };\n+                }\n \n-                        function getSourceInfoErrorAddendum(source) {\n-                            {\n-                                if (source !== undefined) {\n-                                    var fileName = source.fileName.replace(/^.*[\\\\\\/]/, '');\n-                                    var lineNumber = source.lineNumber;\n-                                    return '\\n\\nCheck your code at ' + fileName + ':' + lineNumber + '.';\n-                                }\n-                                return '';\n-                            }\n-                        }\n-                        /**\n-                         * Warn if there's no key explicitly set on dynamic arrays of children or\n-                         * object keys are not valid. This allows us to keep track of children between\n-                         * updates.\n-                         */\n+                /***/\n+            }),\n \n-                        var ownerHasKeyUseWarning = {};\n+        /***/\n+        \"../../../node_modules/is-plain-object/index.js\":\n+            /*!******************************************************!*\\\n+              !*** ../../../node_modules/is-plain-object/index.js ***!\n+              \\******************************************************/\n+            /***/\n+            (function(module, __unused_webpack_exports, __webpack_require__) {\n \n-                        function getCurrentComponentErrorInfo(parentType) {\n-                            {\n-                                var info = getDeclarationErrorAddendum();\n-                                if (!info) {\n-                                    var parentName = typeof parentType === 'string' ? parentType : parentType.displayName || parentType.name;\n-                                    if (parentName) {\n-                                        info = \"\\n\\nCheck the top-level render call using <\" + parentName + \">.\";\n-                                    }\n-                                }\n-                                return info;\n-                            }\n-                        }\n-                        /**\n-                         * Warn if the element doesn't have an explicit key assigned to it.\n-                         * This element is in an array. The array could grow and shrink or be\n-                         * reordered. All children that haven't already been validated are required to\n-                         * have a \"key\" property assigned to it. Error statuses are cached so a warning\n-                         * will only be shown once.\n-                         *\n-                         * @internal\n-                         * @param {ReactElement} element Element that requires a key.\n-                         * @param {*} parentType element's parent's type.\n-                         */\n+                \"use strict\";\n+                /*!\n+                 * is-plain-object <https://github.com/jonschlinkert/is-plain-object>\n+                 *\n+                 * Copyright (c) 2014-2017, Jon Schlinkert.\n+                 * Released under the MIT License.\n+                 */\n \n-                        function validateExplicitKey(element, parentType) {\n-                            {\n-                                if (!element._store || element._store.validated || element.key != null) {\n-                                    return;\n-                                }\n-                                element._store.validated = true;\n-                                var currentComponentErrorInfo = getCurrentComponentErrorInfo(parentType);\n-                                if (ownerHasKeyUseWarning[currentComponentErrorInfo]) {\n-                                    return;\n-                                }\n-                                ownerHasKeyUseWarning[currentComponentErrorInfo] = true; // Usually the current owner is the offender, but if it accepts children as a\n-                                // property, it may be the creator of the child that's responsible for\n-                                // assigning it a key.\n \n-                                var childOwner = '';\n-                                if (element && element._owner && element._owner !== ReactCurrentOwner$1.current) {\n-                                    // Give the component that originally created this child.\n-                                    childOwner = \" It was passed a child from \" + getComponentNameFromType(element._owner.type) + \".\";\n-                                }\n-                                setCurrentlyValidatingElement$1(element);\n-                                error('Each child in a list should have a unique \"key\" prop.' + '%s%s See https://reactjs.org/link/warning-keys for more information.', currentComponentErrorInfo, childOwner);\n-                                setCurrentlyValidatingElement$1(null);\n-                            }\n-                        }\n-                        /**\n-                         * Ensure that every element either is passed in a static location, in an\n-                         * array with an explicit keys property defined, or in an object literal\n-                         * with valid key property.\n-                         *\n-                         * @internal\n-                         * @param {ReactNode} node Statically passed child of any type.\n-                         * @param {*} parentType node's parent's type.\n-                         */\n \n-                        function validateChildKeys(node, parentType) {\n-                            {\n-                                if (typeof node !== 'object') {\n-                                    return;\n-                                }\n-                                if (isArray(node)) {\n-                                    for (var i = 0; i < node.length; i++) {\n-                                        var child = node[i];\n-                                        if (isValidElement(child)) {\n-                                            validateExplicitKey(child, parentType);\n-                                        }\n-                                    }\n-                                } else if (isValidElement(node)) {\n-                                    // This element was passed in a valid location.\n-                                    if (node._store) {\n-                                        node._store.validated = true;\n-                                    }\n-                                } else if (node) {\n-                                    var iteratorFn = getIteratorFn(node);\n-                                    if (typeof iteratorFn === 'function') {\n-                                        // Entry iterators used to provide implicit keys,\n-                                        // but now we print a separate warning for them later.\n-                                        if (iteratorFn !== node.entries) {\n-                                            var iterator = iteratorFn.call(node);\n-                                            var step;\n-                                            while (!(step = iterator.next()).done) {\n-                                                if (isValidElement(step.value)) {\n-                                                    validateExplicitKey(step.value, parentType);\n-                                                }\n-                                            }\n-                                        }\n-                                    }\n-                                }\n-                            }\n-                        }\n-                        /**\n-                         * Given an element, validate that its props follow the propTypes definition,\n-                         * provided by the type.\n-                         *\n-                         * @param {ReactElement} element\n-                         */\n+                var isObject = __webpack_require__( /*! isobject */ \"../../../node_modules/isobject/index.js\");\n \n-                        function validatePropTypes(element) {\n-                            {\n-                                var type = element.type;\n-                                if (type === null || type === undefined || typeof type === 'string') {\n-                                    return;\n-                                }\n-                                var propTypes;\n-                                if (typeof type === 'function') {\n-                                    propTypes = type.propTypes;\n-                                } else if (typeof type === 'object' && (type.$$typeof === REACT_FORWARD_REF_TYPE ||\n-                                        // Note: Memo only checks outer props here.\n-                                        // Inner props are checked in the reconciler.\n-                                        type.$$typeof === REACT_MEMO_TYPE)) {\n-                                    propTypes = type.propTypes;\n-                                } else {\n-                                    return;\n-                                }\n-                                if (propTypes) {\n-                                    // Intentionally inside to avoid triggering lazy initializers:\n-                                    var name = getComponentNameFromType(type);\n-                                    checkPropTypes(propTypes, element.props, 'prop', name, element);\n-                                } else if (type.PropTypes !== undefined && !propTypesMisspellWarningShown) {\n-                                    propTypesMisspellWarningShown = true; // Intentionally inside to avoid triggering lazy initializers:\n+                function isObjectObject(o) {\n+                    return isObject(o) === true && Object.prototype.toString.call(o) === '[object Object]';\n+                }\n+                module.exports = function isPlainObject(o) {\n+                    var ctor, prot;\n+                    if (isObjectObject(o) === false) return false;\n \n-                                    var _name = getComponentNameFromType(type);\n-                                    error('Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?', _name || 'Unknown');\n-                                }\n-                                if (typeof type.getDefaultProps === 'function' && !type.getDefaultProps.isReactClassApproved) {\n-                                    error('getDefaultProps is only used on classic React.createClass ' + 'definitions. Use a static property named `defaultProps` instead.');\n-                                }\n-                            }\n-                        }\n-                        /**\n-                         * Given a fragment, validate that it can only be provided with fragment props\n-                         * @param {ReactElement} fragment\n-                         */\n+                    // If has modified constructor\n+                    ctor = o.constructor;\n+                    if (typeof ctor !== 'function') return false;\n \n-                        function validateFragmentProps(fragment) {\n-                            {\n-                                var keys = Object.keys(fragment.props);\n-                                for (var i = 0; i < keys.length; i++) {\n-                                    var key = keys[i];\n-                                    if (key !== 'children' && key !== 'key') {\n-                                        setCurrentlyValidatingElement$1(fragment);\n-                                        error('Invalid prop `%s` supplied to `React.Fragment`. ' + 'React.Fragment can only have `key` and `children` props.', key);\n-                                        setCurrentlyValidatingElement$1(null);\n-                                        break;\n-                                    }\n-                                }\n-                                if (fragment.ref !== null) {\n-                                    setCurrentlyValidatingElement$1(fragment);\n-                                    error('Invalid attribute `ref` supplied to `React.Fragment`.');\n-                                    setCurrentlyValidatingElement$1(null);\n-                                }\n-                            }\n-                        }\n+                    // If has modified prototype\n+                    prot = ctor.prototype;\n+                    if (isObjectObject(prot) === false) return false;\n \n-                        function jsxWithValidation(type, props, key, isStaticChildren, source, self) {\n-                            {\n-                                var validType = isValidElementType(type); // We warn in this case but don't throw. We expect the element creation to\n-                                // succeed and there will likely be errors in render.\n+                    // If constructor does not have an Object-specific method\n+                    if (prot.hasOwnProperty('isPrototypeOf') === false) {\n+                        return false;\n+                    }\n \n-                                if (!validType) {\n-                                    var info = '';\n-                                    if (type === undefined || typeof type === 'object' && type !== null && Object.keys(type).length === 0) {\n-                                        info += ' You likely forgot to export your component from the file ' + \"it's defined in, or you might have mixed up default and named imports.\";\n-                                    }\n-                                    var sourceInfo = getSourceInfoErrorAddendum(source);\n-                                    if (sourceInfo) {\n-                                        info += sourceInfo;\n-                                    } else {\n-                                        info += getDeclarationErrorAddendum();\n-                                    }\n-                                    var typeString;\n-                                    if (type === null) {\n-                                        typeString = 'null';\n-                                    } else if (isArray(type)) {\n-                                        typeString = 'array';\n-                                    } else if (type !== undefined && type.$$typeof === REACT_ELEMENT_TYPE) {\n-                                        typeString = \"<\" + (getComponentNameFromType(type.type) || 'Unknown') + \" />\";\n-                                        info = ' Did you accidentally export a JSX literal instead of a component?';\n-                                    } else {\n-                                        typeString = typeof type;\n-                                    }\n-                                    error('React.jsx: type is invalid -- expected a string (for ' + 'built-in components) or a class/function (for composite ' + 'components) but got: %s.%s', typeString, info);\n-                                }\n-                                var element = jsxDEV(type, props, key, source, self); // The result can be nullish if a mock or a custom function is used.\n-                                // TODO: Drop this when these are no longer allowed as the type argument.\n+                    // Most likely a plain Object\n+                    return true;\n+                };\n \n-                                if (element == null) {\n-                                    return element;\n-                                } // Skip key warning if the type isn't valid since our key validation logic\n-                                // doesn't expect a non-string/function type and can throw confusing errors.\n-                                // We don't want exception behavior to differ between dev and prod.\n-                                // (Rendering will throw with a helpful message and as soon as the type is\n-                                // fixed, the key warnings will appear.)\n+                /***/\n+            }),\n \n-                                if (validType) {\n-                                    var children = props.children;\n-                                    if (children !== undefined) {\n-                                        if (isStaticChildren) {\n-                                            if (isArray(children)) {\n-                                                for (var i = 0; i < children.length; i++) {\n-                                                    validateChildKeys(children[i], type);\n-                                                }\n-                                                if (Object.freeze) {\n-                                                    Object.freeze(children);\n-                                                }\n-                                            } else {\n-                                                error('React.jsx: Static children should always be an array. ' + 'You are likely explicitly calling React.jsxs or React.jsxDEV. ' + 'Use the Babel transform instead.');\n-                                            }\n-                                        } else {\n-                                            validateChildKeys(children, type);\n-                                        }\n-                                    }\n-                                }\n-                                if (type === REACT_FRAGMENT_TYPE) {\n-                                    validateFragmentProps(element);\n-                                } else {\n-                                    validatePropTypes(element);\n-                                }\n-                                return element;\n-                            }\n-                        } // These two functions exist to still get child warnings in dev\n-                        // even with the prod transform. This means that jsxDEV is purely\n-                        // opt-in behavior for better messages but that we won't stop\n-                        // giving you warnings if you use production apis.\n+        /***/\n+        \"../../../node_modules/is-primitive/index.js\":\n+            /*!***************************************************!*\\\n+              !*** ../../../node_modules/is-primitive/index.js ***!\n+              \\***************************************************/\n+            /***/\n+            (function(module) {\n \n-                        function jsxWithValidationStatic(type, props, key) {\n-                            {\n-                                return jsxWithValidation(type, props, key, true);\n-                            }\n-                        }\n+                \"use strict\";\n+                /*!\n+                 * is-primitive <https://github.com/jonschlinkert/is-primitive>\n+                 *\n+                 * Copyright (c) 2014-present, Jon Schlinkert.\n+                 * Released under the MIT License.\n+                 */\n \n-                        function jsxWithValidationDynamic(type, props, key) {\n-                            {\n-                                return jsxWithValidation(type, props, key, false);\n-                            }\n-                        }\n-                        var jsx = jsxWithValidationDynamic; // we may want to special case jsxs internally to take advantage of static children.\n-                        // for now we can ship identical prod functions\n \n-                        var jsxs = jsxWithValidationStatic;\n-                        exports.Fragment = REACT_FRAGMENT_TYPE;\n-                        exports.jsx = jsx;\n-                        exports.jsxs = jsxs;\n-                    })();\n-                }\n+\n+                module.exports = function isPrimitive(val) {\n+                    if (typeof val === 'object') {\n+                        return val === null;\n+                    }\n+                    return typeof val !== 'function';\n+                };\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/react/jsx-runtime.js\":\n-            /*!**************************************************!*\\\n-              !*** ../../../node_modules/react/jsx-runtime.js ***!\n-              \\**************************************************/\n+        \"../../../node_modules/isarray/index.js\":\n+            /*!**********************************************!*\\\n+              !*** ../../../node_modules/isarray/index.js ***!\n+              \\**********************************************/\n             /***/\n-            (function(module, __unused_webpack_exports, __webpack_require__) {\n+            (function(module) {\n \n+                \"use strict\";\n \n \n-                if (false) {} else {\n-                    module.exports = __webpack_require__( /*! ./cjs/react-jsx-runtime.development.js */ \"../../../node_modules/react/cjs/react-jsx-runtime.development.js\");\n-                }\n+                var toString = {}.toString;\n+                module.exports = Array.isArray || function(arr) {\n+                    return toString.call(arr) == '[object Array]';\n+                };\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/set-value/index.js\":\n-            /*!************************************************!*\\\n-              !*** ../../../node_modules/set-value/index.js ***!\n-              \\************************************************/\n+        \"../../../node_modules/isobject/index.js\":\n+            /*!***********************************************!*\\\n+              !*** ../../../node_modules/isobject/index.js ***!\n+              \\***********************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n                 /*!\n-                 * set-value <https://github.com/jonschlinkert/set-value>\n+                 * isobject <https://github.com/jonschlinkert/isobject>\n                  *\n-                 * Copyright (c) Jon Schlinkert (https://github.com/jonschlinkert).\n-                 * Released under the MIT License.\n+                 * Copyright (c) 2014-2015, Jon Schlinkert.\n+                 * Licensed under the MIT License.\n                  */\n \n \n \n-                const {\n-                    deleteProperty\n-                } = Reflect;\n-                const isPrimitive = __webpack_require__( /*! is-primitive */ \"../../../node_modules/is-primitive/index.js\");\n-                const isPlainObject = __webpack_require__( /*! is-plain-object */ \"../../../node_modules/is-plain-object/index.js\");\n-                const isObject = value => {\n-                    return typeof value === 'object' && value !== null || typeof value === 'function';\n-                };\n-                const isUnsafeKey = key => {\n-                    return key === '__proto__' || key === 'constructor' || key === 'prototype';\n-                };\n-                const validateKey = key => {\n-                    if (!isPrimitive(key)) {\n-                        throw new TypeError('Object keys must be strings or symbols');\n-                    }\n-                    if (isUnsafeKey(key)) {\n-                        throw new Error(`Cannot set unsafe key: \"${key}\"`);\n-                    }\n-                };\n-                const toStringKey = input => {\n-                    return Array.isArray(input) ? input.flat().map(String).join(',') : input;\n-                };\n-                const createMemoKey = (input, options) => {\n-                    if (typeof input !== 'string' || !options) return input;\n-                    let key = input + ';';\n-                    if (options.arrays !== undefined) key += `arrays=${options.arrays};`;\n-                    if (options.separator !== undefined) key += `separator=${options.separator};`;\n-                    if (options.split !== undefined) key += `split=${options.split};`;\n-                    if (options.merge !== undefined) key += `merge=${options.merge};`;\n-                    if (options.preservePaths !== undefined) key += `preservePaths=${options.preservePaths};`;\n-                    return key;\n-                };\n-                const memoize = (input, options, fn) => {\n-                    const key = toStringKey(options ? createMemoKey(input, options) : input);\n-                    validateKey(key);\n-                    const value = setValue.cache.get(key) || fn();\n-                    setValue.cache.set(key, value);\n-                    return value;\n-                };\n-                const splitString = function(input) {\n-                    let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n-                    const sep = options.separator || '.';\n-                    const preserve = sep === '/' ? false : options.preservePaths;\n-                    if (typeof input === 'string' && preserve !== false && /\\//.test(input)) {\n-                        return [input];\n-                    }\n-                    const parts = [];\n-                    let part = '';\n-                    const push = part => {\n-                        let number;\n-                        if (part.trim() !== '' && Number.isInteger(number = Number(part))) {\n-                            parts.push(number);\n-                        } else {\n-                            parts.push(part);\n-                        }\n-                    };\n-                    for (let i = 0; i < input.length; i++) {\n-                        const value = input[i];\n-                        if (value === '\\\\') {\n-                            part += input[++i];\n-                            continue;\n-                        }\n-                        if (value === sep) {\n-                            push(part);\n-                            part = '';\n-                            continue;\n-                        }\n-                        part += value;\n-                    }\n-                    if (part) {\n-                        push(part);\n-                    }\n-                    return parts;\n-                };\n-                const split = (input, options) => {\n-                    if (options && typeof options.split === 'function') return options.split(input);\n-                    if (typeof input === 'symbol') return [input];\n-                    if (Array.isArray(input)) return input;\n-                    return memoize(input, options, () => splitString(input, options));\n-                };\n-                const assignProp = (obj, prop, value, options) => {\n-                    validateKey(prop);\n-\n-                    // Delete property when \"value\" is undefined\n-                    if (value === undefined) {\n-                        deleteProperty(obj, prop);\n-                    } else if (options && options.merge) {\n-                        const merge = options.merge === 'function' ? options.merge : Object.assign;\n-\n-                        // Only merge plain objects\n-                        if (merge && isPlainObject(obj[prop]) && isPlainObject(value)) {\n-                            obj[prop] = merge(obj[prop], value);\n-                        } else {\n-                            obj[prop] = value;\n-                        }\n-                    } else {\n-                        obj[prop] = value;\n-                    }\n-                    return obj;\n-                };\n-                const setValue = (target, path, value, options) => {\n-                    if (!path || !isObject(target)) return target;\n-                    const keys = split(path, options);\n-                    let obj = target;\n-                    for (let i = 0; i < keys.length; i++) {\n-                        const key = keys[i];\n-                        const next = keys[i + 1];\n-                        validateKey(key);\n-                        if (next === undefined) {\n-                            assignProp(obj, key, value, options);\n-                            break;\n-                        }\n-                        if (typeof next === 'number' && !Array.isArray(obj[key])) {\n-                            obj = obj[key] = [];\n-                            continue;\n-                        }\n-                        if (!isObject(obj[key])) {\n-                            obj[key] = {};\n-                        }\n-                        obj = obj[key];\n-                    }\n-                    return target;\n-                };\n-                setValue.split = split;\n-                setValue.cache = new Map();\n-                setValue.clear = () => {\n-                    setValue.cache = new Map();\n+                var isArray = __webpack_require__( /*! isarray */ \"../../../node_modules/isarray/index.js\");\n+                module.exports = function isObject(val) {\n+                    return val != null && typeof val === 'object' && isArray(val) === false;\n                 };\n-                module.exports = setValue;\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../../node_modules/style-value-types/dist/valueTypes.cjs.js\":\n-            /*!**********************************************************************!*\\\n-              !*** ../../../node_modules/style-value-types/dist/valueTypes.cjs.js ***!\n-              \\**********************************************************************/\n+        \"../../../node_modules/linkify-it/build/index.cjs.js\":\n+            /*!***********************************************************!*\\\n+              !*** ../../../node_modules/linkify-it/build/index.cjs.js ***!\n+              \\***********************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports) {\n+            (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                const clamp = (min, max) => v => Math.max(Math.min(v, max), min);\n-                const sanitize = v => v % 1 ? Number(v.toFixed(5)) : v;\n-                const floatRegex = /(-)?([\\d]*\\.?[\\d])+/g;\n-                const colorRegex = /(#[0-9a-f]{6}|#[0-9a-f]{3}|#(?:[0-9a-f]{2}){2,4}|(rgb|hsl)a?\\((-?[\\d\\.]+%?[,\\s]+){2,3}\\s*\\/*\\s*[\\d\\.]+%?\\))/gi;\n-                const singleColorRegex = /^(#[0-9a-f]{3}|#(?:[0-9a-f]{2}){2,4}|(rgb|hsl)a?\\((-?[\\d\\.]+%?[,\\s]+){2,3}\\s*\\/*\\s*[\\d\\.]+%?\\))$/i;\n+                var uc_micro = __webpack_require__( /*! uc.micro */ \"../../../node_modules/uc.micro/build/index.cjs.js\");\n \n-                function isString(v) {\n-                    return typeof v === 'string';\n-                }\n-                const number = {\n-                    test: v => typeof v === 'number',\n-                    parse: parseFloat,\n-                    transform: v => v\n-                };\n-                const alpha = Object.assign(Object.assign({}, number), {\n-                    transform: clamp(0, 1)\n-                });\n-                const scale = Object.assign(Object.assign({}, number), {\n-                    default: 1\n-                });\n-                const createUnitType = unit => ({\n-                    test: v => isString(v) && v.endsWith(unit) && v.split(' ').length === 1,\n-                    parse: parseFloat,\n-                    transform: v => `${v}${unit}`\n-                });\n-                const degrees = createUnitType('deg');\n-                const percent = createUnitType('%');\n-                const px = createUnitType('px');\n-                const vh = createUnitType('vh');\n-                const vw = createUnitType('vw');\n-                const progressPercentage = Object.assign(Object.assign({}, percent), {\n-                    parse: v => percent.parse(v) / 100,\n-                    transform: v => percent.transform(v * 100)\n-                });\n-                const isColorString = (type, testProp) => v => {\n-                    return Boolean(isString(v) && singleColorRegex.test(v) && v.startsWith(type) || testProp && Object.prototype.hasOwnProperty.call(v, testProp));\n-                };\n-                const splitColor = (aName, bName, cName) => v => {\n-                    if (!isString(v)) return v;\n-                    const [a, b, c, alpha] = v.match(floatRegex);\n-                    return {\n-                        [aName]: parseFloat(a),\n-                        [bName]: parseFloat(b),\n-                        [cName]: parseFloat(c),\n-                        alpha: alpha !== undefined ? parseFloat(alpha) : 1\n-                    };\n-                };\n-                const hsla = {\n-                    test: isColorString('hsl', 'hue'),\n-                    parse: splitColor('hue', 'saturation', 'lightness'),\n-                    transform: _ref => {\n-                        let {\n-                            hue,\n-                            saturation,\n-                            lightness,\n-                            alpha: alpha$1 = 1\n-                        } = _ref;\n-                        return 'hsla(' + Math.round(hue) + ', ' + percent.transform(sanitize(saturation)) + ', ' + percent.transform(sanitize(lightness)) + ', ' + sanitize(alpha.transform(alpha$1)) + ')';\n-                    }\n-                };\n-                const clampRgbUnit = clamp(0, 255);\n-                const rgbUnit = Object.assign(Object.assign({}, number), {\n-                    transform: v => Math.round(clampRgbUnit(v))\n-                });\n-                const rgba = {\n-                    test: isColorString('rgb', 'red'),\n-                    parse: splitColor('red', 'green', 'blue'),\n-                    transform: _ref2 => {\n-                        let {\n-                            red,\n-                            green,\n-                            blue,\n-                            alpha: alpha$1 = 1\n-                        } = _ref2;\n-                        return 'rgba(' + rgbUnit.transform(red) + ', ' + rgbUnit.transform(green) + ', ' + rgbUnit.transform(blue) + ', ' + sanitize(alpha.transform(alpha$1)) + ')';\n-                    }\n-                };\n+                function reFactory(opts) {\n+                    const re = {};\n+                    opts = opts || {};\n+                    re.src_Any = uc_micro.Any.source;\n+                    re.src_Cc = uc_micro.Cc.source;\n+                    re.src_Z = uc_micro.Z.source;\n+                    re.src_P = uc_micro.P.source;\n \n-                function parseHex(v) {\n-                    let r = '';\n-                    let g = '';\n-                    let b = '';\n-                    let a = '';\n-                    if (v.length > 5) {\n-                        r = v.substr(1, 2);\n-                        g = v.substr(3, 2);\n-                        b = v.substr(5, 2);\n-                        a = v.substr(7, 2);\n-                    } else {\n-                        r = v.substr(1, 1);\n-                        g = v.substr(2, 1);\n-                        b = v.substr(3, 1);\n-                        a = v.substr(4, 1);\n-                        r += r;\n-                        g += g;\n-                        b += b;\n-                        a += a;\n-                    }\n-                    return {\n-                        red: parseInt(r, 16),\n-                        green: parseInt(g, 16),\n-                        blue: parseInt(b, 16),\n-                        alpha: a ? parseInt(a, 16) / 255 : 1\n-                    };\n+                    // \\p{\\Z\\P\\Cc\\CF} (white spaces + control + format + punctuation)\n+                    re.src_ZPCc = [re.src_Z, re.src_P, re.src_Cc].join('|');\n+\n+                    // \\p{\\Z\\Cc} (white spaces + control)\n+                    re.src_ZCc = [re.src_Z, re.src_Cc].join('|');\n+\n+                    // Experimental. List of chars, completely prohibited in links\n+                    // because can separate it from other part of text\n+                    const text_separators = '[><\\uff5c]';\n+\n+                    // All possible word characters (everything without punctuation, spaces & controls)\n+                    // Defined via punctuation & spaces to save space\n+                    // Should be something like \\p{\\L\\N\\S\\M} (\\w but without `_`)\n+                    re.src_pseudo_letter = '(?:(?!' + text_separators + '|' + re.src_ZPCc + ')' + re.src_Any + ')';\n+                    // The same as abothe but without [0-9]\n+                    // var src_pseudo_letter_non_d = '(?:(?![0-9]|' + src_ZPCc + ')' + src_Any + ')';\n+\n+                    re.src_ip4 = '(?:(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\\\.){3}(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)';\n+\n+                    // Prohibit any of \"@/[]()\" in user/pass to avoid wrong domain fetch.\n+                    re.src_auth = '(?:(?:(?!' + re.src_ZCc + '|[@/\\\\[\\\\]()]).)+@)?';\n+                    re.src_port = '(?::(?:6(?:[0-4]\\\\d{3}|5(?:[0-4]\\\\d{2}|5(?:[0-2]\\\\d|3[0-5])))|[1-5]?\\\\d{1,4}))?';\n+                    re.src_host_terminator = '(?=$|' + text_separators + '|' + re.src_ZPCc + ')' + '(?!' + (opts['---'] ? '-(?!--)|' : '-|') + '_|:\\\\d|\\\\.-|\\\\.(?!$|' + re.src_ZPCc + '))';\n+                    re.src_path = '(?:' + '[/?#]' + '(?:' + '(?!' + re.src_ZCc + '|' + text_separators + '|[()[\\\\]{}.,\"\\'?!\\\\-;]).|' + '\\\\[(?:(?!' + re.src_ZCc + '|\\\\]).)*\\\\]|' + '\\\\((?:(?!' + re.src_ZCc + '|[)]).)*\\\\)|' + '\\\\{(?:(?!' + re.src_ZCc + '|[}]).)*\\\\}|' + '\\\\\"(?:(?!' + re.src_ZCc + '|[\"]).)+\\\\\"|' + \"\\\\'(?:(?!\" + re.src_ZCc + \"|[']).)+\\\\'|\" +\n+                        // allow `I'm_king` if no pair found\n+                        \"\\\\'(?=\" + re.src_pseudo_letter + '|[-])|' +\n+                        // google has many dots in \"google search\" links (#66, #81).\n+                        // github has ... in commit range links,\n+                        // Restrict to\n+                        // - english\n+                        // - percent-encoded\n+                        // - parts of file path\n+                        // - params separator\n+                        // until more examples found.\n+                        '\\\\.{2,}[a-zA-Z0-9%/&]|' + '\\\\.(?!' + re.src_ZCc + '|[.]|$)|' + (opts['---'] ? '\\\\-(?!--(?:[^-]|$))(?:-*)|' // `---` => long dash, terminate\n+                            :\n+                            '\\\\-+|') +\n+                        // allow `,,,` in paths\n+                        ',(?!' + re.src_ZCc + '|$)|' +\n+                        // allow `;` if not followed by space-like char\n+                        ';(?!' + re.src_ZCc + '|$)|' +\n+                        // allow `!!!` in paths, but not at the end\n+                        '\\\\!+(?!' + re.src_ZCc + '|[!]|$)|' + '\\\\?(?!' + re.src_ZCc + '|[?]|$)' + ')+' + '|\\\\/' + ')?';\n+\n+                    // Allow anything in markdown spec, forbid quote (\") at the first position\n+                    // because emails enclosed in quotes are far more common\n+                    re.src_email_name = '[\\\\-;:&=\\\\+\\\\$,\\\\.a-zA-Z0-9_][\\\\-;:&=\\\\+\\\\$,\\\\\"\\\\.a-zA-Z0-9_]*';\n+                    re.src_xn = 'xn--[a-z0-9\\\\-]{1,59}';\n+\n+                    // More to read about domain names\n+                    // http://serverfault.com/questions/638260/\n+\n+                    re.src_domain_root =\n+                        // Allow letters & digits (http://test1)\n+                        '(?:' + re.src_xn + '|' + re.src_pseudo_letter + '{1,63}' + ')';\n+                    re.src_domain = '(?:' + re.src_xn + '|' + '(?:' + re.src_pseudo_letter + ')' + '|' + '(?:' + re.src_pseudo_letter + '(?:-|' + re.src_pseudo_letter + '){0,61}' + re.src_pseudo_letter + ')' + ')';\n+                    re.src_host = '(?:' +\n+                        // Don't need IP check, because digits are already allowed in normal domain names\n+                        //   src_ip4 +\n+                        // '|' +\n+                        '(?:(?:(?:' + re.src_domain + ')\\\\.)*' + re.src_domain /* _root */ + ')' + ')';\n+                    re.tpl_host_fuzzy = '(?:' + re.src_ip4 + '|' + '(?:(?:(?:' + re.src_domain + ')\\\\.)+(?:%TLDS%))' + ')';\n+                    re.tpl_host_no_ip_fuzzy = '(?:(?:(?:' + re.src_domain + ')\\\\.)+(?:%TLDS%))';\n+                    re.src_host_strict = re.src_host + re.src_host_terminator;\n+                    re.tpl_host_fuzzy_strict = re.tpl_host_fuzzy + re.src_host_terminator;\n+                    re.src_host_port_strict = re.src_host + re.src_port + re.src_host_terminator;\n+                    re.tpl_host_port_fuzzy_strict = re.tpl_host_fuzzy + re.src_port + re.src_host_terminator;\n+                    re.tpl_host_port_no_ip_fuzzy_strict = re.tpl_host_no_ip_fuzzy + re.src_port + re.src_host_terminator;\n+\n+                    //\n+                    // Main rules\n+                    //\n+\n+                    // Rude test fuzzy links by host, for quick deny\n+                    re.tpl_host_fuzzy_test = 'localhost|www\\\\.|\\\\.\\\\d{1,3}\\\\.|(?:\\\\.(?:%TLDS%)(?:' + re.src_ZPCc + '|>|$))';\n+                    re.tpl_email_fuzzy = '(^|' + text_separators + '|\"|\\\\(|' + re.src_ZCc + ')' + '(' + re.src_email_name + '@' + re.tpl_host_fuzzy_strict + ')';\n+                    re.tpl_link_fuzzy =\n+                        // Fuzzy link can't be prepended with .:/\\- and non punctuation.\n+                        // but can start with > (markdown blockquote)\n+                        '(^|(?![.:/\\\\-_@])(?:[$+<=>^`|\\uff5c]|' + re.src_ZPCc + '))' + '((?![$+<=>^`|\\uff5c])' + re.tpl_host_port_fuzzy_strict + re.src_path + ')';\n+                    re.tpl_link_no_ip_fuzzy =\n+                        // Fuzzy link can't be prepended with .:/\\- and non punctuation.\n+                        // but can start with > (markdown blockquote)\n+                        '(^|(?![.:/\\\\-_@])(?:[$+<=>^`|\\uff5c]|' + re.src_ZPCc + '))' + '((?![$+<=>^`|\\uff5c])' + re.tpl_host_port_no_ip_fuzzy_strict + re.src_path + ')';\n+                    return re;\n                 }\n-                const hex = {\n-                    test: isColorString('#'),\n-                    parse: parseHex,\n-                    transform: rgba.transform\n-                };\n-                const color = {\n-                    test: v => rgba.test(v) || hex.test(v) || hsla.test(v),\n-                    parse: v => {\n-                        if (rgba.test(v)) {\n-                            return rgba.parse(v);\n-                        } else if (hsla.test(v)) {\n-                            return hsla.parse(v);\n-                        } else {\n-                            return hex.parse(v);\n+\n+                //\n+                // Helpers\n+                //\n+\n+                // Merge objects\n+                //\n+                function assign(obj /* from1, from2, from3, ... */ ) {\n+                    const sources = Array.prototype.slice.call(arguments, 1);\n+                    sources.forEach(function(source) {\n+                        if (!source) {\n+                            return;\n                         }\n-                    },\n-                    transform: v => {\n-                        return isString(v) ? v : v.hasOwnProperty('red') ? rgba.transform(v) : hsla.transform(v);\n-                    }\n-                };\n-                const colorToken = '${c}';\n-                const numberToken = '${n}';\n+                        Object.keys(source).forEach(function(key) {\n+                            obj[key] = source[key];\n+                        });\n+                    });\n+                    return obj;\n+                }\n \n-                function test(v) {\n-                    var _a, _b, _c, _d;\n-                    return isNaN(v) && isString(v) && ((_b = (_a = v.match(floatRegex)) === null || _a === void 0 ? void 0 : _a.length) !== null && _b !== void 0 ? _b : 0) + ((_d = (_c = v.match(colorRegex)) === null || _c === void 0 ? void 0 : _c.length) !== null && _d !== void 0 ? _d : 0) > 0;\n+                function _class(obj) {\n+                    return Object.prototype.toString.call(obj);\n                 }\n \n-                function analyse(v) {\n-                    if (typeof v === 'number') v = `${v}`;\n-                    const values = [];\n-                    let numColors = 0;\n-                    const colors = v.match(colorRegex);\n-                    if (colors) {\n-                        numColors = colors.length;\n-                        v = v.replace(colorRegex, colorToken);\n-                        values.push(...colors.map(color.parse));\n-                    }\n-                    const numbers = v.match(floatRegex);\n-                    if (numbers) {\n-                        v = v.replace(floatRegex, numberToken);\n-                        values.push(...numbers.map(number.parse));\n-                    }\n-                    return {\n-                        values,\n-                        numColors,\n-                        tokenised: v\n-                    };\n+                function isString(obj) {\n+                    return _class(obj) === '[object String]';\n                 }\n \n-                function parse(v) {\n-                    return analyse(v).values;\n+                function isObject(obj) {\n+                    return _class(obj) === '[object Object]';\n                 }\n \n-                function createTransformer(v) {\n-                    const {\n-                        values,\n-                        numColors,\n-                        tokenised\n-                    } = analyse(v);\n-                    const numValues = values.length;\n-                    return v => {\n-                        let output = tokenised;\n-                        for (let i = 0; i < numValues; i++) {\n-                            output = output.replace(i < numColors ? colorToken : numberToken, i < numColors ? color.transform(v[i]) : sanitize(v[i]));\n-                        }\n-                        return output;\n-                    };\n+                function isRegExp(obj) {\n+                    return _class(obj) === '[object RegExp]';\n                 }\n-                const convertNumbersToZero = v => typeof v === 'number' ? 0 : v;\n \n-                function getAnimatableNone(v) {\n-                    const parsed = parse(v);\n-                    const transformer = createTransformer(v);\n-                    return transformer(parsed.map(convertNumbersToZero));\n+                function isFunction(obj) {\n+                    return _class(obj) === '[object Function]';\n                 }\n-                const complex = {\n-                    test,\n-                    parse,\n-                    createTransformer,\n-                    getAnimatableNone\n+\n+                function escapeRE(str) {\n+                    return str.replace(/[.?*+^$[\\]\\\\(){}|-]/g, '\\\\$&');\n+                }\n+\n+                //\n+\n+                const defaultOptions = {\n+                    fuzzyLink: true,\n+                    fuzzyEmail: true,\n+                    fuzzyIP: false\n                 };\n-                const maxDefaults = new Set(['brightness', 'contrast', 'saturate', 'opacity']);\n \n-                function applyDefaultFilter(v) {\n-                    let [name, value] = v.slice(0, -1).split('(');\n-                    if (name === 'drop-shadow') return v;\n-                    const [number] = value.match(floatRegex) || [];\n-                    if (!number) return v;\n-                    const unit = value.replace(number, '');\n-                    let defaultValue = maxDefaults.has(name) ? 1 : 0;\n-                    if (number !== value) defaultValue *= 100;\n-                    return name + '(' + defaultValue + unit + ')';\n+                function isOptionsObj(obj) {\n+                    return Object.keys(obj || {}).reduce(function(acc, k) {\n+                        /* eslint-disable-next-line no-prototype-builtins */\n+                        return acc || defaultOptions.hasOwnProperty(k);\n+                    }, false);\n                 }\n-                const functionRegex = /([a-z-]*)\\(.*?\\)/g;\n-                const filter = Object.assign(Object.assign({}, complex), {\n-                    getAnimatableNone: v => {\n-                        const functions = v.match(functionRegex);\n-                        return functions ? functions.map(applyDefaultFilter).join(' ') : v;\n+                const defaultSchemas = {\n+                    'http:': {\n+                        validate: function(text, pos, self) {\n+                            const tail = text.slice(pos);\n+                            if (!self.re.http) {\n+                                // compile lazily, because \"host\"-containing variables can change on tlds update.\n+                                self.re.http = new RegExp('^\\\\/\\\\/' + self.re.src_auth + self.re.src_host_port_strict + self.re.src_path, 'i');\n+                            }\n+                            if (self.re.http.test(tail)) {\n+                                return tail.match(self.re.http)[0].length;\n+                            }\n+                            return 0;\n+                        }\n+                    },\n+                    'https:': 'http:',\n+                    'ftp:': 'http:',\n+                    '//': {\n+                        validate: function(text, pos, self) {\n+                            const tail = text.slice(pos);\n+                            if (!self.re.no_http) {\n+                                // compile lazily, because \"host\"-containing variables can change on tlds update.\n+                                self.re.no_http = new RegExp('^' + self.re.src_auth +\n+                                    // Don't allow single-level domains, because of false positives like '//test'\n+                                    // with code comments\n+                                    '(?:localhost|(?:(?:' + self.re.src_domain + ')\\\\.)+' + self.re.src_domain_root + ')' + self.re.src_port + self.re.src_host_terminator + self.re.src_path, 'i');\n+                            }\n+                            if (self.re.no_http.test(tail)) {\n+                                // should not be `://` & `///`, that protects from errors in protocol name\n+                                if (pos >= 3 && text[pos - 3] === ':') {\n+                                    return 0;\n+                                }\n+                                if (pos >= 3 && text[pos - 3] === '/') {\n+                                    return 0;\n+                                }\n+                                return tail.match(self.re.no_http)[0].length;\n+                            }\n+                            return 0;\n+                        }\n+                    },\n+                    'mailto:': {\n+                        validate: function(text, pos, self) {\n+                            const tail = text.slice(pos);\n+                            if (!self.re.mailto) {\n+                                self.re.mailto = new RegExp('^' + self.re.src_email_name + '@' + self.re.src_host_strict, 'i');\n+                            }\n+                            if (self.re.mailto.test(tail)) {\n+                                return tail.match(self.re.mailto)[0].length;\n+                            }\n+                            return 0;\n+                        }\n                     }\n-                });\n-                exports.alpha = alpha;\n-                exports.color = color;\n-                exports.complex = complex;\n-                exports.degrees = degrees;\n-                exports.filter = filter;\n-                exports.hex = hex;\n-                exports.hsla = hsla;\n-                exports.number = number;\n-                exports.percent = percent;\n-                exports.progressPercentage = progressPercentage;\n-                exports.px = px;\n-                exports.rgbUnit = rgbUnit;\n-                exports.rgba = rgba;\n-                exports.scale = scale;\n-                exports.vh = vh;\n-                exports.vw = vw;\n-\n-                /***/\n-            }),\n+                };\n \n-        /***/\n-        \"../../../node_modules/toggle-selection/index.js\":\n-            /*!*******************************************************!*\\\n-              !*** ../../../node_modules/toggle-selection/index.js ***!\n-              \\*******************************************************/\n-            /***/\n-            (function(module) {\n+                // RE pattern for 2-character tlds (autogenerated by ./support/tlds_2char_gen.js)\n+                /* eslint-disable-next-line max-len */\n+                const tlds_2ch_src_re = 'a[cdefgilmnoqrstuwxz]|b[abdefghijmnorstvwyz]|c[acdfghiklmnoruvwxyz]|d[ejkmoz]|e[cegrstu]|f[ijkmor]|g[abdefghilmnpqrstuwy]|h[kmnrtu]|i[delmnoqrst]|j[emop]|k[eghimnprwyz]|l[abcikrstuvy]|m[acdeghklmnopqrstuvwxyz]|n[acefgilopruz]|om|p[aefghklmnrstwy]|qa|r[eosuw]|s[abcdeghijklmnortuvxyz]|t[cdfghjklmnortvwz]|u[agksyz]|v[aceginu]|w[fs]|y[et]|z[amw]';\n \n+                // DON'T try to make PRs with changes. Extend TLDs with LinkifyIt.tlds() instead\n+                const tlds_default = 'biz|com|edu|gov|net|org|pro|web|xxx|aero|asia|coop|info|museum|name|shop|\u0440\u0444'.split('|');\n \n+                function resetScanCache(self) {\n+                    self.__index__ = -1;\n+                    self.__text_cache__ = '';\n+                }\n \n-                module.exports = function() {\n-                    var selection = document.getSelection();\n-                    if (!selection.rangeCount) {\n-                        return function() {};\n-                    }\n-                    var active = document.activeElement;\n-                    var ranges = [];\n-                    for (var i = 0; i < selection.rangeCount; i++) {\n-                        ranges.push(selection.getRangeAt(i));\n-                    }\n-                    switch (active.tagName.toUpperCase()) {\n-                        // .toUpperCase handles XHTML\n-                        case 'INPUT':\n-                        case 'TEXTAREA':\n-                            active.blur();\n-                            break;\n-                        default:\n-                            active = null;\n-                            break;\n-                    }\n-                    selection.removeAllRanges();\n-                    return function() {\n-                        selection.type === 'Caret' && selection.removeAllRanges();\n-                        if (!selection.rangeCount) {\n-                            ranges.forEach(function(range) {\n-                                selection.addRange(range);\n-                            });\n+                function createValidator(re) {\n+                    return function(text, pos) {\n+                        const tail = text.slice(pos);\n+                        if (re.test(tail)) {\n+                            return tail.match(re)[0].length;\n                         }\n-                        active && active.focus();\n+                        return 0;\n                     };\n-                };\n-\n-                /***/\n-            }),\n+                }\n \n-        /***/\n-        \"../../../node_modules/tslib/tslib.es6.js\":\n-            /*!************************************************!*\\\n-              !*** ../../../node_modules/tslib/tslib.es6.js ***!\n-              \\************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports) {\n+                function createNormalizer() {\n+                    return function(match, self) {\n+                        self.normalize(match);\n+                    };\n+                }\n \n+                // Schemas compiler. Build regexps.\n+                //\n+                function compile(self) {\n+                    // Load & clone RE patterns.\n+                    const re = self.re = reFactory(self.__opts__);\n \n+                    // Define dynamic patterns\n+                    const tlds = self.__tlds__.slice();\n+                    self.onCompile();\n+                    if (!self.__tlds_replaced__) {\n+                        tlds.push(tlds_2ch_src_re);\n+                    }\n+                    tlds.push(re.src_xn);\n+                    re.src_tlds = tlds.join('|');\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.__assign = void 0;\n-                exports.__asyncDelegator = __asyncDelegator;\n-                exports.__asyncGenerator = __asyncGenerator;\n-                exports.__asyncValues = __asyncValues;\n-                exports.__await = __await;\n-                exports.__awaiter = __awaiter;\n-                exports.__classPrivateFieldGet = __classPrivateFieldGet;\n-                exports.__classPrivateFieldIn = __classPrivateFieldIn;\n-                exports.__classPrivateFieldSet = __classPrivateFieldSet;\n-                exports.__createBinding = void 0;\n-                exports.__decorate = __decorate;\n-                exports.__exportStar = __exportStar;\n-                exports.__extends = __extends;\n-                exports.__generator = __generator;\n-                exports.__importDefault = __importDefault;\n-                exports.__importStar = __importStar;\n-                exports.__makeTemplateObject = __makeTemplateObject;\n-                exports.__metadata = __metadata;\n-                exports.__param = __param;\n-                exports.__read = __read;\n-                exports.__rest = __rest;\n-                exports.__spread = __spread;\n-                exports.__spreadArray = __spreadArray;\n-                exports.__spreadArrays = __spreadArrays;\n-                exports.__values = __values;\n-                /******************************************************************************\n-                Copyright (c) Microsoft Corporation.\n+                    function untpl(tpl) {\n+                        return tpl.replace('%TLDS%', re.src_tlds);\n+                    }\n+                    re.email_fuzzy = RegExp(untpl(re.tpl_email_fuzzy), 'i');\n+                    re.link_fuzzy = RegExp(untpl(re.tpl_link_fuzzy), 'i');\n+                    re.link_no_ip_fuzzy = RegExp(untpl(re.tpl_link_no_ip_fuzzy), 'i');\n+                    re.host_fuzzy_test = RegExp(untpl(re.tpl_host_fuzzy_test), 'i');\n \n-                Permission to use, copy, modify, and/or distribute this software for any\n-                purpose with or without fee is hereby granted.\n+                    //\n+                    // Compile each schema\n+                    //\n \n-                THE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\n-                REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\n-                AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\n-                INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\n-                LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\n-                OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\n-                PERFORMANCE OF THIS SOFTWARE.\n-                ***************************************************************************** */\n-                /* global Reflect, Promise */\n+                    const aliases = [];\n+                    self.__compiled__ = {}; // Reset compiled data\n \n-                var extendStatics = function(d, b) {\n-                    extendStatics = Object.setPrototypeOf || {\n-                        __proto__: []\n+                    function schemaError(name, val) {\n+                        throw new Error('(LinkifyIt) Invalid schema \"' + name + '\": ' + val);\n                     }\n-                    instanceof Array && function(d, b) {\n-                        d.__proto__ = b;\n-                    } || function(d, b) {\n-                        for (var p in b)\n-                            if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];\n-                    };\n-                    return extendStatics(d, b);\n-                };\n+                    Object.keys(self.__schemas__).forEach(function(name) {\n+                        const val = self.__schemas__[name];\n \n-                function __extends(d, b) {\n-                    if (typeof b !== \"function\" && b !== null) throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n-                    extendStatics(d, b);\n+                        // skip disabled methods\n+                        if (val === null) {\n+                            return;\n+                        }\n+                        const compiled = {\n+                            validate: null,\n+                            link: null\n+                        };\n+                        self.__compiled__[name] = compiled;\n+                        if (isObject(val)) {\n+                            if (isRegExp(val.validate)) {\n+                                compiled.validate = createValidator(val.validate);\n+                            } else if (isFunction(val.validate)) {\n+                                compiled.validate = val.validate;\n+                            } else {\n+                                schemaError(name, val);\n+                            }\n+                            if (isFunction(val.normalize)) {\n+                                compiled.normalize = val.normalize;\n+                            } else if (!val.normalize) {\n+                                compiled.normalize = createNormalizer();\n+                            } else {\n+                                schemaError(name, val);\n+                            }\n+                            return;\n+                        }\n+                        if (isString(val)) {\n+                            aliases.push(name);\n+                            return;\n+                        }\n+                        schemaError(name, val);\n+                    });\n \n-                    function __() {\n-                        this.constructor = d;\n-                    }\n-                    d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n-                }\n-                var __assign = function() {\n-                    exports.__assign = __assign = Object.assign || function __assign(t) {\n-                        for (var s, i = 1, n = arguments.length; i < n; i++) {\n-                            s = arguments[i];\n-                            for (var p in s)\n-                                if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n+                    //\n+                    // Compile postponed aliases\n+                    //\n+\n+                    aliases.forEach(function(alias) {\n+                        if (!self.__compiled__[self.__schemas__[alias]]) {\n+                            // Silently fail on missed schemas to avoid errons on disable.\n+                            // schemaError(alias, self.__schemas__[alias]);\n+                            return;\n                         }\n-                        return t;\n+                        self.__compiled__[alias].validate = self.__compiled__[self.__schemas__[alias]].validate;\n+                        self.__compiled__[alias].normalize = self.__compiled__[self.__schemas__[alias]].normalize;\n+                    });\n+\n+                    //\n+                    // Fake record for guessed links\n+                    //\n+                    self.__compiled__[''] = {\n+                        validate: null,\n+                        normalize: createNormalizer()\n                     };\n-                    return __assign.apply(this, arguments);\n-                };\n-                exports.__assign = __assign;\n \n-                function __rest(s, e) {\n-                    var t = {};\n-                    for (var p in s)\n-                        if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];\n-                    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n-                        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n-                            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];\n-                        }\n-                    return t;\n-                }\n+                    //\n+                    // Build schema condition\n+                    //\n+                    const slist = Object.keys(self.__compiled__).filter(function(name) {\n+                        // Filter disabled & fake schemas\n+                        return name.length > 0 && self.__compiled__[name];\n+                    }).map(escapeRE).join('|');\n+                    // (?!_) cause 1.5x slowdown\n+                    self.re.schema_test = RegExp('(^|(?!_)(?:[><\\uff5c]|' + re.src_ZPCc + '))(' + slist + ')', 'i');\n+                    self.re.schema_search = RegExp('(^|(?!_)(?:[><\\uff5c]|' + re.src_ZPCc + '))(' + slist + ')', 'ig');\n+                    self.re.schema_at_start = RegExp('^' + self.re.schema_search.source, 'i');\n+                    self.re.pretest = RegExp('(' + self.re.schema_test.source + ')|(' + self.re.host_fuzzy_test.source + ')|@', 'i');\n \n-                function __decorate(decorators, target, key, desc) {\n-                    var c = arguments.length,\n-                        r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc,\n-                        d;\n-                    if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n-                    else\n-                        for (var i = decorators.length - 1; i >= 0; i--)\n-                            if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n-                    return c > 3 && r && Object.defineProperty(target, key, r), r;\n+                    //\n+                    // Cleanup\n+                    //\n+\n+                    resetScanCache(self);\n                 }\n \n-                function __param(paramIndex, decorator) {\n-                    return function(target, key) {\n-                        decorator(target, key, paramIndex);\n-                    };\n+                /**\n+                 * class Match\n+                 *\n+                 * Match result. Single element of array, returned by [[LinkifyIt#match]]\n+                 **/\n+                function Match(self, shift) {\n+                    const start = self.__index__;\n+                    const end = self.__last_index__;\n+                    const text = self.__text_cache__.slice(start, end);\n+\n+                    /**\n+                     * Match#schema -> String\n+                     *\n+                     * Prefix (protocol) for matched string.\n+                     **/\n+                    this.schema = self.__schema__.toLowerCase();\n+                    /**\n+                     * Match#index -> Number\n+                     *\n+                     * First position of matched string.\n+                     **/\n+                    this.index = start + shift;\n+                    /**\n+                     * Match#lastIndex -> Number\n+                     *\n+                     * Next position after matched string.\n+                     **/\n+                    this.lastIndex = end + shift;\n+                    /**\n+                     * Match#raw -> String\n+                     *\n+                     * Matched string.\n+                     **/\n+                    this.raw = text;\n+                    /**\n+                     * Match#text -> String\n+                     *\n+                     * Notmalized text of matched string.\n+                     **/\n+                    this.text = text;\n+                    /**\n+                     * Match#url -> String\n+                     *\n+                     * Normalized url of matched string.\n+                     **/\n+                    this.url = text;\n                 }\n \n-                function __metadata(metadataKey, metadataValue) {\n-                    if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\n+                function createMatch(self, shift) {\n+                    const match = new Match(self, shift);\n+                    self.__compiled__[match.schema].normalize(match, self);\n+                    return match;\n                 }\n \n-                function __awaiter(thisArg, _arguments, P, generator) {\n-                    function adopt(value) {\n-                        return value instanceof P ? value : new P(function(resolve) {\n-                            resolve(value);\n-                        });\n-                    }\n-                    return new(P || (P = Promise))(function(resolve, reject) {\n-                        function fulfilled(value) {\n-                            try {\n-                                step(generator.next(value));\n-                            } catch (e) {\n-                                reject(e);\n-                            }\n-                        }\n+                /**\n+                 * class LinkifyIt\n+                 **/\n \n-                        function rejected(value) {\n-                            try {\n-                                step(generator[\"throw\"](value));\n-                            } catch (e) {\n-                                reject(e);\n-                            }\n+                /**\n+                 * new LinkifyIt(schemas, options)\n+                 * - schemas (Object): Optional. Additional schemas to validate (prefix/validator)\n+                 * - options (Object): { fuzzyLink|fuzzyEmail|fuzzyIP: true|false }\n+                 *\n+                 * Creates new linkifier instance with optional additional schemas.\n+                 * Can be called without `new` keyword for convenience.\n+                 *\n+                 * By default understands:\n+                 *\n+                 * - `http(s)://...` , `ftp://...`, `mailto:...` & `//...` links\n+                 * - \"fuzzy\" links and emails (example.com, foo@bar.com).\n+                 *\n+                 * `schemas` is an object, where each key/value describes protocol/rule:\n+                 *\n+                 * - __key__ - link prefix (usually, protocol name with `:` at the end, `skype:`\n+                 *   for example). `linkify-it` makes shure that prefix is not preceeded with\n+                 *   alphanumeric char and symbols. Only whitespaces and punctuation allowed.\n+                 * - __value__ - rule to check tail after link prefix\n+                 *   - _String_ - just alias to existing rule\n+                 *   - _Object_\n+                 *     - _validate_ - validator function (should return matched length on success),\n+                 *       or `RegExp`.\n+                 *     - _normalize_ - optional function to normalize text & url of matched result\n+                 *       (for example, for @twitter mentions).\n+                 *\n+                 * `options`:\n+                 *\n+                 * - __fuzzyLink__ - recognige URL-s without `http(s):` prefix. Default `true`.\n+                 * - __fuzzyIP__ - allow IPs in fuzzy links above. Can conflict with some texts\n+                 *   like version numbers. Default `false`.\n+                 * - __fuzzyEmail__ - recognize emails without `mailto:` prefix.\n+                 *\n+                 **/\n+                function LinkifyIt(schemas, options) {\n+                    if (!(this instanceof LinkifyIt)) {\n+                        return new LinkifyIt(schemas, options);\n+                    }\n+                    if (!options) {\n+                        if (isOptionsObj(schemas)) {\n+                            options = schemas;\n+                            schemas = {};\n                         }\n+                    }\n+                    this.__opts__ = assign({}, defaultOptions, options);\n \n-                        function step(result) {\n-                            result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n-                        }\n-                        step((generator = generator.apply(thisArg, _arguments || [])).next());\n-                    });\n+                    // Cache last tested result. Used to skip repeating steps on next `match` call.\n+                    this.__index__ = -1;\n+                    this.__last_index__ = -1; // Next scan position\n+                    this.__schema__ = '';\n+                    this.__text_cache__ = '';\n+                    this.__schemas__ = assign({}, defaultSchemas, schemas);\n+                    this.__compiled__ = {};\n+                    this.__tlds__ = tlds_default;\n+                    this.__tlds_replaced__ = false;\n+                    this.re = {};\n+                    compile(this);\n                 }\n \n-                function __generator(thisArg, body) {\n-                    var _ = {\n-                            label: 0,\n-                            sent: function() {\n-                                if (t[0] & 1) throw t[1];\n-                                return t[1];\n-                            },\n-                            trys: [],\n-                            ops: []\n-                        },\n-                        f,\n-                        y,\n-                        t,\n-                        g;\n-                    return g = {\n-                        next: verb(0),\n-                        \"throw\": verb(1),\n-                        \"return\": verb(2)\n-                    }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() {\n-                        return this;\n-                    }), g;\n+                /** chainable\n+                 * LinkifyIt#add(schema, definition)\n+                 * - schema (String): rule name (fixed pattern prefix)\n+                 * - definition (String|RegExp|Object): schema definition\n+                 *\n+                 * Add new rule definition. See constructor description for details.\n+                 **/\n+                LinkifyIt.prototype.add = function add(schema, definition) {\n+                    this.__schemas__[schema] = definition;\n+                    compile(this);\n+                    return this;\n+                };\n \n-                    function verb(n) {\n-                        return function(v) {\n-                            return step([n, v]);\n-                        };\n+                /** chainable\n+                 * LinkifyIt#set(options)\n+                 * - options (Object): { fuzzyLink|fuzzyEmail|fuzzyIP: true|false }\n+                 *\n+                 * Set recognition options for links without schema.\n+                 **/\n+                LinkifyIt.prototype.set = function set(options) {\n+                    this.__opts__ = assign(this.__opts__, options);\n+                    return this;\n+                };\n+\n+                /**\n+                 * LinkifyIt#test(text) -> Boolean\n+                 *\n+                 * Searches linkifiable pattern and returns `true` on success or `false` on fail.\n+                 **/\n+                LinkifyIt.prototype.test = function test(text) {\n+                    // Reset scan cache\n+                    this.__text_cache__ = text;\n+                    this.__index__ = -1;\n+                    if (!text.length) {\n+                        return false;\n                     }\n+                    let m, ml, me, len, shift, next, re, tld_pos, at_pos;\n \n-                    function step(op) {\n-                        if (f) throw new TypeError(\"Generator is already executing.\");\n-                        while (_) try {\n-                            if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n-                            if (y = 0, t) op = [op[0] & 2, t.value];\n-                            switch (op[0]) {\n-                                case 0:\n-                                case 1:\n-                                    t = op;\n-                                    break;\n-                                case 4:\n-                                    _.label++;\n-                                    return {\n-                                        value: op[1],\n-                                            done: false\n-                                    };\n-                                case 5:\n-                                    _.label++;\n-                                    y = op[1];\n-                                    op = [0];\n-                                    continue;\n-                                case 7:\n-                                    op = _.ops.pop();\n-                                    _.trys.pop();\n-                                    continue;\n-                                default:\n-                                    if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {\n-                                        _ = 0;\n-                                        continue;\n-                                    }\n-                                    if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {\n-                                        _.label = op[1];\n-                                        break;\n-                                    }\n-                                    if (op[0] === 6 && _.label < t[1]) {\n-                                        _.label = t[1];\n-                                        t = op;\n-                                        break;\n-                                    }\n-                                    if (t && _.label < t[2]) {\n-                                        _.label = t[2];\n-                                        _.ops.push(op);\n-                                        break;\n+                    // try to scan for link with schema - that's the most simple rule\n+                    if (this.re.schema_test.test(text)) {\n+                        re = this.re.schema_search;\n+                        re.lastIndex = 0;\n+                        while ((m = re.exec(text)) !== null) {\n+                            len = this.testSchemaAt(text, m[2], re.lastIndex);\n+                            if (len) {\n+                                this.__schema__ = m[2];\n+                                this.__index__ = m.index + m[1].length;\n+                                this.__last_index__ = m.index + m[0].length + len;\n+                                break;\n+                            }\n+                        }\n+                    }\n+                    if (this.__opts__.fuzzyLink && this.__compiled__['http:']) {\n+                        // guess schemaless links\n+                        tld_pos = text.search(this.re.host_fuzzy_test);\n+                        if (tld_pos >= 0) {\n+                            // if tld is located after found link - no need to check fuzzy pattern\n+                            if (this.__index__ < 0 || tld_pos < this.__index__) {\n+                                if ((ml = text.match(this.__opts__.fuzzyIP ? this.re.link_fuzzy : this.re.link_no_ip_fuzzy)) !== null) {\n+                                    shift = ml.index + ml[1].length;\n+                                    if (this.__index__ < 0 || shift < this.__index__) {\n+                                        this.__schema__ = '';\n+                                        this.__index__ = shift;\n+                                        this.__last_index__ = ml.index + ml[0].length;\n                                     }\n-                                    if (t[2]) _.ops.pop();\n-                                    _.trys.pop();\n-                                    continue;\n+                                }\n                             }\n-                            op = body.call(thisArg, _);\n-                        } catch (e) {\n-                            op = [6, e];\n-                            y = 0;\n-                        } finally {\n-                            f = t = 0;\n                         }\n-                        if (op[0] & 5) throw op[1];\n-                        return {\n-                            value: op[0] ? op[1] : void 0,\n-                            done: true\n-                        };\n                     }\n-                }\n-                var __createBinding = Object.create ? function(o, m, k, k2) {\n-                    if (k2 === undefined) k2 = k;\n-                    var desc = Object.getOwnPropertyDescriptor(m, k);\n-                    if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n-                        desc = {\n-                            enumerable: true,\n-                            get: function() {\n-                                return m[k];\n+                    if (this.__opts__.fuzzyEmail && this.__compiled__['mailto:']) {\n+                        // guess schemaless emails\n+                        at_pos = text.indexOf('@');\n+                        if (at_pos >= 0) {\n+                            // We can't skip this check, because this cases are possible:\n+                            // 192.168.1.1@gmail.com, my.in@example.com\n+                            if ((me = text.match(this.re.email_fuzzy)) !== null) {\n+                                shift = me.index + me[1].length;\n+                                next = me.index + me[0].length;\n+                                if (this.__index__ < 0 || shift < this.__index__ || shift === this.__index__ && next > this.__last_index__) {\n+                                    this.__schema__ = 'mailto:';\n+                                    this.__index__ = shift;\n+                                    this.__last_index__ = next;\n+                                }\n                             }\n-                        };\n+                        }\n                     }\n-                    Object.defineProperty(o, k2, desc);\n-                } : function(o, m, k, k2) {\n-                    if (k2 === undefined) k2 = k;\n-                    o[k2] = m[k];\n+                    return this.__index__ >= 0;\n                 };\n-                exports.__createBinding = __createBinding;\n \n-                function __exportStar(m, o) {\n-                    for (var p in m)\n-                        if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\n-                }\n+                /**\n+                 * LinkifyIt#pretest(text) -> Boolean\n+                 *\n+                 * Very quick check, that can give false positives. Returns true if link MAY BE\n+                 * can exists. Can be used for speed optimization, when you need to check that\n+                 * link NOT exists.\n+                 **/\n+                LinkifyIt.prototype.pretest = function pretest(text) {\n+                    return this.re.pretest.test(text);\n+                };\n \n-                function __values(o) {\n-                    var s = typeof Symbol === \"function\" && Symbol.iterator,\n-                        m = s && o[s],\n-                        i = 0;\n-                    if (m) return m.call(o);\n-                    if (o && typeof o.length === \"number\") return {\n-                        next: function() {\n-                            if (o && i >= o.length) o = void 0;\n-                            return {\n-                                value: o && o[i++],\n-                                done: !o\n-                            };\n-                        }\n-                    };\n-                    throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n-                }\n+                /**\n+                 * LinkifyIt#testSchemaAt(text, name, position) -> Number\n+                 * - text (String): text to scan\n+                 * - name (String): rule (schema) name\n+                 * - position (Number): text offset to check from\n+                 *\n+                 * Similar to [[LinkifyIt#test]] but checks only specific protocol tail exactly\n+                 * at given position. Returns length of found pattern (0 on fail).\n+                 **/\n+                LinkifyIt.prototype.testSchemaAt = function testSchemaAt(text, schema, pos) {\n+                    // If not supported schema check requested - terminate\n+                    if (!this.__compiled__[schema.toLowerCase()]) {\n+                        return 0;\n+                    }\n+                    return this.__compiled__[schema.toLowerCase()].validate(text, pos, this);\n+                };\n \n-                function __read(o, n) {\n-                    var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n-                    if (!m) return o;\n-                    var i = m.call(o),\n-                        r,\n-                        ar = [],\n-                        e;\n-                    try {\n-                        while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n-                    } catch (error) {\n-                        e = {\n-                            error: error\n-                        };\n-                    } finally {\n-                        try {\n-                            if (r && !r.done && (m = i[\"return\"])) m.call(i);\n-                        } finally {\n-                            if (e) throw e.error;\n-                        }\n+                /**\n+                 * LinkifyIt#match(text) -> Array|null\n+                 *\n+                 * Returns array of found link descriptions or `null` on fail. We strongly\n+                 * recommend to use [[LinkifyIt#test]] first, for best speed.\n+                 *\n+                 * ##### Result match description\n+                 *\n+                 * - __schema__ - link schema, can be empty for fuzzy links, or `//` for\n+                 *   protocol-neutral  links.\n+                 * - __index__ - offset of matched text\n+                 * - __lastIndex__ - index of next char after mathch end\n+                 * - __raw__ - matched text\n+                 * - __text__ - normalized text\n+                 * - __url__ - link, generated from matched text\n+                 **/\n+                LinkifyIt.prototype.match = function match(text) {\n+                    const result = [];\n+                    let shift = 0;\n+\n+                    // Try to take previous element from cache, if .test() called before\n+                    if (this.__index__ >= 0 && this.__text_cache__ === text) {\n+                        result.push(createMatch(this, shift));\n+                        shift = this.__last_index__;\n                     }\n-                    return ar;\n-                }\n \n-                /** @deprecated */\n-                function __spread() {\n-                    for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n-                    return ar;\n+                    // Cut head if cache was used\n+                    let tail = shift ? text.slice(shift) : text;\n+\n+                    // Scan string until end reached\n+                    while (this.test(tail)) {\n+                        result.push(createMatch(this, shift));\n+                        tail = tail.slice(this.__last_index__);\n+                        shift += this.__last_index__;\n+                    }\n+                    if (result.length) {\n+                        return result;\n+                    }\n+                    return null;\n+                };\n+\n+                /**\n+                 * LinkifyIt#matchAtStart(text) -> Match|null\n+                 *\n+                 * Returns fully-formed (not fuzzy) link if it starts at the beginning\n+                 * of the string, and null otherwise.\n+                 **/\n+                LinkifyIt.prototype.matchAtStart = function matchAtStart(text) {\n+                    // Reset scan cache\n+                    this.__text_cache__ = text;\n+                    this.__index__ = -1;\n+                    if (!text.length) return null;\n+                    const m = this.re.schema_at_start.exec(text);\n+                    if (!m) return null;\n+                    const len = this.testSchemaAt(text, m[2], m[0].length);\n+                    if (!len) return null;\n+                    this.__schema__ = m[2];\n+                    this.__index__ = m.index + m[1].length;\n+                    this.__last_index__ = m.index + m[0].length + len;\n+                    return createMatch(this, 0);\n+                };\n+\n+                /** chainable\n+                 * LinkifyIt#tlds(list [, keepOld]) -> this\n+                 * - list (Array): list of tlds\n+                 * - keepOld (Boolean): merge with current list if `true` (`false` by default)\n+                 *\n+                 * Load (or merge) new tlds list. Those are user for fuzzy links (without prefix)\n+                 * to avoid false positives. By default this algorythm used:\n+                 *\n+                 * - hostname with any 2-letter root zones are ok.\n+                 * - biz|com|edu|gov|net|org|pro|web|xxx|aero|asia|coop|info|museum|name|shop|\u0440\u0444\n+                 *   are ok.\n+                 * - encoded (`xn--...`) root zones are ok.\n+                 *\n+                 * If list is replaced, then exact match for 2-chars root zones will be checked.\n+                 **/\n+                LinkifyIt.prototype.tlds = function tlds(list, keepOld) {\n+                    list = Array.isArray(list) ? list : [list];\n+                    if (!keepOld) {\n+                        this.__tlds__ = list.slice();\n+                        this.__tlds_replaced__ = true;\n+                        compile(this);\n+                        return this;\n+                    }\n+                    this.__tlds__ = this.__tlds__.concat(list).sort().filter(function(el, idx, arr) {\n+                        return el !== arr[idx - 1];\n+                    }).reverse();\n+                    compile(this);\n+                    return this;\n+                };\n+\n+                /**\n+                 * LinkifyIt#normalize(match)\n+                 *\n+                 * Default normalizer (if schema does not define it's own).\n+                 **/\n+                LinkifyIt.prototype.normalize = function normalize(match) {\n+                    // Do minimal possible changes by default. Need to collect feedback prior\n+                    // to move forward https://github.com/markdown-it/linkify-it/issues/1\n+\n+                    if (!match.schema) {\n+                        match.url = 'http://' + match.url;\n+                    }\n+                    if (match.schema === 'mailto:' && !/^mailto:/i.test(match.url)) {\n+                        match.url = 'mailto:' + match.url;\n+                    }\n+                };\n+\n+                /**\n+                 * LinkifyIt#onCompile()\n+                 *\n+                 * Override to modify basic RegExp-s.\n+                 **/\n+                LinkifyIt.prototype.onCompile = function onCompile() {};\n+                module.exports = LinkifyIt;\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../../node_modules/markdown-it/dist/index.cjs.js\":\n+            /*!***********************************************************!*\\\n+              !*** ../../../node_modules/markdown-it/dist/index.cjs.js ***!\n+              \\***********************************************************/\n+            /***/\n+            (function(module, __unused_webpack_exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                var mdurl = __webpack_require__( /*! mdurl */ \"../../../node_modules/mdurl/build/index.cjs.js\");\n+                var ucmicro = __webpack_require__( /*! uc.micro */ \"../../../node_modules/uc.micro/build/index.cjs.js\");\n+                var entities = __webpack_require__( /*! entities */ \"../../../node_modules/entities/lib/index.js\");\n+                var LinkifyIt = __webpack_require__( /*! linkify-it */ \"../../../node_modules/linkify-it/build/index.cjs.js\");\n+                var punycode = __webpack_require__( /*! punycode.js */ \"../../../node_modules/punycode.js/punycode.es6.js\");\n+\n+                function _interopNamespaceDefault(e) {\n+                    var n = Object.create(null);\n+                    if (e) {\n+                        Object.keys(e).forEach(function(k) {\n+                            if (k !== 'default') {\n+                                var d = Object.getOwnPropertyDescriptor(e, k);\n+                                Object.defineProperty(n, k, d.get ? d : {\n+                                    enumerable: true,\n+                                    get: function() {\n+                                        return e[k];\n+                                    }\n+                                });\n+                            }\n+                        });\n+                    }\n+                    n.default = e;\n+                    return Object.freeze(n);\n                 }\n+                var mdurl__namespace = /*#__PURE__*/ _interopNamespaceDefault(mdurl);\n+                var ucmicro__namespace = /*#__PURE__*/ _interopNamespaceDefault(ucmicro);\n \n-                /** @deprecated */\n-                function __spreadArrays() {\n-                    for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\n-                    for (var r = Array(s), k = 0, i = 0; i < il; i++)\n-                        for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) r[k] = a[j];\n-                    return r;\n+                // Utilities\n+                //\n+\n+                function _class(obj) {\n+                    return Object.prototype.toString.call(obj);\n                 }\n \n-                function __spreadArray(to, from, pack) {\n-                    if (pack || arguments.length === 2)\n-                        for (var i = 0, l = from.length, ar; i < l; i++) {\n-                            if (ar || !(i in from)) {\n-                                if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n-                                ar[i] = from[i];\n-                            }\n-                        }\n-                    return to.concat(ar || Array.prototype.slice.call(from));\n+                function isString(obj) {\n+                    return _class(obj) === '[object String]';\n+                }\n+                const _hasOwnProperty = Object.prototype.hasOwnProperty;\n+\n+                function has(object, key) {\n+                    return _hasOwnProperty.call(object, key);\n                 }\n \n-                function __await(v) {\n-                    return this instanceof __await ? (this.v = v, this) : new __await(v);\n+                // Merge objects\n+                //\n+                function assign(obj /* from1, from2, from3, ... */ ) {\n+                    const sources = Array.prototype.slice.call(arguments, 1);\n+                    sources.forEach(function(source) {\n+                        if (!source) {\n+                            return;\n+                        }\n+                        if (typeof source !== 'object') {\n+                            throw new TypeError(source + 'must be object');\n+                        }\n+                        Object.keys(source).forEach(function(key) {\n+                            obj[key] = source[key];\n+                        });\n+                    });\n+                    return obj;\n                 }\n \n-                function __asyncGenerator(thisArg, _arguments, generator) {\n-                    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n-                    var g = generator.apply(thisArg, _arguments || []),\n-                        i,\n-                        q = [];\n-                    return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function() {\n-                        return this;\n-                    }, i;\n+                // Remove element from array and put another array at those position.\n+                // Useful for some operations with tokens\n+                function arrayReplaceAt(src, pos, newElements) {\n+                    return [].concat(src.slice(0, pos), newElements, src.slice(pos + 1));\n+                }\n \n-                    function verb(n) {\n-                        if (g[n]) i[n] = function(v) {\n-                            return new Promise(function(a, b) {\n-                                q.push([n, v, a, b]) > 1 || resume(n, v);\n-                            });\n-                        };\n+                function isValidEntityCode(c) {\n+                    /* eslint no-bitwise:0 */\n+                    // broken sequence\n+                    if (c >= 0xD800 && c <= 0xDFFF) {\n+                        return false;\n                     }\n-\n-                    function resume(n, v) {\n-                        try {\n-                            step(g[n](v));\n-                        } catch (e) {\n-                            settle(q[0][3], e);\n-                        }\n+                    // never used\n+                    if (c >= 0xFDD0 && c <= 0xFDEF) {\n+                        return false;\n                     }\n-\n-                    function step(r) {\n-                        r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r);\n+                    if ((c & 0xFFFF) === 0xFFFF || (c & 0xFFFF) === 0xFFFE) {\n+                        return false;\n                     }\n-\n-                    function fulfill(value) {\n-                        resume(\"next\", value);\n+                    // control codes\n+                    if (c >= 0x00 && c <= 0x08) {\n+                        return false;\n                     }\n-\n-                    function reject(value) {\n-                        resume(\"throw\", value);\n+                    if (c === 0x0B) {\n+                        return false;\n                     }\n-\n-                    function settle(f, v) {\n-                        if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]);\n+                    if (c >= 0x0E && c <= 0x1F) {\n+                        return false;\n+                    }\n+                    if (c >= 0x7F && c <= 0x9F) {\n+                        return false;\n                     }\n+                    // out of range\n+                    if (c > 0x10FFFF) {\n+                        return false;\n+                    }\n+                    return true;\n                 }\n \n-                function __asyncDelegator(o) {\n-                    var i, p;\n-                    return i = {}, verb(\"next\"), verb(\"throw\", function(e) {\n-                        throw e;\n-                    }), verb(\"return\"), i[Symbol.iterator] = function() {\n-                        return this;\n-                    }, i;\n+                function fromCodePoint(c) {\n+                    /* eslint no-bitwise:0 */\n+                    if (c > 0xffff) {\n+                        c -= 0x10000;\n+                        const surrogate1 = 0xd800 + (c >> 10);\n+                        const surrogate2 = 0xdc00 + (c & 0x3ff);\n+                        return String.fromCharCode(surrogate1, surrogate2);\n+                    }\n+                    return String.fromCharCode(c);\n+                }\n+                const UNESCAPE_MD_RE = /\\\\([!\"#$%&'()*+,\\-./:;<=>?@[\\\\\\]^_`{|}~])/g;\n+                const ENTITY_RE = /&([a-z#][a-z0-9]{1,31});/gi;\n+                const UNESCAPE_ALL_RE = new RegExp(UNESCAPE_MD_RE.source + '|' + ENTITY_RE.source, 'gi');\n+                const DIGITAL_ENTITY_TEST_RE = /^#((?:x[a-f0-9]{1,8}|[0-9]{1,8}))$/i;\n \n-                    function verb(n, f) {\n-                        i[n] = o[n] ? function(v) {\n-                            return (p = !p) ? {\n-                                value: __await(o[n](v)),\n-                                done: n === \"return\"\n-                            } : f ? f(v) : v;\n-                        } : f;\n+                function replaceEntityPattern(match, name) {\n+                    if (name.charCodeAt(0) === 0x23 /* # */ && DIGITAL_ENTITY_TEST_RE.test(name)) {\n+                        const code = name[1].toLowerCase() === 'x' ? parseInt(name.slice(2), 16) : parseInt(name.slice(1), 10);\n+                        if (isValidEntityCode(code)) {\n+                            return fromCodePoint(code);\n+                        }\n+                        return match;\n+                    }\n+                    const decoded = entities.decodeHTML(match);\n+                    if (decoded !== match) {\n+                        return decoded;\n                     }\n+                    return match;\n                 }\n \n-                function __asyncValues(o) {\n-                    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n-                    var m = o[Symbol.asyncIterator],\n-                        i;\n-                    return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function() {\n-                        return this;\n-                    }, i);\n+                /* function replaceEntities(str) {\n+                  if (str.indexOf('&') < 0) { return str; }\n \n-                    function verb(n) {\n-                        i[n] = o[n] && function(v) {\n-                            return new Promise(function(resolve, reject) {\n-                                v = o[n](v), settle(resolve, reject, v.done, v.value);\n-                            });\n-                        };\n-                    }\n+                  return str.replace(ENTITY_RE, replaceEntityPattern);\n+                } */\n \n-                    function settle(resolve, reject, d, v) {\n-                        Promise.resolve(v).then(function(v) {\n-                            resolve({\n-                                value: v,\n-                                done: d\n-                            });\n-                        }, reject);\n+                function unescapeMd(str) {\n+                    if (str.indexOf('\\\\') < 0) {\n+                        return str;\n                     }\n+                    return str.replace(UNESCAPE_MD_RE, '$1');\n                 }\n \n-                function __makeTemplateObject(cooked, raw) {\n-                    if (Object.defineProperty) {\n-                        Object.defineProperty(cooked, \"raw\", {\n-                            value: raw\n-                        });\n-                    } else {\n-                        cooked.raw = raw;\n+                function unescapeAll(str) {\n+                    if (str.indexOf('\\\\') < 0 && str.indexOf('&') < 0) {\n+                        return str;\n                     }\n-                    return cooked;\n-                };\n-                var __setModuleDefault = Object.create ? function(o, v) {\n-                    Object.defineProperty(o, \"default\", {\n-                        enumerable: true,\n-                        value: v\n+                    return str.replace(UNESCAPE_ALL_RE, function(match, escaped, entity) {\n+                        if (escaped) {\n+                            return escaped;\n+                        }\n+                        return replaceEntityPattern(match, entity);\n                     });\n-                } : function(o, v) {\n-                    o[\"default\"] = v;\n+                }\n+                const HTML_ESCAPE_TEST_RE = /[&<>\"]/;\n+                const HTML_ESCAPE_REPLACE_RE = /[&<>\"]/g;\n+                const HTML_REPLACEMENTS = {\n+                    '&': '&amp;',\n+                    '<': '&lt;',\n+                    '>': '&gt;',\n+                    '\"': '&quot;'\n                 };\n \n-                function __importStar(mod) {\n-                    if (mod && mod.__esModule) return mod;\n-                    var result = {};\n-                    if (mod != null)\n-                        for (var k in mod)\n-                            if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n-                    __setModuleDefault(result, mod);\n-                    return result;\n+                function replaceUnsafeChar(ch) {\n+                    return HTML_REPLACEMENTS[ch];\n                 }\n \n-                function __importDefault(mod) {\n-                    return mod && mod.__esModule ? mod : {\n-                        default: mod\n-                    };\n+                function escapeHtml(str) {\n+                    if (HTML_ESCAPE_TEST_RE.test(str)) {\n+                        return str.replace(HTML_ESCAPE_REPLACE_RE, replaceUnsafeChar);\n+                    }\n+                    return str;\n                 }\n+                const REGEXP_ESCAPE_RE = /[.?*+^$[\\]\\\\(){}|-]/g;\n \n-                function __classPrivateFieldGet(receiver, state, kind, f) {\n-                    if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\n-                    if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\n-                    return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\n+                function escapeRE(str) {\n+                    return str.replace(REGEXP_ESCAPE_RE, '\\\\$&');\n                 }\n \n-                function __classPrivateFieldSet(receiver, state, value, kind, f) {\n-                    if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\n-                    if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\n-                    if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\n-                    return kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value), value;\n+                function isSpace(code) {\n+                    switch (code) {\n+                        case 0x09:\n+                        case 0x20:\n+                            return true;\n+                    }\n+                    return false;\n                 }\n \n-                function __classPrivateFieldIn(state, receiver) {\n-                    if (receiver === null || typeof receiver !== \"object\" && typeof receiver !== \"function\") throw new TypeError(\"Cannot use 'in' operator on non-object\");\n-                    return typeof state === \"function\" ? receiver === state : state.has(receiver);\n+                // Zs (unicode class) || [\\t\\f\\v\\r\\n]\n+                function isWhiteSpace(code) {\n+                    if (code >= 0x2000 && code <= 0x200A) {\n+                        return true;\n+                    }\n+                    switch (code) {\n+                        case 0x09: // \\t\n+                        case 0x0A: // \\n\n+                        case 0x0B: // \\v\n+                        case 0x0C: // \\f\n+                        case 0x0D: // \\r\n+                        case 0x20:\n+                        case 0xA0:\n+                        case 0x1680:\n+                        case 0x202F:\n+                        case 0x205F:\n+                        case 0x3000:\n+                            return true;\n+                    }\n+                    return false;\n                 }\n \n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/use-callback-ref/dist/es2015/assignRef.js\":\n-            /*!***********************************************************************!*\\\n-              !*** ../../../node_modules/use-callback-ref/dist/es2015/assignRef.js ***!\n-              \\***********************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports) {\n-\n+                /* eslint-disable max-len */\n \n+                // Currently without astral characters support.\n+                function isPunctChar(ch) {\n+                    return ucmicro__namespace.P.test(ch) || ucmicro__namespace.S.test(ch);\n+                }\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.assignRef = assignRef;\n-                /**\n-                 * Assigns a value for a given ref, no matter of the ref format\n-                 * @param {RefObject} ref - a callback function or ref object\n-                 * @param value - a new value\n-                 *\n-                 * @see https://github.com/theKashey/use-callback-ref#assignref\n-                 * @example\n-                 * const refObject = useRef();\n-                 * const refFn = (ref) => {....}\n-                 *\n-                 * assignRef(refObject, \"refValue\");\n-                 * assignRef(refFn, \"refValue\");\n-                 */\n-                function assignRef(ref, value) {\n-                    if (typeof ref === 'function') {\n-                        ref(value);\n-                    } else if (ref) {\n-                        ref.current = value;\n+                // Markdown ASCII punctuation characters.\n+                //\n+                // !, \", #, $, %, &, ', (, ), *, +, ,, -, ., /, :, ;, <, =, >, ?, @, [, \\, ], ^, _, `, {, |, }, or ~\n+                // http://spec.commonmark.org/0.15/#ascii-punctuation-character\n+                //\n+                // Don't confuse with unicode punctuation !!! It lacks some chars in ascii range.\n+                //\n+                function isMdAsciiPunct(ch) {\n+                    switch (ch) {\n+                        case 0x21 /* ! */ :\n+                        case 0x22 /* \" */ :\n+                        case 0x23 /* # */ :\n+                        case 0x24 /* $ */ :\n+                        case 0x25 /* % */ :\n+                        case 0x26 /* & */ :\n+                        case 0x27 /* ' */ :\n+                        case 0x28 /* ( */ :\n+                        case 0x29 /* ) */ :\n+                        case 0x2A /* * */ :\n+                        case 0x2B /* + */ :\n+                        case 0x2C /* , */ :\n+                        case 0x2D /* - */ :\n+                        case 0x2E /* . */ :\n+                        case 0x2F /* / */ :\n+                        case 0x3A /* : */ :\n+                        case 0x3B /* ; */ :\n+                        case 0x3C /* < */ :\n+                        case 0x3D /* = */ :\n+                        case 0x3E /* > */ :\n+                        case 0x3F /* ? */ :\n+                        case 0x40 /* @ */ :\n+                        case 0x5B /* [ */ :\n+                        case 0x5C /* \\ */ :\n+                        case 0x5D /* ] */ :\n+                        case 0x5E /* ^ */ :\n+                        case 0x5F /* _ */ :\n+                        case 0x60 /* ` */ :\n+                        case 0x7B /* { */ :\n+                        case 0x7C /* | */ :\n+                        case 0x7D /* } */ :\n+                        case 0x7E /* ~ */ :\n+                            return true;\n+                        default:\n+                            return false;\n                     }\n-                    return ref;\n                 }\n \n-                /***/\n-            }),\n+                // Hepler to unify [reference labels].\n+                //\n+                function normalizeReference(str) {\n+                    // Trim and collapse whitespace\n+                    //\n+                    str = str.trim().replace(/\\s+/g, ' ');\n \n-        /***/\n-        \"../../../node_modules/use-callback-ref/dist/es2015/createRef.js\":\n-            /*!***********************************************************************!*\\\n-              !*** ../../../node_modules/use-callback-ref/dist/es2015/createRef.js ***!\n-              \\***********************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports) {\n+                    // In node v10 '\u1e9e'.toLowerCase() === '\u1e7e', which is presumed to be a bug\n+                    // fixed in v12 (couldn't find any details).\n+                    //\n+                    // So treat this one as a special case\n+                    // (remove this when node v10 is no longer supported).\n+                    //\n+                    if ('\u1e9e'.toLowerCase() === '\u1e7e') {\n+                        str = str.replace(/\u1e9e/g, '\u00df');\n+                    }\n+\n+                    // .toLowerCase().toUpperCase() should get rid of all differences\n+                    // between letter variants.\n+                    //\n+                    // Simple .toLowerCase() doesn't normalize 125 code points correctly,\n+                    // and .toUpperCase doesn't normalize 6 of them (list of exceptions:\n+                    // \u0130, \u03f4, \u1e9e, \u2126, \u212a, \u212b - those are already uppercased, but have differently\n+                    // uppercased versions).\n+                    //\n+                    // Here's an example showing how it happens. Lets take greek letter omega:\n+                    // uppercase U+0398 (\u0398), U+03f4 (\u03f4) and lowercase U+03b8 (\u03b8), U+03d1 (\u03d1)\n+                    //\n+                    // Unicode entries:\n+                    // 0398;GREEK CAPITAL LETTER THETA;Lu;0;L;;;;;N;;;;03B8;\n+                    // 03B8;GREEK SMALL LETTER THETA;Ll;0;L;;;;;N;;;0398;;0398\n+                    // 03D1;GREEK THETA SYMBOL;Ll;0;L;<compat> 03B8;;;;N;GREEK SMALL LETTER SCRIPT THETA;;0398;;0398\n+                    // 03F4;GREEK CAPITAL THETA SYMBOL;Lu;0;L;<compat> 0398;;;;N;;;;03B8;\n+                    //\n+                    // Case-insensitive comparison should treat all of them as equivalent.\n+                    //\n+                    // But .toLowerCase() doesn't change \u03d1 (it's already lowercase),\n+                    // and .toUpperCase() doesn't change \u03f4 (already uppercase).\n+                    //\n+                    // Applying first lower then upper case normalizes any character:\n+                    // '\\u0398\\u03f4\\u03b8\\u03d1'.toLowerCase().toUpperCase() === '\\u0398\\u0398\\u0398\\u0398'\n+                    //\n+                    // Note: this is equivalent to unicode case folding; unicode normalization\n+                    // is a different step that is not required here.\n+                    //\n+                    // Final result should be uppercased, because it's later stored in an object\n+                    // (this avoid a conflict with Object.prototype members,\n+                    // most notably, `__proto__`)\n+                    //\n+                    return str.toLowerCase().toUpperCase();\n+                }\n \n+                // Re-export libraries commonly used in both markdown-it and its plugins,\n+                // so plugins won't have to depend on them explicitly, which reduces their\n+                // bundled size (e.g. a browser build).\n+                //\n+                const lib = {\n+                    mdurl: mdurl__namespace,\n+                    ucmicro: ucmicro__namespace\n+                };\n+                var utils = /*#__PURE__*/ Object.freeze({\n+                    __proto__: null,\n+                    arrayReplaceAt: arrayReplaceAt,\n+                    assign: assign,\n+                    escapeHtml: escapeHtml,\n+                    escapeRE: escapeRE,\n+                    fromCodePoint: fromCodePoint,\n+                    has: has,\n+                    isMdAsciiPunct: isMdAsciiPunct,\n+                    isPunctChar: isPunctChar,\n+                    isSpace: isSpace,\n+                    isString: isString,\n+                    isValidEntityCode: isValidEntityCode,\n+                    isWhiteSpace: isWhiteSpace,\n+                    lib: lib,\n+                    normalizeReference: normalizeReference,\n+                    unescapeAll: unescapeAll,\n+                    unescapeMd: unescapeMd\n+                });\n \n+                // Parse link label\n+                //\n+                // this function assumes that first character (\"[\") already matches;\n+                // returns the end of the label\n+                //\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.createCallbackRef = createCallbackRef;\n-                /**\n-                 * creates a Ref object with on change callback\n-                 * @param callback\n-                 * @returns {RefObject}\n-                 *\n-                 * @see {@link useCallbackRef}\n-                 * @see https://reactjs.org/docs/refs-and-the-dom.html#creating-refs\n-                 */\n-                function createCallbackRef(callback) {\n-                    var current = null;\n-                    return {\n-                        get current() {\n-                            return current;\n-                        },\n-                        set current(value) {\n-                            var last = current;\n-                            if (last !== value) {\n-                                current = value;\n-                                callback(value, last);\n+                function parseLinkLabel(state, start, disableNested) {\n+                    let level, found, marker, prevPos;\n+                    const max = state.posMax;\n+                    const oldPos = state.pos;\n+                    state.pos = start + 1;\n+                    level = 1;\n+                    while (state.pos < max) {\n+                        marker = state.src.charCodeAt(state.pos);\n+                        if (marker === 0x5D /* ] */ ) {\n+                            level--;\n+                            if (level === 0) {\n+                                found = true;\n+                                break;\n                             }\n                         }\n-                    };\n+                        prevPos = state.pos;\n+                        state.md.inline.skipToken(state);\n+                        if (marker === 0x5B /* [ */ ) {\n+                            if (prevPos === state.pos - 1) {\n+                                // increase level if we find text `[`, which is not a part of any token\n+                                level++;\n+                            } else if (disableNested) {\n+                                state.pos = oldPos;\n+                                return -1;\n+                            }\n+                        }\n+                    }\n+                    let labelEnd = -1;\n+                    if (found) {\n+                        labelEnd = state.pos;\n+                    }\n+\n+                    // restore old state\n+                    state.pos = oldPos;\n+                    return labelEnd;\n                 }\n \n-                /***/\n-            }),\n+                // Parse link destination\n+                //\n \n-        /***/\n-        \"../../../node_modules/use-callback-ref/dist/es2015/index.js\":\n-            /*!*******************************************************************!*\\\n-              !*** ../../../node_modules/use-callback-ref/dist/es2015/index.js ***!\n-              \\*******************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                function parseLinkDestination(str, start, max) {\n+                    let code;\n+                    let pos = start;\n+                    const result = {\n+                        ok: false,\n+                        pos: 0,\n+                        str: ''\n+                    };\n+                    if (str.charCodeAt(pos) === 0x3C /* < */ ) {\n+                        pos++;\n+                        while (pos < max) {\n+                            code = str.charCodeAt(pos);\n+                            if (code === 0x0A /* \\n */ ) {\n+                                return result;\n+                            }\n+                            if (code === 0x3C /* < */ ) {\n+                                return result;\n+                            }\n+                            if (code === 0x3E /* > */ ) {\n+                                result.pos = pos + 1;\n+                                result.str = unescapeAll(str.slice(start + 1, pos));\n+                                result.ok = true;\n+                                return result;\n+                            }\n+                            if (code === 0x5C /* \\ */ && pos + 1 < max) {\n+                                pos += 2;\n+                                continue;\n+                            }\n+                            pos++;\n+                        }\n \n+                        // no closing '>'\n+                        return result;\n+                    }\n \n+                    // this should be ... } else { ... branch\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                Object.defineProperty(exports, \"assignRef\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _assignRef.assignRef;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"createCallbackRef\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _createRef.createCallbackRef;\n+                    let level = 0;\n+                    while (pos < max) {\n+                        code = str.charCodeAt(pos);\n+                        if (code === 0x20) {\n+                            break;\n+                        }\n+\n+                        // ascii control characters\n+                        if (code < 0x20 || code === 0x7F) {\n+                            break;\n+                        }\n+                        if (code === 0x5C /* \\ */ && pos + 1 < max) {\n+                            if (str.charCodeAt(pos + 1) === 0x20) {\n+                                break;\n+                            }\n+                            pos += 2;\n+                            continue;\n+                        }\n+                        if (code === 0x28 /* ( */ ) {\n+                            level++;\n+                            if (level > 32) {\n+                                return result;\n+                            }\n+                        }\n+                        if (code === 0x29 /* ) */ ) {\n+                            if (level === 0) {\n+                                break;\n+                            }\n+                            level--;\n+                        }\n+                        pos++;\n                     }\n-                }));\n-                Object.defineProperty(exports, \"mergeRefs\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _mergeRef.mergeRefs;\n+                    if (start === pos) {\n+                        return result;\n                     }\n-                }));\n-                Object.defineProperty(exports, \"refToCallback\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _refToCallback.refToCallback;\n+                    if (level !== 0) {\n+                        return result;\n                     }\n-                }));\n-                Object.defineProperty(exports, \"transformRef\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _transformRef.transformRef;\n+                    result.str = unescapeAll(str.slice(start, pos));\n+                    result.pos = pos;\n+                    result.ok = true;\n+                    return result;\n+                }\n+\n+                // Parse link title\n+                //\n+\n+                // Parse link title within `str` in [start, max] range,\n+                // or continue previous parsing if `prev_state` is defined (equal to result of last execution).\n+                //\n+                function parseLinkTitle(str, start, max, prev_state) {\n+                    let code;\n+                    let pos = start;\n+                    const state = {\n+                        // if `true`, this is a valid link title\n+                        ok: false,\n+                        // if `true`, this link can be continued on the next line\n+                        can_continue: false,\n+                        // if `ok`, it's the position of the first character after the closing marker\n+                        pos: 0,\n+                        // if `ok`, it's the unescaped title\n+                        str: '',\n+                        // expected closing marker character code\n+                        marker: 0\n+                    };\n+                    if (prev_state) {\n+                        // this is a continuation of a previous parseLinkTitle call on the next line,\n+                        // used in reference links only\n+                        state.str = prev_state.str;\n+                        state.marker = prev_state.marker;\n+                    } else {\n+                        if (pos >= max) {\n+                            return state;\n+                        }\n+                        let marker = str.charCodeAt(pos);\n+                        if (marker !== 0x22 /* \" */ && marker !== 0x27 /* ' */ && marker !== 0x28 /* ( */ ) {\n+                            return state;\n+                        }\n+                        start++;\n+                        pos++;\n+\n+                        // if opening marker is \"(\", switch it to closing marker \")\"\n+                        if (marker === 0x28) {\n+                            marker = 0x29;\n+                        }\n+                        state.marker = marker;\n                     }\n-                }));\n-                Object.defineProperty(exports, \"useCallbackRef\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _useRef.useCallbackRef;\n+                    while (pos < max) {\n+                        code = str.charCodeAt(pos);\n+                        if (code === state.marker) {\n+                            state.pos = pos + 1;\n+                            state.str += unescapeAll(str.slice(start, pos));\n+                            state.ok = true;\n+                            return state;\n+                        } else if (code === 0x28 /* ( */ && state.marker === 0x29 /* ) */ ) {\n+                            return state;\n+                        } else if (code === 0x5C /* \\ */ && pos + 1 < max) {\n+                            pos++;\n+                        }\n+                        pos++;\n                     }\n-                }));\n-                Object.defineProperty(exports, \"useMergeRefs\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _useMergeRef.useMergeRefs;\n+\n+                    // no closing marker found, but this link title may continue on the next line (for references)\n+                    state.can_continue = true;\n+                    state.str += unescapeAll(str.slice(start, pos));\n+                    return state;\n+                }\n+\n+                // Just a shortcut for bulk export\n+\n+                var helpers = /*#__PURE__*/ Object.freeze({\n+                    __proto__: null,\n+                    parseLinkDestination: parseLinkDestination,\n+                    parseLinkLabel: parseLinkLabel,\n+                    parseLinkTitle: parseLinkTitle\n+                });\n+\n+                /**\n+                 * class Renderer\n+                 *\n+                 * Generates HTML from parsed token stream. Each instance has independent\n+                 * copy of rules. Those can be rewritten with ease. Also, you can add new\n+                 * rules if you create plugin and adds new token types.\n+                 **/\n+\n+                const default_rules = {};\n+                default_rules.code_inline = function(tokens, idx, options, env, slf) {\n+                    const token = tokens[idx];\n+                    return '<code' + slf.renderAttrs(token) + '>' + escapeHtml(token.content) + '</code>';\n+                };\n+                default_rules.code_block = function(tokens, idx, options, env, slf) {\n+                    const token = tokens[idx];\n+                    return '<pre' + slf.renderAttrs(token) + '><code>' + escapeHtml(tokens[idx].content) + '</code></pre>\\n';\n+                };\n+                default_rules.fence = function(tokens, idx, options, env, slf) {\n+                    const token = tokens[idx];\n+                    const info = token.info ? unescapeAll(token.info).trim() : '';\n+                    let langName = '';\n+                    let langAttrs = '';\n+                    if (info) {\n+                        const arr = info.split(/(\\s+)/g);\n+                        langName = arr[0];\n+                        langAttrs = arr.slice(2).join('');\n                     }\n-                }));\n-                Object.defineProperty(exports, \"useRefToCallback\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _refToCallback.useRefToCallback;\n+                    let highlighted;\n+                    if (options.highlight) {\n+                        highlighted = options.highlight(token.content, langName, langAttrs) || escapeHtml(token.content);\n+                    } else {\n+                        highlighted = escapeHtml(token.content);\n                     }\n-                }));\n-                Object.defineProperty(exports, \"useTransformRef\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _useTransformRef.useTransformRef;\n+                    if (highlighted.indexOf('<pre') === 0) {\n+                        return highlighted + '\\n';\n                     }\n-                }));\n-                var _assignRef = __webpack_require__( /*! ./assignRef */ \"../../../node_modules/use-callback-ref/dist/es2015/assignRef.js\");\n-                var _useRef = __webpack_require__( /*! ./useRef */ \"../../../node_modules/use-callback-ref/dist/es2015/useRef.js\");\n-                var _createRef = __webpack_require__( /*! ./createRef */ \"../../../node_modules/use-callback-ref/dist/es2015/createRef.js\");\n-                var _mergeRef = __webpack_require__( /*! ./mergeRef */ \"../../../node_modules/use-callback-ref/dist/es2015/mergeRef.js\");\n-                var _useMergeRef = __webpack_require__( /*! ./useMergeRef */ \"../../../node_modules/use-callback-ref/dist/es2015/useMergeRef.js\");\n-                var _useTransformRef = __webpack_require__( /*! ./useTransformRef */ \"../../../node_modules/use-callback-ref/dist/es2015/useTransformRef.js\");\n-                var _transformRef = __webpack_require__( /*! ./transformRef */ \"../../../node_modules/use-callback-ref/dist/es2015/transformRef.js\");\n-                var _refToCallback = __webpack_require__( /*! ./refToCallback */ \"../../../node_modules/use-callback-ref/dist/es2015/refToCallback.js\");\n \n-                /***/\n-            }),\n+                    // If language exists, inject class gently, without modifying original token.\n+                    // May be, one day we will add .deepClone() for token and simplify this part, but\n+                    // now we prefer to keep things local.\n+                    if (info) {\n+                        const i = token.attrIndex('class');\n+                        const tmpAttrs = token.attrs ? token.attrs.slice() : [];\n+                        if (i < 0) {\n+                            tmpAttrs.push(['class', options.langPrefix + langName]);\n+                        } else {\n+                            tmpAttrs[i] = tmpAttrs[i].slice();\n+                            tmpAttrs[i][1] += ' ' + options.langPrefix + langName;\n+                        }\n \n-        /***/\n-        \"../../../node_modules/use-callback-ref/dist/es2015/mergeRef.js\":\n-            /*!**********************************************************************!*\\\n-              !*** ../../../node_modules/use-callback-ref/dist/es2015/mergeRef.js ***!\n-              \\**********************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                        // Fake token just to render attributes\n+                        const tmpToken = {\n+                            attrs: tmpAttrs\n+                        };\n+                        return `<pre><code${slf.renderAttrs(tmpToken)}>${highlighted}</code></pre>\\n`;\n+                    }\n+                    return `<pre><code${slf.renderAttrs(token)}>${highlighted}</code></pre>\\n`;\n+                };\n+                default_rules.image = function(tokens, idx, options, env, slf) {\n+                    const token = tokens[idx];\n \n+                    // \"alt\" attr MUST be set, even if empty. Because it's mandatory and\n+                    // should be placed on proper position for tests.\n+                    //\n+                    // Replace content with actual value\n \n+                    token.attrs[token.attrIndex('alt')][1] = slf.renderInlineAsText(token.children, options, env);\n+                    return slf.renderToken(tokens, idx, options);\n+                };\n+                default_rules.hardbreak = function(tokens, idx, options /*, env */ ) {\n+                    return options.xhtmlOut ? '<br />\\n' : '<br>\\n';\n+                };\n+                default_rules.softbreak = function(tokens, idx, options /*, env */ ) {\n+                    return options.breaks ? options.xhtmlOut ? '<br />\\n' : '<br>\\n' : '\\n';\n+                };\n+                default_rules.text = function(tokens, idx /*, options, env */ ) {\n+                    return escapeHtml(tokens[idx].content);\n+                };\n+                default_rules.html_block = function(tokens, idx /*, options, env */ ) {\n+                    return tokens[idx].content;\n+                };\n+                default_rules.html_inline = function(tokens, idx /*, options, env */ ) {\n+                    return tokens[idx].content;\n+                };\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.mergeRefs = mergeRefs;\n-                var _assignRef = __webpack_require__( /*! ./assignRef */ \"../../../node_modules/use-callback-ref/dist/es2015/assignRef.js\");\n-                var _createRef = __webpack_require__( /*! ./createRef */ \"../../../node_modules/use-callback-ref/dist/es2015/createRef.js\");\n                 /**\n-                 * Merges two or more refs together providing a single interface to set their value\n-                 * @param {RefObject|Ref} refs\n-                 * @returns {MutableRefObject} - a new ref, which translates all changes to {refs}\n+                 * new Renderer()\n                  *\n-                 * @see {@link useMergeRefs} to be used in ReactComponents\n-                 * @example\n-                 * const Component = React.forwardRef((props, ref) => {\n-                 *   const ownRef = useRef();\n-                 *   const domRef = mergeRefs([ref, ownRef]); // \ud83d\udc48 merge together\n-                 *   return <div ref={domRef}>...</div>\n-                 * }\n-                 */\n-                function mergeRefs(refs) {\n-                    return (0, _createRef.createCallbackRef)(function(newValue) {\n-                        return refs.forEach(function(ref) {\n-                            return (0, _assignRef.assignRef)(ref, newValue);\n-                        });\n-                    });\n+                 * Creates new [[Renderer]] instance and fill [[Renderer#rules]] with defaults.\n+                 **/\n+                function Renderer() {\n+                    /**\n+                     * Renderer#rules -> Object\n+                     *\n+                     * Contains render rules for tokens. Can be updated and extended.\n+                     *\n+                     * ##### Example\n+                     *\n+                     * ```javascript\n+                     * var md = require('markdown-it')();\n+                     *\n+                     * md.renderer.rules.strong_open  = function () { return '<b>'; };\n+                     * md.renderer.rules.strong_close = function () { return '</b>'; };\n+                     *\n+                     * var result = md.renderInline(...);\n+                     * ```\n+                     *\n+                     * Each rule is called as independent static function with fixed signature:\n+                     *\n+                     * ```javascript\n+                     * function my_token_render(tokens, idx, options, env, renderer) {\n+                     *   // ...\n+                     *   return renderedHTML;\n+                     * }\n+                     * ```\n+                     *\n+                     * See [source code](https://github.com/markdown-it/markdown-it/blob/master/lib/renderer.mjs)\n+                     * for more details and examples.\n+                     **/\n+                    this.rules = assign({}, default_rules);\n                 }\n \n-                /***/\n-            }),\n+                /**\n+                 * Renderer.renderAttrs(token) -> String\n+                 *\n+                 * Render token attributes to string.\n+                 **/\n+                Renderer.prototype.renderAttrs = function renderAttrs(token) {\n+                    let i, l, result;\n+                    if (!token.attrs) {\n+                        return '';\n+                    }\n+                    result = '';\n+                    for (i = 0, l = token.attrs.length; i < l; i++) {\n+                        result += ' ' + escapeHtml(token.attrs[i][0]) + '=\"' + escapeHtml(token.attrs[i][1]) + '\"';\n+                    }\n+                    return result;\n+                };\n \n-        /***/\n-        \"../../../node_modules/use-callback-ref/dist/es2015/refToCallback.js\":\n-            /*!***************************************************************************!*\\\n-              !*** ../../../node_modules/use-callback-ref/dist/es2015/refToCallback.js ***!\n-              \\***************************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports) {\n+                /**\n+                 * Renderer.renderToken(tokens, idx, options) -> String\n+                 * - tokens (Array): list of tokens\n+                 * - idx (Numbed): token index to render\n+                 * - options (Object): params of parser instance\n+                 *\n+                 * Default token renderer. Can be overriden by custom function\n+                 * in [[Renderer#rules]].\n+                 **/\n+                Renderer.prototype.renderToken = function renderToken(tokens, idx, options) {\n+                    const token = tokens[idx];\n+                    let result = '';\n+\n+                    // Tight list paragraphs\n+                    if (token.hidden) {\n+                        return '';\n+                    }\n+\n+                    // Insert a newline between hidden paragraph and subsequent opening\n+                    // block-level tag.\n+                    //\n+                    // For example, here we should insert a newline before blockquote:\n+                    //  - a\n+                    //    >\n+                    //\n+                    if (token.block && token.nesting !== -1 && idx && tokens[idx - 1].hidden) {\n+                        result += '\\n';\n+                    }\n \n+                    // Add token name, e.g. `<img`\n+                    result += (token.nesting === -1 ? '</' : '<') + token.tag;\n \n+                    // Encode attributes, e.g. `<img src=\"foo\"`\n+                    result += this.renderAttrs(token);\n+\n+                    // Add a slash for self-closing tags, e.g. `<img src=\"foo\" /`\n+                    if (token.nesting === 0 && options.xhtmlOut) {\n+                        result += ' /';\n+                    }\n+\n+                    // Check if we need to add a newline after this tag\n+                    let needLf = false;\n+                    if (token.block) {\n+                        needLf = true;\n+                        if (token.nesting === 1) {\n+                            if (idx + 1 < tokens.length) {\n+                                const nextToken = tokens[idx + 1];\n+                                if (nextToken.type === 'inline' || nextToken.hidden) {\n+                                    // Block-level tag containing an inline tag.\n+                                    //\n+                                    needLf = false;\n+                                } else if (nextToken.nesting === -1 && nextToken.tag === token.tag) {\n+                                    // Opening tag + closing tag of the same type. E.g. `<li></li>`.\n+                                    //\n+                                    needLf = false;\n+                                }\n+                            }\n+                        }\n+                    }\n+                    result += needLf ? '>\\n' : '>';\n+                    return result;\n+                };\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.refToCallback = refToCallback;\n-                exports.useRefToCallback = useRefToCallback;\n                 /**\n-                 * Unmemoized version of {@link useRefToCallback}\n-                 * @see {@link useRefToCallback}\n-                 * @param ref\n-                 */\n-                function refToCallback(ref) {\n-                    return function(newValue) {\n-                        if (typeof ref === 'function') {\n-                            ref(newValue);\n-                        } else if (ref) {\n-                            ref.current = newValue;\n+                 * Renderer.renderInline(tokens, options, env) -> String\n+                 * - tokens (Array): list on block tokens to render\n+                 * - options (Object): params of parser instance\n+                 * - env (Object): additional data from parsed input (references, for example)\n+                 *\n+                 * The same as [[Renderer.render]], but for single token of `inline` type.\n+                 **/\n+                Renderer.prototype.renderInline = function(tokens, options, env) {\n+                    let result = '';\n+                    const rules = this.rules;\n+                    for (let i = 0, len = tokens.length; i < len; i++) {\n+                        const type = tokens[i].type;\n+                        if (typeof rules[type] !== 'undefined') {\n+                            result += rules[type](tokens, i, options, env, this);\n+                        } else {\n+                            result += this.renderToken(tokens, i, options);\n                         }\n-                    };\n-                }\n-                var nullCallback = function() {\n-                    return null;\n+                    }\n+                    return result;\n                 };\n-                // lets maintain a weak ref to, well, ref :)\n-                // not using `kashe` to keep this package small\n-                var weakMem = new WeakMap();\n-                var weakMemoize = function(ref) {\n-                    var usedRef = ref || nullCallback;\n-                    var storedRef = weakMem.get(usedRef);\n-                    if (storedRef) {\n-                        return storedRef;\n+\n+                /** internal\n+                 * Renderer.renderInlineAsText(tokens, options, env) -> String\n+                 * - tokens (Array): list on block tokens to render\n+                 * - options (Object): params of parser instance\n+                 * - env (Object): additional data from parsed input (references, for example)\n+                 *\n+                 * Special kludge for image `alt` attributes to conform CommonMark spec.\n+                 * Don't try to use it! Spec requires to show `alt` content with stripped markup,\n+                 * instead of simple escaping.\n+                 **/\n+                Renderer.prototype.renderInlineAsText = function(tokens, options, env) {\n+                    let result = '';\n+                    for (let i = 0, len = tokens.length; i < len; i++) {\n+                        switch (tokens[i].type) {\n+                            case 'text':\n+                                result += tokens[i].content;\n+                                break;\n+                            case 'image':\n+                                result += this.renderInlineAsText(tokens[i].children, options, env);\n+                                break;\n+                            case 'html_inline':\n+                            case 'html_block':\n+                                result += tokens[i].content;\n+                                break;\n+                            case 'softbreak':\n+                            case 'hardbreak':\n+                                result += '\\n';\n+                                break;\n+                                // all other tokens are skipped\n+                        }\n                     }\n-                    var cb = refToCallback(usedRef);\n-                    weakMem.set(usedRef, cb);\n-                    return cb;\n+                    return result;\n                 };\n+\n                 /**\n-                 * Transforms a given `ref` into `callback`.\n+                 * Renderer.render(tokens, options, env) -> String\n+                 * - tokens (Array): list on block tokens to render\n+                 * - options (Object): params of parser instance\n+                 * - env (Object): additional data from parsed input (references, for example)\n                  *\n-                 * To transform `callback` into ref use {@link useCallbackRef|useCallbackRef(undefined, callback)}\n+                 * Takes token stream and generates HTML. Probably, you will never need to call\n+                 * this method directly.\n+                 **/\n+                Renderer.prototype.render = function(tokens, options, env) {\n+                    let result = '';\n+                    const rules = this.rules;\n+                    for (let i = 0, len = tokens.length; i < len; i++) {\n+                        const type = tokens[i].type;\n+                        if (type === 'inline') {\n+                            result += this.renderInline(tokens[i].children, options, env);\n+                        } else if (typeof rules[type] !== 'undefined') {\n+                            result += rules[type](tokens, i, options, env, this);\n+                        } else {\n+                            result += this.renderToken(tokens, i, options, env);\n+                        }\n+                    }\n+                    return result;\n+                };\n+\n+                /**\n+                 * class Ruler\n                  *\n-                 * @param {ReactRef} ref\n-                 * @returns {Function}\n+                 * Helper class, used by [[MarkdownIt#core]], [[MarkdownIt#block]] and\n+                 * [[MarkdownIt#inline]] to manage sequences of functions (rules):\n                  *\n-                 * @see https://github.com/theKashey/use-callback-ref#reftocallback\n+                 * - keep rules in defined order\n+                 * - assign the name to each rule\n+                 * - enable/disable rules\n+                 * - add/replace rules\n+                 * - allow assign rules to additional named chains (in the same)\n+                 * - cacheing lists of active rules\n                  *\n-                 * @example\n-                 * const ref = useRef(0);\n-                 * const setRef = useRefToCallback(ref);\n-                 * \ud83d\udc49 setRef(10);\n-                 * \u2705 ref.current === 10\n-                 */\n-                function useRefToCallback(ref) {\n-                    return weakMemoize(ref);\n+                 * You will not need use this class directly until write plugins. For simple\n+                 * rules control use [[MarkdownIt.disable]], [[MarkdownIt.enable]] and\n+                 * [[MarkdownIt.use]].\n+                 **/\n+\n+                /**\n+                 * new Ruler()\n+                 **/\n+                function Ruler() {\n+                    // List of added rules. Each element is:\n+                    //\n+                    // {\n+                    //   name: XXX,\n+                    //   enabled: Boolean,\n+                    //   fn: Function(),\n+                    //   alt: [ name2, name3 ]\n+                    // }\n+                    //\n+                    this.__rules__ = [];\n+\n+                    // Cached rule chains.\n+                    //\n+                    // First level - chain name, '' for default.\n+                    // Second level - diginal anchor for fast filtering by charcodes.\n+                    //\n+                    this.__cache__ = null;\n                 }\n \n-                /***/\n-            }),\n+                // Helper methods, should not be used directly\n \n-        /***/\n-        \"../../../node_modules/use-callback-ref/dist/es2015/transformRef.js\":\n-            /*!**************************************************************************!*\\\n-              !*** ../../../node_modules/use-callback-ref/dist/es2015/transformRef.js ***!\n-              \\**************************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                // Find rule index by name\n+                //\n+                Ruler.prototype.__find__ = function(name) {\n+                    for (let i = 0; i < this.__rules__.length; i++) {\n+                        if (this.__rules__[i].name === name) {\n+                            return i;\n+                        }\n+                    }\n+                    return -1;\n+                };\n \n+                // Build rules lookup cache\n+                //\n+                Ruler.prototype.__compile__ = function() {\n+                    const self = this;\n+                    const chains = [''];\n \n+                    // collect unique names\n+                    self.__rules__.forEach(function(rule) {\n+                        if (!rule.enabled) {\n+                            return;\n+                        }\n+                        rule.alt.forEach(function(altName) {\n+                            if (chains.indexOf(altName) < 0) {\n+                                chains.push(altName);\n+                            }\n+                        });\n+                    });\n+                    self.__cache__ = {};\n+                    chains.forEach(function(chain) {\n+                        self.__cache__[chain] = [];\n+                        self.__rules__.forEach(function(rule) {\n+                            if (!rule.enabled) {\n+                                return;\n+                            }\n+                            if (chain && rule.alt.indexOf(chain) < 0) {\n+                                return;\n+                            }\n+                            self.__cache__[chain].push(rule.fn);\n+                        });\n+                    });\n+                };\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.transformRef = transformRef;\n-                var _assignRef = __webpack_require__( /*! ./assignRef */ \"../../../node_modules/use-callback-ref/dist/es2015/assignRef.js\");\n-                var _createRef = __webpack_require__( /*! ./createRef */ \"../../../node_modules/use-callback-ref/dist/es2015/createRef.js\");\n                 /**\n-                 * Transforms one ref to another\n-                 * @example\n-                 * ```tsx\n-                 * const ResizableWithRef = forwardRef((props, ref) =>\n-                 *   <Resizable {...props} ref={transformRef(ref, i => i ? i.resizable : null)}/>\n-                 * );\n+                 * Ruler.at(name, fn [, options])\n+                 * - name (String): rule name to replace.\n+                 * - fn (Function): new rule function.\n+                 * - options (Object): new rule options (not mandatory).\n+                 *\n+                 * Replace rule by name with new function & options. Throws error if name not\n+                 * found.\n+                 *\n+                 * ##### Options:\n+                 *\n+                 * - __alt__ - array with names of \"alternate\" chains.\n+                 *\n+                 * ##### Example\n+                 *\n+                 * Replace existing typographer replacement rule with new one:\n+                 *\n+                 * ```javascript\n+                 * var md = require('markdown-it')();\n+                 *\n+                 * md.core.ruler.at('replacements', function replace(state) {\n+                 *   //...\n+                 * });\n                  * ```\n-                 */\n-                function transformRef(ref, transformer) {\n-                    return (0, _createRef.createCallbackRef)(function(value) {\n-                        return (0, _assignRef.assignRef)(ref, transformer(value));\n-                    });\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/use-callback-ref/dist/es2015/useMergeRef.js\":\n-            /*!*************************************************************************!*\\\n-              !*** ../../../node_modules/use-callback-ref/dist/es2015/useMergeRef.js ***!\n-              \\*************************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n+                 **/\n+                Ruler.prototype.at = function(name, fn, options) {\n+                    const index = this.__find__(name);\n+                    const opt = options || {};\n+                    if (index === -1) {\n+                        throw new Error('Parser rule not found: ' + name);\n+                    }\n+                    this.__rules__[index].fn = fn;\n+                    this.__rules__[index].alt = opt.alt || [];\n+                    this.__cache__ = null;\n+                };\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.useMergeRefs = useMergeRefs;\n-                var _assignRef = __webpack_require__( /*! ./assignRef */ \"../../../node_modules/use-callback-ref/dist/es2015/assignRef.js\");\n-                var _useRef = __webpack_require__( /*! ./useRef */ \"../../../node_modules/use-callback-ref/dist/es2015/useRef.js\");\n                 /**\n-                 * Merges two or more refs together providing a single interface to set their value\n-                 * @param {RefObject|Ref} refs\n-                 * @returns {MutableRefObject} - a new ref, which translates all changes to {refs}\n+                 * Ruler.before(beforeName, ruleName, fn [, options])\n+                 * - beforeName (String): new rule will be added before this one.\n+                 * - ruleName (String): name of added rule.\n+                 * - fn (Function): rule function.\n+                 * - options (Object): rule options (not mandatory).\n                  *\n-                 * @see {@link mergeRefs} a version without buit-in memoization\n-                 * @see https://github.com/theKashey/use-callback-ref#usemergerefs\n-                 * @example\n-                 * const Component = React.forwardRef((props, ref) => {\n-                 *   const ownRef = useRef();\n-                 *   const domRef = useMergeRefs([ref, ownRef]); // \ud83d\udc48 merge together\n-                 *   return <div ref={domRef}>...</div>\n-                 * }\n-                 */\n-                function useMergeRefs(refs, defaultValue) {\n-                    return (0, _useRef.useCallbackRef)(defaultValue || null, function(newValue) {\n-                        return refs.forEach(function(ref) {\n-                            return (0, _assignRef.assignRef)(ref, newValue);\n-                        });\n+                 * Add new rule to chain before one with given name. See also\n+                 * [[Ruler.after]], [[Ruler.push]].\n+                 *\n+                 * ##### Options:\n+                 *\n+                 * - __alt__ - array with names of \"alternate\" chains.\n+                 *\n+                 * ##### Example\n+                 *\n+                 * ```javascript\n+                 * var md = require('markdown-it')();\n+                 *\n+                 * md.block.ruler.before('paragraph', 'my_rule', function replace(state) {\n+                 *   //...\n+                 * });\n+                 * ```\n+                 **/\n+                Ruler.prototype.before = function(beforeName, ruleName, fn, options) {\n+                    const index = this.__find__(beforeName);\n+                    const opt = options || {};\n+                    if (index === -1) {\n+                        throw new Error('Parser rule not found: ' + beforeName);\n+                    }\n+                    this.__rules__.splice(index, 0, {\n+                        name: ruleName,\n+                        enabled: true,\n+                        fn,\n+                        alt: opt.alt || []\n                     });\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/use-callback-ref/dist/es2015/useRef.js\":\n-            /*!********************************************************************!*\\\n-              !*** ../../../node_modules/use-callback-ref/dist/es2015/useRef.js ***!\n-              \\********************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                    this.__cache__ = null;\n+                };\n \n+                /**\n+                 * Ruler.after(afterName, ruleName, fn [, options])\n+                 * - afterName (String): new rule will be added after this one.\n+                 * - ruleName (String): name of added rule.\n+                 * - fn (Function): rule function.\n+                 * - options (Object): rule options (not mandatory).\n+                 *\n+                 * Add new rule to chain after one with given name. See also\n+                 * [[Ruler.before]], [[Ruler.push]].\n+                 *\n+                 * ##### Options:\n+                 *\n+                 * - __alt__ - array with names of \"alternate\" chains.\n+                 *\n+                 * ##### Example\n+                 *\n+                 * ```javascript\n+                 * var md = require('markdown-it')();\n+                 *\n+                 * md.inline.ruler.after('text', 'my_rule', function replace(state) {\n+                 *   //...\n+                 * });\n+                 * ```\n+                 **/\n+                Ruler.prototype.after = function(afterName, ruleName, fn, options) {\n+                    const index = this.__find__(afterName);\n+                    const opt = options || {};\n+                    if (index === -1) {\n+                        throw new Error('Parser rule not found: ' + afterName);\n+                    }\n+                    this.__rules__.splice(index + 1, 0, {\n+                        name: ruleName,\n+                        enabled: true,\n+                        fn,\n+                        alt: opt.alt || []\n+                    });\n+                    this.__cache__ = null;\n+                };\n \n+                /**\n+                 * Ruler.push(ruleName, fn [, options])\n+                 * - ruleName (String): name of added rule.\n+                 * - fn (Function): rule function.\n+                 * - options (Object): rule options (not mandatory).\n+                 *\n+                 * Push new rule to the end of chain. See also\n+                 * [[Ruler.before]], [[Ruler.after]].\n+                 *\n+                 * ##### Options:\n+                 *\n+                 * - __alt__ - array with names of \"alternate\" chains.\n+                 *\n+                 * ##### Example\n+                 *\n+                 * ```javascript\n+                 * var md = require('markdown-it')();\n+                 *\n+                 * md.core.ruler.push('my_rule', function replace(state) {\n+                 *   //...\n+                 * });\n+                 * ```\n+                 **/\n+                Ruler.prototype.push = function(ruleName, fn, options) {\n+                    const opt = options || {};\n+                    this.__rules__.push({\n+                        name: ruleName,\n+                        enabled: true,\n+                        fn,\n+                        alt: opt.alt || []\n+                    });\n+                    this.__cache__ = null;\n+                };\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.useCallbackRef = useCallbackRef;\n-                var _react = __webpack_require__( /*! react */ \"react\");\n                 /**\n-                 * creates a MutableRef with ref change callback\n-                 * @param initialValue - initial ref value\n-                 * @param {Function} callback - a callback to run when value changes\n+                 * Ruler.enable(list [, ignoreInvalid]) -> Array\n+                 * - list (String|Array): list of rule names to enable.\n+                 * - ignoreInvalid (Boolean): set `true` to ignore errors when rule not found.\n                  *\n-                 * @example\n-                 * const ref = useCallbackRef(0, (newValue, oldValue) => console.log(oldValue, '->', newValue);\n-                 * ref.current = 1;\n-                 * // prints 0 -> 1\n+                 * Enable rules with given names. If any rule name not found - throw Error.\n+                 * Errors can be disabled by second param.\n                  *\n-                 * @see https://reactjs.org/docs/hooks-reference.html#useref\n-                 * @see https://github.com/theKashey/use-callback-ref#usecallbackref---to-replace-reactuseref\n-                 * @returns {MutableRefObject}\n-                 */\n-                function useCallbackRef(initialValue, callback) {\n-                    var ref = (0, _react.useState)(function() {\n-                        return {\n-                            // value\n-                            value: initialValue,\n-                            // last callback\n-                            callback: callback,\n-                            // \"memoized\" public interface\n-                            facade: {\n-                                get current() {\n-                                    return ref.value;\n-                                },\n-                                set current(value) {\n-                                    var last = ref.value;\n-                                    if (last !== value) {\n-                                        ref.value = value;\n-                                        ref.callback(value, last);\n-                                    }\n-                                }\n-                            }\n-                        };\n-                    })[0];\n-                    // update callback\n-                    ref.callback = callback;\n-                    return ref.facade;\n-                }\n+                 * Returns list of found rule names (if no exception happened).\n+                 *\n+                 * See also [[Ruler.disable]], [[Ruler.enableOnly]].\n+                 **/\n+                Ruler.prototype.enable = function(list, ignoreInvalid) {\n+                    if (!Array.isArray(list)) {\n+                        list = [list];\n+                    }\n+                    const result = [];\n \n-                /***/\n-            }),\n+                    // Search by name and enable\n+                    list.forEach(function(name) {\n+                        const idx = this.__find__(name);\n+                        if (idx < 0) {\n+                            if (ignoreInvalid) {\n+                                return;\n+                            }\n+                            throw new Error('Rules manager: invalid rule name ' + name);\n+                        }\n+                        this.__rules__[idx].enabled = true;\n+                        result.push(name);\n+                    }, this);\n+                    this.__cache__ = null;\n+                    return result;\n+                };\n \n-        /***/\n-        \"../../../node_modules/use-callback-ref/dist/es2015/useTransformRef.js\":\n-            /*!*****************************************************************************!*\\\n-              !*** ../../../node_modules/use-callback-ref/dist/es2015/useTransformRef.js ***!\n-              \\*****************************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                /**\n+                 * Ruler.enableOnly(list [, ignoreInvalid])\n+                 * - list (String|Array): list of rule names to enable (whitelist).\n+                 * - ignoreInvalid (Boolean): set `true` to ignore errors when rule not found.\n+                 *\n+                 * Enable rules with given names, and disable everything else. If any rule name\n+                 * not found - throw Error. Errors can be disabled by second param.\n+                 *\n+                 * See also [[Ruler.disable]], [[Ruler.enable]].\n+                 **/\n+                Ruler.prototype.enableOnly = function(list, ignoreInvalid) {\n+                    if (!Array.isArray(list)) {\n+                        list = [list];\n+                    }\n+                    this.__rules__.forEach(function(rule) {\n+                        rule.enabled = false;\n+                    });\n+                    this.enable(list, ignoreInvalid);\n+                };\n \n+                /**\n+                 * Ruler.disable(list [, ignoreInvalid]) -> Array\n+                 * - list (String|Array): list of rule names to disable.\n+                 * - ignoreInvalid (Boolean): set `true` to ignore errors when rule not found.\n+                 *\n+                 * Disable rules with given names. If any rule name not found - throw Error.\n+                 * Errors can be disabled by second param.\n+                 *\n+                 * Returns list of found rule names (if no exception happened).\n+                 *\n+                 * See also [[Ruler.enable]], [[Ruler.enableOnly]].\n+                 **/\n+                Ruler.prototype.disable = function(list, ignoreInvalid) {\n+                    if (!Array.isArray(list)) {\n+                        list = [list];\n+                    }\n+                    const result = [];\n \n+                    // Search by name and disable\n+                    list.forEach(function(name) {\n+                        const idx = this.__find__(name);\n+                        if (idx < 0) {\n+                            if (ignoreInvalid) {\n+                                return;\n+                            }\n+                            throw new Error('Rules manager: invalid rule name ' + name);\n+                        }\n+                        this.__rules__[idx].enabled = false;\n+                        result.push(name);\n+                    }, this);\n+                    this.__cache__ = null;\n+                    return result;\n+                };\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.useTransformRef = useTransformRef;\n-                var _assignRef = __webpack_require__( /*! ./assignRef */ \"../../../node_modules/use-callback-ref/dist/es2015/assignRef.js\");\n-                var _useRef = __webpack_require__( /*! ./useRef */ \"../../../node_modules/use-callback-ref/dist/es2015/useRef.js\");\n                 /**\n-                 * Create a _lense_ on Ref, making it possible to transform ref value\n-                 * @param {ReactRef} ref\n-                 * @param {Function} transformer. \ud83d\udc49 Ref would be __NOT updated__ on `transformer` update.\n-                 * @returns {RefObject}\n+                 * Ruler.getRules(chainName) -> Array\n                  *\n-                 * @see https://github.com/theKashey/use-callback-ref#usetransformref-to-replace-reactuseimperativehandle\n-                 * @example\n+                 * Return array of active functions (rules) for given chain name. It analyzes\n+                 * rules configuration, compiles caches if not exists and returns result.\n                  *\n-                 * const ResizableWithRef = forwardRef((props, ref) =>\n-                 *  <Resizable {...props} ref={useTransformRef(ref, i => i ? i.resizable : null)}/>\n-                 * );\n-                 */\n-                function useTransformRef(ref, transformer) {\n-                    return (0, _useRef.useCallbackRef)(null, function(value) {\n-                        return (0, _assignRef.assignRef)(ref, transformer(value));\n-                    });\n-                }\n+                 * Default chain name is `''` (empty string). It can't be skipped. That's\n+                 * done intentionally, to keep signature monomorphic for high speed.\n+                 **/\n+                Ruler.prototype.getRules = function(chainName) {\n+                    if (this.__cache__ === null) {\n+                        this.__compile__();\n+                    }\n \n-                /***/\n-            }),\n+                    // Chain can be empty, if rules disabled. But we still have to return Array.\n+                    return this.__cache__[chainName] || [];\n+                };\n \n-        /***/\n-        \"../../../node_modules/use-sidecar/dist/es2015/config.js\":\n-            /*!***************************************************************!*\\\n-              !*** ../../../node_modules/use-sidecar/dist/es2015/config.js ***!\n-              \\***************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports) {\n+                // Token class\n \n+                /**\n+                 * class Token\n+                 **/\n \n+                /**\n+                 * new Token(type, tag, nesting)\n+                 *\n+                 * Create new token and fill passed properties.\n+                 **/\n+                function Token(type, tag, nesting) {\n+                    /**\n+                     * Token#type -> String\n+                     *\n+                     * Type of the token (string, e.g. \"paragraph_open\")\n+                     **/\n+                    this.type = type;\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.setConfig = exports.config = void 0;\n-                var config = {\n-                    onError: function(e) {\n-                        return console.error(e);\n-                    }\n-                };\n-                exports.config = config;\n-                var setConfig = function(conf) {\n-                    Object.assign(config, conf);\n-                };\n-                exports.setConfig = setConfig;\n+                    /**\n+                     * Token#tag -> String\n+                     *\n+                     * html tag name, e.g. \"p\"\n+                     **/\n+                    this.tag = tag;\n \n-                /***/\n-            }),\n+                    /**\n+                     * Token#attrs -> Array\n+                     *\n+                     * Html attributes. Format: `[ [ name1, value1 ], [ name2, value2 ] ]`\n+                     **/\n+                    this.attrs = null;\n \n-        /***/\n-        \"../../../node_modules/use-sidecar/dist/es2015/env.js\":\n-            /*!************************************************************!*\\\n-              !*** ../../../node_modules/use-sidecar/dist/es2015/env.js ***!\n-              \\************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                    /**\n+                     * Token#map -> Array\n+                     *\n+                     * Source map info. Format: `[ line_begin, line_end ]`\n+                     **/\n+                    this.map = null;\n \n+                    /**\n+                     * Token#nesting -> Number\n+                     *\n+                     * Level change (number in {-1, 0, 1} set), where:\n+                     *\n+                     * -  `1` means the tag is opening\n+                     * -  `0` means the tag is self-closing\n+                     * - `-1` means the tag is closing\n+                     **/\n+                    this.nesting = nesting;\n \n+                    /**\n+                     * Token#level -> Number\n+                     *\n+                     * nesting level, the same as `state.level`\n+                     **/\n+                    this.level = 0;\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.env = void 0;\n-                var _detectNodeEs = __webpack_require__( /*! detect-node-es */ \"../../../node_modules/detect-node-es/esm/browser.js\");\n-                var env = {\n-                    isNode: _detectNodeEs.isNode,\n-                    forceCache: false\n-                };\n-                exports.env = env;\n+                    /**\n+                     * Token#children -> Array\n+                     *\n+                     * An array of child nodes (inline and img tokens)\n+                     **/\n+                    this.children = null;\n \n-                /***/\n-            }),\n+                    /**\n+                     * Token#content -> String\n+                     *\n+                     * In a case of self-closing tag (code, html, fence, etc.),\n+                     * it has contents of this tag.\n+                     **/\n+                    this.content = '';\n \n-        /***/\n-        \"../../../node_modules/use-sidecar/dist/es2015/exports.js\":\n-            /*!****************************************************************!*\\\n-              !*** ../../../node_modules/use-sidecar/dist/es2015/exports.js ***!\n-              \\****************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                    /**\n+                     * Token#markup -> String\n+                     *\n+                     * '*' or '_' for emphasis, fence string for fence, etc.\n+                     **/\n+                    this.markup = '';\n \n+                    /**\n+                     * Token#info -> String\n+                     *\n+                     * Additional information:\n+                     *\n+                     * - Info string for \"fence\" tokens\n+                     * - The value \"auto\" for autolink \"link_open\" and \"link_close\" tokens\n+                     * - The string value of the item marker for ordered-list \"list_item_open\" tokens\n+                     **/\n+                    this.info = '';\n \n+                    /**\n+                     * Token#meta -> Object\n+                     *\n+                     * A place for plugins to store an arbitrary data\n+                     **/\n+                    this.meta = null;\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.exportSidecar = exportSidecar;\n-                var _tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.js\");\n-                var React = _interopRequireWildcard(__webpack_require__( /*! react */ \"react\"));\n+                    /**\n+                     * Token#block -> Boolean\n+                     *\n+                     * True for block-level tokens, false for inline tokens.\n+                     * Used in renderer to calculate line breaks\n+                     **/\n+                    this.block = false;\n \n-                function _getRequireWildcardCache(nodeInterop) {\n-                    if (typeof WeakMap !== \"function\") return null;\n-                    var cacheBabelInterop = new WeakMap();\n-                    var cacheNodeInterop = new WeakMap();\n-                    return (_getRequireWildcardCache = function(nodeInterop) {\n-                        return nodeInterop ? cacheNodeInterop : cacheBabelInterop;\n-                    })(nodeInterop);\n+                    /**\n+                     * Token#hidden -> Boolean\n+                     *\n+                     * If it's true, ignore this element when rendering. Used for tight lists\n+                     * to hide paragraphs.\n+                     **/\n+                    this.hidden = false;\n                 }\n \n-                function _interopRequireWildcard(obj, nodeInterop) {\n-                    if (!nodeInterop && obj && obj.__esModule) {\n-                        return obj;\n-                    }\n-                    if (obj === null || typeof obj !== \"object\" && typeof obj !== \"function\") {\n-                        return {\n-                            default: obj\n-                        };\n+                /**\n+                 * Token.attrIndex(name) -> Number\n+                 *\n+                 * Search attribute index by name.\n+                 **/\n+                Token.prototype.attrIndex = function attrIndex(name) {\n+                    if (!this.attrs) {\n+                        return -1;\n                     }\n-                    var cache = _getRequireWildcardCache(nodeInterop);\n-                    if (cache && cache.has(obj)) {\n-                        return cache.get(obj);\n-                    }\n-                    var newObj = {};\n-                    var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;\n-                    for (var key in obj) {\n-                        if (key !== \"default\" && Object.prototype.hasOwnProperty.call(obj, key)) {\n-                            var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;\n-                            if (desc && (desc.get || desc.set)) {\n-                                Object.defineProperty(newObj, key, desc);\n-                            } else {\n-                                newObj[key] = obj[key];\n-                            }\n+                    const attrs = this.attrs;\n+                    for (let i = 0, len = attrs.length; i < len; i++) {\n+                        if (attrs[i][0] === name) {\n+                            return i;\n                         }\n                     }\n-                    newObj.default = obj;\n-                    if (cache) {\n-                        cache.set(obj, newObj);\n+                    return -1;\n+                };\n+\n+                /**\n+                 * Token.attrPush(attrData)\n+                 *\n+                 * Add `[ name, value ]` attribute to list. Init attrs if necessary\n+                 **/\n+                Token.prototype.attrPush = function attrPush(attrData) {\n+                    if (this.attrs) {\n+                        this.attrs.push(attrData);\n+                    } else {\n+                        this.attrs = [attrData];\n                     }\n-                    return newObj;\n-                }\n-                var SideCar = function(_a) {\n-                    var sideCar = _a.sideCar,\n-                        rest = (0, _tslib.__rest)(_a, [\"sideCar\"]);\n-                    if (!sideCar) {\n-                        throw new Error('Sidecar: please provide `sideCar` property to import the right car');\n+                };\n+\n+                /**\n+                 * Token.attrSet(name, value)\n+                 *\n+                 * Set `name` attribute to `value`. Override old value if exists.\n+                 **/\n+                Token.prototype.attrSet = function attrSet(name, value) {\n+                    const idx = this.attrIndex(name);\n+                    const attrData = [name, value];\n+                    if (idx < 0) {\n+                        this.attrPush(attrData);\n+                    } else {\n+                        this.attrs[idx] = attrData;\n                     }\n-                    var Target = sideCar.read();\n-                    if (!Target) {\n-                        throw new Error('Sidecar medium not found');\n+                };\n+\n+                /**\n+                 * Token.attrGet(name)\n+                 *\n+                 * Get the value of attribute `name`, or null if it does not exist.\n+                 **/\n+                Token.prototype.attrGet = function attrGet(name) {\n+                    const idx = this.attrIndex(name);\n+                    let value = null;\n+                    if (idx >= 0) {\n+                        value = this.attrs[idx][1];\n                     }\n-                    return /*#__PURE__*/ React.createElement(Target, (0, _tslib.__assign)({}, rest));\n+                    return value;\n                 };\n-                SideCar.isSideCarExport = true;\n \n-                function exportSidecar(medium, exported) {\n-                    medium.useMedium(exported);\n-                    return SideCar;\n+                /**\n+                 * Token.attrJoin(name, value)\n+                 *\n+                 * Join value to existing attribute via space. Or create new attribute if not\n+                 * exists. Useful to operate with token classes.\n+                 **/\n+                Token.prototype.attrJoin = function attrJoin(name, value) {\n+                    const idx = this.attrIndex(name);\n+                    if (idx < 0) {\n+                        this.attrPush([name, value]);\n+                    } else {\n+                        this.attrs[idx][1] = this.attrs[idx][1] + ' ' + value;\n+                    }\n+                };\n+\n+                // Core state object\n+                //\n+\n+                function StateCore(src, md, env) {\n+                    this.src = src;\n+                    this.env = env;\n+                    this.tokens = [];\n+                    this.inlineMode = false;\n+                    this.md = md; // link to parser instance\n                 }\n \n-                /***/\n-            }),\n+                // re-export Token class to use in core rules\n+                StateCore.prototype.Token = Token;\n \n-        /***/\n-        \"../../../node_modules/use-sidecar/dist/es2015/hoc.js\":\n-            /*!************************************************************!*\\\n-              !*** ../../../node_modules/use-sidecar/dist/es2015/hoc.js ***!\n-              \\************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                // Normalize input string\n \n+                // https://spec.commonmark.org/0.29/#line-ending\n+                const NEWLINES_RE = /\\r\\n?|\\n/g;\n+                const NULL_RE = /\\0/g;\n \n+                function normalize(state) {\n+                    let str;\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.sidecar = sidecar;\n-                var _tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.js\");\n-                var React = _interopRequireWildcard(__webpack_require__( /*! react */ \"react\"));\n-                var _hook = __webpack_require__( /*! ./hook */ \"../../../node_modules/use-sidecar/dist/es2015/hook.js\");\n+                    // Normalize newlines\n+                    str = state.src.replace(NEWLINES_RE, '\\n');\n \n-                function _getRequireWildcardCache(nodeInterop) {\n-                    if (typeof WeakMap !== \"function\") return null;\n-                    var cacheBabelInterop = new WeakMap();\n-                    var cacheNodeInterop = new WeakMap();\n-                    return (_getRequireWildcardCache = function(nodeInterop) {\n-                        return nodeInterop ? cacheNodeInterop : cacheBabelInterop;\n-                    })(nodeInterop);\n+                    // Replace NULL characters\n+                    str = str.replace(NULL_RE, '\\uFFFD');\n+                    state.src = str;\n                 }\n \n-                function _interopRequireWildcard(obj, nodeInterop) {\n-                    if (!nodeInterop && obj && obj.__esModule) {\n-                        return obj;\n-                    }\n-                    if (obj === null || typeof obj !== \"object\" && typeof obj !== \"function\") {\n-                        return {\n-                            default: obj\n-                        };\n+                function block(state) {\n+                    let token;\n+                    if (state.inlineMode) {\n+                        token = new state.Token('inline', '', 0);\n+                        token.content = state.src;\n+                        token.map = [0, 1];\n+                        token.children = [];\n+                        state.tokens.push(token);\n+                    } else {\n+                        state.md.block.parse(state.src, state.md, state.env, state.tokens);\n                     }\n-                    var cache = _getRequireWildcardCache(nodeInterop);\n-                    if (cache && cache.has(obj)) {\n-                        return cache.get(obj);\n-                    }\n-                    var newObj = {};\n-                    var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;\n-                    for (var key in obj) {\n-                        if (key !== \"default\" && Object.prototype.hasOwnProperty.call(obj, key)) {\n-                            var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;\n-                            if (desc && (desc.get || desc.set)) {\n-                                Object.defineProperty(newObj, key, desc);\n-                            } else {\n-                                newObj[key] = obj[key];\n-                            }\n+                }\n+\n+                function inline(state) {\n+                    const tokens = state.tokens;\n+\n+                    // Parse inlines\n+                    for (let i = 0, l = tokens.length; i < l; i++) {\n+                        const tok = tokens[i];\n+                        if (tok.type === 'inline') {\n+                            state.md.inline.parse(tok.content, state.md, state.env, tok.children);\n                         }\n                     }\n-                    newObj.default = obj;\n-                    if (cache) {\n-                        cache.set(obj, newObj);\n-                    }\n-                    return newObj;\n                 }\n-                // eslint-disable-next-line @typescript-eslint/ban-types\n-                function sidecar(importer, errorComponent) {\n-                    var ErrorCase = function() {\n-                        return errorComponent;\n-                    };\n-                    return function Sidecar(props) {\n-                        var _a = (0, _hook.useSidecar)(importer, props.sideCar),\n-                            Car = _a[0],\n-                            error = _a[1];\n-                        if (error && errorComponent) {\n-                            return ErrorCase;\n-                        }\n-                        // @ts-expect-error type shenanigans\n-                        return Car ? /*#__PURE__*/ React.createElement(Car, (0, _tslib.__assign)({}, props)) : null;\n-                    };\n+\n+                // Replace link-like texts with link nodes.\n+                //\n+                // Currently restricted by `md.validateLink()` to http/https/ftp\n+                //\n+\n+                function isLinkOpen$1(str) {\n+                    return /^<a[>\\s]/i.test(str);\n                 }\n \n-                /***/\n-            }),\n+                function isLinkClose$1(str) {\n+                    return /^<\\/a\\s*>/i.test(str);\n+                }\n \n-        /***/\n-        \"../../../node_modules/use-sidecar/dist/es2015/hook.js\":\n-            /*!*************************************************************!*\\\n-              !*** ../../../node_modules/use-sidecar/dist/es2015/hook.js ***!\n-              \\*************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                function linkify$1(state) {\n+                    const blockTokens = state.tokens;\n+                    if (!state.md.options.linkify) {\n+                        return;\n+                    }\n+                    for (let j = 0, l = blockTokens.length; j < l; j++) {\n+                        if (blockTokens[j].type !== 'inline' || !state.md.linkify.pretest(blockTokens[j].content)) {\n+                            continue;\n+                        }\n+                        let tokens = blockTokens[j].children;\n+                        let htmlLinkLevel = 0;\n \n+                        // We scan from the end, to keep position when new tags added.\n+                        // Use reversed logic in links start/end match\n+                        for (let i = tokens.length - 1; i >= 0; i--) {\n+                            const currentToken = tokens[i];\n \n+                            // Skip content of markdown links\n+                            if (currentToken.type === 'link_close') {\n+                                i--;\n+                                while (tokens[i].level !== currentToken.level && tokens[i].type !== 'link_open') {\n+                                    i--;\n+                                }\n+                                continue;\n+                            }\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.useSidecar = useSidecar;\n-                var _react = __webpack_require__( /*! react */ \"react\");\n-                var _env = __webpack_require__( /*! ./env */ \"../../../node_modules/use-sidecar/dist/es2015/env.js\");\n-                var cache = new WeakMap();\n-                var NO_OPTIONS = {};\n+                            // Skip content of html tag links\n+                            if (currentToken.type === 'html_inline') {\n+                                if (isLinkOpen$1(currentToken.content) && htmlLinkLevel > 0) {\n+                                    htmlLinkLevel--;\n+                                }\n+                                if (isLinkClose$1(currentToken.content)) {\n+                                    htmlLinkLevel++;\n+                                }\n+                            }\n+                            if (htmlLinkLevel > 0) {\n+                                continue;\n+                            }\n+                            if (currentToken.type === 'text' && state.md.linkify.test(currentToken.content)) {\n+                                const text = currentToken.content;\n+                                let links = state.md.linkify.match(text);\n \n-                function useSidecar(importer, effect) {\n-                    var options = effect && effect.options || NO_OPTIONS;\n-                    if (_env.env.isNode && !options.ssr) {\n-                        return [null, null];\n-                    }\n-                    // eslint-disable-next-line react-hooks/rules-of-hooks\n-                    return useRealSidecar(importer, effect);\n-                }\n+                                // Now split string to nodes\n+                                const nodes = [];\n+                                let level = currentToken.level;\n+                                let lastPos = 0;\n \n-                function useRealSidecar(importer, effect) {\n-                    var options = effect && effect.options || NO_OPTIONS;\n-                    var couldUseCache = _env.env.forceCache || _env.env.isNode && !!options.ssr || !options.async;\n-                    var _a = (0, _react.useState)(couldUseCache ? function() {\n-                            return cache.get(importer);\n-                        } : undefined),\n-                        Car = _a[0],\n-                        setCar = _a[1];\n-                    var _b = (0, _react.useState)(null),\n-                        error = _b[0],\n-                        setError = _b[1];\n-                    (0, _react.useEffect)(function() {\n-                        if (!Car) {\n-                            importer().then(function(car) {\n-                                var resolved = effect ? effect.read() : car.default || car;\n-                                if (!resolved) {\n-                                    console.error('Sidecar error: with importer', importer);\n-                                    var error_1;\n-                                    if (effect) {\n-                                        console.error('Sidecar error: with medium', effect);\n-                                        error_1 = new Error('Sidecar medium was not found');\n+                                // forbid escape sequence at the start of the string,\n+                                // this avoids http\\://example.com/ from being linkified as\n+                                // http:<a href=\"//example.com/\">//example.com/</a>\n+                                if (links.length > 0 && links[0].index === 0 && i > 0 && tokens[i - 1].type === 'text_special') {\n+                                    links = links.slice(1);\n+                                }\n+                                for (let ln = 0; ln < links.length; ln++) {\n+                                    const url = links[ln].url;\n+                                    const fullUrl = state.md.normalizeLink(url);\n+                                    if (!state.md.validateLink(fullUrl)) {\n+                                        continue;\n+                                    }\n+                                    let urlText = links[ln].text;\n+\n+                                    // Linkifier might send raw hostnames like \"example.com\", where url\n+                                    // starts with domain name. So we prepend http:// in those cases,\n+                                    // and remove it afterwards.\n+                                    //\n+                                    if (!links[ln].schema) {\n+                                        urlText = state.md.normalizeLinkText('http://' + urlText).replace(/^http:\\/\\//, '');\n+                                    } else if (links[ln].schema === 'mailto:' && !/^mailto:/i.test(urlText)) {\n+                                        urlText = state.md.normalizeLinkText('mailto:' + urlText).replace(/^mailto:/, '');\n                                     } else {\n-                                        error_1 = new Error('Sidecar was not found in exports');\n+                                        urlText = state.md.normalizeLinkText(urlText);\n                                     }\n-                                    setError(function() {\n-                                        return error_1;\n-                                    });\n-                                    throw error_1;\n+                                    const pos = links[ln].index;\n+                                    if (pos > lastPos) {\n+                                        const token = new state.Token('text', '', 0);\n+                                        token.content = text.slice(lastPos, pos);\n+                                        token.level = level;\n+                                        nodes.push(token);\n+                                    }\n+                                    const token_o = new state.Token('link_open', 'a', 1);\n+                                    token_o.attrs = [\n+                                        ['href', fullUrl]\n+                                    ];\n+                                    token_o.level = level++;\n+                                    token_o.markup = 'linkify';\n+                                    token_o.info = 'auto';\n+                                    nodes.push(token_o);\n+                                    const token_t = new state.Token('text', '', 0);\n+                                    token_t.content = urlText;\n+                                    token_t.level = level;\n+                                    nodes.push(token_t);\n+                                    const token_c = new state.Token('link_close', 'a', -1);\n+                                    token_c.level = --level;\n+                                    token_c.markup = 'linkify';\n+                                    token_c.info = 'auto';\n+                                    nodes.push(token_c);\n+                                    lastPos = links[ln].lastIndex;\n                                 }\n-                                cache.set(importer, resolved);\n-                                setCar(function() {\n-                                    return resolved;\n-                                });\n-                            }, function(e) {\n-                                return setError(function() {\n-                                    return e;\n-                                });\n-                            });\n+                                if (lastPos < text.length) {\n+                                    const token = new state.Token('text', '', 0);\n+                                    token.content = text.slice(lastPos);\n+                                    token.level = level;\n+                                    nodes.push(token);\n+                                }\n+\n+                                // replace current node\n+                                blockTokens[j].children = tokens = arrayReplaceAt(tokens, i, nodes);\n+                            }\n                         }\n-                    }, []);\n-                    return [Car, error];\n+                    }\n                 }\n \n-                /***/\n-            }),\n+                // Simple typographic replacements\n+                //\n+                // (c) (C) \u2192 \u00a9\n+                // (tm) (TM) \u2192 \u2122\n+                // (r) (R) \u2192 \u00ae\n+                // +- \u2192 \u00b1\n+                // ... \u2192 \u2026 (also ?.... \u2192 ?.., !.... \u2192 !..)\n+                // ???????? \u2192 ???, !!!!! \u2192 !!!, `,,` \u2192 `,`\n+                // -- \u2192 &ndash;, --- \u2192 &mdash;\n+                //\n \n-        /***/\n-        \"../../../node_modules/use-sidecar/dist/es2015/index.js\":\n-            /*!**************************************************************!*\\\n-              !*** ../../../node_modules/use-sidecar/dist/es2015/index.js ***!\n-              \\**************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                // TODO:\n+                // - fractionals 1/2, 1/4, 3/4 -> \u00bd, \u00bc, \u00be\n+                // - multiplications 2 x 4 -> 2 \u00d7 4\n \n+                const RARE_RE = /\\+-|\\.\\.|\\?\\?\\?\\?|!!!!|,,|--/;\n \n+                // Workaround for phantomjs - need regex without /g flag,\n+                // or root check will fail every second time\n+                const SCOPED_ABBR_TEST_RE = /\\((c|tm|r)\\)/i;\n+                const SCOPED_ABBR_RE = /\\((c|tm|r)\\)/ig;\n+                const SCOPED_ABBR = {\n+                    c: '\u00a9',\n+                    r: '\u00ae',\n+                    tm: '\u2122'\n+                };\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                Object.defineProperty(exports, \"createMedium\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _medium.createMedium;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"createSidecarMedium\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _medium.createSidecarMedium;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"exportSidecar\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _exports.exportSidecar;\n-                    }\n-                }));\n-                Object.defineProperty(exports, \"renderCar\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _renderProp.renderCar;\n+                function replaceFn(match, name) {\n+                    return SCOPED_ABBR[name.toLowerCase()];\n+                }\n+\n+                function replace_scoped(inlineTokens) {\n+                    let inside_autolink = 0;\n+                    for (let i = inlineTokens.length - 1; i >= 0; i--) {\n+                        const token = inlineTokens[i];\n+                        if (token.type === 'text' && !inside_autolink) {\n+                            token.content = token.content.replace(SCOPED_ABBR_RE, replaceFn);\n+                        }\n+                        if (token.type === 'link_open' && token.info === 'auto') {\n+                            inside_autolink--;\n+                        }\n+                        if (token.type === 'link_close' && token.info === 'auto') {\n+                            inside_autolink++;\n+                        }\n                     }\n-                }));\n-                Object.defineProperty(exports, \"setConfig\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _config.setConfig;\n+                }\n+\n+                function replace_rare(inlineTokens) {\n+                    let inside_autolink = 0;\n+                    for (let i = inlineTokens.length - 1; i >= 0; i--) {\n+                        const token = inlineTokens[i];\n+                        if (token.type === 'text' && !inside_autolink) {\n+                            if (RARE_RE.test(token.content)) {\n+                                token.content = token.content.replace(/\\+-/g, '\u00b1')\n+                                    // .., ..., ....... -> \u2026\n+                                    // but ?..... & !..... -> ?.. & !..\n+                                    .replace(/\\.{2,}/g, '\u2026').replace(/([?!])\u2026/g, '$1..').replace(/([?!]){4,}/g, '$1$1$1').replace(/,{2,}/g, ',')\n+                                    // em-dash\n+                                    .replace(/(^|[^-])---(?=[^-]|$)/mg, '$1\\u2014')\n+                                    // en-dash\n+                                    .replace(/(^|\\s)--(?=\\s|$)/mg, '$1\\u2013').replace(/(^|[^-\\s])--(?=[^-\\s]|$)/mg, '$1\\u2013');\n+                            }\n+                        }\n+                        if (token.type === 'link_open' && token.info === 'auto') {\n+                            inside_autolink--;\n+                        }\n+                        if (token.type === 'link_close' && token.info === 'auto') {\n+                            inside_autolink++;\n+                        }\n                     }\n-                }));\n-                Object.defineProperty(exports, \"sidecar\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _hoc.sidecar;\n+                }\n+\n+                function replace(state) {\n+                    let blkIdx;\n+                    if (!state.md.options.typographer) {\n+                        return;\n                     }\n-                }));\n-                Object.defineProperty(exports, \"useSidecar\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _hook.useSidecar;\n+                    for (blkIdx = state.tokens.length - 1; blkIdx >= 0; blkIdx--) {\n+                        if (state.tokens[blkIdx].type !== 'inline') {\n+                            continue;\n+                        }\n+                        if (SCOPED_ABBR_TEST_RE.test(state.tokens[blkIdx].content)) {\n+                            replace_scoped(state.tokens[blkIdx].children);\n+                        }\n+                        if (RARE_RE.test(state.tokens[blkIdx].content)) {\n+                            replace_rare(state.tokens[blkIdx].children);\n+                        }\n                     }\n-                }));\n-                var _hoc = __webpack_require__( /*! ./hoc */ \"../../../node_modules/use-sidecar/dist/es2015/hoc.js\");\n-                var _hook = __webpack_require__( /*! ./hook */ \"../../../node_modules/use-sidecar/dist/es2015/hook.js\");\n-                var _config = __webpack_require__( /*! ./config */ \"../../../node_modules/use-sidecar/dist/es2015/config.js\");\n-                var _medium = __webpack_require__( /*! ./medium */ \"../../../node_modules/use-sidecar/dist/es2015/medium.js\");\n-                var _renderProp = __webpack_require__( /*! ./renderProp */ \"../../../node_modules/use-sidecar/dist/es2015/renderProp.js\");\n-                var _exports = __webpack_require__( /*! ./exports */ \"../../../node_modules/use-sidecar/dist/es2015/exports.js\");\n+                }\n \n-                /***/\n-            }),\n+                // Convert straight quotation marks to typographic ones\n+                //\n \n-        /***/\n-        \"../../../node_modules/use-sidecar/dist/es2015/medium.js\":\n-            /*!***************************************************************!*\\\n-              !*** ../../../node_modules/use-sidecar/dist/es2015/medium.js ***!\n-              \\***************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                const QUOTE_TEST_RE = /['\"]/;\n+                const QUOTE_RE = /['\"]/g;\n+                const APOSTROPHE = '\\u2019'; /* \u2019 */\n \n+                function replaceAt(str, index, ch) {\n+                    return str.slice(0, index) + ch + str.slice(index + 1);\n+                }\n \n+                function process_inlines(tokens, state) {\n+                    let j;\n+                    const stack = [];\n+                    for (let i = 0; i < tokens.length; i++) {\n+                        const token = tokens[i];\n+                        const thisLevel = tokens[i].level;\n+                        for (j = stack.length - 1; j >= 0; j--) {\n+                            if (stack[j].level <= thisLevel) {\n+                                break;\n+                            }\n+                        }\n+                        stack.length = j + 1;\n+                        if (token.type !== 'text') {\n+                            continue;\n+                        }\n+                        let text = token.content;\n+                        let pos = 0;\n+                        let max = text.length;\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.createMedium = createMedium;\n-                exports.createSidecarMedium = createSidecarMedium;\n-                var _tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.js\");\n+                        /* eslint no-labels:0,block-scoped-var:0 */\n+                        OUTER: while (pos < max) {\n+                            QUOTE_RE.lastIndex = pos;\n+                            const t = QUOTE_RE.exec(text);\n+                            if (!t) {\n+                                break;\n+                            }\n+                            let canOpen = true;\n+                            let canClose = true;\n+                            pos = t.index + 1;\n+                            const isSingle = t[0] === \"'\";\n \n-                function ItoI(a) {\n-                    return a;\n-                }\n+                            // Find previous character,\n+                            // default to space if it's the beginning of the line\n+                            //\n+                            let lastChar = 0x20;\n+                            if (t.index - 1 >= 0) {\n+                                lastChar = text.charCodeAt(t.index - 1);\n+                            } else {\n+                                for (j = i - 1; j >= 0; j--) {\n+                                    if (tokens[j].type === 'softbreak' || tokens[j].type === 'hardbreak') break; // lastChar defaults to 0x20\n+                                    if (!tokens[j].content) continue; // should skip all tokens except 'text', 'html_inline' or 'code_inline'\n \n-                function innerCreateMedium(defaults, middleware) {\n-                    if (middleware === void 0) {\n-                        middleware = ItoI;\n-                    }\n-                    var buffer = [];\n-                    var assigned = false;\n-                    var medium = {\n-                        read: function() {\n-                            if (assigned) {\n-                                throw new Error('Sidecar: could not `read` from an `assigned` medium. `read` could be used only with `useMedium`.');\n+                                    lastChar = tokens[j].content.charCodeAt(tokens[j].content.length - 1);\n+                                    break;\n+                                }\n                             }\n-                            if (buffer.length) {\n-                                return buffer[buffer.length - 1];\n+\n+                            // Find next character,\n+                            // default to space if it's the end of the line\n+                            //\n+                            let nextChar = 0x20;\n+                            if (pos < max) {\n+                                nextChar = text.charCodeAt(pos);\n+                            } else {\n+                                for (j = i + 1; j < tokens.length; j++) {\n+                                    if (tokens[j].type === 'softbreak' || tokens[j].type === 'hardbreak') break; // nextChar defaults to 0x20\n+                                    if (!tokens[j].content) continue; // should skip all tokens except 'text', 'html_inline' or 'code_inline'\n+\n+                                    nextChar = tokens[j].content.charCodeAt(0);\n+                                    break;\n+                                }\n                             }\n-                            return defaults;\n-                        },\n-                        useMedium: function(data) {\n-                            var item = middleware(data, assigned);\n-                            buffer.push(item);\n-                            return function() {\n-                                buffer = buffer.filter(function(x) {\n-                                    return x !== item;\n-                                });\n-                            };\n-                        },\n-                        assignSyncMedium: function(cb) {\n-                            assigned = true;\n-                            while (buffer.length) {\n-                                var cbs = buffer;\n-                                buffer = [];\n-                                cbs.forEach(cb);\n+                            const isLastPunctChar = isMdAsciiPunct(lastChar) || isPunctChar(String.fromCharCode(lastChar));\n+                            const isNextPunctChar = isMdAsciiPunct(nextChar) || isPunctChar(String.fromCharCode(nextChar));\n+                            const isLastWhiteSpace = isWhiteSpace(lastChar);\n+                            const isNextWhiteSpace = isWhiteSpace(nextChar);\n+                            if (isNextWhiteSpace) {\n+                                canOpen = false;\n+                            } else if (isNextPunctChar) {\n+                                if (!(isLastWhiteSpace || isLastPunctChar)) {\n+                                    canOpen = false;\n+                                }\n                             }\n-                            buffer = {\n-                                push: function(x) {\n-                                    return cb(x);\n-                                },\n-                                filter: function() {\n-                                    return buffer;\n+                            if (isLastWhiteSpace) {\n+                                canClose = false;\n+                            } else if (isLastPunctChar) {\n+                                if (!(isNextWhiteSpace || isNextPunctChar)) {\n+                                    canClose = false;\n                                 }\n-                            };\n-                        },\n-                        assignMedium: function(cb) {\n-                            assigned = true;\n-                            var pendingQueue = [];\n-                            if (buffer.length) {\n-                                var cbs = buffer;\n-                                buffer = [];\n-                                cbs.forEach(cb);\n-                                pendingQueue = buffer;\n                             }\n-                            var executeQueue = function() {\n-                                var cbs = pendingQueue;\n-                                pendingQueue = [];\n-                                cbs.forEach(cb);\n-                            };\n-                            var cycle = function() {\n-                                return Promise.resolve().then(executeQueue);\n-                            };\n-                            cycle();\n-                            buffer = {\n-                                push: function(x) {\n-                                    pendingQueue.push(x);\n-                                    cycle();\n-                                },\n-                                filter: function(filter) {\n-                                    pendingQueue = pendingQueue.filter(filter);\n-                                    return buffer;\n+                            if (nextChar === 0x22 /* \" */ && t[0] === '\"') {\n+                                if (lastChar >= 0x30 /* 0 */ && lastChar <= 0x39 /* 9 */ ) {\n+                                    // special case: 1\"\" - count first quote as an inch\n+                                    canClose = canOpen = false;\n                                 }\n-                            };\n+                            }\n+                            if (canOpen && canClose) {\n+                                // Replace quotes in the middle of punctuation sequence, but not\n+                                // in the middle of the words, i.e.:\n+                                //\n+                                // 1. foo \" bar \" baz - not replaced\n+                                // 2. foo-\"-bar-\"-baz - replaced\n+                                // 3. foo\"bar\"baz     - not replaced\n+                                //\n+                                canOpen = isLastPunctChar;\n+                                canClose = isNextPunctChar;\n+                            }\n+                            if (!canOpen && !canClose) {\n+                                // middle of word\n+                                if (isSingle) {\n+                                    token.content = replaceAt(token.content, t.index, APOSTROPHE);\n+                                }\n+                                continue;\n+                            }\n+                            if (canClose) {\n+                                // this could be a closing quote, rewind the stack to get a match\n+                                for (j = stack.length - 1; j >= 0; j--) {\n+                                    let item = stack[j];\n+                                    if (stack[j].level < thisLevel) {\n+                                        break;\n+                                    }\n+                                    if (item.single === isSingle && stack[j].level === thisLevel) {\n+                                        item = stack[j];\n+                                        let openQuote;\n+                                        let closeQuote;\n+                                        if (isSingle) {\n+                                            openQuote = state.md.options.quotes[2];\n+                                            closeQuote = state.md.options.quotes[3];\n+                                        } else {\n+                                            openQuote = state.md.options.quotes[0];\n+                                            closeQuote = state.md.options.quotes[1];\n+                                        }\n+\n+                                        // replace token.content *before* tokens[item.token].content,\n+                                        // because, if they are pointing at the same token, replaceAt\n+                                        // could mess up indices when quote length != 1\n+                                        token.content = replaceAt(token.content, t.index, closeQuote);\n+                                        tokens[item.token].content = replaceAt(tokens[item.token].content, item.pos, openQuote);\n+                                        pos += closeQuote.length - 1;\n+                                        if (item.token === i) {\n+                                            pos += openQuote.length - 1;\n+                                        }\n+                                        text = token.content;\n+                                        max = text.length;\n+                                        stack.length = j;\n+                                        continue OUTER;\n+                                    }\n+                                }\n+                            }\n+                            if (canOpen) {\n+                                stack.push({\n+                                    token: i,\n+                                    pos: t.index,\n+                                    single: isSingle,\n+                                    level: thisLevel\n+                                });\n+                            } else if (canClose && isSingle) {\n+                                token.content = replaceAt(token.content, t.index, APOSTROPHE);\n+                            }\n                         }\n-                    };\n-                    return medium;\n+                    }\n                 }\n \n-                function createMedium(defaults, middleware) {\n-                    if (middleware === void 0) {\n-                        middleware = ItoI;\n+                function smartquotes(state) {\n+                    /* eslint max-depth:0 */\n+                    if (!state.md.options.typographer) {\n+                        return;\n                     }\n-                    return innerCreateMedium(defaults, middleware);\n-                }\n-                // eslint-disable-next-line @typescript-eslint/ban-types\n-                function createSidecarMedium(options) {\n-                    if (options === void 0) {\n-                        options = {};\n+                    for (let blkIdx = state.tokens.length - 1; blkIdx >= 0; blkIdx--) {\n+                        if (state.tokens[blkIdx].type !== 'inline' || !QUOTE_TEST_RE.test(state.tokens[blkIdx].content)) {\n+                            continue;\n+                        }\n+                        process_inlines(state.tokens[blkIdx].children, state);\n                     }\n-                    var medium = innerCreateMedium(null);\n-                    medium.options = (0, _tslib.__assign)({\n-                        async: true,\n-                        ssr: false\n-                    }, options);\n-                    return medium;\n                 }\n \n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../../node_modules/use-sidecar/dist/es2015/renderProp.js\":\n-            /*!*******************************************************************!*\\\n-              !*** ../../../node_modules/use-sidecar/dist/es2015/renderProp.js ***!\n-              \\*******************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                // Join raw text tokens with the rest of the text\n+                //\n+                // This is set as a separate rule to provide an opportunity for plugins\n+                // to run text replacements after text join, but before escape join.\n+                //\n+                // For example, `\\:)` shouldn't be replaced with an emoji.\n+                //\n \n+                function text_join(state) {\n+                    let curr, last;\n+                    const blockTokens = state.tokens;\n+                    const l = blockTokens.length;\n+                    for (let j = 0; j < l; j++) {\n+                        if (blockTokens[j].type !== 'inline') continue;\n+                        const tokens = blockTokens[j].children;\n+                        const max = tokens.length;\n+                        for (curr = 0; curr < max; curr++) {\n+                            if (tokens[curr].type === 'text_special') {\n+                                tokens[curr].type = 'text';\n+                            }\n+                        }\n+                        for (curr = last = 0; curr < max; curr++) {\n+                            if (tokens[curr].type === 'text' && curr + 1 < max && tokens[curr + 1].type === 'text') {\n+                                // collapse two adjacent text nodes\n+                                tokens[curr + 1].content = tokens[curr].content + tokens[curr + 1].content;\n+                            } else {\n+                                if (curr !== last) {\n+                                    tokens[last] = tokens[curr];\n+                                }\n+                                last++;\n+                            }\n+                        }\n+                        if (curr !== last) {\n+                            tokens.length = last;\n+                        }\n+                    }\n+                }\n \n+                /** internal\n+                 * class Core\n+                 *\n+                 * Top-level rules executor. Glues block/inline parsers and does intermediate\n+                 * transformations.\n+                 **/\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.renderCar = renderCar;\n-                var _tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.js\");\n-                var React = _interopRequireWildcard(__webpack_require__( /*! react */ \"react\"));\n+                const _rules$2 = [\n+                    ['normalize', normalize],\n+                    ['block', block],\n+                    ['inline', inline],\n+                    ['linkify', linkify$1],\n+                    ['replacements', replace],\n+                    ['smartquotes', smartquotes],\n+                    // `text_join` finds `text_special` tokens (for escape sequences)\n+                    // and joins them with the rest of the text\n+                    ['text_join', text_join]\n+                ];\n \n-                function _getRequireWildcardCache(nodeInterop) {\n-                    if (typeof WeakMap !== \"function\") return null;\n-                    var cacheBabelInterop = new WeakMap();\n-                    var cacheNodeInterop = new WeakMap();\n-                    return (_getRequireWildcardCache = function(nodeInterop) {\n-                        return nodeInterop ? cacheNodeInterop : cacheBabelInterop;\n-                    })(nodeInterop);\n+                /**\n+                 * new Core()\n+                 **/\n+                function Core() {\n+                    /**\n+                     * Core#ruler -> Ruler\n+                     *\n+                     * [[Ruler]] instance. Keep configuration of core rules.\n+                     **/\n+                    this.ruler = new Ruler();\n+                    for (let i = 0; i < _rules$2.length; i++) {\n+                        this.ruler.push(_rules$2[i][0], _rules$2[i][1]);\n+                    }\n                 }\n \n-                function _interopRequireWildcard(obj, nodeInterop) {\n-                    if (!nodeInterop && obj && obj.__esModule) {\n-                        return obj;\n-                    }\n-                    if (obj === null || typeof obj !== \"object\" && typeof obj !== \"function\") {\n-                        return {\n-                            default: obj\n-                        };\n+                /**\n+                 * Core.process(state)\n+                 *\n+                 * Executes core chain rules.\n+                 **/\n+                Core.prototype.process = function(state) {\n+                    const rules = this.ruler.getRules('');\n+                    for (let i = 0, l = rules.length; i < l; i++) {\n+                        rules[i](state);\n                     }\n-                    var cache = _getRequireWildcardCache(nodeInterop);\n-                    if (cache && cache.has(obj)) {\n-                        return cache.get(obj);\n-                    }\n-                    var newObj = {};\n-                    var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;\n-                    for (var key in obj) {\n-                        if (key !== \"default\" && Object.prototype.hasOwnProperty.call(obj, key)) {\n-                            var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;\n-                            if (desc && (desc.get || desc.set)) {\n-                                Object.defineProperty(newObj, key, desc);\n+                };\n+                Core.prototype.State = StateCore;\n+\n+                // Parser state class\n+\n+                function StateBlock(src, md, env, tokens) {\n+                    this.src = src;\n+\n+                    // link to parser instance\n+                    this.md = md;\n+                    this.env = env;\n+\n+                    //\n+                    // Internal state vartiables\n+                    //\n+\n+                    this.tokens = tokens;\n+                    this.bMarks = []; // line begin offsets for fast jumps\n+                    this.eMarks = []; // line end offsets for fast jumps\n+                    this.tShift = []; // offsets of the first non-space characters (tabs not expanded)\n+                    this.sCount = []; // indents for each line (tabs expanded)\n+\n+                    // An amount of virtual spaces (tabs expanded) between beginning\n+                    // of each line (bMarks) and real beginning of that line.\n+                    //\n+                    // It exists only as a hack because blockquotes override bMarks\n+                    // losing information in the process.\n+                    //\n+                    // It's used only when expanding tabs, you can think about it as\n+                    // an initial tab length, e.g. bsCount=21 applied to string `\\t123`\n+                    // means first tab should be expanded to 4-21%4 === 3 spaces.\n+                    //\n+                    this.bsCount = [];\n+\n+                    // block parser variables\n+\n+                    // required block content indent (for example, if we are\n+                    // inside a list, it would be positioned after list marker)\n+                    this.blkIndent = 0;\n+                    this.line = 0; // line index in src\n+                    this.lineMax = 0; // lines count\n+                    this.tight = false; // loose/tight mode for lists\n+                    this.ddIndent = -1; // indent of the current dd block (-1 if there isn't any)\n+                    this.listIndent = -1; // indent of the current list block (-1 if there isn't any)\n+\n+                    // can be 'blockquote', 'list', 'root', 'paragraph' or 'reference'\n+                    // used in lists to determine if they interrupt a paragraph\n+                    this.parentType = 'root';\n+                    this.level = 0;\n+\n+                    // Create caches\n+                    // Generate markers.\n+                    const s = this.src;\n+                    for (let start = 0, pos = 0, indent = 0, offset = 0, len = s.length, indent_found = false; pos < len; pos++) {\n+                        const ch = s.charCodeAt(pos);\n+                        if (!indent_found) {\n+                            if (isSpace(ch)) {\n+                                indent++;\n+                                if (ch === 0x09) {\n+                                    offset += 4 - offset % 4;\n+                                } else {\n+                                    offset++;\n+                                }\n+                                continue;\n                             } else {\n-                                newObj[key] = obj[key];\n+                                indent_found = true;\n                             }\n                         }\n-                    }\n-                    newObj.default = obj;\n-                    if (cache) {\n-                        cache.set(obj, newObj);\n-                    }\n-                    return newObj;\n-                }\n-\n-                function renderCar(WrappedComponent, defaults) {\n-                    function State(_a) {\n-                        var stateRef = _a.stateRef,\n-                            props = _a.props;\n-                        var renderTarget = (0, React.useCallback)(function SideTarget() {\n-                            var args = [];\n-                            for (var _i = 0; _i < arguments.length; _i++) {\n-                                args[_i] = arguments[_i];\n+                        if (ch === 0x0A || pos === len - 1) {\n+                            if (ch !== 0x0A) {\n+                                pos++;\n                             }\n-                            (0, React.useLayoutEffect)(function() {\n-                                stateRef.current(args);\n-                            });\n-                            return null;\n-                        }, []);\n-                        // @ts-ignore\n-                        return /*#__PURE__*/ React.createElement(WrappedComponent, (0, _tslib.__assign)({}, props, {\n-                            children: renderTarget\n-                        }));\n+                            this.bMarks.push(start);\n+                            this.eMarks.push(pos);\n+                            this.tShift.push(indent);\n+                            this.sCount.push(offset);\n+                            this.bsCount.push(0);\n+                            indent_found = false;\n+                            indent = 0;\n+                            offset = 0;\n+                            start = pos + 1;\n+                        }\n                     }\n-                    var Children = /*#__PURE__*/ React.memo(function(_a) {\n-                        var stateRef = _a.stateRef,\n-                            defaultState = _a.defaultState,\n-                            children = _a.children;\n-                        var _b = (0, React.useState)(defaultState.current),\n-                            state = _b[0],\n-                            setState = _b[1];\n-                        (0, React.useEffect)(function() {\n-                            stateRef.current = setState;\n-                        }, []);\n-                        return children.apply(void 0, state);\n-                    }, function() {\n-                        return true;\n-                    });\n-                    return function Combiner(props) {\n-                        var defaultState = React.useRef(defaults(props));\n-                        var ref = React.useRef(function(state) {\n-                            return defaultState.current = state;\n-                        });\n-                        return /*#__PURE__*/ React.createElement(React.Fragment, null, /*#__PURE__*/ React.createElement(State, {\n-                            stateRef: ref,\n-                            props: props\n-                        }), /*#__PURE__*/ React.createElement(Children, {\n-                            stateRef: ref,\n-                            defaultState: defaultState,\n-                            children: props.children\n-                        }));\n-                    };\n-                }\n \n-                /***/\n-            }),\n+                    // Push fake entry to simplify cache bounds checks\n+                    this.bMarks.push(s.length);\n+                    this.eMarks.push(s.length);\n+                    this.tShift.push(0);\n+                    this.sCount.push(0);\n+                    this.bsCount.push(0);\n+                    this.lineMax = this.bMarks.length - 1; // don't count last fake line\n+                }\n \n-        /***/\n-        \"../../../node_modules/vscode-languageserver-types/lib/esm/main.js\":\n-            /*!*************************************************************************!*\\\n-              !*** ../../../node_modules/vscode-languageserver-types/lib/esm/main.js ***!\n-              \\*************************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports) {\n+                // Push new token to \"stream\".\n+                //\n+                StateBlock.prototype.push = function(type, tag, nesting) {\n+                    const token = new Token(type, tag, nesting);\n+                    token.block = true;\n+                    if (nesting < 0) this.level--; // closing tag\n+                    token.level = this.level;\n+                    if (nesting > 0) this.level++; // opening tag\n \n-                /* --------------------------------------------------------------------------------------------\n-                 * Copyright (c) Microsoft Corporation. All rights reserved.\n-                 * Licensed under the MIT License. See License.txt in the project root for license information.\n-                 * ------------------------------------------------------------------------------------------ */\n+                    this.tokens.push(token);\n+                    return token;\n+                };\n+                StateBlock.prototype.isEmpty = function isEmpty(line) {\n+                    return this.bMarks[line] + this.tShift[line] >= this.eMarks[line];\n+                };\n+                StateBlock.prototype.skipEmptyLines = function skipEmptyLines(from) {\n+                    for (let max = this.lineMax; from < max; from++) {\n+                        if (this.bMarks[from] + this.tShift[from] < this.eMarks[from]) {\n+                            break;\n+                        }\n+                    }\n+                    return from;\n+                };\n \n+                // Skip spaces from given position.\n+                StateBlock.prototype.skipSpaces = function skipSpaces(pos) {\n+                    for (let max = this.src.length; pos < max; pos++) {\n+                        const ch = this.src.charCodeAt(pos);\n+                        if (!isSpace(ch)) {\n+                            break;\n+                        }\n+                    }\n+                    return pos;\n+                };\n \n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.uinteger = exports.integer = exports.WorkspaceSymbol = exports.WorkspaceFolder = exports.WorkspaceEdit = exports.WorkspaceChange = exports.VersionedTextDocumentIdentifier = exports.URI = exports.TextEdit = exports.TextDocumentItem = exports.TextDocumentIdentifier = exports.TextDocumentEdit = exports.TextDocument = exports.SymbolTag = exports.SymbolKind = exports.SymbolInformation = exports.SignatureInformation = exports.SemanticTokens = exports.SemanticTokenTypes = exports.SemanticTokenModifiers = exports.SelectionRange = exports.RenameFile = exports.Range = exports.Position = exports.ParameterInformation = exports.OptionalVersionedTextDocumentIdentifier = exports.MarkupKind = exports.MarkupContent = exports.MarkedString = exports.LocationLink = exports.Location = exports.InsertTextMode = exports.InsertTextFormat = exports.InsertReplaceEdit = exports.InlineValueVariableLookup = exports.InlineValueText = exports.InlineValueEvaluatableExpression = exports.InlineValueContext = exports.InlayHintLabelPart = exports.InlayHintKind = exports.InlayHint = exports.Hover = exports.FormattingOptions = exports.FoldingRangeKind = exports.FoldingRange = exports.EOL = exports.DocumentUri = exports.DocumentSymbol = exports.DocumentLink = exports.DocumentHighlightKind = exports.DocumentHighlight = exports.DiagnosticTag = exports.DiagnosticSeverity = exports.DiagnosticRelatedInformation = exports.Diagnostic = exports.DeleteFile = exports.CreateFile = exports.CompletionList = exports.CompletionItemTag = exports.CompletionItemLabelDetails = exports.CompletionItemKind = exports.CompletionItem = exports.Command = exports.ColorPresentation = exports.ColorInformation = exports.Color = exports.CodeLens = exports.CodeDescription = exports.CodeActionTriggerKind = exports.CodeActionKind = exports.CodeActionContext = exports.CodeAction = exports.ChangeAnnotationIdentifier = exports.ChangeAnnotation = exports.AnnotatedTextEdit = void 0;\n-                var DocumentUri;\n-                exports.DocumentUri = DocumentUri;\n-                (function(DocumentUri) {\n-                    function is(value) {\n-                        return typeof value === 'string';\n+                // Skip spaces from given position in reverse.\n+                StateBlock.prototype.skipSpacesBack = function skipSpacesBack(pos, min) {\n+                    if (pos <= min) {\n+                        return pos;\n                     }\n-                    DocumentUri.is = is;\n-                })(DocumentUri || (exports.DocumentUri = DocumentUri = {}));\n-                var URI;\n-                exports.URI = URI;\n-                (function(URI) {\n-                    function is(value) {\n-                        return typeof value === 'string';\n+                    while (pos > min) {\n+                        if (!isSpace(this.src.charCodeAt(--pos))) {\n+                            return pos + 1;\n+                        }\n                     }\n-                    URI.is = is;\n-                })(URI || (exports.URI = URI = {}));\n-                var integer;\n-                exports.integer = integer;\n-                (function(integer) {\n-                    integer.MIN_VALUE = -2147483648;\n-                    integer.MAX_VALUE = 2147483647;\n+                    return pos;\n+                };\n \n-                    function is(value) {\n-                        return typeof value === 'number' && integer.MIN_VALUE <= value && value <= integer.MAX_VALUE;\n+                // Skip char codes from given position\n+                StateBlock.prototype.skipChars = function skipChars(pos, code) {\n+                    for (let max = this.src.length; pos < max; pos++) {\n+                        if (this.src.charCodeAt(pos) !== code) {\n+                            break;\n+                        }\n                     }\n-                    integer.is = is;\n-                })(integer || (exports.integer = integer = {}));\n-                var uinteger;\n-                exports.uinteger = uinteger;\n-                (function(uinteger) {\n-                    uinteger.MIN_VALUE = 0;\n-                    uinteger.MAX_VALUE = 2147483647;\n+                    return pos;\n+                };\n \n-                    function is(value) {\n-                        return typeof value === 'number' && uinteger.MIN_VALUE <= value && value <= uinteger.MAX_VALUE;\n+                // Skip char codes reverse from given position - 1\n+                StateBlock.prototype.skipCharsBack = function skipCharsBack(pos, code, min) {\n+                    if (pos <= min) {\n+                        return pos;\n                     }\n-                    uinteger.is = is;\n-                })(uinteger || (exports.uinteger = uinteger = {}));\n-                /**\n-                 * The Position namespace provides helper functions to work with\n-                 * [Position](#Position) literals.\n-                 */\n-                var Position;\n-                exports.Position = Position;\n-                (function(Position) {\n-                    /**\n-                     * Creates a new Position literal from the given line and character.\n-                     * @param line The position's line.\n-                     * @param character The position's character.\n-                     */\n-                    function create(line, character) {\n-                        if (line === Number.MAX_VALUE) {\n-                            line = uinteger.MAX_VALUE;\n-                        }\n-                        if (character === Number.MAX_VALUE) {\n-                            character = uinteger.MAX_VALUE;\n+                    while (pos > min) {\n+                        if (code !== this.src.charCodeAt(--pos)) {\n+                            return pos + 1;\n                         }\n-                        return {\n-                            line: line,\n-                            character: character\n-                        };\n                     }\n-                    Position.create = create;\n-                    /**\n-                     * Checks whether the given literal conforms to the [Position](#Position) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.objectLiteral(candidate) && Is.uinteger(candidate.line) && Is.uinteger(candidate.character);\n+                    return pos;\n+                };\n+\n+                // cut lines range from source.\n+                StateBlock.prototype.getLines = function getLines(begin, end, indent, keepLastLF) {\n+                    if (begin >= end) {\n+                        return '';\n                     }\n-                    Position.is = is;\n-                })(Position || (exports.Position = Position = {}));\n-                /**\n-                 * The Range namespace provides helper functions to work with\n-                 * [Range](#Range) literals.\n-                 */\n-                var Range;\n-                exports.Range = Range;\n-                (function(Range) {\n-                    function create(one, two, three, four) {\n-                        if (Is.uinteger(one) && Is.uinteger(two) && Is.uinteger(three) && Is.uinteger(four)) {\n-                            return {\n-                                start: Position.create(one, two),\n-                                end: Position.create(three, four)\n-                            };\n-                        } else if (Position.is(one) && Position.is(two)) {\n-                            return {\n-                                start: one,\n-                                end: two\n-                            };\n+                    const queue = new Array(end - begin);\n+                    for (let i = 0, line = begin; line < end; line++, i++) {\n+                        let lineIndent = 0;\n+                        const lineStart = this.bMarks[line];\n+                        let first = lineStart;\n+                        let last;\n+                        if (line + 1 < end || keepLastLF) {\n+                            // No need for bounds check because we have fake entry on tail.\n+                            last = this.eMarks[line] + 1;\n                         } else {\n-                            throw new Error(\"Range#create called with invalid arguments[\".concat(one, \", \").concat(two, \", \").concat(three, \", \").concat(four, \"]\"));\n+                            last = this.eMarks[line];\n+                        }\n+                        while (first < last && lineIndent < indent) {\n+                            const ch = this.src.charCodeAt(first);\n+                            if (isSpace(ch)) {\n+                                if (ch === 0x09) {\n+                                    lineIndent += 4 - (lineIndent + this.bsCount[line]) % 4;\n+                                } else {\n+                                    lineIndent++;\n+                                }\n+                            } else if (first - lineStart < this.tShift[line]) {\n+                                // patched tShift masked characters to look like spaces (blockquotes, list markers)\n+                                lineIndent++;\n+                            } else {\n+                                break;\n+                            }\n+                            first++;\n+                        }\n+                        if (lineIndent > indent) {\n+                            // partially expanding tabs in code blocks, e.g '\\t\\tfoobar'\n+                            // with indent=2 becomes '  \\tfoobar'\n+                            queue[i] = new Array(lineIndent - indent + 1).join(' ') + this.src.slice(first, last);\n+                        } else {\n+                            queue[i] = this.src.slice(first, last);\n                         }\n                     }\n-                    Range.create = create;\n-                    /**\n-                     * Checks whether the given literal conforms to the [Range](#Range) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.objectLiteral(candidate) && Position.is(candidate.start) && Position.is(candidate.end);\n-                    }\n-                    Range.is = is;\n-                })(Range || (exports.Range = Range = {}));\n-                /**\n-                 * The Location namespace provides helper functions to work with\n-                 * [Location](#Location) literals.\n-                 */\n-                var Location;\n-                exports.Location = Location;\n-                (function(Location) {\n-                    /**\n-                     * Creates a Location literal.\n-                     * @param uri The location's uri.\n-                     * @param range The location's range.\n-                     */\n-                    function create(uri, range) {\n-                        return {\n-                            uri: uri,\n-                            range: range\n-                        };\n-                    }\n-                    Location.create = create;\n-                    /**\n-                     * Checks whether the given literal conforms to the [Location](#Location) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.defined(candidate) && Range.is(candidate.range) && (Is.string(candidate.uri) || Is.undefined(candidate.uri));\n+                    return queue.join('');\n+                };\n+\n+                // re-export Token class to use in block rules\n+                StateBlock.prototype.Token = Token;\n+\n+                // GFM table, https://github.github.com/gfm/#tables-extension-\n+\n+                // Limit the amount of empty autocompleted cells in a table,\n+                // see https://github.com/markdown-it/markdown-it/issues/1000,\n+                //\n+                // Both pulldown-cmark and commonmark-hs limit the number of cells this way to ~200k.\n+                // We set it to 65k, which can expand user input by a factor of x370\n+                // (256x256 square is 1.8kB expanded into 650kB).\n+                const MAX_AUTOCOMPLETED_CELLS = 0x10000;\n+\n+                function getLine(state, line) {\n+                    const pos = state.bMarks[line] + state.tShift[line];\n+                    const max = state.eMarks[line];\n+                    return state.src.slice(pos, max);\n+                }\n+\n+                function escapedSplit(str) {\n+                    const result = [];\n+                    const max = str.length;\n+                    let pos = 0;\n+                    let ch = str.charCodeAt(pos);\n+                    let isEscaped = false;\n+                    let lastPos = 0;\n+                    let current = '';\n+                    while (pos < max) {\n+                        if (ch === 0x7c /* | */ ) {\n+                            if (!isEscaped) {\n+                                // pipe separating cells, '|'\n+                                result.push(current + str.substring(lastPos, pos));\n+                                current = '';\n+                                lastPos = pos + 1;\n+                            } else {\n+                                // escaped pipe, '\\|'\n+                                current += str.substring(lastPos, pos - 1);\n+                                lastPos = pos;\n+                            }\n+                        }\n+                        isEscaped = ch === 0x5c /* \\ */ ;\n+                        pos++;\n+                        ch = str.charCodeAt(pos);\n                     }\n-                    Location.is = is;\n-                })(Location || (exports.Location = Location = {}));\n-                /**\n-                 * The LocationLink namespace provides helper functions to work with\n-                 * [LocationLink](#LocationLink) literals.\n-                 */\n-                var LocationLink;\n-                exports.LocationLink = LocationLink;\n-                (function(LocationLink) {\n-                    /**\n-                     * Creates a LocationLink literal.\n-                     * @param targetUri The definition's uri.\n-                     * @param targetRange The full range of the definition.\n-                     * @param targetSelectionRange The span of the symbol definition at the target.\n-                     * @param originSelectionRange The span of the symbol being defined in the originating source file.\n-                     */\n-                    function create(targetUri, targetRange, targetSelectionRange, originSelectionRange) {\n-                        return {\n-                            targetUri: targetUri,\n-                            targetRange: targetRange,\n-                            targetSelectionRange: targetSelectionRange,\n-                            originSelectionRange: originSelectionRange\n-                        };\n+                    result.push(current + str.substring(lastPos));\n+                    return result;\n+                }\n+\n+                function table(state, startLine, endLine, silent) {\n+                    // should have at least two lines\n+                    if (startLine + 2 > endLine) {\n+                        return false;\n                     }\n-                    LocationLink.create = create;\n-                    /**\n-                     * Checks whether the given literal conforms to the [LocationLink](#LocationLink) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.defined(candidate) && Range.is(candidate.targetRange) && Is.string(candidate.targetUri) && Range.is(candidate.targetSelectionRange) && (Range.is(candidate.originSelectionRange) || Is.undefined(candidate.originSelectionRange));\n+                    let nextLine = startLine + 1;\n+                    if (state.sCount[nextLine] < state.blkIndent) {\n+                        return false;\n                     }\n-                    LocationLink.is = is;\n-                })(LocationLink || (exports.LocationLink = LocationLink = {}));\n-                /**\n-                 * The Color namespace provides helper functions to work with\n-                 * [Color](#Color) literals.\n-                 */\n-                var Color;\n-                exports.Color = Color;\n-                (function(Color) {\n-                    /**\n-                     * Creates a new Color literal.\n-                     */\n-                    function create(red, green, blue, alpha) {\n-                        return {\n-                            red: red,\n-                            green: green,\n-                            blue: blue,\n-                            alpha: alpha\n-                        };\n+\n+                    // if it's indented more than 3 spaces, it should be a code block\n+                    if (state.sCount[nextLine] - state.blkIndent >= 4) {\n+                        return false;\n                     }\n-                    Color.create = create;\n-                    /**\n-                     * Checks whether the given literal conforms to the [Color](#Color) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.objectLiteral(candidate) && Is.numberRange(candidate.red, 0, 1) && Is.numberRange(candidate.green, 0, 1) && Is.numberRange(candidate.blue, 0, 1) && Is.numberRange(candidate.alpha, 0, 1);\n+\n+                    // first character of the second line should be '|', '-', ':',\n+                    // and no other characters are allowed but spaces;\n+                    // basically, this is the equivalent of /^[-:|][-:|\\s]*$/ regexp\n+\n+                    let pos = state.bMarks[nextLine] + state.tShift[nextLine];\n+                    if (pos >= state.eMarks[nextLine]) {\n+                        return false;\n                     }\n-                    Color.is = is;\n-                })(Color || (exports.Color = Color = {}));\n-                /**\n-                 * The ColorInformation namespace provides helper functions to work with\n-                 * [ColorInformation](#ColorInformation) literals.\n-                 */\n-                var ColorInformation;\n-                exports.ColorInformation = ColorInformation;\n-                (function(ColorInformation) {\n-                    /**\n-                     * Creates a new ColorInformation literal.\n-                     */\n-                    function create(range, color) {\n-                        return {\n-                            range: range,\n-                            color: color\n-                        };\n+                    const firstCh = state.src.charCodeAt(pos++);\n+                    if (firstCh !== 0x7C /* | */ && firstCh !== 0x2D /* - */ && firstCh !== 0x3A /* : */ ) {\n+                        return false;\n                     }\n-                    ColorInformation.create = create;\n-                    /**\n-                     * Checks whether the given literal conforms to the [ColorInformation](#ColorInformation) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.objectLiteral(candidate) && Range.is(candidate.range) && Color.is(candidate.color);\n+                    if (pos >= state.eMarks[nextLine]) {\n+                        return false;\n                     }\n-                    ColorInformation.is = is;\n-                })(ColorInformation || (exports.ColorInformation = ColorInformation = {}));\n-                /**\n-                 * The Color namespace provides helper functions to work with\n-                 * [ColorPresentation](#ColorPresentation) literals.\n-                 */\n-                var ColorPresentation;\n-                exports.ColorPresentation = ColorPresentation;\n-                (function(ColorPresentation) {\n-                    /**\n-                     * Creates a new ColorInformation literal.\n-                     */\n-                    function create(label, textEdit, additionalTextEdits) {\n-                        return {\n-                            label: label,\n-                            textEdit: textEdit,\n-                            additionalTextEdits: additionalTextEdits\n-                        };\n+                    const secondCh = state.src.charCodeAt(pos++);\n+                    if (secondCh !== 0x7C /* | */ && secondCh !== 0x2D /* - */ && secondCh !== 0x3A /* : */ && !isSpace(secondCh)) {\n+                        return false;\n                     }\n-                    ColorPresentation.create = create;\n-                    /**\n-                     * Checks whether the given literal conforms to the [ColorInformation](#ColorInformation) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.objectLiteral(candidate) && Is.string(candidate.label) && (Is.undefined(candidate.textEdit) || TextEdit.is(candidate)) && (Is.undefined(candidate.additionalTextEdits) || Is.typedArray(candidate.additionalTextEdits, TextEdit.is));\n+\n+                    // if first character is '-', then second character must not be a space\n+                    // (due to parsing ambiguity with list)\n+                    if (firstCh === 0x2D /* - */ && isSpace(secondCh)) {\n+                        return false;\n                     }\n-                    ColorPresentation.is = is;\n-                })(ColorPresentation || (exports.ColorPresentation = ColorPresentation = {}));\n-                /**\n-                 * A set of predefined range kinds.\n-                 */\n-                var FoldingRangeKind;\n-                exports.FoldingRangeKind = FoldingRangeKind;\n-                (function(FoldingRangeKind) {\n-                    /**\n-                     * Folding range for a comment\n-                     */\n-                    FoldingRangeKind.Comment = 'comment';\n-                    /**\n-                     * Folding range for a imports or includes\n-                     */\n-                    FoldingRangeKind.Imports = 'imports';\n-                    /**\n-                     * Folding range for a region (e.g. `#region`)\n-                     */\n-                    FoldingRangeKind.Region = 'region';\n-                })(FoldingRangeKind || (exports.FoldingRangeKind = FoldingRangeKind = {}));\n-                /**\n-                 * The folding range namespace provides helper functions to work with\n-                 * [FoldingRange](#FoldingRange) literals.\n-                 */\n-                var FoldingRange;\n-                exports.FoldingRange = FoldingRange;\n-                (function(FoldingRange) {\n-                    /**\n-                     * Creates a new FoldingRange literal.\n-                     */\n-                    function create(startLine, endLine, startCharacter, endCharacter, kind, collapsedText) {\n-                        var result = {\n-                            startLine: startLine,\n-                            endLine: endLine\n-                        };\n-                        if (Is.defined(startCharacter)) {\n-                            result.startCharacter = startCharacter;\n+                    while (pos < state.eMarks[nextLine]) {\n+                        const ch = state.src.charCodeAt(pos);\n+                        if (ch !== 0x7C /* | */ && ch !== 0x2D /* - */ && ch !== 0x3A /* : */ && !isSpace(ch)) {\n+                            return false;\n                         }\n-                        if (Is.defined(endCharacter)) {\n-                            result.endCharacter = endCharacter;\n+                        pos++;\n+                    }\n+                    let lineText = getLine(state, startLine + 1);\n+                    let columns = lineText.split('|');\n+                    const aligns = [];\n+                    for (let i = 0; i < columns.length; i++) {\n+                        const t = columns[i].trim();\n+                        if (!t) {\n+                            // allow empty columns before and after table, but not in between columns;\n+                            // e.g. allow ` |---| `, disallow ` ---||--- `\n+                            if (i === 0 || i === columns.length - 1) {\n+                                continue;\n+                            } else {\n+                                return false;\n+                            }\n                         }\n-                        if (Is.defined(kind)) {\n-                            result.kind = kind;\n+                        if (!/^:?-+:?$/.test(t)) {\n+                            return false;\n                         }\n-                        if (Is.defined(collapsedText)) {\n-                            result.collapsedText = collapsedText;\n+                        if (t.charCodeAt(t.length - 1) === 0x3A /* : */ ) {\n+                            aligns.push(t.charCodeAt(0) === 0x3A /* : */ ? 'center' : 'right');\n+                        } else if (t.charCodeAt(0) === 0x3A /* : */ ) {\n+                            aligns.push('left');\n+                        } else {\n+                            aligns.push('');\n                         }\n-                        return result;\n                     }\n-                    FoldingRange.create = create;\n-                    /**\n-                     * Checks whether the given literal conforms to the [FoldingRange](#FoldingRange) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.objectLiteral(candidate) && Is.uinteger(candidate.startLine) && Is.uinteger(candidate.startLine) && (Is.undefined(candidate.startCharacter) || Is.uinteger(candidate.startCharacter)) && (Is.undefined(candidate.endCharacter) || Is.uinteger(candidate.endCharacter)) && (Is.undefined(candidate.kind) || Is.string(candidate.kind));\n+                    lineText = getLine(state, startLine).trim();\n+                    if (lineText.indexOf('|') === -1) {\n+                        return false;\n                     }\n-                    FoldingRange.is = is;\n-                })(FoldingRange || (exports.FoldingRange = FoldingRange = {}));\n-                /**\n-                 * The DiagnosticRelatedInformation namespace provides helper functions to work with\n-                 * [DiagnosticRelatedInformation](#DiagnosticRelatedInformation) literals.\n-                 */\n-                var DiagnosticRelatedInformation;\n-                exports.DiagnosticRelatedInformation = DiagnosticRelatedInformation;\n-                (function(DiagnosticRelatedInformation) {\n-                    /**\n-                     * Creates a new DiagnosticRelatedInformation literal.\n-                     */\n-                    function create(location, message) {\n-                        return {\n-                            location: location,\n-                            message: message\n-                        };\n+                    if (state.sCount[startLine] - state.blkIndent >= 4) {\n+                        return false;\n                     }\n-                    DiagnosticRelatedInformation.create = create;\n-                    /**\n-                     * Checks whether the given literal conforms to the [DiagnosticRelatedInformation](#DiagnosticRelatedInformation) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.defined(candidate) && Location.is(candidate.location) && Is.string(candidate.message);\n+                    columns = escapedSplit(lineText);\n+                    if (columns.length && columns[0] === '') columns.shift();\n+                    if (columns.length && columns[columns.length - 1] === '') columns.pop();\n+\n+                    // header row will define an amount of columns in the entire table,\n+                    // and align row should be exactly the same (the rest of the rows can differ)\n+                    const columnCount = columns.length;\n+                    if (columnCount === 0 || columnCount !== aligns.length) {\n+                        return false;\n                     }\n-                    DiagnosticRelatedInformation.is = is;\n-                })(DiagnosticRelatedInformation || (exports.DiagnosticRelatedInformation = DiagnosticRelatedInformation = {}));\n-                /**\n-                 * The diagnostic's severity.\n-                 */\n-                var DiagnosticSeverity;\n-                exports.DiagnosticSeverity = DiagnosticSeverity;\n-                (function(DiagnosticSeverity) {\n-                    /**\n-                     * Reports an error.\n-                     */\n-                    DiagnosticSeverity.Error = 1;\n-                    /**\n-                     * Reports a warning.\n-                     */\n-                    DiagnosticSeverity.Warning = 2;\n-                    /**\n-                     * Reports an information.\n-                     */\n-                    DiagnosticSeverity.Information = 3;\n-                    /**\n-                     * Reports a hint.\n-                     */\n-                    DiagnosticSeverity.Hint = 4;\n-                })(DiagnosticSeverity || (exports.DiagnosticSeverity = DiagnosticSeverity = {}));\n-                /**\n-                 * The diagnostic tags.\n-                 *\n-                 * @since 3.15.0\n-                 */\n-                var DiagnosticTag;\n-                exports.DiagnosticTag = DiagnosticTag;\n-                (function(DiagnosticTag) {\n-                    /**\n-                     * Unused or unnecessary code.\n-                     *\n-                     * Clients are allowed to render diagnostics with this tag faded out instead of having\n-                     * an error squiggle.\n-                     */\n-                    DiagnosticTag.Unnecessary = 1;\n-                    /**\n-                     * Deprecated or obsolete code.\n-                     *\n-                     * Clients are allowed to rendered diagnostics with this tag strike through.\n-                     */\n-                    DiagnosticTag.Deprecated = 2;\n-                })(DiagnosticTag || (exports.DiagnosticTag = DiagnosticTag = {}));\n-                /**\n-                 * The CodeDescription namespace provides functions to deal with descriptions for diagnostic codes.\n-                 *\n-                 * @since 3.16.0\n-                 */\n-                var CodeDescription;\n-                exports.CodeDescription = CodeDescription;\n-                (function(CodeDescription) {\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.objectLiteral(candidate) && Is.string(candidate.href);\n+                    if (silent) {\n+                        return true;\n                     }\n-                    CodeDescription.is = is;\n-                })(CodeDescription || (exports.CodeDescription = CodeDescription = {}));\n-                /**\n-                 * The Diagnostic namespace provides helper functions to work with\n-                 * [Diagnostic](#Diagnostic) literals.\n-                 */\n-                var Diagnostic;\n-                exports.Diagnostic = Diagnostic;\n-                (function(Diagnostic) {\n-                    /**\n-                     * Creates a new Diagnostic literal.\n-                     */\n-                    function create(range, message, severity, code, source, relatedInformation) {\n-                        var result = {\n-                            range: range,\n-                            message: message\n-                        };\n-                        if (Is.defined(severity)) {\n-                            result.severity = severity;\n+                    const oldParentType = state.parentType;\n+                    state.parentType = 'table';\n+\n+                    // use 'blockquote' lists for termination because it's\n+                    // the most similar to tables\n+                    const terminatorRules = state.md.block.ruler.getRules('blockquote');\n+                    const token_to = state.push('table_open', 'table', 1);\n+                    const tableLines = [startLine, 0];\n+                    token_to.map = tableLines;\n+                    const token_tho = state.push('thead_open', 'thead', 1);\n+                    token_tho.map = [startLine, startLine + 1];\n+                    const token_htro = state.push('tr_open', 'tr', 1);\n+                    token_htro.map = [startLine, startLine + 1];\n+                    for (let i = 0; i < columns.length; i++) {\n+                        const token_ho = state.push('th_open', 'th', 1);\n+                        if (aligns[i]) {\n+                            token_ho.attrs = [\n+                                ['style', 'text-align:' + aligns[i]]\n+                            ];\n                         }\n-                        if (Is.defined(code)) {\n-                            result.code = code;\n+                        const token_il = state.push('inline', '', 0);\n+                        token_il.content = columns[i].trim();\n+                        token_il.children = [];\n+                        state.push('th_close', 'th', -1);\n+                    }\n+                    state.push('tr_close', 'tr', -1);\n+                    state.push('thead_close', 'thead', -1);\n+                    let tbodyLines;\n+                    let autocompletedCells = 0;\n+                    for (nextLine = startLine + 2; nextLine < endLine; nextLine++) {\n+                        if (state.sCount[nextLine] < state.blkIndent) {\n+                            break;\n                         }\n-                        if (Is.defined(source)) {\n-                            result.source = source;\n+                        let terminate = false;\n+                        for (let i = 0, l = terminatorRules.length; i < l; i++) {\n+                            if (terminatorRules[i](state, nextLine, endLine, true)) {\n+                                terminate = true;\n+                                break;\n+                            }\n                         }\n-                        if (Is.defined(relatedInformation)) {\n-                            result.relatedInformation = relatedInformation;\n+                        if (terminate) {\n+                            break;\n                         }\n-                        return result;\n-                    }\n-                    Diagnostic.create = create;\n-                    /**\n-                     * Checks whether the given literal conforms to the [Diagnostic](#Diagnostic) interface.\n-                     */\n-                    function is(value) {\n-                        var _a;\n-                        var candidate = value;\n-                        return Is.defined(candidate) && Range.is(candidate.range) && Is.string(candidate.message) && (Is.number(candidate.severity) || Is.undefined(candidate.severity)) && (Is.integer(candidate.code) || Is.string(candidate.code) || Is.undefined(candidate.code)) && (Is.undefined(candidate.codeDescription) || Is.string((_a = candidate.codeDescription) === null || _a === void 0 ? void 0 : _a.href)) && (Is.string(candidate.source) || Is.undefined(candidate.source)) && (Is.undefined(candidate.relatedInformation) || Is.typedArray(candidate.relatedInformation, DiagnosticRelatedInformation.is));\n-                    }\n-                    Diagnostic.is = is;\n-                })(Diagnostic || (exports.Diagnostic = Diagnostic = {}));\n-                /**\n-                 * The Command namespace provides helper functions to work with\n-                 * [Command](#Command) literals.\n-                 */\n-                var Command;\n-                exports.Command = Command;\n-                (function(Command) {\n-                    /**\n-                     * Creates a new Command literal.\n-                     */\n-                    function create(title, command) {\n-                        var args = [];\n-                        for (var _i = 2; _i < arguments.length; _i++) {\n-                            args[_i - 2] = arguments[_i];\n+                        lineText = getLine(state, nextLine).trim();\n+                        if (!lineText) {\n+                            break;\n                         }\n-                        var result = {\n-                            title: title,\n-                            command: command\n-                        };\n-                        if (Is.defined(args) && args.length > 0) {\n-                            result.arguments = args;\n+                        if (state.sCount[nextLine] - state.blkIndent >= 4) {\n+                            break;\n                         }\n-                        return result;\n-                    }\n-                    Command.create = create;\n-                    /**\n-                     * Checks whether the given literal conforms to the [Command](#Command) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.defined(candidate) && Is.string(candidate.title) && Is.string(candidate.command);\n-                    }\n-                    Command.is = is;\n-                })(Command || (exports.Command = Command = {}));\n-                /**\n-                 * The TextEdit namespace provides helper function to create replace,\n-                 * insert and delete edits more easily.\n-                 */\n-                var TextEdit;\n-                exports.TextEdit = TextEdit;\n-                (function(TextEdit) {\n-                    /**\n-                     * Creates a replace text edit.\n-                     * @param range The range of text to be replaced.\n-                     * @param newText The new text.\n-                     */\n-                    function replace(range, newText) {\n-                        return {\n-                            range: range,\n-                            newText: newText\n-                        };\n-                    }\n-                    TextEdit.replace = replace;\n-                    /**\n-                     * Creates a insert text edit.\n-                     * @param position The position to insert the text at.\n-                     * @param newText The text to be inserted.\n-                     */\n-                    function insert(position, newText) {\n-                        return {\n-                            range: {\n-                                start: position,\n-                                end: position\n-                            },\n-                            newText: newText\n-                        };\n+                        columns = escapedSplit(lineText);\n+                        if (columns.length && columns[0] === '') columns.shift();\n+                        if (columns.length && columns[columns.length - 1] === '') columns.pop();\n+\n+                        // note: autocomplete count can be negative if user specifies more columns than header,\n+                        // but that does not affect intended use (which is limiting expansion)\n+                        autocompletedCells += columnCount - columns.length;\n+                        if (autocompletedCells > MAX_AUTOCOMPLETED_CELLS) {\n+                            break;\n+                        }\n+                        if (nextLine === startLine + 2) {\n+                            const token_tbo = state.push('tbody_open', 'tbody', 1);\n+                            token_tbo.map = tbodyLines = [startLine + 2, 0];\n+                        }\n+                        const token_tro = state.push('tr_open', 'tr', 1);\n+                        token_tro.map = [nextLine, nextLine + 1];\n+                        for (let i = 0; i < columnCount; i++) {\n+                            const token_tdo = state.push('td_open', 'td', 1);\n+                            if (aligns[i]) {\n+                                token_tdo.attrs = [\n+                                    ['style', 'text-align:' + aligns[i]]\n+                                ];\n+                            }\n+                            const token_il = state.push('inline', '', 0);\n+                            token_il.content = columns[i] ? columns[i].trim() : '';\n+                            token_il.children = [];\n+                            state.push('td_close', 'td', -1);\n+                        }\n+                        state.push('tr_close', 'tr', -1);\n                     }\n-                    TextEdit.insert = insert;\n-                    /**\n-                     * Creates a delete text edit.\n-                     * @param range The range of text to be deleted.\n-                     */\n-                    function del(range) {\n-                        return {\n-                            range: range,\n-                            newText: ''\n-                        };\n+                    if (tbodyLines) {\n+                        state.push('tbody_close', 'tbody', -1);\n+                        tbodyLines[1] = nextLine;\n                     }\n-                    TextEdit.del = del;\n+                    state.push('table_close', 'table', -1);\n+                    tableLines[1] = nextLine;\n+                    state.parentType = oldParentType;\n+                    state.line = nextLine;\n+                    return true;\n+                }\n \n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.objectLiteral(candidate) && Is.string(candidate.newText) && Range.is(candidate.range);\n+                // Code block (4 spaces padded)\n+\n+                function code(state, startLine, endLine /*, silent */ ) {\n+                    if (state.sCount[startLine] - state.blkIndent < 4) {\n+                        return false;\n                     }\n-                    TextEdit.is = is;\n-                })(TextEdit || (exports.TextEdit = TextEdit = {}));\n-                var ChangeAnnotation;\n-                exports.ChangeAnnotation = ChangeAnnotation;\n-                (function(ChangeAnnotation) {\n-                    function create(label, needsConfirmation, description) {\n-                        var result = {\n-                            label: label\n-                        };\n-                        if (needsConfirmation !== undefined) {\n-                            result.needsConfirmation = needsConfirmation;\n+                    let nextLine = startLine + 1;\n+                    let last = nextLine;\n+                    while (nextLine < endLine) {\n+                        if (state.isEmpty(nextLine)) {\n+                            nextLine++;\n+                            continue;\n                         }\n-                        if (description !== undefined) {\n-                            result.description = description;\n+                        if (state.sCount[nextLine] - state.blkIndent >= 4) {\n+                            nextLine++;\n+                            last = nextLine;\n+                            continue;\n                         }\n-                        return result;\n+                        break;\n                     }\n-                    ChangeAnnotation.create = create;\n+                    state.line = last;\n+                    const token = state.push('code_block', 'code', 0);\n+                    token.content = state.getLines(startLine, last, 4 + state.blkIndent, false) + '\\n';\n+                    token.map = [startLine, state.line];\n+                    return true;\n+                }\n \n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.objectLiteral(candidate) && Is.string(candidate.label) && (Is.boolean(candidate.needsConfirmation) || candidate.needsConfirmation === undefined) && (Is.string(candidate.description) || candidate.description === undefined);\n-                    }\n-                    ChangeAnnotation.is = is;\n-                })(ChangeAnnotation || (exports.ChangeAnnotation = ChangeAnnotation = {}));\n-                var ChangeAnnotationIdentifier;\n-                exports.ChangeAnnotationIdentifier = ChangeAnnotationIdentifier;\n-                (function(ChangeAnnotationIdentifier) {\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.string(candidate);\n-                    }\n-                    ChangeAnnotationIdentifier.is = is;\n-                })(ChangeAnnotationIdentifier || (exports.ChangeAnnotationIdentifier = ChangeAnnotationIdentifier = {}));\n-                var AnnotatedTextEdit;\n-                exports.AnnotatedTextEdit = AnnotatedTextEdit;\n-                (function(AnnotatedTextEdit) {\n-                    /**\n-                     * Creates an annotated replace text edit.\n-                     *\n-                     * @param range The range of text to be replaced.\n-                     * @param newText The new text.\n-                     * @param annotation The annotation.\n-                     */\n-                    function replace(range, newText, annotation) {\n-                        return {\n-                            range: range,\n-                            newText: newText,\n-                            annotationId: annotation\n-                        };\n+                // fences (``` lang, ~~~ lang)\n+\n+                function fence(state, startLine, endLine, silent) {\n+                    let pos = state.bMarks[startLine] + state.tShift[startLine];\n+                    let max = state.eMarks[startLine];\n+\n+                    // if it's indented more than 3 spaces, it should be a code block\n+                    if (state.sCount[startLine] - state.blkIndent >= 4) {\n+                        return false;\n                     }\n-                    AnnotatedTextEdit.replace = replace;\n-                    /**\n-                     * Creates an annotated insert text edit.\n-                     *\n-                     * @param position The position to insert the text at.\n-                     * @param newText The text to be inserted.\n-                     * @param annotation The annotation.\n-                     */\n-                    function insert(position, newText, annotation) {\n-                        return {\n-                            range: {\n-                                start: position,\n-                                end: position\n-                            },\n-                            newText: newText,\n-                            annotationId: annotation\n-                        };\n+                    if (pos + 3 > max) {\n+                        return false;\n                     }\n-                    AnnotatedTextEdit.insert = insert;\n-                    /**\n-                     * Creates an annotated delete text edit.\n-                     *\n-                     * @param range The range of text to be deleted.\n-                     * @param annotation The annotation.\n-                     */\n-                    function del(range, annotation) {\n-                        return {\n-                            range: range,\n-                            newText: '',\n-                            annotationId: annotation\n-                        };\n+                    const marker = state.src.charCodeAt(pos);\n+                    if (marker !== 0x7E /* ~ */ && marker !== 0x60 /* ` */ ) {\n+                        return false;\n                     }\n-                    AnnotatedTextEdit.del = del;\n \n-                    function is(value) {\n-                        var candidate = value;\n-                        return TextEdit.is(candidate) && (ChangeAnnotation.is(candidate.annotationId) || ChangeAnnotationIdentifier.is(candidate.annotationId));\n+                    // scan marker length\n+                    let mem = pos;\n+                    pos = state.skipChars(pos, marker);\n+                    let len = pos - mem;\n+                    if (len < 3) {\n+                        return false;\n                     }\n-                    AnnotatedTextEdit.is = is;\n-                })(AnnotatedTextEdit || (exports.AnnotatedTextEdit = AnnotatedTextEdit = {}));\n-                /**\n-                 * The TextDocumentEdit namespace provides helper function to create\n-                 * an edit that manipulates a text document.\n-                 */\n-                var TextDocumentEdit;\n-                exports.TextDocumentEdit = TextDocumentEdit;\n-                (function(TextDocumentEdit) {\n-                    /**\n-                     * Creates a new `TextDocumentEdit`\n-                     */\n-                    function create(textDocument, edits) {\n-                        return {\n-                            textDocument: textDocument,\n-                            edits: edits\n-                        };\n+                    const markup = state.src.slice(mem, pos);\n+                    const params = state.src.slice(pos, max);\n+                    if (marker === 0x60 /* ` */ ) {\n+                        if (params.indexOf(String.fromCharCode(marker)) >= 0) {\n+                            return false;\n+                        }\n                     }\n-                    TextDocumentEdit.create = create;\n \n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.defined(candidate) && OptionalVersionedTextDocumentIdentifier.is(candidate.textDocument) && Array.isArray(candidate.edits);\n+                    // Since start is found, we can report success here in validation mode\n+                    if (silent) {\n+                        return true;\n                     }\n-                    TextDocumentEdit.is = is;\n-                })(TextDocumentEdit || (exports.TextDocumentEdit = TextDocumentEdit = {}));\n-                var CreateFile;\n-                exports.CreateFile = CreateFile;\n-                (function(CreateFile) {\n-                    function create(uri, options, annotation) {\n-                        var result = {\n-                            kind: 'create',\n-                            uri: uri\n-                        };\n-                        if (options !== undefined && (options.overwrite !== undefined || options.ignoreIfExists !== undefined)) {\n-                            result.options = options;\n+\n+                    // search end of block\n+                    let nextLine = startLine;\n+                    let haveEndMarker = false;\n+                    for (;;) {\n+                        nextLine++;\n+                        if (nextLine >= endLine) {\n+                            // unclosed block should be autoclosed by end of document.\n+                            // also block seems to be autoclosed by end of parent\n+                            break;\n                         }\n-                        if (annotation !== undefined) {\n-                            result.annotationId = annotation;\n+                        pos = mem = state.bMarks[nextLine] + state.tShift[nextLine];\n+                        max = state.eMarks[nextLine];\n+                        if (pos < max && state.sCount[nextLine] < state.blkIndent) {\n+                            // non-empty line with negative indent should stop the list:\n+                            // - ```\n+                            //  test\n+                            break;\n                         }\n-                        return result;\n-                    }\n-                    CreateFile.create = create;\n+                        if (state.src.charCodeAt(pos) !== marker) {\n+                            continue;\n+                        }\n+                        if (state.sCount[nextLine] - state.blkIndent >= 4) {\n+                            // closing fence should be indented less than 4 spaces\n+                            continue;\n+                        }\n+                        pos = state.skipChars(pos, marker);\n \n-                    function is(value) {\n-                        var candidate = value;\n-                        return candidate && candidate.kind === 'create' && Is.string(candidate.uri) && (candidate.options === undefined || (candidate.options.overwrite === undefined || Is.boolean(candidate.options.overwrite)) && (candidate.options.ignoreIfExists === undefined || Is.boolean(candidate.options.ignoreIfExists))) && (candidate.annotationId === undefined || ChangeAnnotationIdentifier.is(candidate.annotationId));\n-                    }\n-                    CreateFile.is = is;\n-                })(CreateFile || (exports.CreateFile = CreateFile = {}));\n-                var RenameFile;\n-                exports.RenameFile = RenameFile;\n-                (function(RenameFile) {\n-                    function create(oldUri, newUri, options, annotation) {\n-                        var result = {\n-                            kind: 'rename',\n-                            oldUri: oldUri,\n-                            newUri: newUri\n-                        };\n-                        if (options !== undefined && (options.overwrite !== undefined || options.ignoreIfExists !== undefined)) {\n-                            result.options = options;\n+                        // closing code fence must be at least as long as the opening one\n+                        if (pos - mem < len) {\n+                            continue;\n                         }\n-                        if (annotation !== undefined) {\n-                            result.annotationId = annotation;\n+\n+                        // make sure tail has spaces only\n+                        pos = state.skipSpaces(pos);\n+                        if (pos < max) {\n+                            continue;\n                         }\n-                        return result;\n+                        haveEndMarker = true;\n+                        // found!\n+                        break;\n                     }\n-                    RenameFile.create = create;\n \n-                    function is(value) {\n-                        var candidate = value;\n-                        return candidate && candidate.kind === 'rename' && Is.string(candidate.oldUri) && Is.string(candidate.newUri) && (candidate.options === undefined || (candidate.options.overwrite === undefined || Is.boolean(candidate.options.overwrite)) && (candidate.options.ignoreIfExists === undefined || Is.boolean(candidate.options.ignoreIfExists))) && (candidate.annotationId === undefined || ChangeAnnotationIdentifier.is(candidate.annotationId));\n+                    // If a fence has heading spaces, they should be removed from its inner block\n+                    len = state.sCount[startLine];\n+                    state.line = nextLine + (haveEndMarker ? 1 : 0);\n+                    const token = state.push('fence', 'code', 0);\n+                    token.info = params;\n+                    token.content = state.getLines(startLine + 1, nextLine, len, true);\n+                    token.markup = markup;\n+                    token.map = [startLine, state.line];\n+                    return true;\n+                }\n+\n+                // Block quotes\n+\n+                function blockquote(state, startLine, endLine, silent) {\n+                    let pos = state.bMarks[startLine] + state.tShift[startLine];\n+                    let max = state.eMarks[startLine];\n+                    const oldLineMax = state.lineMax;\n+\n+                    // if it's indented more than 3 spaces, it should be a code block\n+                    if (state.sCount[startLine] - state.blkIndent >= 4) {\n+                        return false;\n                     }\n-                    RenameFile.is = is;\n-                })(RenameFile || (exports.RenameFile = RenameFile = {}));\n-                var DeleteFile;\n-                exports.DeleteFile = DeleteFile;\n-                (function(DeleteFile) {\n-                    function create(uri, options, annotation) {\n-                        var result = {\n-                            kind: 'delete',\n-                            uri: uri\n-                        };\n-                        if (options !== undefined && (options.recursive !== undefined || options.ignoreIfNotExists !== undefined)) {\n-                            result.options = options;\n-                        }\n-                        if (annotation !== undefined) {\n-                            result.annotationId = annotation;\n-                        }\n-                        return result;\n+\n+                    // check the block quote marker\n+                    if (state.src.charCodeAt(pos) !== 0x3E /* > */ ) {\n+                        return false;\n                     }\n-                    DeleteFile.create = create;\n \n-                    function is(value) {\n-                        var candidate = value;\n-                        return candidate && candidate.kind === 'delete' && Is.string(candidate.uri) && (candidate.options === undefined || (candidate.options.recursive === undefined || Is.boolean(candidate.options.recursive)) && (candidate.options.ignoreIfNotExists === undefined || Is.boolean(candidate.options.ignoreIfNotExists))) && (candidate.annotationId === undefined || ChangeAnnotationIdentifier.is(candidate.annotationId));\n+                    // we know that it's going to be a valid blockquote,\n+                    // so no point trying to find the end of it in silent mode\n+                    if (silent) {\n+                        return true;\n                     }\n-                    DeleteFile.is = is;\n-                })(DeleteFile || (exports.DeleteFile = DeleteFile = {}));\n-                var WorkspaceEdit;\n-                exports.WorkspaceEdit = WorkspaceEdit;\n-                (function(WorkspaceEdit) {\n-                    function is(value) {\n-                        var candidate = value;\n-                        return candidate && (candidate.changes !== undefined || candidate.documentChanges !== undefined) && (candidate.documentChanges === undefined || candidate.documentChanges.every(function(change) {\n-                            if (Is.string(change.kind)) {\n-                                return CreateFile.is(change) || RenameFile.is(change) || DeleteFile.is(change);\n+                    const oldBMarks = [];\n+                    const oldBSCount = [];\n+                    const oldSCount = [];\n+                    const oldTShift = [];\n+                    const terminatorRules = state.md.block.ruler.getRules('blockquote');\n+                    const oldParentType = state.parentType;\n+                    state.parentType = 'blockquote';\n+                    let lastLineEmpty = false;\n+                    let nextLine;\n+\n+                    // Search the end of the block\n+                    //\n+                    // Block ends with either:\n+                    //  1. an empty line outside:\n+                    //     ```\n+                    //     > test\n+                    //\n+                    //     ```\n+                    //  2. an empty line inside:\n+                    //     ```\n+                    //     >\n+                    //     test\n+                    //     ```\n+                    //  3. another tag:\n+                    //     ```\n+                    //     > test\n+                    //      - - -\n+                    //     ```\n+                    for (nextLine = startLine; nextLine < endLine; nextLine++) {\n+                        // check if it's outdented, i.e. it's inside list item and indented\n+                        // less than said list item:\n+                        //\n+                        // ```\n+                        // 1. anything\n+                        //    > current blockquote\n+                        // 2. checking this line\n+                        // ```\n+                        const isOutdented = state.sCount[nextLine] < state.blkIndent;\n+                        pos = state.bMarks[nextLine] + state.tShift[nextLine];\n+                        max = state.eMarks[nextLine];\n+                        if (pos >= max) {\n+                            // Case 1: line is not inside the blockquote, and this line is empty.\n+                            break;\n+                        }\n+                        if (state.src.charCodeAt(pos++) === 0x3E /* > */ && !isOutdented) {\n+                            // This line is inside the blockquote.\n+\n+                            // set offset past spaces and \">\"\n+                            let initial = state.sCount[nextLine] + 1;\n+                            let spaceAfterMarker;\n+                            let adjustTab;\n+\n+                            // skip one optional space after '>'\n+                            if (state.src.charCodeAt(pos) === 0x20 /* space */ ) {\n+                                // ' >   test '\n+                                //     ^ -- position start of line here:\n+                                pos++;\n+                                initial++;\n+                                adjustTab = false;\n+                                spaceAfterMarker = true;\n+                            } else if (state.src.charCodeAt(pos) === 0x09 /* tab */ ) {\n+                                spaceAfterMarker = true;\n+                                if ((state.bsCount[nextLine] + initial) % 4 === 3) {\n+                                    // '  >\\t  test '\n+                                    //       ^ -- position start of line here (tab has width===1)\n+                                    pos++;\n+                                    initial++;\n+                                    adjustTab = false;\n+                                } else {\n+                                    // ' >\\t  test '\n+                                    //    ^ -- position start of line here + shift bsCount slightly\n+                                    //         to make extra space appear\n+                                    adjustTab = true;\n+                                }\n                             } else {\n-                                return TextDocumentEdit.is(change);\n+                                spaceAfterMarker = false;\n                             }\n-                        }));\n+                            let offset = initial;\n+                            oldBMarks.push(state.bMarks[nextLine]);\n+                            state.bMarks[nextLine] = pos;\n+                            while (pos < max) {\n+                                const ch = state.src.charCodeAt(pos);\n+                                if (isSpace(ch)) {\n+                                    if (ch === 0x09) {\n+                                        offset += 4 - (offset + state.bsCount[nextLine] + (adjustTab ? 1 : 0)) % 4;\n+                                    } else {\n+                                        offset++;\n+                                    }\n+                                } else {\n+                                    break;\n+                                }\n+                                pos++;\n+                            }\n+                            lastLineEmpty = pos >= max;\n+                            oldBSCount.push(state.bsCount[nextLine]);\n+                            state.bsCount[nextLine] = state.sCount[nextLine] + 1 + (spaceAfterMarker ? 1 : 0);\n+                            oldSCount.push(state.sCount[nextLine]);\n+                            state.sCount[nextLine] = offset - initial;\n+                            oldTShift.push(state.tShift[nextLine]);\n+                            state.tShift[nextLine] = pos - state.bMarks[nextLine];\n+                            continue;\n+                        }\n+\n+                        // Case 2: line is not inside the blockquote, and the last line was empty.\n+                        if (lastLineEmpty) {\n+                            break;\n+                        }\n+\n+                        // Case 3: another tag found.\n+                        let terminate = false;\n+                        for (let i = 0, l = terminatorRules.length; i < l; i++) {\n+                            if (terminatorRules[i](state, nextLine, endLine, true)) {\n+                                terminate = true;\n+                                break;\n+                            }\n+                        }\n+                        if (terminate) {\n+                            // Quirk to enforce \"hard termination mode\" for paragraphs;\n+                            // normally if you call `tokenize(state, startLine, nextLine)`,\n+                            // paragraphs will look below nextLine for paragraph continuation,\n+                            // but if blockquote is terminated by another tag, they shouldn't\n+                            state.lineMax = nextLine;\n+                            if (state.blkIndent !== 0) {\n+                                // state.blkIndent was non-zero, we now set it to zero,\n+                                // so we need to re-calculate all offsets to appear as\n+                                // if indent wasn't changed\n+                                oldBMarks.push(state.bMarks[nextLine]);\n+                                oldBSCount.push(state.bsCount[nextLine]);\n+                                oldTShift.push(state.tShift[nextLine]);\n+                                oldSCount.push(state.sCount[nextLine]);\n+                                state.sCount[nextLine] -= state.blkIndent;\n+                            }\n+                            break;\n+                        }\n+                        oldBMarks.push(state.bMarks[nextLine]);\n+                        oldBSCount.push(state.bsCount[nextLine]);\n+                        oldTShift.push(state.tShift[nextLine]);\n+                        oldSCount.push(state.sCount[nextLine]);\n+\n+                        // A negative indentation means that this is a paragraph continuation\n+                        //\n+                        state.sCount[nextLine] = -1;\n                     }\n-                    WorkspaceEdit.is = is;\n-                })(WorkspaceEdit || (exports.WorkspaceEdit = WorkspaceEdit = {}));\n-                var TextEditChangeImpl = /** @class */ function() {\n-                    function TextEditChangeImpl(edits, changeAnnotations) {\n-                        this.edits = edits;\n-                        this.changeAnnotations = changeAnnotations;\n+                    const oldIndent = state.blkIndent;\n+                    state.blkIndent = 0;\n+                    const token_o = state.push('blockquote_open', 'blockquote', 1);\n+                    token_o.markup = '>';\n+                    const lines = [startLine, 0];\n+                    token_o.map = lines;\n+                    state.md.block.tokenize(state, startLine, nextLine);\n+                    const token_c = state.push('blockquote_close', 'blockquote', -1);\n+                    token_c.markup = '>';\n+                    state.lineMax = oldLineMax;\n+                    state.parentType = oldParentType;\n+                    lines[1] = state.line;\n+\n+                    // Restore original tShift; this might not be necessary since the parser\n+                    // has already been here, but just to make sure we can do that.\n+                    for (let i = 0; i < oldTShift.length; i++) {\n+                        state.bMarks[i + startLine] = oldBMarks[i];\n+                        state.tShift[i + startLine] = oldTShift[i];\n+                        state.sCount[i + startLine] = oldSCount[i];\n+                        state.bsCount[i + startLine] = oldBSCount[i];\n                     }\n-                    TextEditChangeImpl.prototype.insert = function(position, newText, annotation) {\n-                        var edit;\n-                        var id;\n-                        if (annotation === undefined) {\n-                            edit = TextEdit.insert(position, newText);\n-                        } else if (ChangeAnnotationIdentifier.is(annotation)) {\n-                            id = annotation;\n-                            edit = AnnotatedTextEdit.insert(position, newText, annotation);\n-                        } else {\n-                            this.assertChangeAnnotations(this.changeAnnotations);\n-                            id = this.changeAnnotations.manage(annotation);\n-                            edit = AnnotatedTextEdit.insert(position, newText, id);\n-                        }\n-                        this.edits.push(edit);\n-                        if (id !== undefined) {\n-                            return id;\n+                    state.blkIndent = oldIndent;\n+                    return true;\n+                }\n+\n+                // Horizontal rule\n+\n+                function hr(state, startLine, endLine, silent) {\n+                    const max = state.eMarks[startLine];\n+                    // if it's indented more than 3 spaces, it should be a code block\n+                    if (state.sCount[startLine] - state.blkIndent >= 4) {\n+                        return false;\n+                    }\n+                    let pos = state.bMarks[startLine] + state.tShift[startLine];\n+                    const marker = state.src.charCodeAt(pos++);\n+\n+                    // Check hr marker\n+                    if (marker !== 0x2A /* * */ && marker !== 0x2D /* - */ && marker !== 0x5F /* _ */ ) {\n+                        return false;\n+                    }\n+\n+                    // markers can be mixed with spaces, but there should be at least 3 of them\n+\n+                    let cnt = 1;\n+                    while (pos < max) {\n+                        const ch = state.src.charCodeAt(pos++);\n+                        if (ch !== marker && !isSpace(ch)) {\n+                            return false;\n                         }\n-                    };\n-                    TextEditChangeImpl.prototype.replace = function(range, newText, annotation) {\n-                        var edit;\n-                        var id;\n-                        if (annotation === undefined) {\n-                            edit = TextEdit.replace(range, newText);\n-                        } else if (ChangeAnnotationIdentifier.is(annotation)) {\n-                            id = annotation;\n-                            edit = AnnotatedTextEdit.replace(range, newText, annotation);\n-                        } else {\n-                            this.assertChangeAnnotations(this.changeAnnotations);\n-                            id = this.changeAnnotations.manage(annotation);\n-                            edit = AnnotatedTextEdit.replace(range, newText, id);\n+                        if (ch === marker) {\n+                            cnt++;\n                         }\n-                        this.edits.push(edit);\n-                        if (id !== undefined) {\n-                            return id;\n+                    }\n+                    if (cnt < 3) {\n+                        return false;\n+                    }\n+                    if (silent) {\n+                        return true;\n+                    }\n+                    state.line = startLine + 1;\n+                    const token = state.push('hr', 'hr', 0);\n+                    token.map = [startLine, state.line];\n+                    token.markup = Array(cnt + 1).join(String.fromCharCode(marker));\n+                    return true;\n+                }\n+\n+                // Lists\n+\n+                // Search `[-+*][\\n ]`, returns next pos after marker on success\n+                // or -1 on fail.\n+                function skipBulletListMarker(state, startLine) {\n+                    const max = state.eMarks[startLine];\n+                    let pos = state.bMarks[startLine] + state.tShift[startLine];\n+                    const marker = state.src.charCodeAt(pos++);\n+                    // Check bullet\n+                    if (marker !== 0x2A /* * */ && marker !== 0x2D /* - */ && marker !== 0x2B /* + */ ) {\n+                        return -1;\n+                    }\n+                    if (pos < max) {\n+                        const ch = state.src.charCodeAt(pos);\n+                        if (!isSpace(ch)) {\n+                            // \" -test \" - is not a list item\n+                            return -1;\n                         }\n-                    };\n-                    TextEditChangeImpl.prototype.delete = function(range, annotation) {\n-                        var edit;\n-                        var id;\n-                        if (annotation === undefined) {\n-                            edit = TextEdit.del(range);\n-                        } else if (ChangeAnnotationIdentifier.is(annotation)) {\n-                            id = annotation;\n-                            edit = AnnotatedTextEdit.del(range, annotation);\n-                        } else {\n-                            this.assertChangeAnnotations(this.changeAnnotations);\n-                            id = this.changeAnnotations.manage(annotation);\n-                            edit = AnnotatedTextEdit.del(range, id);\n+                    }\n+                    return pos;\n+                }\n+\n+                // Search `\\d+[.)][\\n ]`, returns next pos after marker on success\n+                // or -1 on fail.\n+                function skipOrderedListMarker(state, startLine) {\n+                    const start = state.bMarks[startLine] + state.tShift[startLine];\n+                    const max = state.eMarks[startLine];\n+                    let pos = start;\n+\n+                    // List marker should have at least 2 chars (digit + dot)\n+                    if (pos + 1 >= max) {\n+                        return -1;\n+                    }\n+                    let ch = state.src.charCodeAt(pos++);\n+                    if (ch < 0x30 /* 0 */ || ch > 0x39 /* 9 */ ) {\n+                        return -1;\n+                    }\n+                    for (;;) {\n+                        // EOL -> fail\n+                        if (pos >= max) {\n+                            return -1;\n                         }\n-                        this.edits.push(edit);\n-                        if (id !== undefined) {\n-                            return id;\n+                        ch = state.src.charCodeAt(pos++);\n+                        if (ch >= 0x30 /* 0 */ && ch <= 0x39 /* 9 */ ) {\n+                            // List marker should have no more than 9 digits\n+                            // (prevents integer overflow in browsers)\n+                            if (pos - start >= 10) {\n+                                return -1;\n+                            }\n+                            continue;\n                         }\n-                    };\n-                    TextEditChangeImpl.prototype.add = function(edit) {\n-                        this.edits.push(edit);\n-                    };\n-                    TextEditChangeImpl.prototype.all = function() {\n-                        return this.edits;\n-                    };\n-                    TextEditChangeImpl.prototype.clear = function() {\n-                        this.edits.splice(0, this.edits.length);\n-                    };\n-                    TextEditChangeImpl.prototype.assertChangeAnnotations = function(value) {\n-                        if (value === undefined) {\n-                            throw new Error(\"Text edit change is not configured to manage change annotations.\");\n+\n+                        // found valid marker\n+                        if (ch === 0x29 /* ) */ || ch === 0x2e /* . */ ) {\n+                            break;\n                         }\n-                    };\n-                    return TextEditChangeImpl;\n-                }();\n-                /**\n-                 * A helper class\n-                 */\n-                var ChangeAnnotations = /** @class */ function() {\n-                    function ChangeAnnotations(annotations) {\n-                        this._annotations = annotations === undefined ? Object.create(null) : annotations;\n-                        this._counter = 0;\n-                        this._size = 0;\n+                        return -1;\n                     }\n-                    ChangeAnnotations.prototype.all = function() {\n-                        return this._annotations;\n-                    };\n-                    Object.defineProperty(ChangeAnnotations.prototype, \"size\", {\n-                        get: function() {\n-                            return this._size;\n-                        },\n-                        enumerable: false,\n-                        configurable: true\n-                    });\n-                    ChangeAnnotations.prototype.manage = function(idOrAnnotation, annotation) {\n-                        var id;\n-                        if (ChangeAnnotationIdentifier.is(idOrAnnotation)) {\n-                            id = idOrAnnotation;\n-                        } else {\n-                            id = this.nextId();\n-                            annotation = idOrAnnotation;\n+                    if (pos < max) {\n+                        ch = state.src.charCodeAt(pos);\n+                        if (!isSpace(ch)) {\n+                            // \" 1.test \" - is not a list item\n+                            return -1;\n                         }\n-                        if (this._annotations[id] !== undefined) {\n-                            throw new Error(\"Id \".concat(id, \" is already in use.\"));\n+                    }\n+                    return pos;\n+                }\n+\n+                function markTightParagraphs(state, idx) {\n+                    const level = state.level + 2;\n+                    for (let i = idx + 2, l = state.tokens.length - 2; i < l; i++) {\n+                        if (state.tokens[i].level === level && state.tokens[i].type === 'paragraph_open') {\n+                            state.tokens[i + 2].hidden = true;\n+                            state.tokens[i].hidden = true;\n+                            i += 2;\n                         }\n-                        if (annotation === undefined) {\n-                            throw new Error(\"No annotation provided for id \".concat(id));\n+                    }\n+                }\n+\n+                function list(state, startLine, endLine, silent) {\n+                    let max, pos, start, token;\n+                    let nextLine = startLine;\n+                    let tight = true;\n+\n+                    // if it's indented more than 3 spaces, it should be a code block\n+                    if (state.sCount[nextLine] - state.blkIndent >= 4) {\n+                        return false;\n+                    }\n+\n+                    // Special case:\n+                    //  - item 1\n+                    //   - item 2\n+                    //    - item 3\n+                    //     - item 4\n+                    //      - this one is a paragraph continuation\n+                    if (state.listIndent >= 0 && state.sCount[nextLine] - state.listIndent >= 4 && state.sCount[nextLine] < state.blkIndent) {\n+                        return false;\n+                    }\n+                    let isTerminatingParagraph = false;\n+\n+                    // limit conditions when list can interrupt\n+                    // a paragraph (validation mode only)\n+                    if (silent && state.parentType === 'paragraph') {\n+                        // Next list item should still terminate previous list item;\n+                        //\n+                        // This code can fail if plugins use blkIndent as well as lists,\n+                        // but I hope the spec gets fixed long before that happens.\n+                        //\n+                        if (state.sCount[nextLine] >= state.blkIndent) {\n+                            isTerminatingParagraph = true;\n                         }\n-                        this._annotations[id] = annotation;\n-                        this._size++;\n-                        return id;\n-                    };\n-                    ChangeAnnotations.prototype.nextId = function() {\n-                        this._counter++;\n-                        return this._counter.toString();\n-                    };\n-                    return ChangeAnnotations;\n-                }();\n-                /**\n-                 * A workspace change helps constructing changes to a workspace.\n-                 */\n-                var WorkspaceChange = /** @class */ function() {\n-                    function WorkspaceChange(workspaceEdit) {\n-                        var _this = this;\n-                        this._textEditChanges = Object.create(null);\n-                        if (workspaceEdit !== undefined) {\n-                            this._workspaceEdit = workspaceEdit;\n-                            if (workspaceEdit.documentChanges) {\n-                                this._changeAnnotations = new ChangeAnnotations(workspaceEdit.changeAnnotations);\n-                                workspaceEdit.changeAnnotations = this._changeAnnotations.all();\n-                                workspaceEdit.documentChanges.forEach(function(change) {\n-                                    if (TextDocumentEdit.is(change)) {\n-                                        var textEditChange = new TextEditChangeImpl(change.edits, _this._changeAnnotations);\n-                                        _this._textEditChanges[change.textDocument.uri] = textEditChange;\n-                                    }\n-                                });\n-                            } else if (workspaceEdit.changes) {\n-                                Object.keys(workspaceEdit.changes).forEach(function(key) {\n-                                    var textEditChange = new TextEditChangeImpl(workspaceEdit.changes[key]);\n-                                    _this._textEditChanges[key] = textEditChange;\n-                                });\n-                            }\n-                        } else {\n-                            this._workspaceEdit = {};\n+                    }\n+\n+                    // Detect list type and position after marker\n+                    let isOrdered;\n+                    let markerValue;\n+                    let posAfterMarker;\n+                    if ((posAfterMarker = skipOrderedListMarker(state, nextLine)) >= 0) {\n+                        isOrdered = true;\n+                        start = state.bMarks[nextLine] + state.tShift[nextLine];\n+                        markerValue = Number(state.src.slice(start, posAfterMarker - 1));\n+\n+                        // If we're starting a new ordered list right after\n+                        // a paragraph, it should start with 1.\n+                        if (isTerminatingParagraph && markerValue !== 1) return false;\n+                    } else if ((posAfterMarker = skipBulletListMarker(state, nextLine)) >= 0) {\n+                        isOrdered = false;\n+                    } else {\n+                        return false;\n+                    }\n+\n+                    // If we're starting a new unordered list right after\n+                    // a paragraph, first line should not be empty.\n+                    if (isTerminatingParagraph) {\n+                        if (state.skipSpaces(posAfterMarker) >= state.eMarks[nextLine]) return false;\n+                    }\n+\n+                    // For validation mode we can terminate immediately\n+                    if (silent) {\n+                        return true;\n+                    }\n+\n+                    // We should terminate list on style change. Remember first one to compare.\n+                    const markerCharCode = state.src.charCodeAt(posAfterMarker - 1);\n+\n+                    // Start list\n+                    const listTokIdx = state.tokens.length;\n+                    if (isOrdered) {\n+                        token = state.push('ordered_list_open', 'ol', 1);\n+                        if (markerValue !== 1) {\n+                            token.attrs = [\n+                                ['start', markerValue]\n+                            ];\n                         }\n+                    } else {\n+                        token = state.push('bullet_list_open', 'ul', 1);\n                     }\n-                    Object.defineProperty(WorkspaceChange.prototype, \"edit\", {\n-                        /**\n-                         * Returns the underlying [WorkspaceEdit](#WorkspaceEdit) literal\n-                         * use to be returned from a workspace edit operation like rename.\n-                         */\n-                        get: function() {\n-                            this.initDocumentChanges();\n-                            if (this._changeAnnotations !== undefined) {\n-                                if (this._changeAnnotations.size === 0) {\n-                                    this._workspaceEdit.changeAnnotations = undefined;\n-                                } else {\n-                                    this._workspaceEdit.changeAnnotations = this._changeAnnotations.all();\n-                                }\n-                            }\n-                            return this._workspaceEdit;\n-                        },\n-                        enumerable: false,\n-                        configurable: true\n-                    });\n-                    WorkspaceChange.prototype.getTextEditChange = function(key) {\n-                        if (OptionalVersionedTextDocumentIdentifier.is(key)) {\n-                            this.initDocumentChanges();\n-                            if (this._workspaceEdit.documentChanges === undefined) {\n-                                throw new Error('Workspace edit is not configured for document changes.');\n-                            }\n-                            var textDocument = {\n-                                uri: key.uri,\n-                                version: key.version\n-                            };\n-                            var result = this._textEditChanges[textDocument.uri];\n-                            if (!result) {\n-                                var edits = [];\n-                                var textDocumentEdit = {\n-                                    textDocument: textDocument,\n-                                    edits: edits\n-                                };\n-                                this._workspaceEdit.documentChanges.push(textDocumentEdit);\n-                                result = new TextEditChangeImpl(edits, this._changeAnnotations);\n-                                this._textEditChanges[textDocument.uri] = result;\n-                            }\n-                            return result;\n-                        } else {\n-                            this.initChanges();\n-                            if (this._workspaceEdit.changes === undefined) {\n-                                throw new Error('Workspace edit is not configured for normal text edit changes.');\n-                            }\n-                            var result = this._textEditChanges[key];\n-                            if (!result) {\n-                                var edits = [];\n-                                this._workspaceEdit.changes[key] = edits;\n-                                result = new TextEditChangeImpl(edits);\n-                                this._textEditChanges[key] = result;\n+                    const listLines = [nextLine, 0];\n+                    token.map = listLines;\n+                    token.markup = String.fromCharCode(markerCharCode);\n+\n+                    //\n+                    // Iterate list items\n+                    //\n+\n+                    let prevEmptyEnd = false;\n+                    const terminatorRules = state.md.block.ruler.getRules('list');\n+                    const oldParentType = state.parentType;\n+                    state.parentType = 'list';\n+                    while (nextLine < endLine) {\n+                        pos = posAfterMarker;\n+                        max = state.eMarks[nextLine];\n+                        const initial = state.sCount[nextLine] + posAfterMarker - (state.bMarks[nextLine] + state.tShift[nextLine]);\n+                        let offset = initial;\n+                        while (pos < max) {\n+                            const ch = state.src.charCodeAt(pos);\n+                            if (ch === 0x09) {\n+                                offset += 4 - (offset + state.bsCount[nextLine]) % 4;\n+                            } else if (ch === 0x20) {\n+                                offset++;\n+                            } else {\n+                                break;\n                             }\n-                            return result;\n-                        }\n-                    };\n-                    WorkspaceChange.prototype.initDocumentChanges = function() {\n-                        if (this._workspaceEdit.documentChanges === undefined && this._workspaceEdit.changes === undefined) {\n-                            this._changeAnnotations = new ChangeAnnotations();\n-                            this._workspaceEdit.documentChanges = [];\n-                            this._workspaceEdit.changeAnnotations = this._changeAnnotations.all();\n+                            pos++;\n                         }\n-                    };\n-                    WorkspaceChange.prototype.initChanges = function() {\n-                        if (this._workspaceEdit.documentChanges === undefined && this._workspaceEdit.changes === undefined) {\n-                            this._workspaceEdit.changes = Object.create(null);\n+                        const contentStart = pos;\n+                        let indentAfterMarker;\n+                        if (contentStart >= max) {\n+                            // trimming space in \"-    \\n  3\" case, indent is 1 here\n+                            indentAfterMarker = 1;\n+                        } else {\n+                            indentAfterMarker = offset - initial;\n                         }\n-                    };\n-                    WorkspaceChange.prototype.createFile = function(uri, optionsOrAnnotation, options) {\n-                        this.initDocumentChanges();\n-                        if (this._workspaceEdit.documentChanges === undefined) {\n-                            throw new Error('Workspace edit is not configured for document changes.');\n+\n+                        // If we have more than 4 spaces, the indent is 1\n+                        // (the rest is just indented code block)\n+                        if (indentAfterMarker > 4) {\n+                            indentAfterMarker = 1;\n                         }\n-                        var annotation;\n-                        if (ChangeAnnotation.is(optionsOrAnnotation) || ChangeAnnotationIdentifier.is(optionsOrAnnotation)) {\n-                            annotation = optionsOrAnnotation;\n-                        } else {\n-                            options = optionsOrAnnotation;\n+\n+                        // \"  -  test\"\n+                        //  ^^^^^ - calculating total length of this thing\n+                        const indent = initial + indentAfterMarker;\n+\n+                        // Run subparser & write tokens\n+                        token = state.push('list_item_open', 'li', 1);\n+                        token.markup = String.fromCharCode(markerCharCode);\n+                        const itemLines = [nextLine, 0];\n+                        token.map = itemLines;\n+                        if (isOrdered) {\n+                            token.info = state.src.slice(start, posAfterMarker - 1);\n                         }\n-                        var operation;\n-                        var id;\n-                        if (annotation === undefined) {\n-                            operation = CreateFile.create(uri, options);\n+\n+                        // change current state, then restore it after parser subcall\n+                        const oldTight = state.tight;\n+                        const oldTShift = state.tShift[nextLine];\n+                        const oldSCount = state.sCount[nextLine];\n+\n+                        //  - example list\n+                        // ^ listIndent position will be here\n+                        //   ^ blkIndent position will be here\n+                        //\n+                        const oldListIndent = state.listIndent;\n+                        state.listIndent = state.blkIndent;\n+                        state.blkIndent = indent;\n+                        state.tight = true;\n+                        state.tShift[nextLine] = contentStart - state.bMarks[nextLine];\n+                        state.sCount[nextLine] = offset;\n+                        if (contentStart >= max && state.isEmpty(nextLine + 1)) {\n+                            // workaround for this case\n+                            // (list item is empty, list terminates before \"foo\"):\n+                            // ~~~~~~~~\n+                            //   -\n+                            //\n+                            //     foo\n+                            // ~~~~~~~~\n+                            state.line = Math.min(state.line + 2, endLine);\n                         } else {\n-                            id = ChangeAnnotationIdentifier.is(annotation) ? annotation : this._changeAnnotations.manage(annotation);\n-                            operation = CreateFile.create(uri, options, id);\n-                        }\n-                        this._workspaceEdit.documentChanges.push(operation);\n-                        if (id !== undefined) {\n-                            return id;\n+                            state.md.block.tokenize(state, nextLine, endLine, true);\n                         }\n-                    };\n-                    WorkspaceChange.prototype.renameFile = function(oldUri, newUri, optionsOrAnnotation, options) {\n-                        this.initDocumentChanges();\n-                        if (this._workspaceEdit.documentChanges === undefined) {\n-                            throw new Error('Workspace edit is not configured for document changes.');\n+\n+                        // If any of list item is tight, mark list as tight\n+                        if (!state.tight || prevEmptyEnd) {\n+                            tight = false;\n                         }\n-                        var annotation;\n-                        if (ChangeAnnotation.is(optionsOrAnnotation) || ChangeAnnotationIdentifier.is(optionsOrAnnotation)) {\n-                            annotation = optionsOrAnnotation;\n-                        } else {\n-                            options = optionsOrAnnotation;\n+                        // Item become loose if finish with empty line,\n+                        // but we should filter last element, because it means list finish\n+                        prevEmptyEnd = state.line - nextLine > 1 && state.isEmpty(state.line - 1);\n+                        state.blkIndent = state.listIndent;\n+                        state.listIndent = oldListIndent;\n+                        state.tShift[nextLine] = oldTShift;\n+                        state.sCount[nextLine] = oldSCount;\n+                        state.tight = oldTight;\n+                        token = state.push('list_item_close', 'li', -1);\n+                        token.markup = String.fromCharCode(markerCharCode);\n+                        nextLine = state.line;\n+                        itemLines[1] = nextLine;\n+                        if (nextLine >= endLine) {\n+                            break;\n                         }\n-                        var operation;\n-                        var id;\n-                        if (annotation === undefined) {\n-                            operation = RenameFile.create(oldUri, newUri, options);\n-                        } else {\n-                            id = ChangeAnnotationIdentifier.is(annotation) ? annotation : this._changeAnnotations.manage(annotation);\n-                            operation = RenameFile.create(oldUri, newUri, options, id);\n+\n+                        //\n+                        // Try to check if list is terminated or continued.\n+                        //\n+                        if (state.sCount[nextLine] < state.blkIndent) {\n+                            break;\n                         }\n-                        this._workspaceEdit.documentChanges.push(operation);\n-                        if (id !== undefined) {\n-                            return id;\n+\n+                        // if it's indented more than 3 spaces, it should be a code block\n+                        if (state.sCount[nextLine] - state.blkIndent >= 4) {\n+                            break;\n                         }\n-                    };\n-                    WorkspaceChange.prototype.deleteFile = function(uri, optionsOrAnnotation, options) {\n-                        this.initDocumentChanges();\n-                        if (this._workspaceEdit.documentChanges === undefined) {\n-                            throw new Error('Workspace edit is not configured for document changes.');\n+\n+                        // fail if terminating block found\n+                        let terminate = false;\n+                        for (let i = 0, l = terminatorRules.length; i < l; i++) {\n+                            if (terminatorRules[i](state, nextLine, endLine, true)) {\n+                                terminate = true;\n+                                break;\n+                            }\n                         }\n-                        var annotation;\n-                        if (ChangeAnnotation.is(optionsOrAnnotation) || ChangeAnnotationIdentifier.is(optionsOrAnnotation)) {\n-                            annotation = optionsOrAnnotation;\n-                        } else {\n-                            options = optionsOrAnnotation;\n+                        if (terminate) {\n+                            break;\n                         }\n-                        var operation;\n-                        var id;\n-                        if (annotation === undefined) {\n-                            operation = DeleteFile.create(uri, options);\n+\n+                        // fail if list has another type\n+                        if (isOrdered) {\n+                            posAfterMarker = skipOrderedListMarker(state, nextLine);\n+                            if (posAfterMarker < 0) {\n+                                break;\n+                            }\n+                            start = state.bMarks[nextLine] + state.tShift[nextLine];\n                         } else {\n-                            id = ChangeAnnotationIdentifier.is(annotation) ? annotation : this._changeAnnotations.manage(annotation);\n-                            operation = DeleteFile.create(uri, options, id);\n+                            posAfterMarker = skipBulletListMarker(state, nextLine);\n+                            if (posAfterMarker < 0) {\n+                                break;\n+                            }\n                         }\n-                        this._workspaceEdit.documentChanges.push(operation);\n-                        if (id !== undefined) {\n-                            return id;\n+                        if (markerCharCode !== state.src.charCodeAt(posAfterMarker - 1)) {\n+                            break;\n                         }\n-                    };\n-                    return WorkspaceChange;\n-                }();\n-                exports.WorkspaceChange = WorkspaceChange;\n-                /**\n-                 * The TextDocumentIdentifier namespace provides helper functions to work with\n-                 * [TextDocumentIdentifier](#TextDocumentIdentifier) literals.\n-                 */\n-                var TextDocumentIdentifier;\n-                exports.TextDocumentIdentifier = TextDocumentIdentifier;\n-                (function(TextDocumentIdentifier) {\n-                    /**\n-                     * Creates a new TextDocumentIdentifier literal.\n-                     * @param uri The document's uri.\n-                     */\n-                    function create(uri) {\n-                        return {\n-                            uri: uri\n-                        };\n-                    }\n-                    TextDocumentIdentifier.create = create;\n-                    /**\n-                     * Checks whether the given literal conforms to the [TextDocumentIdentifier](#TextDocumentIdentifier) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.defined(candidate) && Is.string(candidate.uri);\n-                    }\n-                    TextDocumentIdentifier.is = is;\n-                })(TextDocumentIdentifier || (exports.TextDocumentIdentifier = TextDocumentIdentifier = {}));\n-                /**\n-                 * The VersionedTextDocumentIdentifier namespace provides helper functions to work with\n-                 * [VersionedTextDocumentIdentifier](#VersionedTextDocumentIdentifier) literals.\n-                 */\n-                var VersionedTextDocumentIdentifier;\n-                exports.VersionedTextDocumentIdentifier = VersionedTextDocumentIdentifier;\n-                (function(VersionedTextDocumentIdentifier) {\n-                    /**\n-                     * Creates a new VersionedTextDocumentIdentifier literal.\n-                     * @param uri The document's uri.\n-                     * @param version The document's version.\n-                     */\n-                    function create(uri, version) {\n-                        return {\n-                            uri: uri,\n-                            version: version\n-                        };\n-                    }\n-                    VersionedTextDocumentIdentifier.create = create;\n-                    /**\n-                     * Checks whether the given literal conforms to the [VersionedTextDocumentIdentifier](#VersionedTextDocumentIdentifier) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.defined(candidate) && Is.string(candidate.uri) && Is.integer(candidate.version);\n-                    }\n-                    VersionedTextDocumentIdentifier.is = is;\n-                })(VersionedTextDocumentIdentifier || (exports.VersionedTextDocumentIdentifier = VersionedTextDocumentIdentifier = {}));\n-                /**\n-                 * The OptionalVersionedTextDocumentIdentifier namespace provides helper functions to work with\n-                 * [OptionalVersionedTextDocumentIdentifier](#OptionalVersionedTextDocumentIdentifier) literals.\n-                 */\n-                var OptionalVersionedTextDocumentIdentifier;\n-                exports.OptionalVersionedTextDocumentIdentifier = OptionalVersionedTextDocumentIdentifier;\n-                (function(OptionalVersionedTextDocumentIdentifier) {\n-                    /**\n-                     * Creates a new OptionalVersionedTextDocumentIdentifier literal.\n-                     * @param uri The document's uri.\n-                     * @param version The document's version.\n-                     */\n-                    function create(uri, version) {\n-                        return {\n-                            uri: uri,\n-                            version: version\n-                        };\n-                    }\n-                    OptionalVersionedTextDocumentIdentifier.create = create;\n-                    /**\n-                     * Checks whether the given literal conforms to the [OptionalVersionedTextDocumentIdentifier](#OptionalVersionedTextDocumentIdentifier) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.defined(candidate) && Is.string(candidate.uri) && (candidate.version === null || Is.integer(candidate.version));\n-                    }\n-                    OptionalVersionedTextDocumentIdentifier.is = is;\n-                })(OptionalVersionedTextDocumentIdentifier || (exports.OptionalVersionedTextDocumentIdentifier = OptionalVersionedTextDocumentIdentifier = {}));\n-                /**\n-                 * The TextDocumentItem namespace provides helper functions to work with\n-                 * [TextDocumentItem](#TextDocumentItem) literals.\n-                 */\n-                var TextDocumentItem;\n-                exports.TextDocumentItem = TextDocumentItem;\n-                (function(TextDocumentItem) {\n-                    /**\n-                     * Creates a new TextDocumentItem literal.\n-                     * @param uri The document's uri.\n-                     * @param languageId The document's language identifier.\n-                     * @param version The document's version number.\n-                     * @param text The document's text.\n-                     */\n-                    function create(uri, languageId, version, text) {\n-                        return {\n-                            uri: uri,\n-                            languageId: languageId,\n-                            version: version,\n-                            text: text\n-                        };\n-                    }\n-                    TextDocumentItem.create = create;\n-                    /**\n-                     * Checks whether the given literal conforms to the [TextDocumentItem](#TextDocumentItem) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.defined(candidate) && Is.string(candidate.uri) && Is.string(candidate.languageId) && Is.integer(candidate.version) && Is.string(candidate.text);\n-                    }\n-                    TextDocumentItem.is = is;\n-                })(TextDocumentItem || (exports.TextDocumentItem = TextDocumentItem = {}));\n-                /**\n-                 * Describes the content type that a client supports in various\n-                 * result literals like `Hover`, `ParameterInfo` or `CompletionItem`.\n-                 *\n-                 * Please note that `MarkupKinds` must not start with a `$`. This kinds\n-                 * are reserved for internal usage.\n-                 */\n-                var MarkupKind;\n-                exports.MarkupKind = MarkupKind;\n-                (function(MarkupKind) {\n-                    /**\n-                     * Plain text is supported as a content format\n-                     */\n-                    MarkupKind.PlainText = 'plaintext';\n-                    /**\n-                     * Markdown is supported as a content format\n-                     */\n-                    MarkupKind.Markdown = 'markdown';\n-                    /**\n-                     * Checks whether the given value is a value of the [MarkupKind](#MarkupKind) type.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return candidate === MarkupKind.PlainText || candidate === MarkupKind.Markdown;\n-                    }\n-                    MarkupKind.is = is;\n-                })(MarkupKind || (exports.MarkupKind = MarkupKind = {}));\n-                var MarkupContent;\n-                exports.MarkupContent = MarkupContent;\n-                (function(MarkupContent) {\n-                    /**\n-                     * Checks whether the given value conforms to the [MarkupContent](#MarkupContent) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.objectLiteral(value) && MarkupKind.is(candidate.kind) && Is.string(candidate.value);\n-                    }\n-                    MarkupContent.is = is;\n-                })(MarkupContent || (exports.MarkupContent = MarkupContent = {}));\n-                /**\n-                 * The kind of a completion entry.\n-                 */\n-                var CompletionItemKind;\n-                exports.CompletionItemKind = CompletionItemKind;\n-                (function(CompletionItemKind) {\n-                    CompletionItemKind.Text = 1;\n-                    CompletionItemKind.Method = 2;\n-                    CompletionItemKind.Function = 3;\n-                    CompletionItemKind.Constructor = 4;\n-                    CompletionItemKind.Field = 5;\n-                    CompletionItemKind.Variable = 6;\n-                    CompletionItemKind.Class = 7;\n-                    CompletionItemKind.Interface = 8;\n-                    CompletionItemKind.Module = 9;\n-                    CompletionItemKind.Property = 10;\n-                    CompletionItemKind.Unit = 11;\n-                    CompletionItemKind.Value = 12;\n-                    CompletionItemKind.Enum = 13;\n-                    CompletionItemKind.Keyword = 14;\n-                    CompletionItemKind.Snippet = 15;\n-                    CompletionItemKind.Color = 16;\n-                    CompletionItemKind.File = 17;\n-                    CompletionItemKind.Reference = 18;\n-                    CompletionItemKind.Folder = 19;\n-                    CompletionItemKind.EnumMember = 20;\n-                    CompletionItemKind.Constant = 21;\n-                    CompletionItemKind.Struct = 22;\n-                    CompletionItemKind.Event = 23;\n-                    CompletionItemKind.Operator = 24;\n-                    CompletionItemKind.TypeParameter = 25;\n-                })(CompletionItemKind || (exports.CompletionItemKind = CompletionItemKind = {}));\n-                /**\n-                 * Defines whether the insert text in a completion item should be interpreted as\n-                 * plain text or a snippet.\n-                 */\n-                var InsertTextFormat;\n-                exports.InsertTextFormat = InsertTextFormat;\n-                (function(InsertTextFormat) {\n-                    /**\n-                     * The primary text to be inserted is treated as a plain string.\n-                     */\n-                    InsertTextFormat.PlainText = 1;\n-                    /**\n-                     * The primary text to be inserted is treated as a snippet.\n-                     *\n-                     * A snippet can define tab stops and placeholders with `$1`, `$2`\n-                     * and `${3:foo}`. `$0` defines the final tab stop, it defaults to\n-                     * the end of the snippet. Placeholders with equal identifiers are linked,\n-                     * that is typing in one will update others too.\n-                     *\n-                     * See also: https://microsoft.github.io/language-server-protocol/specifications/specification-current/#snippet_syntax\n-                     */\n-                    InsertTextFormat.Snippet = 2;\n-                })(InsertTextFormat || (exports.InsertTextFormat = InsertTextFormat = {}));\n-                /**\n-                 * Completion item tags are extra annotations that tweak the rendering of a completion\n-                 * item.\n-                 *\n-                 * @since 3.15.0\n-                 */\n-                var CompletionItemTag;\n-                exports.CompletionItemTag = CompletionItemTag;\n-                (function(CompletionItemTag) {\n-                    /**\n-                     * Render a completion as obsolete, usually using a strike-out.\n-                     */\n-                    CompletionItemTag.Deprecated = 1;\n-                })(CompletionItemTag || (exports.CompletionItemTag = CompletionItemTag = {}));\n-                /**\n-                 * The InsertReplaceEdit namespace provides functions to deal with insert / replace edits.\n-                 *\n-                 * @since 3.16.0\n-                 */\n-                var InsertReplaceEdit;\n-                exports.InsertReplaceEdit = InsertReplaceEdit;\n-                (function(InsertReplaceEdit) {\n-                    /**\n-                     * Creates a new insert / replace edit\n-                     */\n-                    function create(newText, insert, replace) {\n-                        return {\n-                            newText: newText,\n-                            insert: insert,\n-                            replace: replace\n-                        };\n-                    }\n-                    InsertReplaceEdit.create = create;\n-                    /**\n-                     * Checks whether the given literal conforms to the [InsertReplaceEdit](#InsertReplaceEdit) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return candidate && Is.string(candidate.newText) && Range.is(candidate.insert) && Range.is(candidate.replace);\n-                    }\n-                    InsertReplaceEdit.is = is;\n-                })(InsertReplaceEdit || (exports.InsertReplaceEdit = InsertReplaceEdit = {}));\n-                /**\n-                 * How whitespace and indentation is handled during completion\n-                 * item insertion.\n-                 *\n-                 * @since 3.16.0\n-                 */\n-                var InsertTextMode;\n-                exports.InsertTextMode = InsertTextMode;\n-                (function(InsertTextMode) {\n-                    /**\n-                     * The insertion or replace strings is taken as it is. If the\n-                     * value is multi line the lines below the cursor will be\n-                     * inserted using the indentation defined in the string value.\n-                     * The client will not apply any kind of adjustments to the\n-                     * string.\n-                     */\n-                    InsertTextMode.asIs = 1;\n-                    /**\n-                     * The editor adjusts leading whitespace of new lines so that\n-                     * they match the indentation up to the cursor of the line for\n-                     * which the item is accepted.\n-                     *\n-                     * Consider a line like this: <2tabs><cursor><3tabs>foo. Accepting a\n-                     * multi line completion item is indented using 2 tabs and all\n-                     * following lines inserted will be indented using 2 tabs as well.\n-                     */\n-                    InsertTextMode.adjustIndentation = 2;\n-                })(InsertTextMode || (exports.InsertTextMode = InsertTextMode = {}));\n-                var CompletionItemLabelDetails;\n-                exports.CompletionItemLabelDetails = CompletionItemLabelDetails;\n-                (function(CompletionItemLabelDetails) {\n-                    function is(value) {\n-                        var candidate = value;\n-                        return candidate && (Is.string(candidate.detail) || candidate.detail === undefined) && (Is.string(candidate.description) || candidate.description === undefined);\n-                    }\n-                    CompletionItemLabelDetails.is = is;\n-                })(CompletionItemLabelDetails || (exports.CompletionItemLabelDetails = CompletionItemLabelDetails = {}));\n-                /**\n-                 * The CompletionItem namespace provides functions to deal with\n-                 * completion items.\n-                 */\n-                var CompletionItem;\n-                exports.CompletionItem = CompletionItem;\n-                (function(CompletionItem) {\n-                    /**\n-                     * Create a completion item and seed it with a label.\n-                     * @param label The completion item's label\n-                     */\n-                    function create(label) {\n-                        return {\n-                            label: label\n-                        };\n-                    }\n-                    CompletionItem.create = create;\n-                })(CompletionItem || (exports.CompletionItem = CompletionItem = {}));\n-                /**\n-                 * The CompletionList namespace provides functions to deal with\n-                 * completion lists.\n-                 */\n-                var CompletionList;\n-                exports.CompletionList = CompletionList;\n-                (function(CompletionList) {\n-                    /**\n-                     * Creates a new completion list.\n-                     *\n-                     * @param items The completion items.\n-                     * @param isIncomplete The list is not complete.\n-                     */\n-                    function create(items, isIncomplete) {\n-                        return {\n-                            items: items ? items : [],\n-                            isIncomplete: !!isIncomplete\n-                        };\n                     }\n-                    CompletionList.create = create;\n-                })(CompletionList || (exports.CompletionList = CompletionList = {}));\n-                var MarkedString;\n-                exports.MarkedString = MarkedString;\n-                (function(MarkedString) {\n-                    /**\n-                     * Creates a marked string from plain text.\n-                     *\n-                     * @param plainText The plain text.\n-                     */\n-                    function fromPlainText(plainText) {\n-                        return plainText.replace(/[\\\\`*_{}[\\]()#+\\-.!]/g, '\\\\$&'); // escape markdown syntax tokens: http://daringfireball.net/projects/markdown/syntax#backslash\n+\n+                    // Finalize list\n+                    if (isOrdered) {\n+                        token = state.push('ordered_list_close', 'ol', -1);\n+                    } else {\n+                        token = state.push('bullet_list_close', 'ul', -1);\n                     }\n+                    token.markup = String.fromCharCode(markerCharCode);\n+                    listLines[1] = nextLine;\n+                    state.line = nextLine;\n+                    state.parentType = oldParentType;\n \n-                    MarkedString.fromPlainText = fromPlainText;\n-                    /**\n-                     * Checks whether the given value conforms to the [MarkedString](#MarkedString) type.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.string(candidate) || Is.objectLiteral(candidate) && Is.string(candidate.language) && Is.string(candidate.value);\n+                    // mark paragraphs tight if needed\n+                    if (tight) {\n+                        markTightParagraphs(state, listTokIdx);\n                     }\n-                    MarkedString.is = is;\n-                })(MarkedString || (exports.MarkedString = MarkedString = {}));\n-                var Hover;\n-                exports.Hover = Hover;\n-                (function(Hover) {\n-                    /**\n-                     * Checks whether the given value conforms to the [Hover](#Hover) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return !!candidate && Is.objectLiteral(candidate) && (MarkupContent.is(candidate.contents) || MarkedString.is(candidate.contents) || Is.typedArray(candidate.contents, MarkedString.is)) && (value.range === undefined || Range.is(value.range));\n+                    return true;\n+                }\n+\n+                function reference(state, startLine, _endLine, silent) {\n+                    let pos = state.bMarks[startLine] + state.tShift[startLine];\n+                    let max = state.eMarks[startLine];\n+                    let nextLine = startLine + 1;\n+\n+                    // if it's indented more than 3 spaces, it should be a code block\n+                    if (state.sCount[startLine] - state.blkIndent >= 4) {\n+                        return false;\n                     }\n-                    Hover.is = is;\n-                })(Hover || (exports.Hover = Hover = {}));\n-                /**\n-                 * The ParameterInformation namespace provides helper functions to work with\n-                 * [ParameterInformation](#ParameterInformation) literals.\n-                 */\n-                var ParameterInformation;\n-                exports.ParameterInformation = ParameterInformation;\n-                (function(ParameterInformation) {\n-                    /**\n-                     * Creates a new parameter information literal.\n-                     *\n-                     * @param label A label string.\n-                     * @param documentation A doc string.\n-                     */\n-                    function create(label, documentation) {\n-                        return documentation ? {\n-                            label: label,\n-                            documentation: documentation\n-                        } : {\n-                            label: label\n-                        };\n+                    if (state.src.charCodeAt(pos) !== 0x5B /* [ */ ) {\n+                        return false;\n                     }\n-                    ParameterInformation.create = create;\n-                })(ParameterInformation || (exports.ParameterInformation = ParameterInformation = {}));\n-                /**\n-                 * The SignatureInformation namespace provides helper functions to work with\n-                 * [SignatureInformation](#SignatureInformation) literals.\n-                 */\n-                var SignatureInformation;\n-                exports.SignatureInformation = SignatureInformation;\n-                (function(SignatureInformation) {\n-                    function create(label, documentation) {\n-                        var parameters = [];\n-                        for (var _i = 2; _i < arguments.length; _i++) {\n-                            parameters[_i - 2] = arguments[_i];\n-                        }\n-                        var result = {\n-                            label: label\n-                        };\n-                        if (Is.defined(documentation)) {\n-                            result.documentation = documentation;\n+\n+                    function getNextLine(nextLine) {\n+                        const endLine = state.lineMax;\n+                        if (nextLine >= endLine || state.isEmpty(nextLine)) {\n+                            // empty line or end of input\n+                            return null;\n                         }\n-                        if (Is.defined(parameters)) {\n-                            result.parameters = parameters;\n-                        } else {\n-                            result.parameters = [];\n+                        let isContinuation = false;\n+\n+                        // this would be a code block normally, but after paragraph\n+                        // it's considered a lazy continuation regardless of what's there\n+                        if (state.sCount[nextLine] - state.blkIndent > 3) {\n+                            isContinuation = true;\n                         }\n-                        return result;\n-                    }\n-                    SignatureInformation.create = create;\n-                })(SignatureInformation || (exports.SignatureInformation = SignatureInformation = {}));\n-                /**\n-                 * A document highlight kind.\n-                 */\n-                var DocumentHighlightKind;\n-                exports.DocumentHighlightKind = DocumentHighlightKind;\n-                (function(DocumentHighlightKind) {\n-                    /**\n-                     * A textual occurrence.\n-                     */\n-                    DocumentHighlightKind.Text = 1;\n-                    /**\n-                     * Read-access of a symbol, like reading a variable.\n-                     */\n-                    DocumentHighlightKind.Read = 2;\n-                    /**\n-                     * Write-access of a symbol, like writing to a variable.\n-                     */\n-                    DocumentHighlightKind.Write = 3;\n-                })(DocumentHighlightKind || (exports.DocumentHighlightKind = DocumentHighlightKind = {}));\n-                /**\n-                 * DocumentHighlight namespace to provide helper functions to work with\n-                 * [DocumentHighlight](#DocumentHighlight) literals.\n-                 */\n-                var DocumentHighlight;\n-                exports.DocumentHighlight = DocumentHighlight;\n-                (function(DocumentHighlight) {\n-                    /**\n-                     * Create a DocumentHighlight object.\n-                     * @param range The range the highlight applies to.\n-                     * @param kind The highlight kind\n-                     */\n-                    function create(range, kind) {\n-                        var result = {\n-                            range: range\n-                        };\n-                        if (Is.number(kind)) {\n-                            result.kind = kind;\n+\n+                        // quirk for blockquotes, this line should already be checked by that rule\n+                        if (state.sCount[nextLine] < 0) {\n+                            isContinuation = true;\n                         }\n-                        return result;\n-                    }\n-                    DocumentHighlight.create = create;\n-                })(DocumentHighlight || (exports.DocumentHighlight = DocumentHighlight = {}));\n-                /**\n-                 * A symbol kind.\n-                 */\n-                var SymbolKind;\n-                exports.SymbolKind = SymbolKind;\n-                (function(SymbolKind) {\n-                    SymbolKind.File = 1;\n-                    SymbolKind.Module = 2;\n-                    SymbolKind.Namespace = 3;\n-                    SymbolKind.Package = 4;\n-                    SymbolKind.Class = 5;\n-                    SymbolKind.Method = 6;\n-                    SymbolKind.Property = 7;\n-                    SymbolKind.Field = 8;\n-                    SymbolKind.Constructor = 9;\n-                    SymbolKind.Enum = 10;\n-                    SymbolKind.Interface = 11;\n-                    SymbolKind.Function = 12;\n-                    SymbolKind.Variable = 13;\n-                    SymbolKind.Constant = 14;\n-                    SymbolKind.String = 15;\n-                    SymbolKind.Number = 16;\n-                    SymbolKind.Boolean = 17;\n-                    SymbolKind.Array = 18;\n-                    SymbolKind.Object = 19;\n-                    SymbolKind.Key = 20;\n-                    SymbolKind.Null = 21;\n-                    SymbolKind.EnumMember = 22;\n-                    SymbolKind.Struct = 23;\n-                    SymbolKind.Event = 24;\n-                    SymbolKind.Operator = 25;\n-                    SymbolKind.TypeParameter = 26;\n-                })(SymbolKind || (exports.SymbolKind = SymbolKind = {}));\n-                /**\n-                 * Symbol tags are extra annotations that tweak the rendering of a symbol.\n-                 * @since 3.16\n-                 */\n-                var SymbolTag;\n-                exports.SymbolTag = SymbolTag;\n-                (function(SymbolTag) {\n-                    /**\n-                     * Render a symbol as obsolete, usually using a strike-out.\n-                     */\n-                    SymbolTag.Deprecated = 1;\n-                })(SymbolTag || (exports.SymbolTag = SymbolTag = {}));\n-                var SymbolInformation;\n-                exports.SymbolInformation = SymbolInformation;\n-                (function(SymbolInformation) {\n-                    /**\n-                     * Creates a new symbol information literal.\n-                     *\n-                     * @param name The name of the symbol.\n-                     * @param kind The kind of the symbol.\n-                     * @param range The range of the location of the symbol.\n-                     * @param uri The resource of the location of symbol.\n-                     * @param containerName The name of the symbol containing the symbol.\n-                     */\n-                    function create(name, kind, range, uri, containerName) {\n-                        var result = {\n-                            name: name,\n-                            kind: kind,\n-                            location: {\n-                                uri: uri,\n-                                range: range\n+                        if (!isContinuation) {\n+                            const terminatorRules = state.md.block.ruler.getRules('reference');\n+                            const oldParentType = state.parentType;\n+                            state.parentType = 'reference';\n+\n+                            // Some tags can terminate paragraph without empty line.\n+                            let terminate = false;\n+                            for (let i = 0, l = terminatorRules.length; i < l; i++) {\n+                                if (terminatorRules[i](state, nextLine, endLine, true)) {\n+                                    terminate = true;\n+                                    break;\n+                                }\n+                            }\n+                            state.parentType = oldParentType;\n+                            if (terminate) {\n+                                // terminated by another block\n+                                return null;\n                             }\n-                        };\n-                        if (containerName) {\n-                            result.containerName = containerName;\n                         }\n-                        return result;\n+                        const pos = state.bMarks[nextLine] + state.tShift[nextLine];\n+                        const max = state.eMarks[nextLine];\n+\n+                        // max + 1 explicitly includes the newline\n+                        return state.src.slice(pos, max + 1);\n                     }\n-                    SymbolInformation.create = create;\n-                })(SymbolInformation || (exports.SymbolInformation = SymbolInformation = {}));\n-                var WorkspaceSymbol;\n-                exports.WorkspaceSymbol = WorkspaceSymbol;\n-                (function(WorkspaceSymbol) {\n-                    /**\n-                     * Create a new workspace symbol.\n-                     *\n-                     * @param name The name of the symbol.\n-                     * @param kind The kind of the symbol.\n-                     * @param uri The resource of the location of the symbol.\n-                     * @param range An options range of the location.\n-                     * @returns A WorkspaceSymbol.\n-                     */\n-                    function create(name, kind, uri, range) {\n-                        return range !== undefined ? {\n-                            name: name,\n-                            kind: kind,\n-                            location: {\n-                                uri: uri,\n-                                range: range\n+                    let str = state.src.slice(pos, max + 1);\n+                    max = str.length;\n+                    let labelEnd = -1;\n+                    for (pos = 1; pos < max; pos++) {\n+                        const ch = str.charCodeAt(pos);\n+                        if (ch === 0x5B /* [ */ ) {\n+                            return false;\n+                        } else if (ch === 0x5D /* ] */ ) {\n+                            labelEnd = pos;\n+                            break;\n+                        } else if (ch === 0x0A /* \\n */ ) {\n+                            const lineContent = getNextLine(nextLine);\n+                            if (lineContent !== null) {\n+                                str += lineContent;\n+                                max = str.length;\n+                                nextLine++;\n                             }\n-                        } : {\n-                            name: name,\n-                            kind: kind,\n-                            location: {\n-                                uri: uri\n+                        } else if (ch === 0x5C /* \\ */ ) {\n+                            pos++;\n+                            if (pos < max && str.charCodeAt(pos) === 0x0A) {\n+                                const lineContent = getNextLine(nextLine);\n+                                if (lineContent !== null) {\n+                                    str += lineContent;\n+                                    max = str.length;\n+                                    nextLine++;\n+                                }\n                             }\n-                        };\n-                    }\n-                    WorkspaceSymbol.create = create;\n-                })(WorkspaceSymbol || (exports.WorkspaceSymbol = WorkspaceSymbol = {}));\n-                var DocumentSymbol;\n-                exports.DocumentSymbol = DocumentSymbol;\n-                (function(DocumentSymbol) {\n-                    /**\n-                     * Creates a new symbol information literal.\n-                     *\n-                     * @param name The name of the symbol.\n-                     * @param detail The detail of the symbol.\n-                     * @param kind The kind of the symbol.\n-                     * @param range The range of the symbol.\n-                     * @param selectionRange The selectionRange of the symbol.\n-                     * @param children Children of the symbol.\n-                     */\n-                    function create(name, detail, kind, range, selectionRange, children) {\n-                        var result = {\n-                            name: name,\n-                            detail: detail,\n-                            kind: kind,\n-                            range: range,\n-                            selectionRange: selectionRange\n-                        };\n-                        if (children !== undefined) {\n-                            result.children = children;\n                         }\n-                        return result;\n                     }\n-                    DocumentSymbol.create = create;\n-                    /**\n-                     * Checks whether the given literal conforms to the [DocumentSymbol](#DocumentSymbol) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return candidate && Is.string(candidate.name) && Is.number(candidate.kind) && Range.is(candidate.range) && Range.is(candidate.selectionRange) && (candidate.detail === undefined || Is.string(candidate.detail)) && (candidate.deprecated === undefined || Is.boolean(candidate.deprecated)) && (candidate.children === undefined || Array.isArray(candidate.children)) && (candidate.tags === undefined || Array.isArray(candidate.tags));\n+                    if (labelEnd < 0 || str.charCodeAt(labelEnd + 1) !== 0x3A /* : */ ) {\n+                        return false;\n                     }\n-                    DocumentSymbol.is = is;\n-                })(DocumentSymbol || (exports.DocumentSymbol = DocumentSymbol = {}));\n-                /**\n-                 * A set of predefined code action kinds\n-                 */\n-                var CodeActionKind;\n-                exports.CodeActionKind = CodeActionKind;\n-                (function(CodeActionKind) {\n-                    /**\n-                     * Empty kind.\n-                     */\n-                    CodeActionKind.Empty = '';\n-                    /**\n-                     * Base kind for quickfix actions: 'quickfix'\n-                     */\n-                    CodeActionKind.QuickFix = 'quickfix';\n-                    /**\n-                     * Base kind for refactoring actions: 'refactor'\n-                     */\n-                    CodeActionKind.Refactor = 'refactor';\n-                    /**\n-                     * Base kind for refactoring extraction actions: 'refactor.extract'\n-                     *\n-                     * Example extract actions:\n-                     *\n-                     * - Extract method\n-                     * - Extract function\n-                     * - Extract variable\n-                     * - Extract interface from class\n-                     * - ...\n-                     */\n-                    CodeActionKind.RefactorExtract = 'refactor.extract';\n-                    /**\n-                     * Base kind for refactoring inline actions: 'refactor.inline'\n-                     *\n-                     * Example inline actions:\n-                     *\n-                     * - Inline function\n-                     * - Inline variable\n-                     * - Inline constant\n-                     * - ...\n-                     */\n-                    CodeActionKind.RefactorInline = 'refactor.inline';\n-                    /**\n-                     * Base kind for refactoring rewrite actions: 'refactor.rewrite'\n-                     *\n-                     * Example rewrite actions:\n-                     *\n-                     * - Convert JavaScript function to class\n-                     * - Add or remove parameter\n-                     * - Encapsulate field\n-                     * - Make method static\n-                     * - Move method to base class\n-                     * - ...\n-                     */\n-                    CodeActionKind.RefactorRewrite = 'refactor.rewrite';\n-                    /**\n-                     * Base kind for source actions: `source`\n-                     *\n-                     * Source code actions apply to the entire file.\n-                     */\n-                    CodeActionKind.Source = 'source';\n-                    /**\n-                     * Base kind for an organize imports source action: `source.organizeImports`\n-                     */\n-                    CodeActionKind.SourceOrganizeImports = 'source.organizeImports';\n-                    /**\n-                     * Base kind for auto-fix source actions: `source.fixAll`.\n-                     *\n-                     * Fix all actions automatically fix errors that have a clear fix that do not require user input.\n-                     * They should not suppress errors or perform unsafe fixes such as generating new types or classes.\n-                     *\n-                     * @since 3.15.0\n-                     */\n-                    CodeActionKind.SourceFixAll = 'source.fixAll';\n-                })(CodeActionKind || (exports.CodeActionKind = CodeActionKind = {}));\n-                /**\n-                 * The reason why code actions were requested.\n-                 *\n-                 * @since 3.17.0\n-                 */\n-                var CodeActionTriggerKind;\n-                exports.CodeActionTriggerKind = CodeActionTriggerKind;\n-                (function(CodeActionTriggerKind) {\n-                    /**\n-                     * Code actions were explicitly requested by the user or by an extension.\n-                     */\n-                    CodeActionTriggerKind.Invoked = 1;\n-                    /**\n-                     * Code actions were requested automatically.\n-                     *\n-                     * This typically happens when current selection in a file changes, but can\n-                     * also be triggered when file content changes.\n-                     */\n-                    CodeActionTriggerKind.Automatic = 2;\n-                })(CodeActionTriggerKind || (exports.CodeActionTriggerKind = CodeActionTriggerKind = {}));\n-                /**\n-                 * The CodeActionContext namespace provides helper functions to work with\n-                 * [CodeActionContext](#CodeActionContext) literals.\n-                 */\n-                var CodeActionContext;\n-                exports.CodeActionContext = CodeActionContext;\n-                (function(CodeActionContext) {\n-                    /**\n-                     * Creates a new CodeActionContext literal.\n-                     */\n-                    function create(diagnostics, only, triggerKind) {\n-                        var result = {\n-                            diagnostics: diagnostics\n-                        };\n-                        if (only !== undefined && only !== null) {\n-                            result.only = only;\n-                        }\n-                        if (triggerKind !== undefined && triggerKind !== null) {\n-                            result.triggerKind = triggerKind;\n+\n+                    // [label]:   destination   'title'\n+                    //         ^^^ skip optional whitespace here\n+                    for (pos = labelEnd + 2; pos < max; pos++) {\n+                        const ch = str.charCodeAt(pos);\n+                        if (ch === 0x0A) {\n+                            const lineContent = getNextLine(nextLine);\n+                            if (lineContent !== null) {\n+                                str += lineContent;\n+                                max = str.length;\n+                                nextLine++;\n+                            }\n+                        } else if (isSpace(ch));\n+                        else {\n+                            break;\n                         }\n-                        return result;\n                     }\n-                    CodeActionContext.create = create;\n-                    /**\n-                     * Checks whether the given literal conforms to the [CodeActionContext](#CodeActionContext) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.defined(candidate) && Is.typedArray(candidate.diagnostics, Diagnostic.is) && (candidate.only === undefined || Is.typedArray(candidate.only, Is.string)) && (candidate.triggerKind === undefined || candidate.triggerKind === CodeActionTriggerKind.Invoked || candidate.triggerKind === CodeActionTriggerKind.Automatic);\n+\n+                    // [label]:   destination   'title'\n+                    //            ^^^^^^^^^^^ parse this\n+                    const destRes = state.md.helpers.parseLinkDestination(str, pos, max);\n+                    if (!destRes.ok) {\n+                        return false;\n                     }\n-                    CodeActionContext.is = is;\n-                })(CodeActionContext || (exports.CodeActionContext = CodeActionContext = {}));\n-                var CodeAction;\n-                exports.CodeAction = CodeAction;\n-                (function(CodeAction) {\n-                    function create(title, kindOrCommandOrEdit, kind) {\n-                        var result = {\n-                            title: title\n-                        };\n-                        var checkKind = true;\n-                        if (typeof kindOrCommandOrEdit === 'string') {\n-                            checkKind = false;\n-                            result.kind = kindOrCommandOrEdit;\n-                        } else if (Command.is(kindOrCommandOrEdit)) {\n-                            result.command = kindOrCommandOrEdit;\n-                        } else {\n-                            result.edit = kindOrCommandOrEdit;\n-                        }\n-                        if (checkKind && kind !== undefined) {\n-                            result.kind = kind;\n-                        }\n-                        return result;\n+                    const href = state.md.normalizeLink(destRes.str);\n+                    if (!state.md.validateLink(href)) {\n+                        return false;\n                     }\n-                    CodeAction.create = create;\n+                    pos = destRes.pos;\n \n-                    function is(value) {\n-                        var candidate = value;\n-                        return candidate && Is.string(candidate.title) && (candidate.diagnostics === undefined || Is.typedArray(candidate.diagnostics, Diagnostic.is)) && (candidate.kind === undefined || Is.string(candidate.kind)) && (candidate.edit !== undefined || candidate.command !== undefined) && (candidate.command === undefined || Command.is(candidate.command)) && (candidate.isPreferred === undefined || Is.boolean(candidate.isPreferred)) && (candidate.edit === undefined || WorkspaceEdit.is(candidate.edit));\n-                    }\n-                    CodeAction.is = is;\n-                })(CodeAction || (exports.CodeAction = CodeAction = {}));\n-                /**\n-                 * The CodeLens namespace provides helper functions to work with\n-                 * [CodeLens](#CodeLens) literals.\n-                 */\n-                var CodeLens;\n-                exports.CodeLens = CodeLens;\n-                (function(CodeLens) {\n-                    /**\n-                     * Creates a new CodeLens literal.\n-                     */\n-                    function create(range, data) {\n-                        var result = {\n-                            range: range\n-                        };\n-                        if (Is.defined(data)) {\n-                            result.data = data;\n+                    // save cursor state, we could require to rollback later\n+                    const destEndPos = pos;\n+                    const destEndLineNo = nextLine;\n+\n+                    // [label]:   destination   'title'\n+                    //                       ^^^ skipping those spaces\n+                    const start = pos;\n+                    for (; pos < max; pos++) {\n+                        const ch = str.charCodeAt(pos);\n+                        if (ch === 0x0A) {\n+                            const lineContent = getNextLine(nextLine);\n+                            if (lineContent !== null) {\n+                                str += lineContent;\n+                                max = str.length;\n+                                nextLine++;\n+                            }\n+                        } else if (isSpace(ch));\n+                        else {\n+                            break;\n                         }\n-                        return result;\n                     }\n-                    CodeLens.create = create;\n-                    /**\n-                     * Checks whether the given literal conforms to the [CodeLens](#CodeLens) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.defined(candidate) && Range.is(candidate.range) && (Is.undefined(candidate.command) || Command.is(candidate.command));\n+\n+                    // [label]:   destination   'title'\n+                    //                          ^^^^^^^ parse this\n+                    let titleRes = state.md.helpers.parseLinkTitle(str, pos, max);\n+                    while (titleRes.can_continue) {\n+                        const lineContent = getNextLine(nextLine);\n+                        if (lineContent === null) break;\n+                        str += lineContent;\n+                        pos = max;\n+                        max = str.length;\n+                        nextLine++;\n+                        titleRes = state.md.helpers.parseLinkTitle(str, pos, max, titleRes);\n                     }\n-                    CodeLens.is = is;\n-                })(CodeLens || (exports.CodeLens = CodeLens = {}));\n-                /**\n-                 * The FormattingOptions namespace provides helper functions to work with\n-                 * [FormattingOptions](#FormattingOptions) literals.\n-                 */\n-                var FormattingOptions;\n-                exports.FormattingOptions = FormattingOptions;\n-                (function(FormattingOptions) {\n-                    /**\n-                     * Creates a new FormattingOptions literal.\n-                     */\n-                    function create(tabSize, insertSpaces) {\n-                        return {\n-                            tabSize: tabSize,\n-                            insertSpaces: insertSpaces\n-                        };\n+                    let title;\n+                    if (pos < max && start !== pos && titleRes.ok) {\n+                        title = titleRes.str;\n+                        pos = titleRes.pos;\n+                    } else {\n+                        title = '';\n+                        pos = destEndPos;\n+                        nextLine = destEndLineNo;\n                     }\n-                    FormattingOptions.create = create;\n-                    /**\n-                     * Checks whether the given literal conforms to the [FormattingOptions](#FormattingOptions) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.defined(candidate) && Is.uinteger(candidate.tabSize) && Is.boolean(candidate.insertSpaces);\n+\n+                    // skip trailing spaces until the rest of the line\n+                    while (pos < max) {\n+                        const ch = str.charCodeAt(pos);\n+                        if (!isSpace(ch)) {\n+                            break;\n+                        }\n+                        pos++;\n                     }\n-                    FormattingOptions.is = is;\n-                })(FormattingOptions || (exports.FormattingOptions = FormattingOptions = {}));\n-                /**\n-                 * The DocumentLink namespace provides helper functions to work with\n-                 * [DocumentLink](#DocumentLink) literals.\n-                 */\n-                var DocumentLink;\n-                exports.DocumentLink = DocumentLink;\n-                (function(DocumentLink) {\n-                    /**\n-                     * Creates a new DocumentLink literal.\n-                     */\n-                    function create(range, target, data) {\n-                        return {\n-                            range: range,\n-                            target: target,\n-                            data: data\n-                        };\n+                    if (pos < max && str.charCodeAt(pos) !== 0x0A) {\n+                        if (title) {\n+                            // garbage at the end of the line after title,\n+                            // but it could still be a valid reference if we roll back\n+                            title = '';\n+                            pos = destEndPos;\n+                            nextLine = destEndLineNo;\n+                            while (pos < max) {\n+                                const ch = str.charCodeAt(pos);\n+                                if (!isSpace(ch)) {\n+                                    break;\n+                                }\n+                                pos++;\n+                            }\n+                        }\n                     }\n-                    DocumentLink.create = create;\n-                    /**\n-                     * Checks whether the given literal conforms to the [DocumentLink](#DocumentLink) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.defined(candidate) && Range.is(candidate.range) && (Is.undefined(candidate.target) || Is.string(candidate.target));\n+                    if (pos < max && str.charCodeAt(pos) !== 0x0A) {\n+                        // garbage at the end of the line\n+                        return false;\n                     }\n-                    DocumentLink.is = is;\n-                })(DocumentLink || (exports.DocumentLink = DocumentLink = {}));\n-                /**\n-                 * The SelectionRange namespace provides helper function to work with\n-                 * SelectionRange literals.\n-                 */\n-                var SelectionRange;\n-                exports.SelectionRange = SelectionRange;\n-                (function(SelectionRange) {\n-                    /**\n-                     * Creates a new SelectionRange\n-                     * @param range the range.\n-                     * @param parent an optional parent.\n-                     */\n-                    function create(range, parent) {\n-                        return {\n-                            range: range,\n-                            parent: parent\n-                        };\n+                    const label = normalizeReference(str.slice(1, labelEnd));\n+                    if (!label) {\n+                        // CommonMark 0.20 disallows empty labels\n+                        return false;\n                     }\n-                    SelectionRange.create = create;\n \n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.objectLiteral(candidate) && Range.is(candidate.range) && (candidate.parent === undefined || SelectionRange.is(candidate.parent));\n+                    // Reference can not terminate anything. This check is for safety only.\n+                    /* istanbul ignore if */\n+                    if (silent) {\n+                        return true;\n                     }\n-                    SelectionRange.is = is;\n-                })(SelectionRange || (exports.SelectionRange = SelectionRange = {}));\n-                /**\n-                 * A set of predefined token types. This set is not fixed\n-                 * an clients can specify additional token types via the\n-                 * corresponding client capabilities.\n-                 *\n-                 * @since 3.16.0\n-                 */\n-                var SemanticTokenTypes;\n-                exports.SemanticTokenTypes = SemanticTokenTypes;\n-                (function(SemanticTokenTypes) {\n-                    SemanticTokenTypes[\"namespace\"] = \"namespace\";\n-                    /**\n-                     * Represents a generic type. Acts as a fallback for types which can't be mapped to\n-                     * a specific type like class or enum.\n-                     */\n-                    SemanticTokenTypes[\"type\"] = \"type\";\n-                    SemanticTokenTypes[\"class\"] = \"class\";\n-                    SemanticTokenTypes[\"enum\"] = \"enum\";\n-                    SemanticTokenTypes[\"interface\"] = \"interface\";\n-                    SemanticTokenTypes[\"struct\"] = \"struct\";\n-                    SemanticTokenTypes[\"typeParameter\"] = \"typeParameter\";\n-                    SemanticTokenTypes[\"parameter\"] = \"parameter\";\n-                    SemanticTokenTypes[\"variable\"] = \"variable\";\n-                    SemanticTokenTypes[\"property\"] = \"property\";\n-                    SemanticTokenTypes[\"enumMember\"] = \"enumMember\";\n-                    SemanticTokenTypes[\"event\"] = \"event\";\n-                    SemanticTokenTypes[\"function\"] = \"function\";\n-                    SemanticTokenTypes[\"method\"] = \"method\";\n-                    SemanticTokenTypes[\"macro\"] = \"macro\";\n-                    SemanticTokenTypes[\"keyword\"] = \"keyword\";\n-                    SemanticTokenTypes[\"modifier\"] = \"modifier\";\n-                    SemanticTokenTypes[\"comment\"] = \"comment\";\n-                    SemanticTokenTypes[\"string\"] = \"string\";\n-                    SemanticTokenTypes[\"number\"] = \"number\";\n-                    SemanticTokenTypes[\"regexp\"] = \"regexp\";\n-                    SemanticTokenTypes[\"operator\"] = \"operator\";\n-                    /**\n-                     * @since 3.17.0\n-                     */\n-                    SemanticTokenTypes[\"decorator\"] = \"decorator\";\n-                })(SemanticTokenTypes || (exports.SemanticTokenTypes = SemanticTokenTypes = {}));\n-                /**\n-                 * A set of predefined token modifiers. This set is not fixed\n-                 * an clients can specify additional token types via the\n-                 * corresponding client capabilities.\n-                 *\n-                 * @since 3.16.0\n-                 */\n-                var SemanticTokenModifiers;\n-                exports.SemanticTokenModifiers = SemanticTokenModifiers;\n-                (function(SemanticTokenModifiers) {\n-                    SemanticTokenModifiers[\"declaration\"] = \"declaration\";\n-                    SemanticTokenModifiers[\"definition\"] = \"definition\";\n-                    SemanticTokenModifiers[\"readonly\"] = \"readonly\";\n-                    SemanticTokenModifiers[\"static\"] = \"static\";\n-                    SemanticTokenModifiers[\"deprecated\"] = \"deprecated\";\n-                    SemanticTokenModifiers[\"abstract\"] = \"abstract\";\n-                    SemanticTokenModifiers[\"async\"] = \"async\";\n-                    SemanticTokenModifiers[\"modification\"] = \"modification\";\n-                    SemanticTokenModifiers[\"documentation\"] = \"documentation\";\n-                    SemanticTokenModifiers[\"defaultLibrary\"] = \"defaultLibrary\";\n-                })(SemanticTokenModifiers || (exports.SemanticTokenModifiers = SemanticTokenModifiers = {}));\n-                /**\n-                 * @since 3.16.0\n-                 */\n-                var SemanticTokens;\n-                exports.SemanticTokens = SemanticTokens;\n-                (function(SemanticTokens) {\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.objectLiteral(candidate) && (candidate.resultId === undefined || typeof candidate.resultId === 'string') && Array.isArray(candidate.data) && (candidate.data.length === 0 || typeof candidate.data[0] === 'number');\n+                    if (typeof state.env.references === 'undefined') {\n+                        state.env.references = {};\n                     }\n-                    SemanticTokens.is = is;\n-                })(SemanticTokens || (exports.SemanticTokens = SemanticTokens = {}));\n-                /**\n-                 * The InlineValueText namespace provides functions to deal with InlineValueTexts.\n-                 *\n-                 * @since 3.17.0\n-                 */\n-                var InlineValueText;\n-                exports.InlineValueText = InlineValueText;\n-                (function(InlineValueText) {\n-                    /**\n-                     * Creates a new InlineValueText literal.\n-                     */\n-                    function create(range, text) {\n-                        return {\n-                            range: range,\n-                            text: text\n+                    if (typeof state.env.references[label] === 'undefined') {\n+                        state.env.references[label] = {\n+                            title,\n+                            href\n                         };\n                     }\n-                    InlineValueText.create = create;\n+                    state.line = nextLine;\n+                    return true;\n+                }\n \n-                    function is(value) {\n-                        var candidate = value;\n-                        return candidate !== undefined && candidate !== null && Range.is(candidate.range) && Is.string(candidate.text);\n-                    }\n-                    InlineValueText.is = is;\n-                })(InlineValueText || (exports.InlineValueText = InlineValueText = {}));\n-                /**\n-                 * The InlineValueVariableLookup namespace provides functions to deal with InlineValueVariableLookups.\n-                 *\n-                 * @since 3.17.0\n-                 */\n-                var InlineValueVariableLookup;\n-                exports.InlineValueVariableLookup = InlineValueVariableLookup;\n-                (function(InlineValueVariableLookup) {\n-                    /**\n-                     * Creates a new InlineValueText literal.\n-                     */\n-                    function create(range, variableName, caseSensitiveLookup) {\n-                        return {\n-                            range: range,\n-                            variableName: variableName,\n-                            caseSensitiveLookup: caseSensitiveLookup\n-                        };\n-                    }\n-                    InlineValueVariableLookup.create = create;\n+                // List of valid html blocks names, according to commonmark spec\n+                // https://spec.commonmark.org/0.30/#html-blocks\n \n-                    function is(value) {\n-                        var candidate = value;\n-                        return candidate !== undefined && candidate !== null && Range.is(candidate.range) && Is.boolean(candidate.caseSensitiveLookup) && (Is.string(candidate.variableName) || candidate.variableName === undefined);\n+                var block_names = ['address', 'article', 'aside', 'base', 'basefont', 'blockquote', 'body', 'caption', 'center', 'col', 'colgroup', 'dd', 'details', 'dialog', 'dir', 'div', 'dl', 'dt', 'fieldset', 'figcaption', 'figure', 'footer', 'form', 'frame', 'frameset', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'head', 'header', 'hr', 'html', 'iframe', 'legend', 'li', 'link', 'main', 'menu', 'menuitem', 'nav', 'noframes', 'ol', 'optgroup', 'option', 'p', 'param', 'search', 'section', 'summary', 'table', 'tbody', 'td', 'tfoot', 'th', 'thead', 'title', 'tr', 'track', 'ul'];\n+\n+                // Regexps to match html elements\n+\n+                const attr_name = '[a-zA-Z_:][a-zA-Z0-9:._-]*';\n+                const unquoted = '[^\"\\'=<>`\\\\x00-\\\\x20]+';\n+                const single_quoted = \"'[^']*'\";\n+                const double_quoted = '\"[^\"]*\"';\n+                const attr_value = '(?:' + unquoted + '|' + single_quoted + '|' + double_quoted + ')';\n+                const attribute = '(?:\\\\s+' + attr_name + '(?:\\\\s*=\\\\s*' + attr_value + ')?)';\n+                const open_tag = '<[A-Za-z][A-Za-z0-9\\\\-]*' + attribute + '*\\\\s*\\\\/?>';\n+                const close_tag = '<\\\\/[A-Za-z][A-Za-z0-9\\\\-]*\\\\s*>';\n+                const comment = '<!---?>|<!--(?:[^-]|-[^-]|--[^>])*-->';\n+                const processing = '<[?][\\\\s\\\\S]*?[?]>';\n+                const declaration = '<![A-Za-z][^>]*>';\n+                const cdata = '<!\\\\[CDATA\\\\[[\\\\s\\\\S]*?\\\\]\\\\]>';\n+                const HTML_TAG_RE = new RegExp('^(?:' + open_tag + '|' + close_tag + '|' + comment + '|' + processing + '|' + declaration + '|' + cdata + ')');\n+                const HTML_OPEN_CLOSE_TAG_RE = new RegExp('^(?:' + open_tag + '|' + close_tag + ')');\n+\n+                // HTML block\n+\n+                // An array of opening and corresponding closing sequences for html tags,\n+                // last argument defines whether it can terminate a paragraph or not\n+                //\n+                const HTML_SEQUENCES = [\n+                    [/^<(script|pre|style|textarea)(?=(\\s|>|$))/i, /<\\/(script|pre|style|textarea)>/i, true],\n+                    [/^<!--/, /-->/, true],\n+                    [/^<\\?/, /\\?>/, true],\n+                    [/^<![A-Z]/, />/, true],\n+                    [/^<!\\[CDATA\\[/, /\\]\\]>/, true],\n+                    [new RegExp('^</?(' + block_names.join('|') + ')(?=(\\\\s|/?>|$))', 'i'), /^$/, true],\n+                    [new RegExp(HTML_OPEN_CLOSE_TAG_RE.source + '\\\\s*$'), /^$/, false]\n+                ];\n+\n+                function html_block(state, startLine, endLine, silent) {\n+                    let pos = state.bMarks[startLine] + state.tShift[startLine];\n+                    let max = state.eMarks[startLine];\n+\n+                    // if it's indented more than 3 spaces, it should be a code block\n+                    if (state.sCount[startLine] - state.blkIndent >= 4) {\n+                        return false;\n                     }\n-                    InlineValueVariableLookup.is = is;\n-                })(InlineValueVariableLookup || (exports.InlineValueVariableLookup = InlineValueVariableLookup = {}));\n-                /**\n-                 * The InlineValueEvaluatableExpression namespace provides functions to deal with InlineValueEvaluatableExpression.\n-                 *\n-                 * @since 3.17.0\n-                 */\n-                var InlineValueEvaluatableExpression;\n-                exports.InlineValueEvaluatableExpression = InlineValueEvaluatableExpression;\n-                (function(InlineValueEvaluatableExpression) {\n-                    /**\n-                     * Creates a new InlineValueEvaluatableExpression literal.\n-                     */\n-                    function create(range, expression) {\n-                        return {\n-                            range: range,\n-                            expression: expression\n-                        };\n+                    if (!state.md.options.html) {\n+                        return false;\n                     }\n-                    InlineValueEvaluatableExpression.create = create;\n-\n-                    function is(value) {\n-                        var candidate = value;\n-                        return candidate !== undefined && candidate !== null && Range.is(candidate.range) && (Is.string(candidate.expression) || candidate.expression === undefined);\n+                    if (state.src.charCodeAt(pos) !== 0x3C /* < */ ) {\n+                        return false;\n                     }\n-                    InlineValueEvaluatableExpression.is = is;\n-                })(InlineValueEvaluatableExpression || (exports.InlineValueEvaluatableExpression = InlineValueEvaluatableExpression = {}));\n-                /**\n-                 * The InlineValueContext namespace provides helper functions to work with\n-                 * [InlineValueContext](#InlineValueContext) literals.\n-                 *\n-                 * @since 3.17.0\n-                 */\n-                var InlineValueContext;\n-                exports.InlineValueContext = InlineValueContext;\n-                (function(InlineValueContext) {\n-                    /**\n-                     * Creates a new InlineValueContext literal.\n-                     */\n-                    function create(frameId, stoppedLocation) {\n-                        return {\n-                            frameId: frameId,\n-                            stoppedLocation: stoppedLocation\n-                        };\n+                    let lineText = state.src.slice(pos, max);\n+                    let i = 0;\n+                    for (; i < HTML_SEQUENCES.length; i++) {\n+                        if (HTML_SEQUENCES[i][0].test(lineText)) {\n+                            break;\n+                        }\n                     }\n-                    InlineValueContext.create = create;\n-                    /**\n-                     * Checks whether the given literal conforms to the [InlineValueContext](#InlineValueContext) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.defined(candidate) && Range.is(value.stoppedLocation);\n+                    if (i === HTML_SEQUENCES.length) {\n+                        return false;\n                     }\n-                    InlineValueContext.is = is;\n-                })(InlineValueContext || (exports.InlineValueContext = InlineValueContext = {}));\n-                /**\n-                 * Inlay hint kinds.\n-                 *\n-                 * @since 3.17.0\n-                 */\n-                var InlayHintKind;\n-                exports.InlayHintKind = InlayHintKind;\n-                (function(InlayHintKind) {\n-                    /**\n-                     * An inlay hint that for a type annotation.\n-                     */\n-                    InlayHintKind.Type = 1;\n-                    /**\n-                     * An inlay hint that is for a parameter.\n-                     */\n-                    InlayHintKind.Parameter = 2;\n-\n-                    function is(value) {\n-                        return value === 1 || value === 2;\n+                    if (silent) {\n+                        // true if this sequence can be a terminator, false otherwise\n+                        return HTML_SEQUENCES[i][2];\n                     }\n-                    InlayHintKind.is = is;\n-                })(InlayHintKind || (exports.InlayHintKind = InlayHintKind = {}));\n-                var InlayHintLabelPart;\n-                exports.InlayHintLabelPart = InlayHintLabelPart;\n-                (function(InlayHintLabelPart) {\n-                    function create(value) {\n-                        return {\n-                            value: value\n-                        };\n+                    let nextLine = startLine + 1;\n+\n+                    // If we are here - we detected HTML block.\n+                    // Let's roll down till block end.\n+                    if (!HTML_SEQUENCES[i][1].test(lineText)) {\n+                        for (; nextLine < endLine; nextLine++) {\n+                            if (state.sCount[nextLine] < state.blkIndent) {\n+                                break;\n+                            }\n+                            pos = state.bMarks[nextLine] + state.tShift[nextLine];\n+                            max = state.eMarks[nextLine];\n+                            lineText = state.src.slice(pos, max);\n+                            if (HTML_SEQUENCES[i][1].test(lineText)) {\n+                                if (lineText.length !== 0) {\n+                                    nextLine++;\n+                                }\n+                                break;\n+                            }\n+                        }\n                     }\n-                    InlayHintLabelPart.create = create;\n+                    state.line = nextLine;\n+                    const token = state.push('html_block', '', 0);\n+                    token.map = [startLine, nextLine];\n+                    token.content = state.getLines(startLine, nextLine, state.blkIndent, true);\n+                    return true;\n+                }\n \n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.objectLiteral(candidate) && (candidate.tooltip === undefined || Is.string(candidate.tooltip) || MarkupContent.is(candidate.tooltip)) && (candidate.location === undefined || Location.is(candidate.location)) && (candidate.command === undefined || Command.is(candidate.command));\n+                // heading (#, ##, ...)\n+\n+                function heading(state, startLine, endLine, silent) {\n+                    let pos = state.bMarks[startLine] + state.tShift[startLine];\n+                    let max = state.eMarks[startLine];\n+\n+                    // if it's indented more than 3 spaces, it should be a code block\n+                    if (state.sCount[startLine] - state.blkIndent >= 4) {\n+                        return false;\n                     }\n-                    InlayHintLabelPart.is = is;\n-                })(InlayHintLabelPart || (exports.InlayHintLabelPart = InlayHintLabelPart = {}));\n-                var InlayHint;\n-                exports.InlayHint = InlayHint;\n-                (function(InlayHint) {\n-                    function create(position, label, kind) {\n-                        var result = {\n-                            position: position,\n-                            label: label\n-                        };\n-                        if (kind !== undefined) {\n-                            result.kind = kind;\n-                        }\n-                        return result;\n+                    let ch = state.src.charCodeAt(pos);\n+                    if (ch !== 0x23 /* # */ || pos >= max) {\n+                        return false;\n                     }\n-                    InlayHint.create = create;\n \n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.objectLiteral(candidate) && Position.is(candidate.position) && (Is.string(candidate.label) || Is.typedArray(candidate.label, InlayHintLabelPart.is)) && (candidate.kind === undefined || InlayHintKind.is(candidate.kind)) && candidate.textEdits === undefined || Is.typedArray(candidate.textEdits, TextEdit.is) && (candidate.tooltip === undefined || Is.string(candidate.tooltip) || MarkupContent.is(candidate.tooltip)) && (candidate.paddingLeft === undefined || Is.boolean(candidate.paddingLeft)) && (candidate.paddingRight === undefined || Is.boolean(candidate.paddingRight));\n+                    // count heading level\n+                    let level = 1;\n+                    ch = state.src.charCodeAt(++pos);\n+                    while (ch === 0x23 /* # */ && pos < max && level <= 6) {\n+                        level++;\n+                        ch = state.src.charCodeAt(++pos);\n                     }\n-                    InlayHint.is = is;\n-                })(InlayHint || (exports.InlayHint = InlayHint = {}));\n-                var WorkspaceFolder;\n-                exports.WorkspaceFolder = WorkspaceFolder;\n-                (function(WorkspaceFolder) {\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.objectLiteral(candidate) && URI.is(candidate.uri) && Is.string(candidate.name);\n+                    if (level > 6 || pos < max && !isSpace(ch)) {\n+                        return false;\n                     }\n-                    WorkspaceFolder.is = is;\n-                })(WorkspaceFolder || (exports.WorkspaceFolder = WorkspaceFolder = {}));\n-                var EOL = ['\\n', '\\r\\n', '\\r'];\n-                /**\n-                 * @deprecated Use the text document from the new vscode-languageserver-textdocument package.\n-                 */\n-                exports.EOL = EOL;\n-                var TextDocument;\n-                exports.TextDocument = TextDocument;\n-                (function(TextDocument) {\n-                    /**\n-                     * Creates a new ITextDocument literal from the given uri and content.\n-                     * @param uri The document's uri.\n-                     * @param languageId The document's language Id.\n-                     * @param version The document's version.\n-                     * @param content The document's content.\n-                     */\n-                    function create(uri, languageId, version, content) {\n-                        return new FullTextDocument(uri, languageId, version, content);\n+                    if (silent) {\n+                        return true;\n                     }\n-                    TextDocument.create = create;\n-                    /**\n-                     * Checks whether the given literal conforms to the [ITextDocument](#ITextDocument) interface.\n-                     */\n-                    function is(value) {\n-                        var candidate = value;\n-                        return Is.defined(candidate) && Is.string(candidate.uri) && (Is.undefined(candidate.languageId) || Is.string(candidate.languageId)) && Is.uinteger(candidate.lineCount) && Is.func(candidate.getText) && Is.func(candidate.positionAt) && Is.func(candidate.offsetAt) ? true : false;\n+\n+                    // Let's cut tails like '    ###  ' from the end of string\n+\n+                    max = state.skipSpacesBack(max, pos);\n+                    const tmp = state.skipCharsBack(max, 0x23, pos); // #\n+                    if (tmp > pos && isSpace(state.src.charCodeAt(tmp - 1))) {\n+                        max = tmp;\n                     }\n-                    TextDocument.is = is;\n+                    state.line = startLine + 1;\n+                    const token_o = state.push('heading_open', 'h' + String(level), 1);\n+                    token_o.markup = '########'.slice(0, level);\n+                    token_o.map = [startLine, state.line];\n+                    const token_i = state.push('inline', '', 0);\n+                    token_i.content = state.src.slice(pos, max).trim();\n+                    token_i.map = [startLine, state.line];\n+                    token_i.children = [];\n+                    const token_c = state.push('heading_close', 'h' + String(level), -1);\n+                    token_c.markup = '########'.slice(0, level);\n+                    return true;\n+                }\n \n-                    function applyEdits(document, edits) {\n-                        var text = document.getText();\n-                        var sortedEdits = mergeSort(edits, function(a, b) {\n-                            var diff = a.range.start.line - b.range.start.line;\n-                            if (diff === 0) {\n-                                return a.range.start.character - b.range.start.character;\n+                // lheading (---, ===)\n+\n+                function lheading(state, startLine, endLine /*, silent */ ) {\n+                    const terminatorRules = state.md.block.ruler.getRules('paragraph');\n+\n+                    // if it's indented more than 3 spaces, it should be a code block\n+                    if (state.sCount[startLine] - state.blkIndent >= 4) {\n+                        return false;\n+                    }\n+                    const oldParentType = state.parentType;\n+                    state.parentType = 'paragraph'; // use paragraph to match terminatorRules\n+\n+                    // jump line-by-line until empty one or EOF\n+                    let level = 0;\n+                    let marker;\n+                    let nextLine = startLine + 1;\n+                    for (; nextLine < endLine && !state.isEmpty(nextLine); nextLine++) {\n+                        // this would be a code block normally, but after paragraph\n+                        // it's considered a lazy continuation regardless of what's there\n+                        if (state.sCount[nextLine] - state.blkIndent > 3) {\n+                            continue;\n+                        }\n+\n+                        //\n+                        // Check for underline in setext header\n+                        //\n+                        if (state.sCount[nextLine] >= state.blkIndent) {\n+                            let pos = state.bMarks[nextLine] + state.tShift[nextLine];\n+                            const max = state.eMarks[nextLine];\n+                            if (pos < max) {\n+                                marker = state.src.charCodeAt(pos);\n+                                if (marker === 0x2D /* - */ || marker === 0x3D /* = */ ) {\n+                                    pos = state.skipChars(pos, marker);\n+                                    pos = state.skipSpaces(pos);\n+                                    if (pos >= max) {\n+                                        level = marker === 0x3D /* = */ ? 1 : 2;\n+                                        break;\n+                                    }\n+                                }\n                             }\n-                            return diff;\n-                        });\n-                        var lastModifiedOffset = text.length;\n-                        for (var i = sortedEdits.length - 1; i >= 0; i--) {\n-                            var e = sortedEdits[i];\n-                            var startOffset = document.offsetAt(e.range.start);\n-                            var endOffset = document.offsetAt(e.range.end);\n-                            if (endOffset <= lastModifiedOffset) {\n-                                text = text.substring(0, startOffset) + e.newText + text.substring(endOffset, text.length);\n-                            } else {\n-                                throw new Error('Overlapping edit');\n+                        }\n+\n+                        // quirk for blockquotes, this line should already be checked by that rule\n+                        if (state.sCount[nextLine] < 0) {\n+                            continue;\n+                        }\n+\n+                        // Some tags can terminate paragraph without empty line.\n+                        let terminate = false;\n+                        for (let i = 0, l = terminatorRules.length; i < l; i++) {\n+                            if (terminatorRules[i](state, nextLine, endLine, true)) {\n+                                terminate = true;\n+                                break;\n                             }\n-                            lastModifiedOffset = startOffset;\n                         }\n-                        return text;\n+                        if (terminate) {\n+                            break;\n+                        }\n                     }\n-                    TextDocument.applyEdits = applyEdits;\n+                    if (!level) {\n+                        // Didn't find valid underline\n+                        return false;\n+                    }\n+                    const content = state.getLines(startLine, nextLine, state.blkIndent, false).trim();\n+                    state.line = nextLine + 1;\n+                    const token_o = state.push('heading_open', 'h' + String(level), 1);\n+                    token_o.markup = String.fromCharCode(marker);\n+                    token_o.map = [startLine, state.line];\n+                    const token_i = state.push('inline', '', 0);\n+                    token_i.content = content;\n+                    token_i.map = [startLine, state.line - 1];\n+                    token_i.children = [];\n+                    const token_c = state.push('heading_close', 'h' + String(level), -1);\n+                    token_c.markup = String.fromCharCode(marker);\n+                    state.parentType = oldParentType;\n+                    return true;\n+                }\n \n-                    function mergeSort(data, compare) {\n-                        if (data.length <= 1) {\n-                            // sorted\n-                            return data;\n+                // Paragraph\n+\n+                function paragraph(state, startLine, endLine) {\n+                    const terminatorRules = state.md.block.ruler.getRules('paragraph');\n+                    const oldParentType = state.parentType;\n+                    let nextLine = startLine + 1;\n+                    state.parentType = 'paragraph';\n+\n+                    // jump line-by-line until empty one or EOF\n+                    for (; nextLine < endLine && !state.isEmpty(nextLine); nextLine++) {\n+                        // this would be a code block normally, but after paragraph\n+                        // it's considered a lazy continuation regardless of what's there\n+                        if (state.sCount[nextLine] - state.blkIndent > 3) {\n+                            continue;\n                         }\n-                        var p = data.length / 2 | 0;\n-                        var left = data.slice(0, p);\n-                        var right = data.slice(p);\n-                        mergeSort(left, compare);\n-                        mergeSort(right, compare);\n-                        var leftIdx = 0;\n-                        var rightIdx = 0;\n-                        var i = 0;\n-                        while (leftIdx < left.length && rightIdx < right.length) {\n-                            var ret = compare(left[leftIdx], right[rightIdx]);\n-                            if (ret <= 0) {\n-                                // smaller_equal -> take left to preserve order\n-                                data[i++] = left[leftIdx++];\n-                            } else {\n-                                // greater -> take right\n-                                data[i++] = right[rightIdx++];\n-                            }\n+\n+                        // quirk for blockquotes, this line should already be checked by that rule\n+                        if (state.sCount[nextLine] < 0) {\n+                            continue;\n                         }\n-                        while (leftIdx < left.length) {\n-                            data[i++] = left[leftIdx++];\n+\n+                        // Some tags can terminate paragraph without empty line.\n+                        let terminate = false;\n+                        for (let i = 0, l = terminatorRules.length; i < l; i++) {\n+                            if (terminatorRules[i](state, nextLine, endLine, true)) {\n+                                terminate = true;\n+                                break;\n+                            }\n                         }\n-                        while (rightIdx < right.length) {\n-                            data[i++] = right[rightIdx++];\n+                        if (terminate) {\n+                            break;\n                         }\n-                        return data;\n                     }\n-                })(TextDocument || (exports.TextDocument = TextDocument = {}));\n+                    const content = state.getLines(startLine, nextLine, state.blkIndent, false).trim();\n+                    state.line = nextLine;\n+                    const token_o = state.push('paragraph_open', 'p', 1);\n+                    token_o.map = [startLine, state.line];\n+                    const token_i = state.push('inline', '', 0);\n+                    token_i.content = content;\n+                    token_i.map = [startLine, state.line];\n+                    token_i.children = [];\n+                    state.push('paragraph_close', 'p', -1);\n+                    state.parentType = oldParentType;\n+                    return true;\n+                }\n+\n+                /** internal\n+                 * class ParserBlock\n+                 *\n+                 * Block-level tokenizer.\n+                 **/\n+\n+                const _rules$1 = [\n+                    // First 2 params - rule name & source. Secondary array - list of rules,\n+                    // which can be terminated by this one.\n+                    ['table', table, ['paragraph', 'reference']],\n+                    ['code', code],\n+                    ['fence', fence, ['paragraph', 'reference', 'blockquote', 'list']],\n+                    ['blockquote', blockquote, ['paragraph', 'reference', 'blockquote', 'list']],\n+                    ['hr', hr, ['paragraph', 'reference', 'blockquote', 'list']],\n+                    ['list', list, ['paragraph', 'reference', 'blockquote']],\n+                    ['reference', reference],\n+                    ['html_block', html_block, ['paragraph', 'reference', 'blockquote']],\n+                    ['heading', heading, ['paragraph', 'reference', 'blockquote']],\n+                    ['lheading', lheading],\n+                    ['paragraph', paragraph]\n+                ];\n+\n                 /**\n-                 * @deprecated Use the text document from the new vscode-languageserver-textdocument package.\n-                 */\n-                var FullTextDocument = /** @class */ function() {\n-                    function FullTextDocument(uri, languageId, version, content) {\n-                        this._uri = uri;\n-                        this._languageId = languageId;\n-                        this._version = version;\n-                        this._content = content;\n-                        this._lineOffsets = undefined;\n+                 * new ParserBlock()\n+                 **/\n+                function ParserBlock() {\n+                    /**\n+                     * ParserBlock#ruler -> Ruler\n+                     *\n+                     * [[Ruler]] instance. Keep configuration of block rules.\n+                     **/\n+                    this.ruler = new Ruler();\n+                    for (let i = 0; i < _rules$1.length; i++) {\n+                        this.ruler.push(_rules$1[i][0], _rules$1[i][1], {\n+                            alt: (_rules$1[i][2] || []).slice()\n+                        });\n                     }\n-                    Object.defineProperty(FullTextDocument.prototype, \"uri\", {\n-                        get: function() {\n-                            return this._uri;\n-                        },\n-                        enumerable: false,\n-                        configurable: true\n-                    });\n-                    Object.defineProperty(FullTextDocument.prototype, \"languageId\", {\n-                        get: function() {\n-                            return this._languageId;\n-                        },\n-                        enumerable: false,\n-                        configurable: true\n-                    });\n-                    Object.defineProperty(FullTextDocument.prototype, \"version\", {\n-                        get: function() {\n-                            return this._version;\n-                        },\n-                        enumerable: false,\n-                        configurable: true\n-                    });\n-                    FullTextDocument.prototype.getText = function(range) {\n-                        if (range) {\n-                            var start = this.offsetAt(range.start);\n-                            var end = this.offsetAt(range.end);\n-                            return this._content.substring(start, end);\n+                }\n+\n+                // Generate tokens for input range\n+                //\n+                ParserBlock.prototype.tokenize = function(state, startLine, endLine) {\n+                    const rules = this.ruler.getRules('');\n+                    const len = rules.length;\n+                    const maxNesting = state.md.options.maxNesting;\n+                    let line = startLine;\n+                    let hasEmptyLines = false;\n+                    while (line < endLine) {\n+                        state.line = line = state.skipEmptyLines(line);\n+                        if (line >= endLine) {\n+                            break;\n                         }\n-                        return this._content;\n-                    };\n-                    FullTextDocument.prototype.update = function(event, version) {\n-                        this._content = event.text;\n-                        this._version = version;\n-                        this._lineOffsets = undefined;\n-                    };\n-                    FullTextDocument.prototype.getLineOffsets = function() {\n-                        if (this._lineOffsets === undefined) {\n-                            var lineOffsets = [];\n-                            var text = this._content;\n-                            var isLineStart = true;\n-                            for (var i = 0; i < text.length; i++) {\n-                                if (isLineStart) {\n-                                    lineOffsets.push(i);\n-                                    isLineStart = false;\n-                                }\n-                                var ch = text.charAt(i);\n-                                isLineStart = ch === '\\r' || ch === '\\n';\n-                                if (ch === '\\r' && i + 1 < text.length && text.charAt(i + 1) === '\\n') {\n-                                    i++;\n-                                }\n-                            }\n-                            if (isLineStart && text.length > 0) {\n-                                lineOffsets.push(text.length);\n-                            }\n-                            this._lineOffsets = lineOffsets;\n+\n+                        // Termination condition for nested calls.\n+                        // Nested calls currently used for blockquotes & lists\n+                        if (state.sCount[line] < state.blkIndent) {\n+                            break;\n                         }\n-                        return this._lineOffsets;\n-                    };\n-                    FullTextDocument.prototype.positionAt = function(offset) {\n-                        offset = Math.max(Math.min(offset, this._content.length), 0);\n-                        var lineOffsets = this.getLineOffsets();\n-                        var low = 0,\n-                            high = lineOffsets.length;\n-                        if (high === 0) {\n-                            return Position.create(0, offset);\n+\n+                        // If nesting level exceeded - skip tail to the end. That's not ordinary\n+                        // situation and we should not care about content.\n+                        if (state.level >= maxNesting) {\n+                            state.line = endLine;\n+                            break;\n                         }\n-                        while (low < high) {\n-                            var mid = Math.floor((low + high) / 2);\n-                            if (lineOffsets[mid] > offset) {\n-                                high = mid;\n-                            } else {\n-                                low = mid + 1;\n+\n+                        // Try all possible rules.\n+                        // On success, rule should:\n+                        //\n+                        // - update `state.line`\n+                        // - update `state.tokens`\n+                        // - return true\n+                        const prevLine = state.line;\n+                        let ok = false;\n+                        for (let i = 0; i < len; i++) {\n+                            ok = rules[i](state, line, endLine, false);\n+                            if (ok) {\n+                                if (prevLine >= state.line) {\n+                                    throw new Error(\"block rule didn't increment state.line\");\n+                                }\n+                                break;\n                             }\n                         }\n-                        // low is the least x for which the line offset is larger than the current offset\n-                        // or array.length if no line offset is larger than the current offset\n-                        var line = low - 1;\n-                        return Position.create(line, offset - lineOffsets[line]);\n-                    };\n-                    FullTextDocument.prototype.offsetAt = function(position) {\n-                        var lineOffsets = this.getLineOffsets();\n-                        if (position.line >= lineOffsets.length) {\n-                            return this._content.length;\n-                        } else if (position.line < 0) {\n-                            return 0;\n-                        }\n-                        var lineOffset = lineOffsets[position.line];\n-                        var nextLineOffset = position.line + 1 < lineOffsets.length ? lineOffsets[position.line + 1] : this._content.length;\n-                        return Math.max(Math.min(lineOffset + position.character, nextLineOffset), lineOffset);\n-                    };\n-                    Object.defineProperty(FullTextDocument.prototype, \"lineCount\", {\n-                        get: function() {\n-                            return this.getLineOffsets().length;\n-                        },\n-                        enumerable: false,\n-                        configurable: true\n-                    });\n-                    return FullTextDocument;\n-                }();\n-                var Is;\n-                (function(Is) {\n-                    var toString = Object.prototype.toString;\n \n-                    function defined(value) {\n-                        return typeof value !== 'undefined';\n-                    }\n-                    Is.defined = defined;\n+                        // this can only happen if user disables paragraph rule\n+                        if (!ok) throw new Error('none of the block rules matched');\n \n-                    function undefined(value) {\n-                        return typeof value === 'undefined';\n-                    }\n-                    Is.undefined = undefined;\n+                        // set state.tight if we had an empty line before current tag\n+                        // i.e. latest empty line should not count\n+                        state.tight = !hasEmptyLines;\n \n-                    function boolean(value) {\n-                        return value === true || value === false;\n+                        // paragraph might \"eat\" one newline after it in nested lists\n+                        if (state.isEmpty(state.line - 1)) {\n+                            hasEmptyLines = true;\n+                        }\n+                        line = state.line;\n+                        if (line < endLine && state.isEmpty(line)) {\n+                            hasEmptyLines = true;\n+                            line++;\n+                            state.line = line;\n+                        }\n                     }\n-                    Is.boolean = boolean;\n+                };\n \n-                    function string(value) {\n-                        return toString.call(value) === '[object String]';\n+                /**\n+                 * ParserBlock.parse(str, md, env, outTokens)\n+                 *\n+                 * Process input string and push block tokens into `outTokens`\n+                 **/\n+                ParserBlock.prototype.parse = function(src, md, env, outTokens) {\n+                    if (!src) {\n+                        return;\n                     }\n-                    Is.string = string;\n+                    const state = new this.State(src, md, env, outTokens);\n+                    this.tokenize(state, state.line, state.lineMax);\n+                };\n+                ParserBlock.prototype.State = StateBlock;\n \n-                    function number(value) {\n-                        return toString.call(value) === '[object Number]';\n-                    }\n-                    Is.number = number;\n+                // Inline parser state\n \n-                    function numberRange(value, min, max) {\n-                        return toString.call(value) === '[object Number]' && min <= value && value <= max;\n-                    }\n-                    Is.numberRange = numberRange;\n+                function StateInline(src, md, env, outTokens) {\n+                    this.src = src;\n+                    this.env = env;\n+                    this.md = md;\n+                    this.tokens = outTokens;\n+                    this.tokens_meta = Array(outTokens.length);\n+                    this.pos = 0;\n+                    this.posMax = this.src.length;\n+                    this.level = 0;\n+                    this.pending = '';\n+                    this.pendingLevel = 0;\n \n-                    function integer(value) {\n-                        return toString.call(value) === '[object Number]' && -2147483648 <= value && value <= 2147483647;\n-                    }\n-                    Is.integer = integer;\n+                    // Stores { start: end } pairs. Useful for backtrack\n+                    // optimization of pairs parse (emphasis, strikes).\n+                    this.cache = {};\n \n-                    function uinteger(value) {\n-                        return toString.call(value) === '[object Number]' && 0 <= value && value <= 2147483647;\n-                    }\n-                    Is.uinteger = uinteger;\n+                    // List of emphasis-like delimiters for current tag\n+                    this.delimiters = [];\n \n-                    function func(value) {\n-                        return toString.call(value) === '[object Function]';\n-                    }\n-                    Is.func = func;\n+                    // Stack of delimiter lists for upper level tags\n+                    this._prev_delimiters = [];\n \n-                    function objectLiteral(value) {\n-                        // Strictly speaking class instances pass this check as well. Since the LSP\n-                        // doesn't use classes we ignore this for now. If we do we need to add something\n-                        // like this: `Object.getPrototypeOf(Object.getPrototypeOf(x)) === null`\n-                        return value !== null && typeof value === 'object';\n+                    // backtick length => last seen position\n+                    this.backticks = {};\n+                    this.backticksScanned = false;\n+\n+                    // Counter used to disable inline linkify-it execution\n+                    // inside <a> and markdown links\n+                    this.linkLevel = 0;\n+                }\n+\n+                // Flush pending text\n+                //\n+                StateInline.prototype.pushPending = function() {\n+                    const token = new Token('text', '', 0);\n+                    token.content = this.pending;\n+                    token.level = this.pendingLevel;\n+                    this.tokens.push(token);\n+                    this.pending = '';\n+                    return token;\n+                };\n+\n+                // Push new token to \"stream\".\n+                // If pending text exists - flush it as text token\n+                //\n+                StateInline.prototype.push = function(type, tag, nesting) {\n+                    if (this.pending) {\n+                        this.pushPending();\n                     }\n-                    Is.objectLiteral = objectLiteral;\n+                    const token = new Token(type, tag, nesting);\n+                    let token_meta = null;\n+                    if (nesting < 0) {\n+                        // closing tag\n+                        this.level--;\n+                        this.delimiters = this._prev_delimiters.pop();\n+                    }\n+                    token.level = this.level;\n+                    if (nesting > 0) {\n+                        // opening tag\n+                        this.level++;\n+                        this._prev_delimiters.push(this.delimiters);\n+                        this.delimiters = [];\n+                        token_meta = {\n+                            delimiters: this.delimiters\n+                        };\n+                    }\n+                    this.pendingLevel = this.level;\n+                    this.tokens.push(token);\n+                    this.tokens_meta.push(token_meta);\n+                    return token;\n+                };\n \n-                    function typedArray(value, check) {\n-                        return Array.isArray(value) && value.every(check);\n+                // Scan a sequence of emphasis-like markers, and determine whether\n+                // it can start an emphasis sequence or end an emphasis sequence.\n+                //\n+                //  - start - position to scan from (it should point at a valid marker);\n+                //  - canSplitWord - determine if these markers can be found inside a word\n+                //\n+                StateInline.prototype.scanDelims = function(start, canSplitWord) {\n+                    const max = this.posMax;\n+                    const marker = this.src.charCodeAt(start);\n+\n+                    // treat beginning of the line as a whitespace\n+                    const lastChar = start > 0 ? this.src.charCodeAt(start - 1) : 0x20;\n+                    let pos = start;\n+                    while (pos < max && this.src.charCodeAt(pos) === marker) {\n+                        pos++;\n                     }\n-                    Is.typedArray = typedArray;\n-                })(Is || (Is = {}));\n+                    const count = pos - start;\n \n-                /***/\n-            }),\n+                    // treat end of the line as a whitespace\n+                    const nextChar = pos < max ? this.src.charCodeAt(pos) : 0x20;\n+                    const isLastPunctChar = isMdAsciiPunct(lastChar) || isPunctChar(String.fromCharCode(lastChar));\n+                    const isNextPunctChar = isMdAsciiPunct(nextChar) || isPunctChar(String.fromCharCode(nextChar));\n+                    const isLastWhiteSpace = isWhiteSpace(lastChar);\n+                    const isNextWhiteSpace = isWhiteSpace(nextChar);\n+                    const left_flanking = !isNextWhiteSpace && (!isNextPunctChar || isLastWhiteSpace || isLastPunctChar);\n+                    const right_flanking = !isLastWhiteSpace && (!isLastPunctChar || isNextWhiteSpace || isNextPunctChar);\n+                    const can_open = left_flanking && (canSplitWord || !right_flanking || isLastPunctChar);\n+                    const can_close = right_flanking && (canSplitWord || !left_flanking || isNextPunctChar);\n+                    return {\n+                        can_open,\n+                        can_close,\n+                        length: count\n+                    };\n+                };\n \n-        /***/\n-        \"../../graphiql-react/dist/SchemaReference.cjs.js\":\n-            /*!********************************************************!*\\\n-              !*** ../../graphiql-react/dist/SchemaReference.cjs.js ***!\n-              \\********************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                // re-export Token class to use in block rules\n+                StateInline.prototype.Token = Token;\n \n+                // Skip text characters for text token, place those to pending buffer\n+                // and increment current pos\n \n+                // Rule to skip pure text\n+                // '{}$%@~+=:' reserved for extentions\n \n-                var m = Object.defineProperty;\n-                var l = (n, r) => m(n, \"name\", {\n-                    value: r,\n-                    configurable: !0\n-                });\n-                const t = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\"),\n-                    s = __webpack_require__( /*! ./forEachState.cjs.js */ \"../../graphiql-react/dist/forEachState.cjs.js\");\n-\n-                function o(n, r) {\n-                    const e = {\n-                        schema: n,\n-                        type: null,\n-                        parentType: null,\n-                        inputType: null,\n-                        directiveDef: null,\n-                        fieldDef: null,\n-                        argDef: null,\n-                        argDefs: null,\n-                        objectFieldDefs: null\n-                    };\n-                    return s.forEachState(r, i => {\n-                        var a, c;\n-                        switch (i.kind) {\n-                            case \"Query\":\n-                            case \"ShortQuery\":\n-                                e.type = n.getQueryType();\n-                                break;\n-                            case \"Mutation\":\n-                                e.type = n.getMutationType();\n-                                break;\n-                            case \"Subscription\":\n-                                e.type = n.getSubscriptionType();\n-                                break;\n-                            case \"InlineFragment\":\n-                            case \"FragmentDefinition\":\n-                                i.type && (e.type = n.getType(i.type));\n-                                break;\n-                            case \"Field\":\n-                            case \"AliasedField\":\n-                                e.fieldDef = e.type && i.name ? T(n, e.parentType, i.name) : null, e.type = (a = e.fieldDef) === null || a === void 0 ? void 0 : a.type;\n-                                break;\n-                            case \"SelectionSet\":\n-                                e.parentType = e.type ? t.getNamedType(e.type) : null;\n-                                break;\n-                            case \"Directive\":\n-                                e.directiveDef = i.name ? n.getDirective(i.name) : null;\n-                                break;\n-                            case \"Arguments\":\n-                                const f = i.prevState ? i.prevState.kind === \"Field\" ? e.fieldDef : i.prevState.kind === \"Directive\" ? e.directiveDef : i.prevState.kind === \"AliasedField\" ? i.prevState.name && T(n, e.parentType, i.prevState.name) : null : null;\n-                                e.argDefs = f ? f.args : null;\n-                                break;\n-                            case \"Argument\":\n-                                if (e.argDef = null, e.argDefs) {\n-                                    for (let u = 0; u < e.argDefs.length; u++)\n-                                        if (e.argDefs[u].name === i.name) {\n-                                            e.argDef = e.argDefs[u];\n-                                            break;\n-                                        }\n-                                }\n-                                e.inputType = (c = e.argDef) === null || c === void 0 ? void 0 : c.type;\n-                                break;\n-                            case \"EnumValue\":\n-                                const d = e.inputType ? t.getNamedType(e.inputType) : null;\n-                                e.enumValue = d instanceof t.GraphQLEnumType ? b(d.getValues(), u => u.value === i.name) : null;\n-                                break;\n-                            case \"ListValue\":\n-                                const g = e.inputType ? t.getNullableType(e.inputType) : null;\n-                                e.inputType = g instanceof t.GraphQLList ? g.ofType : null;\n-                                break;\n-                            case \"ObjectValue\":\n-                                const y = e.inputType ? t.getNamedType(e.inputType) : null;\n-                                e.objectFieldDefs = y instanceof t.GraphQLInputObjectType ? y.getFields() : null;\n-                                break;\n-                            case \"ObjectField\":\n-                                const p = i.name && e.objectFieldDefs ? e.objectFieldDefs[i.name] : null;\n-                                e.inputType = p == null ? void 0 : p.type;\n-                                break;\n-                            case \"NamedType\":\n-                                e.type = i.name ? n.getType(i.name) : null;\n-                                break;\n-                        }\n-                    }), e;\n-                }\n-                l(o, \"getTypeInfo\");\n+                // !, \", #, $, %, &, ', (, ), *, +, ,, -, ., /, :, ;, <, =, >, ?, @, [, \\, ], ^, _, `, {, |, }, or ~\n \n-                function T(n, r, e) {\n-                    if (e === t.SchemaMetaFieldDef.name && n.getQueryType() === r) return t.SchemaMetaFieldDef;\n-                    if (e === t.TypeMetaFieldDef.name && n.getQueryType() === r) return t.TypeMetaFieldDef;\n-                    if (e === t.TypeNameMetaFieldDef.name && t.isCompositeType(r)) return t.TypeNameMetaFieldDef;\n-                    if (r && r.getFields) return r.getFields()[e];\n+                // !!!! Don't confuse with \"Markdown ASCII Punctuation\" chars\n+                // http://spec.commonmark.org/0.15/#ascii-punctuation-character\n+                function isTerminatorChar(ch) {\n+                    switch (ch) {\n+                        case 0x0A /* \\n */ :\n+                        case 0x21 /* ! */ :\n+                        case 0x23 /* # */ :\n+                        case 0x24 /* $ */ :\n+                        case 0x25 /* % */ :\n+                        case 0x26 /* & */ :\n+                        case 0x2A /* * */ :\n+                        case 0x2B /* + */ :\n+                        case 0x2D /* - */ :\n+                        case 0x3A /* : */ :\n+                        case 0x3C /* < */ :\n+                        case 0x3D /* = */ :\n+                        case 0x3E /* > */ :\n+                        case 0x40 /* @ */ :\n+                        case 0x5B /* [ */ :\n+                        case 0x5C /* \\ */ :\n+                        case 0x5D /* ] */ :\n+                        case 0x5E /* ^ */ :\n+                        case 0x5F /* _ */ :\n+                        case 0x60 /* ` */ :\n+                        case 0x7B /* { */ :\n+                        case 0x7D /* } */ :\n+                        case 0x7E /* ~ */ :\n+                            return true;\n+                        default:\n+                            return false;\n+                    }\n                 }\n-                l(T, \"getFieldDef\");\n \n-                function b(n, r) {\n-                    for (let e = 0; e < n.length; e++)\n-                        if (r(n[e])) return n[e];\n+                function text(state, silent) {\n+                    let pos = state.pos;\n+                    while (pos < state.posMax && !isTerminatorChar(state.src.charCodeAt(pos))) {\n+                        pos++;\n+                    }\n+                    if (pos === state.pos) {\n+                        return false;\n+                    }\n+                    if (!silent) {\n+                        state.pending += state.src.slice(state.pos, pos);\n+                    }\n+                    state.pos = pos;\n+                    return true;\n                 }\n-                l(b, \"find\");\n \n-                function v(n) {\n-                    return {\n-                        kind: \"Field\",\n-                        schema: n.schema,\n-                        field: n.fieldDef,\n-                        type: D(n.fieldDef) ? null : n.parentType\n-                    };\n-                }\n-                l(v, \"getFieldReference\");\n+                // Alternative implementation, for memory.\n+                //\n+                // It costs 10% of performance, but allows extend terminators list, if place it\n+                // to `ParserInline` property. Probably, will switch to it sometime, such\n+                // flexibility required.\n \n-                function F(n) {\n-                    return {\n-                        kind: \"Directive\",\n-                        schema: n.schema,\n-                        directive: n.directiveDef\n-                    };\n-                }\n-                l(F, \"getDirectiveReference\");\n+                /*\n+                var TERMINATOR_RE = /[\\n!#$%&*+\\-:<=>@[\\\\\\]^_`{}~]/;\n \n-                function k(n) {\n-                    return n.directiveDef ? {\n-                        kind: \"Argument\",\n-                        schema: n.schema,\n-                        argument: n.argDef,\n-                        directive: n.directiveDef\n-                    } : {\n-                        kind: \"Argument\",\n-                        schema: n.schema,\n-                        argument: n.argDef,\n-                        field: n.fieldDef,\n-                        type: D(n.fieldDef) ? null : n.parentType\n-                    };\n-                }\n-                l(k, \"getArgumentReference\");\n+                module.exports = function text(state, silent) {\n+                  var pos = state.pos,\n+                      idx = state.src.slice(pos).search(TERMINATOR_RE);\n \n-                function S(n) {\n-                    return {\n-                        kind: \"EnumValue\",\n-                        value: n.enumValue || void 0,\n-                        type: n.inputType ? t.getNamedType(n.inputType) : void 0\n-                    };\n-                }\n-                l(S, \"getEnumValueReference\");\n+                  // first char is terminator -> empty text\n+                  if (idx === 0) { return false; }\n \n-                function h(n, r) {\n-                    return {\n-                        kind: \"Type\",\n-                        schema: n.schema,\n-                        type: r || n.type\n-                    };\n-                }\n-                l(h, \"getTypeReference\");\n+                  // no terminator -> text till end of string\n+                  if (idx < 0) {\n+                    if (!silent) { state.pending += state.src.slice(pos); }\n+                    state.pos = state.src.length;\n+                    return true;\n+                  }\n \n-                function D(n) {\n-                    return n.name.slice(0, 2) === \"__\";\n-                }\n-                l(D, \"isMetaField\");\n-                exports.getArgumentReference = k;\n-                exports.getDirectiveReference = F;\n-                exports.getEnumValueReference = S;\n-                exports.getFieldReference = v;\n-                exports.getTypeInfo = o;\n-                exports.getTypeReference = h;\n+                  if (!silent) { state.pending += state.src.slice(pos, pos + idx); }\n \n-                /***/\n-            }),\n+                  state.pos += idx;\n \n-        /***/\n-        \"../../graphiql-react/dist/brace-fold.cjs.js\":\n-            /*!***************************************************!*\\\n-              !*** ../../graphiql-react/dist/brace-fold.cjs.js ***!\n-              \\***************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                  return true;\n+                }; */\n \n+                // Process links like https://example.org/\n \n+                // RFC3986: scheme = ALPHA *( ALPHA / DIGIT / \"+\" / \"-\" / \".\" )\n+                const SCHEME_RE = /(?:^|[^a-z0-9.+-])([a-z][a-z0-9.+-]*)$/i;\n \n-                var S = Object.defineProperty;\n-                var y = (d, L) => S(d, \"name\", {\n-                    value: L,\n-                    configurable: !0\n-                });\n-                const _ = __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\");\n-\n-                function m(d, L) {\n-                    for (var e = 0; e < L.length; e++) {\n-                        const g = L[e];\n-                        if (typeof g != \"string\" && !Array.isArray(g)) {\n-                            for (const t in g)\n-                                if (t !== \"default\" && !(t in d)) {\n-                                    const a = Object.getOwnPropertyDescriptor(g, t);\n-                                    a && Object.defineProperty(d, t, a.get ? a : {\n-                                        enumerable: !0,\n-                                        get: () => g[t]\n-                                    });\n-                                }\n-                        }\n+                function linkify(state, silent) {\n+                    if (!state.md.options.linkify) return false;\n+                    if (state.linkLevel > 0) return false;\n+                    const pos = state.pos;\n+                    const max = state.posMax;\n+                    if (pos + 3 > max) return false;\n+                    if (state.src.charCodeAt(pos) !== 0x3A /* : */ ) return false;\n+                    if (state.src.charCodeAt(pos + 1) !== 0x2F /* / */ ) return false;\n+                    if (state.src.charCodeAt(pos + 2) !== 0x2F /* / */ ) return false;\n+                    const match = state.pending.match(SCHEME_RE);\n+                    if (!match) return false;\n+                    const proto = match[1];\n+                    const link = state.md.linkify.matchAtStart(state.src.slice(pos - proto.length));\n+                    if (!link) return false;\n+                    let url = link.url;\n+\n+                    // invalid link, but still detected by linkify somehow;\n+                    // need to check to prevent infinite loop below\n+                    if (url.length <= proto.length) return false;\n+\n+                    // disallow '*' at the end of the link (conflicts with emphasis)\n+                    url = url.replace(/\\*+$/, '');\n+                    const fullUrl = state.md.normalizeLink(url);\n+                    if (!state.md.validateLink(fullUrl)) return false;\n+                    if (!silent) {\n+                        state.pending = state.pending.slice(0, -proto.length);\n+                        const token_o = state.push('link_open', 'a', 1);\n+                        token_o.attrs = [\n+                            ['href', fullUrl]\n+                        ];\n+                        token_o.markup = 'linkify';\n+                        token_o.info = 'auto';\n+                        const token_t = state.push('text', '', 0);\n+                        token_t.content = state.md.normalizeLinkText(url);\n+                        const token_c = state.push('link_close', 'a', -1);\n+                        token_c.markup = 'linkify';\n+                        token_c.info = 'auto';\n                     }\n-                    return Object.freeze(Object.defineProperty(d, Symbol.toStringTag, {\n-                        value: \"Module\"\n-                    }));\n+                    state.pos += url.length - proto.length;\n+                    return true;\n                 }\n-                y(m, \"_mergeNamespaces\");\n-                var I = {\n-                    exports: {}\n-                };\n-                (function(d, L) {\n-                    (function(e) {\n-                        e(_.requireCodemirror());\n-                    })(function(e) {\n-                        function g(t) {\n-                            return function(a, f) {\n-                                var n = f.line,\n-                                    o = a.getLine(n);\n-\n-                                function v(l) {\n-                                    for (var u, c = f.ch, h = 0;;) {\n-                                        var b = c <= 0 ? -1 : o.lastIndexOf(l[0], c - 1);\n-                                        if (b == -1) {\n-                                            if (h == 1) break;\n-                                            h = 1, c = o.length;\n-                                            continue;\n-                                        }\n-                                        if (h == 1 && b < f.ch) break;\n-                                        if (u = a.getTokenTypeAt(e.Pos(n, b + 1)), !/^(comment|string)/.test(u)) return {\n-                                            ch: b + 1,\n-                                            tokenType: u,\n-                                            pair: l\n-                                        };\n-                                        c = b - 1;\n-                                    }\n-                                }\n-                                y(v, \"findOpening\");\n \n-                                function k(l) {\n-                                    var u = 1,\n-                                        c = a.lastLine(),\n-                                        h,\n-                                        b = l.ch,\n-                                        j;\n-                                    e: for (var T = n; T <= c; ++T)\n-                                        for (var A = a.getLine(T), p = T == n ? b : 0;;) {\n-                                            var F = A.indexOf(l.pair[0], p),\n-                                                O = A.indexOf(l.pair[1], p);\n-                                            if (F < 0 && (F = A.length), O < 0 && (O = A.length), p = Math.min(F, O), p == A.length) break;\n-                                            if (a.getTokenTypeAt(e.Pos(T, p + 1)) == l.tokenType) {\n-                                                if (p == F) ++u;\n-                                                else if (!--u) {\n-                                                    h = T, j = p;\n-                                                    break e;\n-                                                }\n-                                            }\n-                                            ++p;\n-                                        }\n-                                    return h == null || n == h ? null : {\n-                                        from: e.Pos(n, b),\n-                                        to: e.Pos(h, j)\n-                                    };\n-                                }\n-                                y(k, \"findRange\");\n-                                for (var i = [], r = 0; r < t.length; r++) {\n-                                    var s = v(t[r]);\n-                                    s && i.push(s);\n-                                }\n-                                i.sort(function(l, u) {\n-                                    return l.ch - u.ch;\n-                                });\n-                                for (var r = 0; r < i.length; r++) {\n-                                    var P = k(i[r]);\n-                                    if (P) return P;\n-                                }\n-                                return null;\n-                            };\n-                        }\n-                        y(g, \"bracketFolding\"), e.registerHelper(\"fold\", \"brace\", g([\n-                            [\"{\", \"}\"],\n-                            [\"[\", \"]\"]\n-                        ])), e.registerHelper(\"fold\", \"brace-paren\", g([\n-                            [\"{\", \"}\"],\n-                            [\"[\", \"]\"],\n-                            [\"(\", \")\"]\n-                        ])), e.registerHelper(\"fold\", \"import\", function(t, a) {\n-                            function f(r) {\n-                                if (r < t.firstLine() || r > t.lastLine()) return null;\n-                                var s = t.getTokenAt(e.Pos(r, 1));\n-                                if (/\\S/.test(s.string) || (s = t.getTokenAt(e.Pos(r, s.end + 1))), s.type != \"keyword\" || s.string != \"import\") return null;\n-                                for (var P = r, l = Math.min(t.lastLine(), r + 10); P <= l; ++P) {\n-                                    var u = t.getLine(P),\n-                                        c = u.indexOf(\";\");\n-                                    if (c != -1) return {\n-                                        startCh: s.end,\n-                                        end: e.Pos(P, c)\n-                                    };\n-                                }\n-                            }\n-                            y(f, \"hasImport\");\n-                            var n = a.line,\n-                                o = f(n),\n-                                v;\n-                            if (!o || f(n - 1) || (v = f(n - 2)) && v.end.line == n - 1) return null;\n-                            for (var k = o.end;;) {\n-                                var i = f(k.line + 1);\n-                                if (i == null) break;\n-                                k = i.end;\n-                            }\n-                            return {\n-                                from: t.clipPos(e.Pos(n, o.startCh + 1)),\n-                                to: k\n-                            };\n-                        }), e.registerHelper(\"fold\", \"include\", function(t, a) {\n-                            function f(i) {\n-                                if (i < t.firstLine() || i > t.lastLine()) return null;\n-                                var r = t.getTokenAt(e.Pos(i, 1));\n-                                if (/\\S/.test(r.string) || (r = t.getTokenAt(e.Pos(i, r.end + 1))), r.type == \"meta\" && r.string.slice(0, 8) == \"#include\") return r.start + 8;\n-                            }\n-                            y(f, \"hasInclude\");\n-                            var n = a.line,\n-                                o = f(n);\n-                            if (o == null || f(n - 1) != null) return null;\n-                            for (var v = n;;) {\n-                                var k = f(v + 1);\n-                                if (k == null) break;\n-                                ++v;\n+                // Proceess '\\n'\n+\n+                function newline(state, silent) {\n+                    let pos = state.pos;\n+                    if (state.src.charCodeAt(pos) !== 0x0A /* \\n */ ) {\n+                        return false;\n+                    }\n+                    const pmax = state.pending.length - 1;\n+                    const max = state.posMax;\n+\n+                    // '  \\n' -> hardbreak\n+                    // Lookup in pending chars is bad practice! Don't copy to other rules!\n+                    // Pending string is stored in concat mode, indexed lookups will cause\n+                    // convertion to flat mode.\n+                    if (!silent) {\n+                        if (pmax >= 0 && state.pending.charCodeAt(pmax) === 0x20) {\n+                            if (pmax >= 1 && state.pending.charCodeAt(pmax - 1) === 0x20) {\n+                                // Find whitespaces tail of pending chars.\n+                                let ws = pmax - 1;\n+                                while (ws >= 1 && state.pending.charCodeAt(ws - 1) === 0x20) ws--;\n+                                state.pending = state.pending.slice(0, ws);\n+                                state.push('hardbreak', 'br', 0);\n+                            } else {\n+                                state.pending = state.pending.slice(0, -1);\n+                                state.push('softbreak', 'br', 0);\n                             }\n-                            return {\n-                                from: e.Pos(n, o + 1),\n-                                to: t.clipPos(e.Pos(v))\n-                            };\n-                        });\n-                    });\n-                })();\n-                var H = I.exports;\n-                const q = _.getDefaultExportFromCjs(H),\n-                    w = m({\n-                        __proto__: null,\n-                        default: q\n-                    }, [H]);\n-                exports.braceFold = w;\n+                        } else {\n+                            state.push('softbreak', 'br', 0);\n+                        }\n+                    }\n+                    pos++;\n \n-                /***/\n-            }),\n+                    // skip heading spaces for next line\n+                    while (pos < max && isSpace(state.src.charCodeAt(pos))) {\n+                        pos++;\n+                    }\n+                    state.pos = pos;\n+                    return true;\n+                }\n \n-        /***/\n-        \"../../graphiql-react/dist/closebrackets.cjs.js\":\n-            /*!******************************************************!*\\\n-              !*** ../../graphiql-react/dist/closebrackets.cjs.js ***!\n-              \\******************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                // Process escaped chars and hardbreaks\n \n+                const ESCAPED = [];\n+                for (let i = 0; i < 256; i++) {\n+                    ESCAPED.push(0);\n+                }\n+                '\\\\!\"#$%&\\'()*+,./:;<=>?@[]^_`{|}~-'.split('').forEach(function(ch) {\n+                    ESCAPED[ch.charCodeAt(0)] = 1;\n+                });\n \n+                function escape(state, silent) {\n+                    let pos = state.pos;\n+                    const max = state.posMax;\n+                    if (state.src.charCodeAt(pos) !== 0x5C /* \\ */ ) return false;\n+                    pos++;\n \n-                var G = Object.defineProperty;\n-                var f = (S, P) => G(S, \"name\", {\n-                    value: P,\n-                    configurable: !0\n-                });\n-                const q = __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\");\n-\n-                function H(S, P) {\n-                    for (var a = 0; a < P.length; a++) {\n-                        const c = P[a];\n-                        if (typeof c != \"string\" && !Array.isArray(c)) {\n-                            for (const i in c)\n-                                if (i !== \"default\" && !(i in S)) {\n-                                    const v = Object.getOwnPropertyDescriptor(c, i);\n-                                    v && Object.defineProperty(S, i, v.get ? v : {\n-                                        enumerable: !0,\n-                                        get: () => c[i]\n-                                    });\n-                                }\n+                    // '\\' at the end of the inline block\n+                    if (pos >= max) return false;\n+                    let ch1 = state.src.charCodeAt(pos);\n+                    if (ch1 === 0x0A) {\n+                        if (!silent) {\n+                            state.push('hardbreak', 'br', 0);\n+                        }\n+                        pos++;\n+                        // skip leading whitespaces from next line\n+                        while (pos < max) {\n+                            ch1 = state.src.charCodeAt(pos);\n+                            if (!isSpace(ch1)) break;\n+                            pos++;\n                         }\n+                        state.pos = pos;\n+                        return true;\n                     }\n-                    return Object.freeze(Object.defineProperty(S, Symbol.toStringTag, {\n-                        value: \"Module\"\n-                    }));\n+                    let escapedStr = state.src[pos];\n+                    if (ch1 >= 0xD800 && ch1 <= 0xDBFF && pos + 1 < max) {\n+                        const ch2 = state.src.charCodeAt(pos + 1);\n+                        if (ch2 >= 0xDC00 && ch2 <= 0xDFFF) {\n+                            escapedStr += state.src[pos + 1];\n+                            pos++;\n+                        }\n+                    }\n+                    const origStr = '\\\\' + escapedStr;\n+                    if (!silent) {\n+                        const token = state.push('text_special', '', 0);\n+                        if (ch1 < 256 && ESCAPED[ch1] !== 0) {\n+                            token.content = escapedStr;\n+                        } else {\n+                            token.content = origStr;\n+                        }\n+                        token.markup = origStr;\n+                        token.info = 'escape';\n+                    }\n+                    state.pos = pos + 1;\n+                    return true;\n                 }\n-                f(H, \"_mergeNamespaces\");\n-                var J = {\n-                    exports: {}\n-                };\n-                (function(S, P) {\n-                    (function(a) {\n-                        a(q.requireCodemirror());\n-                    })(function(a) {\n-                        var c = {\n-                                pairs: `()[]{}''\"\"`,\n-                                closeBefore: `)]}'\":;>`,\n-                                triples: \"\",\n-                                explode: \"[]{}\"\n-                            },\n-                            i = a.Pos;\n-                        a.defineOption(\"autoCloseBrackets\", !1, function(e, t, n) {\n-                            n && n != a.Init && (e.removeKeyMap(B), e.state.closeBrackets = null), t && (_(v(t, \"pairs\")), e.state.closeBrackets = t, e.addKeyMap(B));\n-                        });\n \n-                        function v(e, t) {\n-                            return t == \"pairs\" && typeof e == \"string\" ? e : typeof e == \"object\" && e[t] != null ? e[t] : c[t];\n-                        }\n-                        f(v, \"getOption\");\n-                        var B = {\n-                            Backspace: L,\n-                            Enter: W\n-                        };\n+                // Parse backticks\n \n-                        function _(e) {\n-                            for (var t = 0; t < e.length; t++) {\n-                                var n = e.charAt(t),\n-                                    s = \"'\" + n + \"'\";\n-                                B[s] || (B[s] = K(n));\n-                            }\n-                        }\n-                        f(_, \"ensureBound\"), _(c.pairs + \"`\");\n+                function backtick(state, silent) {\n+                    let pos = state.pos;\n+                    const ch = state.src.charCodeAt(pos);\n+                    if (ch !== 0x60 /* ` */ ) {\n+                        return false;\n+                    }\n+                    const start = pos;\n+                    pos++;\n+                    const max = state.posMax;\n \n-                        function K(e) {\n-                            return function(t) {\n-                                return z(t, e);\n-                            };\n-                        }\n-                        f(K, \"handler\");\n+                    // scan marker length\n+                    while (pos < max && state.src.charCodeAt(pos) === 0x60 /* ` */ ) {\n+                        pos++;\n+                    }\n+                    const marker = state.src.slice(start, pos);\n+                    const openerLength = marker.length;\n+                    if (state.backticksScanned && (state.backticks[openerLength] || 0) <= start) {\n+                        if (!silent) state.pending += marker;\n+                        state.pos += openerLength;\n+                        return true;\n+                    }\n+                    let matchEnd = pos;\n+                    let matchStart;\n \n-                        function x(e) {\n-                            var t = e.state.closeBrackets;\n-                            if (!t || t.override) return t;\n-                            var n = e.getModeAt(e.getCursor());\n-                            return n.closeBrackets || t;\n-                        }\n-                        f(x, \"getConfig\");\n+                    // Nothing found in the cache, scan until the end of the line (or until marker is found)\n+                    while ((matchStart = state.src.indexOf('`', matchEnd)) !== -1) {\n+                        matchEnd = matchStart + 1;\n \n-                        function L(e) {\n-                            var t = x(e);\n-                            if (!t || e.getOption(\"disableInput\")) return a.Pass;\n-                            for (var n = v(t, \"pairs\"), s = e.listSelections(), r = 0; r < s.length; r++) {\n-                                if (!s[r].empty()) return a.Pass;\n-                                var h = w(e, s[r].head);\n-                                if (!h || n.indexOf(h) % 2 != 0) return a.Pass;\n-                            }\n-                            for (var r = s.length - 1; r >= 0; r--) {\n-                                var o = s[r].head;\n-                                e.replaceRange(\"\", i(o.line, o.ch - 1), i(o.line, o.ch + 1), \"+delete\");\n+                        // scan marker length\n+                        while (matchEnd < max && state.src.charCodeAt(matchEnd) === 0x60 /* ` */ ) {\n+                            matchEnd++;\n+                        }\n+                        const closerLength = matchEnd - matchStart;\n+                        if (closerLength === openerLength) {\n+                            // Found matching closer length.\n+                            if (!silent) {\n+                                const token = state.push('code_inline', 'code', 0);\n+                                token.markup = marker;\n+                                token.content = state.src.slice(pos, matchStart).replace(/\\n/g, ' ').replace(/^ (.+) $/, '$1');\n                             }\n+                            state.pos = matchEnd;\n+                            return true;\n                         }\n-                        f(L, \"handleBackspace\");\n \n-                        function W(e) {\n-                            var t = x(e),\n-                                n = t && v(t, \"explode\");\n-                            if (!n || e.getOption(\"disableInput\")) return a.Pass;\n-                            for (var s = e.listSelections(), r = 0; r < s.length; r++) {\n-                                if (!s[r].empty()) return a.Pass;\n-                                var h = w(e, s[r].head);\n-                                if (!h || n.indexOf(h) % 2 != 0) return a.Pass;\n-                            }\n-                            e.operation(function() {\n-                                var o = e.lineSeparator() || `\n-`;\n-                                e.replaceSelection(o + o, null), O(e, -1), s = e.listSelections();\n-                                for (var g = 0; g < s.length; g++) {\n-                                    var A = s[g].head.line;\n-                                    e.indentLine(A, null, !0), e.indentLine(A + 1, null, !0);\n-                                }\n-                            });\n+                        // Some different length found, put it in cache as upper limit of where closer can be found\n+                        state.backticks[closerLength] = matchStart;\n+                    }\n+\n+                    // Scanned through the end, didn't find anything\n+                    state.backticksScanned = true;\n+                    if (!silent) state.pending += marker;\n+                    state.pos += openerLength;\n+                    return true;\n+                }\n+\n+                // ~~strike through~~\n+                //\n+\n+                // Insert each marker as a separate text token, and add it to delimiter list\n+                //\n+                function strikethrough_tokenize(state, silent) {\n+                    const start = state.pos;\n+                    const marker = state.src.charCodeAt(start);\n+                    if (silent) {\n+                        return false;\n+                    }\n+                    if (marker !== 0x7E /* ~ */ ) {\n+                        return false;\n+                    }\n+                    const scanned = state.scanDelims(state.pos, true);\n+                    let len = scanned.length;\n+                    const ch = String.fromCharCode(marker);\n+                    if (len < 2) {\n+                        return false;\n+                    }\n+                    let token;\n+                    if (len % 2) {\n+                        token = state.push('text', '', 0);\n+                        token.content = ch;\n+                        len--;\n+                    }\n+                    for (let i = 0; i < len; i += 2) {\n+                        token = state.push('text', '', 0);\n+                        token.content = ch + ch;\n+                        state.delimiters.push({\n+                            marker,\n+                            length: 0,\n+                            // disable \"rule of 3\" length checks meant for emphasis\n+                            token: state.tokens.length - 1,\n+                            end: -1,\n+                            open: scanned.can_open,\n+                            close: scanned.can_close\n+                        });\n+                    }\n+                    state.pos += scanned.length;\n+                    return true;\n+                }\n+\n+                function postProcess$1(state, delimiters) {\n+                    let token;\n+                    const loneMarkers = [];\n+                    const max = delimiters.length;\n+                    for (let i = 0; i < max; i++) {\n+                        const startDelim = delimiters[i];\n+                        if (startDelim.marker !== 0x7E /* ~ */ ) {\n+                            continue;\n                         }\n-                        f(W, \"handleEnter\");\n-\n-                        function O(e, t) {\n-                            for (var n = [], s = e.listSelections(), r = 0, h = 0; h < s.length; h++) {\n-                                var o = s[h];\n-                                o.head == e.getCursor() && (r = h);\n-                                var g = o.head.ch || t > 0 ? {\n-                                    line: o.head.line,\n-                                    ch: o.head.ch + t\n-                                } : {\n-                                    line: o.head.line - 1\n-                                };\n-                                n.push({\n-                                    anchor: g,\n-                                    head: g\n-                                });\n-                            }\n-                            e.setSelections(n, r);\n+                        if (startDelim.end === -1) {\n+                            continue;\n+                        }\n+                        const endDelim = delimiters[startDelim.end];\n+                        token = state.tokens[startDelim.token];\n+                        token.type = 's_open';\n+                        token.tag = 's';\n+                        token.nesting = 1;\n+                        token.markup = '~~';\n+                        token.content = '';\n+                        token = state.tokens[endDelim.token];\n+                        token.type = 's_close';\n+                        token.tag = 's';\n+                        token.nesting = -1;\n+                        token.markup = '~~';\n+                        token.content = '';\n+                        if (state.tokens[endDelim.token - 1].type === 'text' && state.tokens[endDelim.token - 1].content === '~') {\n+                            loneMarkers.push(endDelim.token - 1);\n                         }\n-                        f(O, \"moveSel\");\n+                    }\n \n-                        function $(e) {\n-                            var t = a.cmpPos(e.anchor, e.head) > 0;\n-                            return {\n-                                anchor: new i(e.anchor.line, e.anchor.ch + (t ? -1 : 1)),\n-                                head: new i(e.head.line, e.head.ch + (t ? 1 : -1))\n-                            };\n+                    // If a marker sequence has an odd number of characters, it's splitted\n+                    // like this: `~~~~~` -> `~` + `~~` + `~~`, leaving one marker at the\n+                    // start of the sequence.\n+                    //\n+                    // So, we have to move all those markers after subsequent s_close tags.\n+                    //\n+                    while (loneMarkers.length) {\n+                        const i = loneMarkers.pop();\n+                        let j = i + 1;\n+                        while (j < state.tokens.length && state.tokens[j].type === 's_close') {\n+                            j++;\n                         }\n-                        f($, \"contractSelection\");\n+                        j--;\n+                        if (i !== j) {\n+                            token = state.tokens[j];\n+                            state.tokens[j] = state.tokens[i];\n+                            state.tokens[i] = token;\n+                        }\n+                    }\n+                }\n \n-                        function z(e, t) {\n-                            var n = x(e);\n-                            if (!n || e.getOption(\"disableInput\")) return a.Pass;\n-                            var s = v(n, \"pairs\"),\n-                                r = s.indexOf(t);\n-                            if (r == -1) return a.Pass;\n-                            for (var h = v(n, \"closeBefore\"), o = v(n, \"triples\"), g = s.charAt(r + 1) == t, A = e.listSelections(), R = r % 2 == 0, b, j = 0; j < A.length; j++) {\n-                                var I = A[j],\n-                                    l = I.head,\n-                                    u,\n-                                    y = e.getRange(l, i(l.line, l.ch + 1));\n-                                if (R && !I.empty()) u = \"surround\";\n-                                else if ((g || !R) && y == t) g && N(e, l) ? u = \"both\" : o.indexOf(t) >= 0 && e.getRange(l, i(l.line, l.ch + 3)) == t + t + t ? u = \"skipThree\" : u = \"skip\";\n-                                else if (g && l.ch > 1 && o.indexOf(t) >= 0 && e.getRange(i(l.line, l.ch - 2), l) == t + t) {\n-                                    if (l.ch > 2 && /\\bstring/.test(e.getTokenTypeAt(i(l.line, l.ch - 2)))) return a.Pass;\n-                                    u = \"addFour\";\n-                                } else if (g) {\n-                                    var F = l.ch == 0 ? \" \" : e.getRange(i(l.line, l.ch - 1), l);\n-                                    if (!a.isWordChar(y) && F != t && !a.isWordChar(F)) u = \"both\";\n-                                    else return a.Pass;\n-                                } else if (R && (y.length === 0 || /\\s/.test(y) || h.indexOf(y) > -1)) u = \"both\";\n-                                else return a.Pass;\n-                                if (!b) b = u;\n-                                else if (b != u) return a.Pass;\n-                            }\n-                            var k = r % 2 ? s.charAt(r - 1) : t,\n-                                E = r % 2 ? t : s.charAt(r + 1);\n-                            e.operation(function() {\n-                                if (b == \"skip\") O(e, 1);\n-                                else if (b == \"skipThree\") O(e, 3);\n-                                else if (b == \"surround\") {\n-                                    for (var p = e.getSelections(), d = 0; d < p.length; d++) p[d] = k + p[d] + E;\n-                                    e.replaceSelections(p, \"around\"), p = e.listSelections().slice();\n-                                    for (var d = 0; d < p.length; d++) p[d] = $(p[d]);\n-                                    e.setSelections(p);\n-                                } else b == \"both\" ? (e.replaceSelection(k + E, null), e.triggerElectric(k + E), O(e, -1)) : b == \"addFour\" && (e.replaceSelection(k + k + k + k, \"before\"), O(e, 1));\n-                            });\n-                        }\n-                        f(z, \"handleChar\");\n-\n-                        function w(e, t) {\n-                            var n = e.getRange(i(t.line, t.ch - 1), i(t.line, t.ch + 1));\n-                            return n.length == 2 ? n : null;\n-                        }\n-                        f(w, \"charsAround\");\n-\n-                        function N(e, t) {\n-                            var n = e.getTokenAt(i(t.line, t.ch + 1));\n-                            return /\\bstring/.test(n.type) && n.start == t.ch && (t.ch == 0 || !/\\bstring/.test(e.getTokenTypeAt(t)));\n-                        }\n-                        f(N, \"stringStartsAfter\");\n-                    });\n-                })();\n-                var D = J.exports;\n-                const Q = q.getDefaultExportFromCjs(D),\n-                    T = H({\n-                        __proto__: null,\n-                        default: Q\n-                    }, [D]);\n-                exports.closebrackets = T;\n+                // Walk through delimiter list and replace text tokens with tags\n+                //\n+                function strikethrough_postProcess(state) {\n+                    const tokens_meta = state.tokens_meta;\n+                    const max = state.tokens_meta.length;\n+                    postProcess$1(state, state.delimiters);\n+                    for (let curr = 0; curr < max; curr++) {\n+                        if (tokens_meta[curr] && tokens_meta[curr].delimiters) {\n+                            postProcess$1(state, tokens_meta[curr].delimiters);\n+                        }\n+                    }\n+                }\n+                var r_strikethrough = {\n+                    tokenize: strikethrough_tokenize,\n+                    postProcess: strikethrough_postProcess\n+                };\n \n-                /***/\n-            }),\n+                // Process *this* and _that_\n+                //\n \n-        /***/\n-        \"../../graphiql-react/dist/codemirror.cjs.js\":\n-            /*!***************************************************!*\\\n-              !*** ../../graphiql-react/dist/codemirror.cjs.js ***!\n-              \\***************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                // Insert each marker as a separate text token, and add it to delimiter list\n+                //\n+                function emphasis_tokenize(state, silent) {\n+                    const start = state.pos;\n+                    const marker = state.src.charCodeAt(start);\n+                    if (silent) {\n+                        return false;\n+                    }\n+                    if (marker !== 0x5F /* _ */ && marker !== 0x2A /* * */ ) {\n+                        return false;\n+                    }\n+                    const scanned = state.scanDelims(state.pos, marker === 0x2A);\n+                    for (let i = 0; i < scanned.length; i++) {\n+                        const token = state.push('text', '', 0);\n+                        token.content = String.fromCharCode(marker);\n+                        state.delimiters.push({\n+                            // Char code of the starting marker (number).\n+                            //\n+                            marker,\n+                            // Total length of these series of delimiters.\n+                            //\n+                            length: scanned.length,\n+                            // A position of the token this delimiter corresponds to.\n+                            //\n+                            token: state.tokens.length - 1,\n+                            // If this delimiter is matched as a valid opener, `end` will be\n+                            // equal to its position, otherwise it's `-1`.\n+                            //\n+                            end: -1,\n+                            // Boolean flags that determine if this delimiter could open or close\n+                            // an emphasis.\n+                            //\n+                            open: scanned.can_open,\n+                            close: scanned.can_close\n+                        });\n+                    }\n+                    state.pos += scanned.length;\n+                    return true;\n+                }\n \n+                function postProcess(state, delimiters) {\n+                    const max = delimiters.length;\n+                    for (let i = max - 1; i >= 0; i--) {\n+                        const startDelim = delimiters[i];\n+                        if (startDelim.marker !== 0x5F /* _ */ && startDelim.marker !== 0x2A /* * */ ) {\n+                            continue;\n+                        }\n \n+                        // Process only opening markers\n+                        if (startDelim.end === -1) {\n+                            continue;\n+                        }\n+                        const endDelim = delimiters[startDelim.end];\n \n-                var u = Object.defineProperty;\n-                var n = (r, t) => u(r, \"name\", {\n-                    value: t,\n-                    configurable: !0\n-                });\n-                const s = __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\");\n-\n-                function a(r, t) {\n-                    for (var i = 0; i < t.length; i++) {\n-                        const e = t[i];\n-                        if (typeof e != \"string\" && !Array.isArray(e)) {\n-                            for (const o in e)\n-                                if (o !== \"default\" && !(o in r)) {\n-                                    const c = Object.getOwnPropertyDescriptor(e, o);\n-                                    c && Object.defineProperty(r, o, c.get ? c : {\n-                                        enumerable: !0,\n-                                        get: () => e[o]\n-                                    });\n-                                }\n+                        // If the previous delimiter has the same marker and is adjacent to this one,\n+                        // merge those into one strong delimiter.\n+                        //\n+                        // `<em><em>whatever</em></em>` -> `<strong>whatever</strong>`\n+                        //\n+                        const isStrong = i > 0 && delimiters[i - 1].end === startDelim.end + 1 &&\n+                            // check that first two markers match and adjacent\n+                            delimiters[i - 1].marker === startDelim.marker && delimiters[i - 1].token === startDelim.token - 1 &&\n+                            // check that last two markers are adjacent (we can safely assume they match)\n+                            delimiters[startDelim.end + 1].token === endDelim.token + 1;\n+                        const ch = String.fromCharCode(startDelim.marker);\n+                        const token_o = state.tokens[startDelim.token];\n+                        token_o.type = isStrong ? 'strong_open' : 'em_open';\n+                        token_o.tag = isStrong ? 'strong' : 'em';\n+                        token_o.nesting = 1;\n+                        token_o.markup = isStrong ? ch + ch : ch;\n+                        token_o.content = '';\n+                        const token_c = state.tokens[endDelim.token];\n+                        token_c.type = isStrong ? 'strong_close' : 'em_close';\n+                        token_c.tag = isStrong ? 'strong' : 'em';\n+                        token_c.nesting = -1;\n+                        token_c.markup = isStrong ? ch + ch : ch;\n+                        token_c.content = '';\n+                        if (isStrong) {\n+                            state.tokens[delimiters[i - 1].token].content = '';\n+                            state.tokens[delimiters[startDelim.end + 1].token].content = '';\n+                            i--;\n                         }\n                     }\n-                    return Object.freeze(Object.defineProperty(r, Symbol.toStringTag, {\n-                        value: \"Module\"\n-                    }));\n                 }\n-                n(a, \"_mergeNamespaces\");\n-                var d = s.requireCodemirror();\n-                const f = s.getDefaultExportFromCjs(d),\n-                    l = a({\n-                        __proto__: null,\n-                        default: f\n-                    }, [d]);\n-                exports.CodeMirror = f;\n-                exports.codemirror = l;\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../graphiql-react/dist/codemirror.cjs2.js\":\n-            /*!****************************************************!*\\\n-              !*** ../../graphiql-react/dist/codemirror.cjs2.js ***!\n-              \\****************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                // Walk through delimiter list and replace text tokens with tags\n+                //\n+                function emphasis_post_process(state) {\n+                    const tokens_meta = state.tokens_meta;\n+                    const max = state.tokens_meta.length;\n+                    postProcess(state, state.delimiters);\n+                    for (let curr = 0; curr < max; curr++) {\n+                        if (tokens_meta[curr] && tokens_meta[curr].delimiters) {\n+                            postProcess(state, tokens_meta[curr].delimiters);\n+                        }\n+                    }\n+                }\n+                var r_emphasis = {\n+                    tokenize: emphasis_tokenize,\n+                    postProcess: emphasis_post_process\n+                };\n \n+                // Process [link](<to> \"stuff\")\n \n-                var su = Object.defineProperty;\n-                var u = (He, Dn) => su(He, \"name\", {\n-                    value: Dn,\n-                    configurable: !0\n-                });\n-                var uu = typeof globalThis < \"u\" ? globalThis : typeof window < \"u\" ? window : typeof __webpack_require__.g < \"u\" ? __webpack_require__.g : typeof self < \"u\" ? self : {};\n-\n-                function fu(He) {\n-                    return He && He.__esModule && Object.prototype.hasOwnProperty.call(He, \"default\") ? He.default : He;\n-                }\n-                u(fu, \"getDefaultExportFromCjs\");\n-                var Mn = {\n-                        exports: {}\n-                    },\n-                    Ko;\n+                function link(state, silent) {\n+                    let code, label, res, ref;\n+                    let href = '';\n+                    let title = '';\n+                    let start = state.pos;\n+                    let parseReference = true;\n+                    if (state.src.charCodeAt(state.pos) !== 0x5B /* [ */ ) {\n+                        return false;\n+                    }\n+                    const oldPos = state.pos;\n+                    const max = state.posMax;\n+                    const labelStart = state.pos + 1;\n+                    const labelEnd = state.md.helpers.parseLinkLabel(state, state.pos, true);\n \n-                function hu() {\n-                    return Ko || (Ko = 1, function(He, Dn) {\n-                        (function(ie, Lr) {\n-                            He.exports = Lr();\n-                        })(uu, function() {\n-                            var ie = navigator.userAgent,\n-                                Lr = navigator.platform,\n-                                Fe = /gecko\\/\\d/i.test(ie),\n-                                Nn = /MSIE \\d/.test(ie),\n-                                An = /Trident\\/(?:[7-9]|\\d{2,})\\..*rv:(\\d+)/.exec(ie),\n-                                kr = /Edge\\/(\\d+)/.exec(ie),\n-                                O = Nn || An || kr,\n-                                I = O && (Nn ? document.documentMode || 6 : +(kr || An)[1]),\n-                                ne = !kr && /WebKit\\//.test(ie),\n-                                _o = ne && /Qt\\/\\d+\\.\\d+/.test(ie),\n-                                Tr = !kr && /Chrome\\//.test(ie),\n-                                we = /Opera\\//.test(ie),\n-                                Mr = /Apple Computer/.test(navigator.vendor),\n-                                Xo = /Mac OS X 1\\d\\D([8-9]|\\d\\d)\\D/.test(ie),\n-                                Yo = /PhantomJS/.test(ie),\n-                                Ut = Mr && (/Mobile\\/\\w+/.test(ie) || navigator.maxTouchPoints > 2),\n-                                Dr = /Android/.test(ie),\n-                                Kt = Ut || Dr || /webOS|BlackBerry|Opera Mini|Opera Mobi|IEMobile/i.test(ie),\n-                                me = Ut || /Mac/.test(Lr),\n-                                qo = /\\bCrOS\\b/.test(ie),\n-                                Zo = /win/i.test(Lr),\n-                                et = we && ie.match(/Version\\/(\\d*\\.\\d*)/);\n-                            et && (et = Number(et[1])), et && et >= 15 && (we = !1, ne = !0);\n-                            var On = me && (_o || we && (et == null || et < 12.11)),\n-                                ci = Fe || O && I >= 9;\n-\n-                            function mt(e) {\n-                                return new RegExp(\"(^|\\\\s)\" + e + \"(?:$|\\\\s)\\\\s*\");\n-                            }\n-                            u(mt, \"classTest\");\n-                            var tt = u(function(e, t) {\n-                                var i = e.className,\n-                                    r = mt(t).exec(i);\n-                                if (r) {\n-                                    var n = i.slice(r.index + r[0].length);\n-                                    e.className = i.slice(0, r.index) + (n ? r[1] + n : \"\");\n-                                }\n-                            }, \"rmClass\");\n-\n-                            function Ue(e) {\n-                                for (var t = e.childNodes.length; t > 0; --t) e.removeChild(e.firstChild);\n-                                return e;\n-                            }\n-                            u(Ue, \"removeChildren\");\n-\n-                            function ve(e, t) {\n-                                return Ue(e).appendChild(t);\n-                            }\n-                            u(ve, \"removeChildrenAndAdd\");\n-\n-                            function T(e, t, i, r) {\n-                                var n = document.createElement(e);\n-                                if (i && (n.className = i), r && (n.style.cssText = r), typeof t == \"string\") n.appendChild(document.createTextNode(t));\n-                                else if (t)\n-                                    for (var l = 0; l < t.length; ++l) n.appendChild(t[l]);\n-                                return n;\n-                            }\n-                            u(T, \"elt\");\n-\n-                            function bt(e, t, i, r) {\n-                                var n = T(e, t, i, r);\n-                                return n.setAttribute(\"role\", \"presentation\"), n;\n-                            }\n-                            u(bt, \"eltP\");\n-                            var rt;\n-                            document.createRange ? rt = u(function(e, t, i, r) {\n-                                var n = document.createRange();\n-                                return n.setEnd(r || e, i), n.setStart(e, t), n;\n-                            }, \"range\") : rt = u(function(e, t, i) {\n-                                var r = document.body.createTextRange();\n-                                try {\n-                                    r.moveToElementText(e.parentNode);\n-                                } catch {\n-                                    return r;\n-                                }\n-                                return r.collapse(!0), r.moveEnd(\"character\", i), r.moveStart(\"character\", t), r;\n-                            }, \"range\");\n-\n-                            function Ke(e, t) {\n-                                if (t.nodeType == 3 && (t = t.parentNode), e.contains) return e.contains(t);\n-                                do\n-                                    if (t.nodeType == 11 && (t = t.host), t == e) return !0; while (t = t.parentNode);\n-                            }\n-                            u(Ke, \"contains\");\n+                    // parser failed to find ']', so it's not a valid link\n+                    if (labelEnd < 0) {\n+                        return false;\n+                    }\n+                    let pos = labelEnd + 1;\n+                    if (pos < max && state.src.charCodeAt(pos) === 0x28 /* ( */ ) {\n+                        //\n+                        // Inline link\n+                        //\n \n-                            function be() {\n-                                var e;\n-                                try {\n-                                    e = document.activeElement;\n-                                } catch {\n-                                    e = document.body || null;\n-                                }\n-                                for (; e && e.shadowRoot && e.shadowRoot.activeElement;) e = e.shadowRoot.activeElement;\n-                                return e;\n-                            }\n-                            u(be, \"activeElt\");\n-\n-                            function it(e, t) {\n-                                var i = e.className;\n-                                mt(t).test(i) || (e.className += (i ? \" \" : \"\") + t);\n-                            }\n-                            u(it, \"addClass\");\n-\n-                            function di(e, t) {\n-                                for (var i = e.split(\" \"), r = 0; r < i.length; r++) i[r] && !mt(i[r]).test(t) && (t += \" \" + i[r]);\n-                                return t;\n-                            }\n-                            u(di, \"joinClasses\");\n-                            var _t = u(function(e) {\n-                                e.select();\n-                            }, \"selectInput\");\n-                            Ut ? _t = u(function(e) {\n-                                e.selectionStart = 0, e.selectionEnd = e.value.length;\n-                            }, \"selectInput\") : O && (_t = u(function(e) {\n-                                try {\n-                                    e.select();\n-                                } catch {}\n-                            }, \"selectInput\"));\n+                        // might have found a valid shortcut link, disable reference parsing\n+                        parseReference = false;\n \n-                            function pi(e) {\n-                                var t = Array.prototype.slice.call(arguments, 1);\n-                                return function() {\n-                                    return e.apply(null, t);\n-                                };\n+                        // [link](  <href>  \"title\"  )\n+                        //        ^^ skipping these spaces\n+                        pos++;\n+                        for (; pos < max; pos++) {\n+                            code = state.src.charCodeAt(pos);\n+                            if (!isSpace(code) && code !== 0x0A) {\n+                                break;\n                             }\n-                            u(pi, \"bind\");\n+                        }\n+                        if (pos >= max) {\n+                            return false;\n+                        }\n \n-                            function nt(e, t, i) {\n-                                t || (t = {});\n-                                for (var r in e) e.hasOwnProperty(r) && (i !== !1 || !t.hasOwnProperty(r)) && (t[r] = e[r]);\n-                                return t;\n-                            }\n-                            u(nt, \"copyObj\");\n-\n-                            function xe(e, t, i, r, n) {\n-                                t == null && (t = e.search(/[^\\s\\u00a0]/), t == -1 && (t = e.length));\n-                                for (var l = r || 0, o = n || 0;;) {\n-                                    var a = e.indexOf(\"\t\", l);\n-                                    if (a < 0 || a >= t) return o + (t - l);\n-                                    o += a - l, o += i - o % i, l = a + 1;\n-                                }\n-                            }\n-                            u(xe, \"countColumn\");\n-                            var _e = u(function() {\n-                                this.id = null, this.f = null, this.time = 0, this.handler = pi(this.onTimeout, this);\n-                            }, \"Delayed\");\n-                            _e.prototype.onTimeout = function(e) {\n-                                e.id = 0, e.time <= +new Date() ? e.f() : setTimeout(e.handler, e.time - +new Date());\n-                            }, _e.prototype.set = function(e, t) {\n-                                this.f = t;\n-                                var i = +new Date() + e;\n-                                (!this.id || i < this.time) && (clearTimeout(this.id), this.id = setTimeout(this.handler, e), this.time = i);\n-                            };\n-\n-                            function ee(e, t) {\n-                                for (var i = 0; i < e.length; ++i)\n-                                    if (e[i] == t) return i;\n-                                return -1;\n+                        // [link](  <href>  \"title\"  )\n+                        //          ^^^^^^ parsing link destination\n+                        start = pos;\n+                        res = state.md.helpers.parseLinkDestination(state.src, pos, state.posMax);\n+                        if (res.ok) {\n+                            href = state.md.normalizeLink(res.str);\n+                            if (state.md.validateLink(href)) {\n+                                pos = res.pos;\n+                            } else {\n+                                href = '';\n                             }\n-                            u(ee, \"indexOf\");\n-                            var Wn = 50,\n-                                Nr = {\n-                                    toString: function() {\n-                                        return \"CodeMirror.Pass\";\n-                                    }\n-                                },\n-                                Me = {\n-                                    scroll: !1\n-                                },\n-                                vi = {\n-                                    origin: \"*mouse\"\n-                                },\n-                                Xt = {\n-                                    origin: \"+move\"\n-                                };\n \n-                            function gi(e, t, i) {\n-                                for (var r = 0, n = 0;;) {\n-                                    var l = e.indexOf(\"\t\", r);\n-                                    l == -1 && (l = e.length);\n-                                    var o = l - r;\n-                                    if (l == e.length || n + o >= t) return r + Math.min(o, t - n);\n-                                    if (n += l - r, n += i - n % i, r = l + 1, n >= t) return r;\n+                            // [link](  <href>  \"title\"  )\n+                            //                ^^ skipping these spaces\n+                            start = pos;\n+                            for (; pos < max; pos++) {\n+                                code = state.src.charCodeAt(pos);\n+                                if (!isSpace(code) && code !== 0x0A) {\n+                                    break;\n                                 }\n                             }\n-                            u(gi, \"findColumn\");\n-                            var Ar = [\"\"];\n \n-                            function yi(e) {\n-                                for (; Ar.length <= e;) Ar.push(H(Ar) + \" \");\n-                                return Ar[e];\n-                            }\n-                            u(yi, \"spaceStr\");\n+                            // [link](  <href>  \"title\"  )\n+                            //                  ^^^^^^^ parsing link title\n+                            res = state.md.helpers.parseLinkTitle(state.src, pos, state.posMax);\n+                            if (pos < max && start !== pos && res.ok) {\n+                                title = res.str;\n+                                pos = res.pos;\n \n-                            function H(e) {\n-                                return e[e.length - 1];\n+                                // [link](  <href>  \"title\"  )\n+                                //                         ^^ skipping these spaces\n+                                for (; pos < max; pos++) {\n+                                    code = state.src.charCodeAt(pos);\n+                                    if (!isSpace(code) && code !== 0x0A) {\n+                                        break;\n+                                    }\n+                                }\n                             }\n-                            u(H, \"lst\");\n-\n-                            function Or(e, t) {\n-                                for (var i = [], r = 0; r < e.length; r++) i[r] = t(e[r], r);\n-                                return i;\n+                        }\n+                        if (pos >= max || state.src.charCodeAt(pos) !== 0x29 /* ) */ ) {\n+                            // parsing a valid shortcut link failed, fallback to reference\n+                            parseReference = true;\n+                        }\n+                        pos++;\n+                    }\n+                    if (parseReference) {\n+                        //\n+                        // Link reference\n+                        //\n+                        if (typeof state.env.references === 'undefined') {\n+                            return false;\n+                        }\n+                        if (pos < max && state.src.charCodeAt(pos) === 0x5B /* [ */ ) {\n+                            start = pos + 1;\n+                            pos = state.md.helpers.parseLinkLabel(state, pos);\n+                            if (pos >= 0) {\n+                                label = state.src.slice(start, pos++);\n+                            } else {\n+                                pos = labelEnd + 1;\n                             }\n-                            u(Or, \"map\");\n+                        } else {\n+                            pos = labelEnd + 1;\n+                        }\n \n-                            function Qo(e, t, i) {\n-                                for (var r = 0, n = i(t); r < e.length && i(e[r]) <= n;) r++;\n-                                e.splice(r, 0, t);\n-                            }\n-                            u(Qo, \"insertSorted\");\n+                        // covers label === '' and label === undefined\n+                        // (collapsed reference link and shortcut reference link respectively)\n+                        if (!label) {\n+                            label = state.src.slice(labelStart, labelEnd);\n+                        }\n+                        ref = state.env.references[normalizeReference(label)];\n+                        if (!ref) {\n+                            state.pos = oldPos;\n+                            return false;\n+                        }\n+                        href = ref.href;\n+                        title = ref.title;\n+                    }\n \n-                            function Hn() {}\n-                            u(Hn, \"nothing\");\n+                    //\n+                    // We found the end of the link, and know for a fact it's a valid link;\n+                    // so all that's left to do is to call tokenizer.\n+                    //\n+                    if (!silent) {\n+                        state.pos = labelStart;\n+                        state.posMax = labelEnd;\n+                        const token_o = state.push('link_open', 'a', 1);\n+                        const attrs = [\n+                            ['href', href]\n+                        ];\n+                        token_o.attrs = attrs;\n+                        if (title) {\n+                            attrs.push(['title', title]);\n+                        }\n+                        state.linkLevel++;\n+                        state.md.inline.tokenize(state);\n+                        state.linkLevel--;\n+                        state.push('link_close', 'a', -1);\n+                    }\n+                    state.pos = pos;\n+                    state.posMax = max;\n+                    return true;\n+                }\n \n-                            function Fn(e, t) {\n-                                var i;\n-                                return Object.create ? i = Object.create(e) : (Hn.prototype = e, i = new Hn()), t && nt(t, i), i;\n-                            }\n-                            u(Fn, \"createObj\");\n-                            var Jo = /[\\u00df\\u0587\\u0590-\\u05f4\\u0600-\\u06ff\\u3040-\\u309f\\u30a0-\\u30ff\\u3400-\\u4db5\\u4e00-\\u9fcc\\uac00-\\ud7af]/;\n+                // Process ![image](<src> \"title\")\n \n-                            function mi(e) {\n-                                return /\\w/.test(e) || e > \"\u0080\" && (e.toUpperCase() != e.toLowerCase() || Jo.test(e));\n-                            }\n-                            u(mi, \"isWordCharBasic\");\n+                function image(state, silent) {\n+                    let code, content, label, pos, ref, res, title, start;\n+                    let href = '';\n+                    const oldPos = state.pos;\n+                    const max = state.posMax;\n+                    if (state.src.charCodeAt(state.pos) !== 0x21 /* ! */ ) {\n+                        return false;\n+                    }\n+                    if (state.src.charCodeAt(state.pos + 1) !== 0x5B /* [ */ ) {\n+                        return false;\n+                    }\n+                    const labelStart = state.pos + 2;\n+                    const labelEnd = state.md.helpers.parseLinkLabel(state, state.pos + 1, false);\n \n-                            function Wr(e, t) {\n-                                return t ? t.source.indexOf(\"\\\\w\") > -1 && mi(e) ? !0 : t.test(e) : mi(e);\n-                            }\n-                            u(Wr, \"isWordChar\");\n+                    // parser failed to find ']', so it's not a valid link\n+                    if (labelEnd < 0) {\n+                        return false;\n+                    }\n+                    pos = labelEnd + 1;\n+                    if (pos < max && state.src.charCodeAt(pos) === 0x28 /* ( */ ) {\n+                        //\n+                        // Inline link\n+                        //\n \n-                            function Pn(e) {\n-                                for (var t in e)\n-                                    if (e.hasOwnProperty(t) && e[t]) return !1;\n-                                return !0;\n+                        // [link](  <href>  \"title\"  )\n+                        //        ^^ skipping these spaces\n+                        pos++;\n+                        for (; pos < max; pos++) {\n+                            code = state.src.charCodeAt(pos);\n+                            if (!isSpace(code) && code !== 0x0A) {\n+                                break;\n                             }\n-                            u(Pn, \"isEmpty\");\n-                            var jo = /[\\u0300-\\u036f\\u0483-\\u0489\\u0591-\\u05bd\\u05bf\\u05c1\\u05c2\\u05c4\\u05c5\\u05c7\\u0610-\\u061a\\u064b-\\u065e\\u0670\\u06d6-\\u06dc\\u06de-\\u06e4\\u06e7\\u06e8\\u06ea-\\u06ed\\u0711\\u0730-\\u074a\\u07a6-\\u07b0\\u07eb-\\u07f3\\u0816-\\u0819\\u081b-\\u0823\\u0825-\\u0827\\u0829-\\u082d\\u0900-\\u0902\\u093c\\u0941-\\u0948\\u094d\\u0951-\\u0955\\u0962\\u0963\\u0981\\u09bc\\u09be\\u09c1-\\u09c4\\u09cd\\u09d7\\u09e2\\u09e3\\u0a01\\u0a02\\u0a3c\\u0a41\\u0a42\\u0a47\\u0a48\\u0a4b-\\u0a4d\\u0a51\\u0a70\\u0a71\\u0a75\\u0a81\\u0a82\\u0abc\\u0ac1-\\u0ac5\\u0ac7\\u0ac8\\u0acd\\u0ae2\\u0ae3\\u0b01\\u0b3c\\u0b3e\\u0b3f\\u0b41-\\u0b44\\u0b4d\\u0b56\\u0b57\\u0b62\\u0b63\\u0b82\\u0bbe\\u0bc0\\u0bcd\\u0bd7\\u0c3e-\\u0c40\\u0c46-\\u0c48\\u0c4a-\\u0c4d\\u0c55\\u0c56\\u0c62\\u0c63\\u0cbc\\u0cbf\\u0cc2\\u0cc6\\u0ccc\\u0ccd\\u0cd5\\u0cd6\\u0ce2\\u0ce3\\u0d3e\\u0d41-\\u0d44\\u0d4d\\u0d57\\u0d62\\u0d63\\u0dca\\u0dcf\\u0dd2-\\u0dd4\\u0dd6\\u0ddf\\u0e31\\u0e34-\\u0e3a\\u0e47-\\u0e4e\\u0eb1\\u0eb4-\\u0eb9\\u0ebb\\u0ebc\\u0ec8-\\u0ecd\\u0f18\\u0f19\\u0f35\\u0f37\\u0f39\\u0f71-\\u0f7e\\u0f80-\\u0f84\\u0f86\\u0f87\\u0f90-\\u0f97\\u0f99-\\u0fbc\\u0fc6\\u102d-\\u1030\\u1032-\\u1037\\u1039\\u103a\\u103d\\u103e\\u1058\\u1059\\u105e-\\u1060\\u1071-\\u1074\\u1082\\u1085\\u1086\\u108d\\u109d\\u135f\\u1712-\\u1714\\u1732-\\u1734\\u1752\\u1753\\u1772\\u1773\\u17b7-\\u17bd\\u17c6\\u17c9-\\u17d3\\u17dd\\u180b-\\u180d\\u18a9\\u1920-\\u1922\\u1927\\u1928\\u1932\\u1939-\\u193b\\u1a17\\u1a18\\u1a56\\u1a58-\\u1a5e\\u1a60\\u1a62\\u1a65-\\u1a6c\\u1a73-\\u1a7c\\u1a7f\\u1b00-\\u1b03\\u1b34\\u1b36-\\u1b3a\\u1b3c\\u1b42\\u1b6b-\\u1b73\\u1b80\\u1b81\\u1ba2-\\u1ba5\\u1ba8\\u1ba9\\u1c2c-\\u1c33\\u1c36\\u1c37\\u1cd0-\\u1cd2\\u1cd4-\\u1ce0\\u1ce2-\\u1ce8\\u1ced\\u1dc0-\\u1de6\\u1dfd-\\u1dff\\u200c\\u200d\\u20d0-\\u20f0\\u2cef-\\u2cf1\\u2de0-\\u2dff\\u302a-\\u302f\\u3099\\u309a\\ua66f-\\ua672\\ua67c\\ua67d\\ua6f0\\ua6f1\\ua802\\ua806\\ua80b\\ua825\\ua826\\ua8c4\\ua8e0-\\ua8f1\\ua926-\\ua92d\\ua947-\\ua951\\ua980-\\ua982\\ua9b3\\ua9b6-\\ua9b9\\ua9bc\\uaa29-\\uaa2e\\uaa31\\uaa32\\uaa35\\uaa36\\uaa43\\uaa4c\\uaab0\\uaab2-\\uaab4\\uaab7\\uaab8\\uaabe\\uaabf\\uaac1\\uabe5\\uabe8\\uabed\\udc00-\\udfff\\ufb1e\\ufe00-\\ufe0f\\ufe20-\\ufe26\\uff9e\\uff9f]/;\n+                        }\n+                        if (pos >= max) {\n+                            return false;\n+                        }\n \n-                            function bi(e) {\n-                                return e.charCodeAt(0) >= 768 && jo.test(e);\n+                        // [link](  <href>  \"title\"  )\n+                        //          ^^^^^^ parsing link destination\n+                        start = pos;\n+                        res = state.md.helpers.parseLinkDestination(state.src, pos, state.posMax);\n+                        if (res.ok) {\n+                            href = state.md.normalizeLink(res.str);\n+                            if (state.md.validateLink(href)) {\n+                                pos = res.pos;\n+                            } else {\n+                                href = '';\n                             }\n-                            u(bi, \"isExtendingChar\");\n+                        }\n \n-                            function En(e, t, i) {\n-                                for (;\n-                                    (i < 0 ? t > 0 : t < e.length) && bi(e.charAt(t));) t += i;\n-                                return t;\n+                        // [link](  <href>  \"title\"  )\n+                        //                ^^ skipping these spaces\n+                        start = pos;\n+                        for (; pos < max; pos++) {\n+                            code = state.src.charCodeAt(pos);\n+                            if (!isSpace(code) && code !== 0x0A) {\n+                                break;\n                             }\n-                            u(En, \"skipExtendingChars\");\n+                        }\n \n-                            function Yt(e, t, i) {\n-                                for (var r = t > i ? -1 : 1;;) {\n-                                    if (t == i) return t;\n-                                    var n = (t + i) / 2,\n-                                        l = r < 0 ? Math.ceil(n) : Math.floor(n);\n-                                    if (l == t) return e(l) ? t : i;\n-                                    e(l) ? i = l : t = l + r;\n-                                }\n-                            }\n-                            u(Yt, \"findFirst\");\n+                        // [link](  <href>  \"title\"  )\n+                        //                  ^^^^^^^ parsing link title\n+                        res = state.md.helpers.parseLinkTitle(state.src, pos, state.posMax);\n+                        if (pos < max && start !== pos && res.ok) {\n+                            title = res.str;\n+                            pos = res.pos;\n \n-                            function Vo(e, t, i, r) {\n-                                if (!e) return r(t, i, \"ltr\", 0);\n-                                for (var n = !1, l = 0; l < e.length; ++l) {\n-                                    var o = e[l];\n-                                    (o.from < i && o.to > t || t == i && o.to == t) && (r(Math.max(o.from, t), Math.min(o.to, i), o.level == 1 ? \"rtl\" : \"ltr\", l), n = !0);\n+                            // [link](  <href>  \"title\"  )\n+                            //                         ^^ skipping these spaces\n+                            for (; pos < max; pos++) {\n+                                code = state.src.charCodeAt(pos);\n+                                if (!isSpace(code) && code !== 0x0A) {\n+                                    break;\n                                 }\n-                                n || r(t, i, \"ltr\");\n                             }\n-                            u(Vo, \"iterateBidiSections\");\n-                            var qt = null;\n-\n-                            function Zt(e, t, i) {\n-                                var _r2;\n-                                var r;\n-                                qt = null;\n-                                for (var n = 0; n < e.length; ++n) {\n-                                    var l = e[n];\n-                                    if (l.from < t && l.to > t) return n;\n-                                    l.to == t && (l.from != l.to && i == \"before\" ? r = n : qt = n), l.from == t && (l.from != l.to && i != \"before\" ? r = n : qt = n);\n-                                }\n-                                return (_r2 = r) !== null && _r2 !== void 0 ? _r2 : qt;\n+                        } else {\n+                            title = '';\n+                        }\n+                        if (pos >= max || state.src.charCodeAt(pos) !== 0x29 /* ) */ ) {\n+                            state.pos = oldPos;\n+                            return false;\n+                        }\n+                        pos++;\n+                    } else {\n+                        //\n+                        // Link reference\n+                        //\n+                        if (typeof state.env.references === 'undefined') {\n+                            return false;\n+                        }\n+                        if (pos < max && state.src.charCodeAt(pos) === 0x5B /* [ */ ) {\n+                            start = pos + 1;\n+                            pos = state.md.helpers.parseLinkLabel(state, pos);\n+                            if (pos >= 0) {\n+                                label = state.src.slice(start, pos++);\n+                            } else {\n+                                pos = labelEnd + 1;\n                             }\n-                            u(Zt, \"getBidiPartAt\");\n-                            var $o = function() {\n-                                var e = \"bbbbbbbbbtstwsbbbbbbbbbbbbbbssstwNN%%%NNNNNN,N,N1111111111NNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNbbbbbbsbbbbbbbbbbbbbbbbbbbbbbbbbb,N%%%%NNNNLNNNNN%%11NLNNN1LNNNNNLLLLLLLLLLLLLLLLLLLLLLLNLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLN\",\n-                                    t = \"nnnnnnNNr%%r,rNNmmmmmmmmmmmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmmmmmmmmmmmmmmmnnnnnnnnnn%nnrrrmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmnNmmmmmmrrmmNmmmmrr1111111111\";\n+                        } else {\n+                            pos = labelEnd + 1;\n+                        }\n \n-                                function i(f) {\n-                                    return f <= 247 ? e.charAt(f) : 1424 <= f && f <= 1524 ? \"R\" : 1536 <= f && f <= 1785 ? t.charAt(f - 1536) : 1774 <= f && f <= 2220 ? \"r\" : 8192 <= f && f <= 8203 ? \"w\" : f == 8204 ? \"b\" : \"L\";\n-                                }\n-                                u(i, \"charType\");\n-                                var r = /[\\u0590-\\u05f4\\u0600-\\u06ff\\u0700-\\u08ac]/,\n-                                    n = /[stwN]/,\n-                                    l = /[LRr]/,\n-                                    o = /[Lb1n]/,\n-                                    a = /[1n]/;\n+                        // covers label === '' and label === undefined\n+                        // (collapsed reference link and shortcut reference link respectively)\n+                        if (!label) {\n+                            label = state.src.slice(labelStart, labelEnd);\n+                        }\n+                        ref = state.env.references[normalizeReference(label)];\n+                        if (!ref) {\n+                            state.pos = oldPos;\n+                            return false;\n+                        }\n+                        href = ref.href;\n+                        title = ref.title;\n+                    }\n \n-                                function s(f, h, c) {\n-                                    this.level = f, this.from = h, this.to = c;\n-                                }\n-                                return u(s, \"BidiSpan\"),\n-                                    function(f, h) {\n-                                        var c = h == \"ltr\" ? \"L\" : \"R\";\n-                                        if (f.length == 0 || h == \"ltr\" && !r.test(f)) return !1;\n-                                        for (var p = f.length, d = [], v = 0; v < p; ++v) d.push(i(f.charCodeAt(v)));\n-                                        for (var g = 0, m = c; g < p; ++g) {\n-                                            var b = d[g];\n-                                            b == \"m\" ? d[g] = m : m = b;\n-                                        }\n-                                        for (var C = 0, x = c; C < p; ++C) {\n-                                            var w = d[C];\n-                                            w == \"1\" && x == \"r\" ? d[C] = \"n\" : l.test(w) && (x = w, w == \"r\" && (d[C] = \"R\"));\n-                                        }\n-                                        for (var k = 1, L = d[0]; k < p - 1; ++k) {\n-                                            var A = d[k];\n-                                            A == \"+\" && L == \"1\" && d[k + 1] == \"1\" ? d[k] = \"1\" : A == \",\" && L == d[k + 1] && (L == \"1\" || L == \"n\") && (d[k] = L), L = A;\n-                                        }\n-                                        for (var E = 0; E < p; ++E) {\n-                                            var j = d[E];\n-                                            if (j == \",\") d[E] = \"N\";\n-                                            else if (j == \"%\") {\n-                                                var B = void 0;\n-                                                for (B = E + 1; B < p && d[B] == \"%\"; ++B);\n-                                                for (var pe = E && d[E - 1] == \"!\" || B < p && d[B] == \"1\" ? \"1\" : \"N\", fe = E; fe < B; ++fe) d[fe] = pe;\n-                                                E = B - 1;\n-                                            }\n-                                        }\n-                                        for (var _ = 0, he = c; _ < p; ++_) {\n-                                            var $ = d[_];\n-                                            he == \"L\" && $ == \"1\" ? d[_] = \"L\" : l.test($) && (he = $);\n-                                        }\n-                                        for (var Y = 0; Y < p; ++Y)\n-                                            if (n.test(d[Y])) {\n-                                                var X = void 0;\n-                                                for (X = Y + 1; X < p && n.test(d[X]); ++X);\n-                                                for (var z = (Y ? d[Y - 1] : c) == \"L\", ce = (X < p ? d[X] : c) == \"L\", zt = z == ce ? z ? \"L\" : \"R\" : c, $e = Y; $e < X; ++$e) d[$e] = zt;\n-                                                Y = X - 1;\n-                                            }\n-                                        for (var re = [], We, V = 0; V < p;)\n-                                            if (o.test(d[V])) {\n-                                                var kn = V;\n-                                                for (++V; V < p && o.test(d[V]); ++V);\n-                                                re.push(new s(0, kn, V));\n-                                            } else {\n-                                                var Ge = V,\n-                                                    gt = re.length,\n-                                                    yt = h == \"rtl\" ? 1 : 0;\n-                                                for (++V; V < p && d[V] != \"L\"; ++V);\n-                                                for (var oe = Ge; oe < V;)\n-                                                    if (a.test(d[oe])) {\n-                                                        Ge < oe && (re.splice(gt, 0, new s(1, Ge, oe)), gt += yt);\n-                                                        var Gt = oe;\n-                                                        for (++oe; oe < V && a.test(d[oe]); ++oe);\n-                                                        re.splice(gt, 0, new s(2, Gt, oe)), gt += yt, Ge = oe;\n-                                                    } else ++oe;\n-                                                Ge < V && re.splice(gt, 0, new s(1, Ge, V));\n-                                            }\n-                                        return h == \"ltr\" && (re[0].level == 1 && (We = f.match(/^\\s+/)) && (re[0].from = We[0].length, re.unshift(new s(0, 0, We[0].length))), H(re).level == 1 && (We = f.match(/\\s+$/)) && (H(re).to -= We[0].length, re.push(new s(0, p - We[0].length, p)))), h == \"rtl\" ? re.reverse() : re;\n-                                    };\n-                            }();\n+                    //\n+                    // We found the end of the link, and know for a fact it's a valid link;\n+                    // so all that's left to do is to call tokenizer.\n+                    //\n+                    if (!silent) {\n+                        content = state.src.slice(labelStart, labelEnd);\n+                        const tokens = [];\n+                        state.md.inline.parse(content, state.md, state.env, tokens);\n+                        const token = state.push('image', 'img', 0);\n+                        const attrs = [\n+                            ['src', href],\n+                            ['alt', '']\n+                        ];\n+                        token.attrs = attrs;\n+                        token.children = tokens;\n+                        token.content = content;\n+                        if (title) {\n+                            attrs.push(['title', title]);\n+                        }\n+                    }\n+                    state.pos = pos;\n+                    state.posMax = max;\n+                    return true;\n+                }\n \n-                            function Pe(e, t) {\n-                                var i = e.order;\n-                                return i == null && (i = e.order = $o(e.text, t)), i;\n-                            }\n-                            u(Pe, \"getOrder\");\n-                            var In = [],\n-                                M = u(function(e, t, i) {\n-                                    if (e.addEventListener) e.addEventListener(t, i, !1);\n-                                    else if (e.attachEvent) e.attachEvent(\"on\" + t, i);\n-                                    else {\n-                                        var r = e._handlers || (e._handlers = {});\n-                                        r[t] = (r[t] || In).concat(i);\n-                                    }\n-                                }, \"on\");\n-\n-                            function xi(e, t) {\n-                                return e._handlers && e._handlers[t] || In;\n-                            }\n-                            u(xi, \"getHandlers\");\n-\n-                            function ge(e, t, i) {\n-                                if (e.removeEventListener) e.removeEventListener(t, i, !1);\n-                                else if (e.detachEvent) e.detachEvent(\"on\" + t, i);\n-                                else {\n-                                    var r = e._handlers,\n-                                        n = r && r[t];\n-                                    if (n) {\n-                                        var l = ee(n, i);\n-                                        l > -1 && (r[t] = n.slice(0, l).concat(n.slice(l + 1)));\n-                                    }\n-                                }\n-                            }\n-                            u(ge, \"off\");\n+                // Process autolinks '<protocol:...>'\n \n-                            function U(e, t) {\n-                                var i = xi(e, t);\n-                                if (i.length)\n-                                    for (var r = Array.prototype.slice.call(arguments, 2), n = 0; n < i.length; ++n) i[n].apply(null, r);\n-                            }\n-                            u(U, \"signal\");\n+                /* eslint max-len:0 */\n+                const EMAIL_RE = /^([a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*)$/;\n+                /* eslint-disable-next-line no-control-regex */\n+                const AUTOLINK_RE = /^([a-zA-Z][a-zA-Z0-9+.-]{1,31}):([^<>\\x00-\\x20]*)$/;\n \n-                            function q(e, t, i) {\n-                                return typeof t == \"string\" && (t = {\n-                                    type: t,\n-                                    preventDefault: function() {\n-                                        this.defaultPrevented = !0;\n-                                    }\n-                                }), U(e, i || t.type, e, t), Ci(t) || t.codemirrorIgnore;\n-                            }\n-                            u(q, \"signalDOMEvent\");\n+                function autolink(state, silent) {\n+                    let pos = state.pos;\n+                    if (state.src.charCodeAt(pos) !== 0x3C /* < */ ) {\n+                        return false;\n+                    }\n+                    const start = state.pos;\n+                    const max = state.posMax;\n+                    for (;;) {\n+                        if (++pos >= max) return false;\n+                        const ch = state.src.charCodeAt(pos);\n+                        if (ch === 0x3C /* < */ ) return false;\n+                        if (ch === 0x3E /* > */ ) break;\n+                    }\n+                    const url = state.src.slice(start + 1, pos);\n+                    if (AUTOLINK_RE.test(url)) {\n+                        const fullUrl = state.md.normalizeLink(url);\n+                        if (!state.md.validateLink(fullUrl)) {\n+                            return false;\n+                        }\n+                        if (!silent) {\n+                            const token_o = state.push('link_open', 'a', 1);\n+                            token_o.attrs = [\n+                                ['href', fullUrl]\n+                            ];\n+                            token_o.markup = 'autolink';\n+                            token_o.info = 'auto';\n+                            const token_t = state.push('text', '', 0);\n+                            token_t.content = state.md.normalizeLinkText(url);\n+                            const token_c = state.push('link_close', 'a', -1);\n+                            token_c.markup = 'autolink';\n+                            token_c.info = 'auto';\n+                        }\n+                        state.pos += url.length + 2;\n+                        return true;\n+                    }\n+                    if (EMAIL_RE.test(url)) {\n+                        const fullUrl = state.md.normalizeLink('mailto:' + url);\n+                        if (!state.md.validateLink(fullUrl)) {\n+                            return false;\n+                        }\n+                        if (!silent) {\n+                            const token_o = state.push('link_open', 'a', 1);\n+                            token_o.attrs = [\n+                                ['href', fullUrl]\n+                            ];\n+                            token_o.markup = 'autolink';\n+                            token_o.info = 'auto';\n+                            const token_t = state.push('text', '', 0);\n+                            token_t.content = state.md.normalizeLinkText(url);\n+                            const token_c = state.push('link_close', 'a', -1);\n+                            token_c.markup = 'autolink';\n+                            token_c.info = 'auto';\n+                        }\n+                        state.pos += url.length + 2;\n+                        return true;\n+                    }\n+                    return false;\n+                }\n \n-                            function Rn(e) {\n-                                var t = e._handlers && e._handlers.cursorActivity;\n-                                if (t)\n-                                    for (var i = e.curOp.cursorActivityHandlers || (e.curOp.cursorActivityHandlers = []), r = 0; r < t.length; ++r) ee(i, t[r]) == -1 && i.push(t[r]);\n-                            }\n-                            u(Rn, \"signalCursorActivity\");\n+                // Process html tags\n \n-                            function Ce(e, t) {\n-                                return xi(e, t).length > 0;\n-                            }\n-                            u(Ce, \"hasHandler\");\n+                function isLinkOpen(str) {\n+                    return /^<a[>\\s]/i.test(str);\n+                }\n \n-                            function xt(e) {\n-                                e.prototype.on = function(t, i) {\n-                                    M(this, t, i);\n-                                }, e.prototype.off = function(t, i) {\n-                                    ge(this, t, i);\n-                                };\n-                            }\n-                            u(xt, \"eventMixin\");\n+                function isLinkClose(str) {\n+                    return /^<\\/a\\s*>/i.test(str);\n+                }\n \n-                            function ae(e) {\n-                                e.preventDefault ? e.preventDefault() : e.returnValue = !1;\n-                            }\n-                            u(ae, \"e_preventDefault\");\n+                function isLetter(ch) {\n+                    /* eslint no-bitwise:0 */\n+                    const lc = ch | 0x20; // to lower case\n+                    return lc >= 0x61 /* a */ && lc <= 0x7a /* z */ ;\n+                }\n \n-                            function Bn(e) {\n-                                e.stopPropagation ? e.stopPropagation() : e.cancelBubble = !0;\n-                            }\n-                            u(Bn, \"e_stopPropagation\");\n+                function html_inline(state, silent) {\n+                    if (!state.md.options.html) {\n+                        return false;\n+                    }\n \n-                            function Ci(e) {\n-                                return e.defaultPrevented != null ? e.defaultPrevented : e.returnValue == !1;\n-                            }\n-                            u(Ci, \"e_defaultPrevented\");\n+                    // Check start\n+                    const max = state.posMax;\n+                    const pos = state.pos;\n+                    if (state.src.charCodeAt(pos) !== 0x3C /* < */ || pos + 2 >= max) {\n+                        return false;\n+                    }\n \n-                            function Qt(e) {\n-                                ae(e), Bn(e);\n-                            }\n-                            u(Qt, \"e_stop\");\n+                    // Quick fail on second char\n+                    const ch = state.src.charCodeAt(pos + 1);\n+                    if (ch !== 0x21 /* ! */ && ch !== 0x3F /* ? */ && ch !== 0x2F /* / */ && !isLetter(ch)) {\n+                        return false;\n+                    }\n+                    const match = state.src.slice(pos).match(HTML_TAG_RE);\n+                    if (!match) {\n+                        return false;\n+                    }\n+                    if (!silent) {\n+                        const token = state.push('html_inline', '', 0);\n+                        token.content = match[0];\n+                        if (isLinkOpen(token.content)) state.linkLevel++;\n+                        if (isLinkClose(token.content)) state.linkLevel--;\n+                    }\n+                    state.pos += match[0].length;\n+                    return true;\n+                }\n \n-                            function wi(e) {\n-                                return e.target || e.srcElement;\n-                            }\n-                            u(wi, \"e_target\");\n+                // Process html entity - &#123;, &#xAF;, &quot;, ...\n \n-                            function zn(e) {\n-                                var t = e.which;\n-                                return t == null && (e.button & 1 ? t = 1 : e.button & 2 ? t = 3 : e.button & 4 && (t = 2)), me && e.ctrlKey && t == 1 && (t = 3), t;\n-                            }\n-                            u(zn, \"e_button\");\n-                            var ea = function() {\n-                                    if (O && I < 9) return !1;\n-                                    var e = T(\"div\");\n-                                    return \"draggable\" in e || \"dragDrop\" in e;\n-                                }(),\n-                                Si;\n+                const DIGITAL_RE = /^&#((?:x[a-f0-9]{1,6}|[0-9]{1,7}));/i;\n+                const NAMED_RE = /^&([a-z][a-z0-9]{1,31});/i;\n \n-                            function ta(e) {\n-                                if (Si == null) {\n-                                    var t = T(\"span\", \"\u200b\");\n-                                    ve(e, T(\"span\", [t, document.createTextNode(\"x\")])), e.firstChild.offsetHeight != 0 && (Si = t.offsetWidth <= 1 && t.offsetHeight > 2 && !(O && I < 8));\n+                function entity(state, silent) {\n+                    const pos = state.pos;\n+                    const max = state.posMax;\n+                    if (state.src.charCodeAt(pos) !== 0x26 /* & */ ) return false;\n+                    if (pos + 1 >= max) return false;\n+                    const ch = state.src.charCodeAt(pos + 1);\n+                    if (ch === 0x23 /* # */ ) {\n+                        const match = state.src.slice(pos).match(DIGITAL_RE);\n+                        if (match) {\n+                            if (!silent) {\n+                                const code = match[1][0].toLowerCase() === 'x' ? parseInt(match[1].slice(1), 16) : parseInt(match[1], 10);\n+                                const token = state.push('text_special', '', 0);\n+                                token.content = isValidEntityCode(code) ? fromCodePoint(code) : fromCodePoint(0xFFFD);\n+                                token.markup = match[0];\n+                                token.info = 'entity';\n+                            }\n+                            state.pos += match[0].length;\n+                            return true;\n+                        }\n+                    } else {\n+                        const match = state.src.slice(pos).match(NAMED_RE);\n+                        if (match) {\n+                            const decoded = entities.decodeHTML(match[0]);\n+                            if (decoded !== match[0]) {\n+                                if (!silent) {\n+                                    const token = state.push('text_special', '', 0);\n+                                    token.content = decoded;\n+                                    token.markup = match[0];\n+                                    token.info = 'entity';\n                                 }\n-                                var i = Si ? T(\"span\", \"\u200b\") : T(\"span\", \"\u00a0\", null, \"display: inline-block; width: 1px; margin-right: -1px\");\n-                                return i.setAttribute(\"cm-text\", \"\"), i;\n+                                state.pos += match[0].length;\n+                                return true;\n                             }\n-                            u(ta, \"zeroWidthElement\");\n-                            var Li;\n+                        }\n+                    }\n+                    return false;\n+                }\n \n-                            function ra(e) {\n-                                if (Li != null) return Li;\n-                                var t = ve(e, document.createTextNode(\"A\u062eA\")),\n-                                    i = rt(t, 0, 1).getBoundingClientRect(),\n-                                    r = rt(t, 1, 2).getBoundingClientRect();\n-                                return Ue(e), !i || i.left == i.right ? !1 : Li = r.right - i.right < 3;\n-                            }\n-                            u(ra, \"hasBadBidiRects\");\n-                            var ki = `\n+                // For each opening emphasis-like marker find a matching closing one\n+                //\n \n-b`.split(/\\n/).length != 3 ? function(e) {\n-                                    for (var t = 0, i = [], r = e.length; t <= r;) {\n-                                        var n = e.indexOf(`\n-`, t);\n-                                        n == -1 && (n = e.length);\n-                                        var l = e.slice(t, e.charAt(n - 1) == \"\\r\" ? n - 1 : n),\n-                                            o = l.indexOf(\"\\r\");\n-                                        o != -1 ? (i.push(l.slice(0, o)), t += o + 1) : (i.push(l), t = n + 1);\n-                                    }\n-                                    return i;\n-                                } : function(e) {\n-                                    return e.split(/\\r\\n?|\\n/);\n-                                },\n-                                ia = window.getSelection ? function(e) {\n-                                    try {\n-                                        return e.selectionStart != e.selectionEnd;\n-                                    } catch {\n-                                        return !1;\n-                                    }\n-                                } : function(e) {\n-                                    var t;\n-                                    try {\n-                                        t = e.ownerDocument.selection.createRange();\n-                                    } catch {}\n-                                    return !t || t.parentElement() != e ? !1 : t.compareEndPoints(\"StartToEnd\", t) != 0;\n-                                },\n-                                na = function() {\n-                                    var e = T(\"div\");\n-                                    return \"oncopy\" in e ? !0 : (e.setAttribute(\"oncopy\", \"return;\"), typeof e.oncopy == \"function\");\n-                                }(),\n-                                Ti = null;\n-\n-                            function la(e) {\n-                                if (Ti != null) return Ti;\n-                                var t = ve(e, T(\"span\", \"x\")),\n-                                    i = t.getBoundingClientRect(),\n-                                    r = rt(t, 0, 1).getBoundingClientRect();\n-                                return Ti = Math.abs(i.left - r.left) > 1;\n-                            }\n-                            u(la, \"hasBadZoomedRects\");\n-                            var Mi = {},\n-                                Ct = {};\n-\n-                            function oa(e, t) {\n-                                arguments.length > 2 && (t.dependencies = Array.prototype.slice.call(arguments, 2)), Mi[e] = t;\n-                            }\n-                            u(oa, \"defineMode\");\n-\n-                            function aa(e, t) {\n-                                Ct[e] = t;\n-                            }\n-                            u(aa, \"defineMIME\");\n-\n-                            function Hr(e) {\n-                                if (typeof e == \"string\" && Ct.hasOwnProperty(e)) e = Ct[e];\n-                                else if (e && typeof e.name == \"string\" && Ct.hasOwnProperty(e.name)) {\n-                                    var t = Ct[e.name];\n-                                    typeof t == \"string\" && (t = {\n-                                        name: t\n-                                    }), e = Fn(t, e), e.name = t.name;\n-                                } else {\n-                                    if (typeof e == \"string\" && /^[\\w\\-]+\\/[\\w\\-]+\\+xml$/.test(e)) return Hr(\"application/xml\");\n-                                    if (typeof e == \"string\" && /^[\\w\\-]+\\/[\\w\\-]+\\+json$/.test(e)) return Hr(\"application/json\");\n-                                }\n-                                return typeof e == \"string\" ? {\n-                                    name: e\n-                                } : e || {\n-                                    name: \"null\"\n-                                };\n-                            }\n-                            u(Hr, \"resolveMode\");\n+                function processDelimiters(delimiters) {\n+                    const openersBottom = {};\n+                    const max = delimiters.length;\n+                    if (!max) return;\n \n-                            function Di(e, t) {\n-                                t = Hr(t);\n-                                var i = Mi[t.name];\n-                                if (!i) return Di(e, \"text/plain\");\n-                                var r = i(e, t);\n-                                if (wt.hasOwnProperty(t.name)) {\n-                                    var n = wt[t.name];\n-                                    for (var l in n) n.hasOwnProperty(l) && (r.hasOwnProperty(l) && (r[\"_\" + l] = r[l]), r[l] = n[l]);\n-                                }\n-                                if (r.name = t.name, t.helperType && (r.helperType = t.helperType), t.modeProps)\n-                                    for (var o in t.modeProps) r[o] = t.modeProps[o];\n-                                return r;\n-                            }\n-                            u(Di, \"getMode\");\n-                            var wt = {};\n+                    // headerIdx is the first delimiter of the current (where closer is) delimiter run\n+                    let headerIdx = 0;\n+                    let lastTokenIdx = -2; // needs any value lower than -1\n+                    const jumps = [];\n+                    for (let closerIdx = 0; closerIdx < max; closerIdx++) {\n+                        const closer = delimiters[closerIdx];\n+                        jumps.push(0);\n \n-                            function sa(e, t) {\n-                                var i = wt.hasOwnProperty(e) ? wt[e] : wt[e] = {};\n-                                nt(t, i);\n-                            }\n-                            u(sa, \"extendMode\");\n-\n-                            function lt(e, t) {\n-                                if (t === !0) return t;\n-                                if (e.copyState) return e.copyState(t);\n-                                var i = {};\n-                                for (var r in t) {\n-                                    var n = t[r];\n-                                    n instanceof Array && (n = n.concat([])), i[r] = n;\n-                                }\n-                                return i;\n-                            }\n-                            u(lt, \"copyState\");\n+                        // markers belong to same delimiter run if:\n+                        //  - they have adjacent tokens\n+                        //  - AND markers are the same\n+                        //\n+                        if (delimiters[headerIdx].marker !== closer.marker || lastTokenIdx !== closer.token - 1) {\n+                            headerIdx = closerIdx;\n+                        }\n+                        lastTokenIdx = closer.token;\n \n-                            function Ni(e, t) {\n-                                for (var i; e.innerMode && (i = e.innerMode(t), !(!i || i.mode == e));) t = i.state, e = i.mode;\n-                                return i || {\n-                                    mode: e,\n-                                    state: t\n-                                };\n-                            }\n-                            u(Ni, \"innerMode\");\n+                        // Length is only used for emphasis-specific \"rule of 3\",\n+                        // if it's not defined (in strikethrough or 3rd party plugins),\n+                        // we can default it to 0 to disable those checks.\n+                        //\n+                        closer.length = closer.length || 0;\n+                        if (!closer.close) continue;\n \n-                            function Gn(e, t, i) {\n-                                return e.startState ? e.startState(t, i) : !0;\n-                            }\n-                            u(Gn, \"startState\");\n-                            var K = u(function(e, t, i) {\n-                                this.pos = this.start = 0, this.string = e, this.tabSize = t || 8, this.lastColumnPos = this.lastColumnValue = 0, this.lineStart = 0, this.lineOracle = i;\n-                            }, \"StringStream\");\n-                            K.prototype.eol = function() {\n-                                return this.pos >= this.string.length;\n-                            }, K.prototype.sol = function() {\n-                                return this.pos == this.lineStart;\n-                            }, K.prototype.peek = function() {\n-                                return this.string.charAt(this.pos) || void 0;\n-                            }, K.prototype.next = function() {\n-                                if (this.pos < this.string.length) return this.string.charAt(this.pos++);\n-                            }, K.prototype.eat = function(e) {\n-                                var t = this.string.charAt(this.pos),\n-                                    i;\n-                                if (typeof e == \"string\" ? i = t == e : i = t && (e.test ? e.test(t) : e(t)), i) return ++this.pos, t;\n-                            }, K.prototype.eatWhile = function(e) {\n-                                for (var t = this.pos; this.eat(e););\n-                                return this.pos > t;\n-                            }, K.prototype.eatSpace = function() {\n-                                for (var e = this.pos;\n-                                    /[\\s\\u00a0]/.test(this.string.charAt(this.pos));) ++this.pos;\n-                                return this.pos > e;\n-                            }, K.prototype.skipToEnd = function() {\n-                                this.pos = this.string.length;\n-                            }, K.prototype.skipTo = function(e) {\n-                                var t = this.string.indexOf(e, this.pos);\n-                                if (t > -1) return this.pos = t, !0;\n-                            }, K.prototype.backUp = function(e) {\n-                                this.pos -= e;\n-                            }, K.prototype.column = function() {\n-                                return this.lastColumnPos < this.start && (this.lastColumnValue = xe(this.string, this.start, this.tabSize, this.lastColumnPos, this.lastColumnValue), this.lastColumnPos = this.start), this.lastColumnValue - (this.lineStart ? xe(this.string, this.lineStart, this.tabSize) : 0);\n-                            }, K.prototype.indentation = function() {\n-                                return xe(this.string, null, this.tabSize) - (this.lineStart ? xe(this.string, this.lineStart, this.tabSize) : 0);\n-                            }, K.prototype.match = function(e, t, i) {\n-                                if (typeof e == \"string\") {\n-                                    var r = u(function(o) {\n-                                            return i ? o.toLowerCase() : o;\n-                                        }, \"cased\"),\n-                                        n = this.string.substr(this.pos, e.length);\n-                                    if (r(n) == r(e)) return t !== !1 && (this.pos += e.length), !0;\n-                                } else {\n-                                    var l = this.string.slice(this.pos).match(e);\n-                                    return l && l.index > 0 ? null : (l && t !== !1 && (this.pos += l[0].length), l);\n-                                }\n-                            }, K.prototype.current = function() {\n-                                return this.string.slice(this.start, this.pos);\n-                            }, K.prototype.hideFirstChars = function(e, t) {\n-                                this.lineStart += e;\n-                                try {\n-                                    return t();\n-                                } finally {\n-                                    this.lineStart -= e;\n-                                }\n-                            }, K.prototype.lookAhead = function(e) {\n-                                var t = this.lineOracle;\n-                                return t && t.lookAhead(e);\n-                            }, K.prototype.baseToken = function() {\n-                                var e = this.lineOracle;\n-                                return e && e.baseToken(this.pos);\n-                            };\n-\n-                            function S(e, t) {\n-                                if (t -= e.first, t < 0 || t >= e.size) throw new Error(\"There is no line \" + (t + e.first) + \" in the document.\");\n-                                for (var i = e; !i.lines;)\n-                                    for (var r = 0;; ++r) {\n-                                        var n = i.children[r],\n-                                            l = n.chunkSize();\n-                                        if (t < l) {\n-                                            i = n;\n-                                            break;\n-                                        }\n-                                        t -= l;\n-                                    }\n-                                return i.lines[t];\n-                            }\n-                            u(S, \"getLine\");\n+                        // Previously calculated lower bounds (previous fails)\n+                        // for each marker, each delimiter length modulo 3,\n+                        // and for whether this closer can be an opener;\n+                        // https://github.com/commonmark/cmark/commit/34250e12ccebdc6372b8b49c44fab57c72443460\n+                        /* eslint-disable-next-line no-prototype-builtins */\n+                        if (!openersBottom.hasOwnProperty(closer.marker)) {\n+                            openersBottom[closer.marker] = [-1, -1, -1, -1, -1, -1];\n+                        }\n+                        const minOpenerIdx = openersBottom[closer.marker][(closer.open ? 3 : 0) + closer.length % 3];\n+                        let openerIdx = headerIdx - jumps[headerIdx] - 1;\n+                        let newMinOpenerIdx = openerIdx;\n+                        for (; openerIdx > minOpenerIdx; openerIdx -= jumps[openerIdx] + 1) {\n+                            const opener = delimiters[openerIdx];\n+                            if (opener.marker !== closer.marker) continue;\n+                            if (opener.open && opener.end < 0) {\n+                                let isOddMatch = false;\n \n-                            function ot(e, t, i) {\n-                                var r = [],\n-                                    n = t.line;\n-                                return e.iter(t.line, i.line + 1, function(l) {\n-                                    var o = l.text;\n-                                    n == i.line && (o = o.slice(0, i.ch)), n == t.line && (o = o.slice(t.ch)), r.push(o), ++n;\n-                                }), r;\n-                            }\n-                            u(ot, \"getBetween\");\n-\n-                            function Ai(e, t, i) {\n-                                var r = [];\n-                                return e.iter(t, i, function(n) {\n-                                    r.push(n.text);\n-                                }), r;\n-                            }\n-                            u(Ai, \"getLines\");\n-\n-                            function De(e, t) {\n-                                var i = t - e.height;\n-                                if (i)\n-                                    for (var r = e; r; r = r.parent) r.height += i;\n-                            }\n-                            u(De, \"updateLineHeight\");\n-\n-                            function F(e) {\n-                                if (e.parent == null) return null;\n-                                for (var t = e.parent, i = ee(t.lines, e), r = t.parent; r; t = r, r = r.parent)\n-                                    for (var n = 0; r.children[n] != t; ++n) i += r.children[n].chunkSize();\n-                                return i + t.first;\n-                            }\n-                            u(F, \"lineNo\");\n-\n-                            function at(e, t) {\n-                                var i = e.first;\n-                                e: do {\n-                                    for (var r = 0; r < e.children.length; ++r) {\n-                                        var n = e.children[r],\n-                                            l = n.height;\n-                                        if (t < l) {\n-                                            e = n;\n-                                            continue e;\n+                                // from spec:\n+                                //\n+                                // If one of the delimiters can both open and close emphasis, then the\n+                                // sum of the lengths of the delimiter runs containing the opening and\n+                                // closing delimiters must not be a multiple of 3 unless both lengths\n+                                // are multiples of 3.\n+                                //\n+                                if (opener.close || closer.open) {\n+                                    if ((opener.length + closer.length) % 3 === 0) {\n+                                        if (opener.length % 3 !== 0 || closer.length % 3 !== 0) {\n+                                            isOddMatch = true;\n                                         }\n-                                        t -= l, i += n.chunkSize();\n                                     }\n-                                    return i;\n-                                } while (!e.lines);\n-                                for (var o = 0; o < e.lines.length; ++o) {\n-                                    var a = e.lines[o],\n-                                        s = a.height;\n-                                    if (t < s) break;\n-                                    t -= s;\n                                 }\n-                                return i + o;\n+                                if (!isOddMatch) {\n+                                    // If previous delimiter cannot be an opener, we can safely skip\n+                                    // the entire sequence in future checks. This is required to make\n+                                    // sure algorithm has linear complexity (see *_*_*_*_*_... case).\n+                                    //\n+                                    const lastJump = openerIdx > 0 && !delimiters[openerIdx - 1].open ? jumps[openerIdx - 1] + 1 : 0;\n+                                    jumps[closerIdx] = closerIdx - openerIdx + lastJump;\n+                                    jumps[openerIdx] = lastJump;\n+                                    closer.open = false;\n+                                    opener.end = closerIdx;\n+                                    opener.close = false;\n+                                    newMinOpenerIdx = -1;\n+                                    // treat next token as start of run,\n+                                    // it optimizes skips in **<...>**a**<...>** pathological case\n+                                    lastTokenIdx = -2;\n+                                    break;\n+                                }\n                             }\n-                            u(at, \"lineAtHeight\");\n+                        }\n+                        if (newMinOpenerIdx !== -1) {\n+                            // If match for this delimiter run failed, we want to set lower bound for\n+                            // future lookups. This is required to make sure algorithm has linear\n+                            // complexity.\n+                            //\n+                            // See details here:\n+                            // https://github.com/commonmark/cmark/issues/178#issuecomment-270417442\n+                            //\n+                            openersBottom[closer.marker][(closer.open ? 3 : 0) + (closer.length || 0) % 3] = newMinOpenerIdx;\n+                        }\n+                    }\n+                }\n \n-                            function Jt(e, t) {\n-                                return t >= e.first && t < e.first + e.size;\n-                            }\n-                            u(Jt, \"isLine\");\n+                function link_pairs(state) {\n+                    const tokens_meta = state.tokens_meta;\n+                    const max = state.tokens_meta.length;\n+                    processDelimiters(state.delimiters);\n+                    for (let curr = 0; curr < max; curr++) {\n+                        if (tokens_meta[curr] && tokens_meta[curr].delimiters) {\n+                            processDelimiters(tokens_meta[curr].delimiters);\n+                        }\n+                    }\n+                }\n \n-                            function Oi(e, t) {\n-                                return String(e.lineNumberFormatter(t + e.firstLineNumber));\n-                            }\n-                            u(Oi, \"lineNumberFor\");\n+                // Clean up tokens after emphasis and strikethrough postprocessing:\n+                // merge adjacent text nodes into one and re-calculate all token levels\n+                //\n+                // This is necessary because initially emphasis delimiter markers (*, _, ~)\n+                // are treated as their own separate text tokens. Then emphasis rule either\n+                // leaves them as text (needed to merge with adjacent text) or turns them\n+                // into opening/closing tags (which messes up levels inside).\n+                //\n \n-                            function y(e, t, i) {\n-                                if (i === void 0 && (i = null), !(this instanceof y)) return new y(e, t, i);\n-                                this.line = e, this.ch = t, this.sticky = i;\n-                            }\n-                            u(y, \"Pos\");\n+                function fragments_join(state) {\n+                    let curr, last;\n+                    let level = 0;\n+                    const tokens = state.tokens;\n+                    const max = state.tokens.length;\n+                    for (curr = last = 0; curr < max; curr++) {\n+                        // re-calculate levels after emphasis/strikethrough turns some text nodes\n+                        // into opening/closing tags\n+                        if (tokens[curr].nesting < 0) level--; // closing tag\n+                        tokens[curr].level = level;\n+                        if (tokens[curr].nesting > 0) level++; // opening tag\n \n-                            function D(e, t) {\n-                                return e.line - t.line || e.ch - t.ch;\n+                        if (tokens[curr].type === 'text' && curr + 1 < max && tokens[curr + 1].type === 'text') {\n+                            // collapse two adjacent text nodes\n+                            tokens[curr + 1].content = tokens[curr].content + tokens[curr + 1].content;\n+                        } else {\n+                            if (curr !== last) {\n+                                tokens[last] = tokens[curr];\n                             }\n-                            u(D, \"cmp\");\n+                            last++;\n+                        }\n+                    }\n+                    if (curr !== last) {\n+                        tokens.length = last;\n+                    }\n+                }\n \n-                            function Wi(e, t) {\n-                                return e.sticky == t.sticky && D(e, t) == 0;\n-                            }\n-                            u(Wi, \"equalCursorPos\");\n+                /** internal\n+                 * class ParserInline\n+                 *\n+                 * Tokenizes paragraph content.\n+                 **/\n \n-                            function Hi(e) {\n-                                return y(e.line, e.ch);\n-                            }\n-                            u(Hi, \"copyPos\");\n+                // Parser rules\n \n-                            function Fr(e, t) {\n-                                return D(e, t) < 0 ? t : e;\n-                            }\n-                            u(Fr, \"maxPos\");\n+                const _rules = [\n+                    ['text', text],\n+                    ['linkify', linkify],\n+                    ['newline', newline],\n+                    ['escape', escape],\n+                    ['backticks', backtick],\n+                    ['strikethrough', r_strikethrough.tokenize],\n+                    ['emphasis', r_emphasis.tokenize],\n+                    ['link', link],\n+                    ['image', image],\n+                    ['autolink', autolink],\n+                    ['html_inline', html_inline],\n+                    ['entity', entity]\n+                ];\n \n-                            function Pr(e, t) {\n-                                return D(e, t) < 0 ? e : t;\n-                            }\n-                            u(Pr, \"minPos\");\n+                // `rule2` ruleset was created specifically for emphasis/strikethrough\n+                // post-processing and may be changed in the future.\n+                //\n+                // Don't use this for anything except pairs (plugins working with `balance_pairs`).\n+                //\n+                const _rules2 = [\n+                    ['balance_pairs', link_pairs],\n+                    ['strikethrough', r_strikethrough.postProcess],\n+                    ['emphasis', r_emphasis.postProcess],\n+                    // rules for pairs separate '**' into its own text tokens, which may be left unused,\n+                    // rule below merges unused segments back with the rest of the text\n+                    ['fragments_join', fragments_join]\n+                ];\n \n-                            function Un(e, t) {\n-                                return Math.max(e.first, Math.min(t, e.first + e.size - 1));\n-                            }\n-                            u(Un, \"clipLine\");\n+                /**\n+                 * new ParserInline()\n+                 **/\n+                function ParserInline() {\n+                    /**\n+                     * ParserInline#ruler -> Ruler\n+                     *\n+                     * [[Ruler]] instance. Keep configuration of inline rules.\n+                     **/\n+                    this.ruler = new Ruler();\n+                    for (let i = 0; i < _rules.length; i++) {\n+                        this.ruler.push(_rules[i][0], _rules[i][1]);\n+                    }\n \n-                            function N(e, t) {\n-                                if (t.line < e.first) return y(e.first, 0);\n-                                var i = e.first + e.size - 1;\n-                                return t.line > i ? y(i, S(e, i).text.length) : ua(t, S(e, t.line).text.length);\n-                            }\n-                            u(N, \"clipPos\");\n+                    /**\n+                     * ParserInline#ruler2 -> Ruler\n+                     *\n+                     * [[Ruler]] instance. Second ruler used for post-processing\n+                     * (e.g. in emphasis-like rules).\n+                     **/\n+                    this.ruler2 = new Ruler();\n+                    for (let i = 0; i < _rules2.length; i++) {\n+                        this.ruler2.push(_rules2[i][0], _rules2[i][1]);\n+                    }\n+                }\n \n-                            function ua(e, t) {\n-                                var i = e.ch;\n-                                return i == null || i > t ? y(e.line, t) : i < 0 ? y(e.line, 0) : e;\n+                // Skip single token by running all rules in validation mode;\n+                // returns `true` if any rule reported success\n+                //\n+                ParserInline.prototype.skipToken = function(state) {\n+                    const pos = state.pos;\n+                    const rules = this.ruler.getRules('');\n+                    const len = rules.length;\n+                    const maxNesting = state.md.options.maxNesting;\n+                    const cache = state.cache;\n+                    if (typeof cache[pos] !== 'undefined') {\n+                        state.pos = cache[pos];\n+                        return;\n+                    }\n+                    let ok = false;\n+                    if (state.level < maxNesting) {\n+                        for (let i = 0; i < len; i++) {\n+                            // Increment state.level and decrement it later to limit recursion.\n+                            // It's harmless to do here, because no tokens are created. But ideally,\n+                            // we'd need a separate private state variable for this purpose.\n+                            //\n+                            state.level++;\n+                            ok = rules[i](state, true);\n+                            state.level--;\n+                            if (ok) {\n+                                if (pos >= state.pos) {\n+                                    throw new Error(\"inline rule didn't increment state.pos\");\n+                                }\n+                                break;\n                             }\n-                            u(ua, \"clipToLen\");\n+                        }\n+                    } else {\n+                        // Too much nesting, just skip until the end of the paragraph.\n+                        //\n+                        // NOTE: this will cause links to behave incorrectly in the following case,\n+                        //       when an amount of `[` is exactly equal to `maxNesting + 1`:\n+                        //\n+                        //       [[[[[[[[[[[[[[[[[[[[[foo]()\n+                        //\n+                        // TODO: remove this workaround when CM standard will allow nested links\n+                        //       (we can replace it by preventing links from being parsed in\n+                        //       validation mode)\n+                        //\n+                        state.pos = state.posMax;\n+                    }\n+                    if (!ok) {\n+                        state.pos++;\n+                    }\n+                    cache[pos] = state.pos;\n+                };\n \n-                            function Kn(e, t) {\n-                                for (var i = [], r = 0; r < t.length; r++) i[r] = N(e, t[r]);\n-                                return i;\n+                // Generate tokens for input range\n+                //\n+                ParserInline.prototype.tokenize = function(state) {\n+                    const rules = this.ruler.getRules('');\n+                    const len = rules.length;\n+                    const end = state.posMax;\n+                    const maxNesting = state.md.options.maxNesting;\n+                    while (state.pos < end) {\n+                        // Try all possible rules.\n+                        // On success, rule should:\n+                        //\n+                        // - update `state.pos`\n+                        // - update `state.tokens`\n+                        // - return true\n+                        const prevPos = state.pos;\n+                        let ok = false;\n+                        if (state.level < maxNesting) {\n+                            for (let i = 0; i < len; i++) {\n+                                ok = rules[i](state, false);\n+                                if (ok) {\n+                                    if (prevPos >= state.pos) {\n+                                        throw new Error(\"inline rule didn't increment state.pos\");\n+                                    }\n+                                    break;\n+                                }\n                             }\n-                            u(Kn, \"clipPosArray\");\n-                            var Er = u(function(e, t) {\n-                                    this.state = e, this.lookAhead = t;\n-                                }, \"SavedContext\"),\n-                                Ne = u(function(e, t, i, r) {\n-                                    this.state = t, this.doc = e, this.line = i, this.maxLookAhead = r || 0, this.baseTokens = null, this.baseTokenPos = 1;\n-                                }, \"Context\");\n-                            Ne.prototype.lookAhead = function(e) {\n-                                var t = this.doc.getLine(this.line + e);\n-                                return t != null && e > this.maxLookAhead && (this.maxLookAhead = e), t;\n-                            }, Ne.prototype.baseToken = function(e) {\n-                                if (!this.baseTokens) return null;\n-                                for (; this.baseTokens[this.baseTokenPos] <= e;) this.baseTokenPos += 2;\n-                                var t = this.baseTokens[this.baseTokenPos + 1];\n-                                return {\n-                                    type: t && t.replace(/( |^)overlay .*/, \"\"),\n-                                    size: this.baseTokens[this.baseTokenPos] - e\n-                                };\n-                            }, Ne.prototype.nextLine = function() {\n-                                this.line++, this.maxLookAhead > 0 && this.maxLookAhead--;\n-                            }, Ne.fromSaved = function(e, t, i) {\n-                                return t instanceof Er ? new Ne(e, lt(e.mode, t.state), i, t.lookAhead) : new Ne(e, lt(e.mode, t), i);\n-                            }, Ne.prototype.save = function(e) {\n-                                var t = e !== !1 ? lt(this.doc.mode, this.state) : this.state;\n-                                return this.maxLookAhead > 0 ? new Er(t, this.maxLookAhead) : t;\n-                            };\n-\n-                            function _n(e, t, i, r) {\n-                                var n = [e.state.modeGen],\n-                                    l = {};\n-                                Jn(e, t.text, e.doc.mode, i, function(f, h) {\n-                                    return n.push(f, h);\n-                                }, l, r);\n-                                for (var o = i.state, a = u(function(f) {\n-                                        i.baseTokens = n;\n-                                        var h = e.state.overlays[f],\n-                                            c = 1,\n-                                            p = 0;\n-                                        i.state = !0, Jn(e, t.text, h.mode, i, function(d, v) {\n-                                            for (var g = c; p < d;) {\n-                                                var m = n[c];\n-                                                m > d && n.splice(c, 1, d, n[c + 1], m), c += 2, p = Math.min(d, m);\n-                                            }\n-                                            if (v)\n-                                                if (h.opaque) n.splice(g, c - g, d, \"overlay \" + v), c = g + 2;\n-                                                else\n-                                                    for (; g < c; g += 2) {\n-                                                        var b = n[g + 1];\n-                                                        n[g + 1] = (b ? b + \" \" : \"\") + \"overlay \" + v;\n-                                                    }\n-                                        }, l), i.state = o, i.baseTokens = null, i.baseTokenPos = 1;\n-                                    }, \"loop\"), s = 0; s < e.state.overlays.length; ++s) a(s);\n-                                return {\n-                                    styles: n,\n-                                    classes: l.bgClass || l.textClass ? l : null\n-                                };\n+                        }\n+                        if (ok) {\n+                            if (state.pos >= end) {\n+                                break;\n                             }\n-                            u(_n, \"highlightLine\");\n+                            continue;\n+                        }\n+                        state.pending += state.src[state.pos++];\n+                    }\n+                    if (state.pending) {\n+                        state.pushPending();\n+                    }\n+                };\n \n-                            function Xn(e, t, i) {\n-                                if (!t.styles || t.styles[0] != e.state.modeGen) {\n-                                    var r = jt(e, F(t)),\n-                                        n = t.text.length > e.options.maxHighlightLength && lt(e.doc.mode, r.state),\n-                                        l = _n(e, t, r);\n-                                    n && (r.state = n), t.stateAfter = r.save(!n), t.styles = l.styles, l.classes ? t.styleClasses = l.classes : t.styleClasses && (t.styleClasses = null), i === e.doc.highlightFrontier && (e.doc.modeFrontier = Math.max(e.doc.modeFrontier, ++e.doc.highlightFrontier));\n-                                }\n-                                return t.styles;\n-                            }\n-                            u(Xn, \"getLineStyles\");\n-\n-                            function jt(e, t, i) {\n-                                var r = e.doc,\n-                                    n = e.display;\n-                                if (!r.mode.startState) return new Ne(r, !0, t);\n-                                var l = fa(e, t, i),\n-                                    o = l > r.first && S(r, l - 1).stateAfter,\n-                                    a = o ? Ne.fromSaved(r, o, l) : new Ne(r, Gn(r.mode), l);\n-                                return r.iter(l, t, function(s) {\n-                                    Fi(e, s.text, a);\n-                                    var f = a.line;\n-                                    s.stateAfter = f == t - 1 || f % 5 == 0 || f >= n.viewFrom && f < n.viewTo ? a.save() : null, a.nextLine();\n-                                }), i && (r.modeFrontier = a.line), a;\n-                            }\n-                            u(jt, \"getContextBefore\");\n-\n-                            function Fi(e, t, i, r) {\n-                                var n = e.doc.mode,\n-                                    l = new K(t, e.options.tabSize, i);\n-                                for (l.start = l.pos = r || 0, t == \"\" && Yn(n, i.state); !l.eol();) Pi(n, l, i.state), l.start = l.pos;\n-                            }\n-                            u(Fi, \"processLine\");\n-\n-                            function Yn(e, t) {\n-                                if (e.blankLine) return e.blankLine(t);\n-                                if (e.innerMode) {\n-                                    var i = Ni(e, t);\n-                                    if (i.mode.blankLine) return i.mode.blankLine(i.state);\n-                                }\n-                            }\n-                            u(Yn, \"callBlankLine\");\n-\n-                            function Pi(e, t, i, r) {\n-                                for (var n = 0; n < 10; n++) {\n-                                    r && (r[0] = Ni(e, i).mode);\n-                                    var l = e.token(t, i);\n-                                    if (t.pos > t.start) return l;\n-                                }\n-                                throw new Error(\"Mode \" + e.name + \" failed to advance stream.\");\n-                            }\n-                            u(Pi, \"readToken\");\n-                            var qn = u(function(e, t, i) {\n-                                this.start = e.start, this.end = e.pos, this.string = e.current(), this.type = t || null, this.state = i;\n-                            }, \"Token\");\n-\n-                            function Zn(e, t, i, r) {\n-                                var n = e.doc,\n-                                    l = n.mode,\n-                                    o;\n-                                t = N(n, t);\n-                                var a = S(n, t.line),\n-                                    s = jt(e, t.line, i),\n-                                    f = new K(a.text, e.options.tabSize, s),\n-                                    h;\n-                                for (r && (h = []);\n-                                    (r || f.pos < t.ch) && !f.eol();) f.start = f.pos, o = Pi(l, f, s.state), r && h.push(new qn(f, o, lt(n.mode, s.state)));\n-                                return r ? h : new qn(f, o, s.state);\n-                            }\n-                            u(Zn, \"takeToken\");\n+                /**\n+                 * ParserInline.parse(str, md, env, outTokens)\n+                 *\n+                 * Process input string and push inline tokens into `outTokens`\n+                 **/\n+                ParserInline.prototype.parse = function(str, md, env, outTokens) {\n+                    const state = new this.State(str, md, env, outTokens);\n+                    this.tokenize(state);\n+                    const rules = this.ruler2.getRules('');\n+                    const len = rules.length;\n+                    for (let i = 0; i < len; i++) {\n+                        rules[i](state);\n+                    }\n+                };\n+                ParserInline.prototype.State = StateInline;\n \n-                            function Qn(e, t) {\n-                                if (e)\n-                                    for (;;) {\n-                                        var i = e.match(/(?:^|\\s+)line-(background-)?(\\S+)/);\n-                                        if (!i) break;\n-                                        e = e.slice(0, i.index) + e.slice(i.index + i[0].length);\n-                                        var r = i[1] ? \"bgClass\" : \"textClass\";\n-                                        t[r] == null ? t[r] = i[2] : new RegExp(\"(?:^|\\\\s)\" + i[2] + \"(?:$|\\\\s)\").test(t[r]) || (t[r] += \" \" + i[2]);\n-                                    }\n-                                return e;\n-                            }\n-                            u(Qn, \"extractLineClasses\");\n-\n-                            function Jn(e, t, i, r, n, l, o) {\n-                                var a = i.flattenSpans;\n-                                a == null && (a = e.options.flattenSpans);\n-                                var s = 0,\n-                                    f = null,\n-                                    h = new K(t, e.options.tabSize, r),\n-                                    c,\n-                                    p = e.options.addModeClass && [null];\n-                                for (t == \"\" && Qn(Yn(i, r.state), l); !h.eol();) {\n-                                    if (h.pos > e.options.maxHighlightLength ? (a = !1, o && Fi(e, t, r, h.pos), h.pos = t.length, c = null) : c = Qn(Pi(i, h, r.state, p), l), p) {\n-                                        var d = p[0].name;\n-                                        d && (c = \"m-\" + (c ? d + \" \" + c : d));\n-                                    }\n-                                    if (!a || f != c) {\n-                                        for (; s < h.start;) s = Math.min(h.start, s + 5e3), n(s, f);\n-                                        f = c;\n-                                    }\n-                                    h.start = h.pos;\n-                                }\n-                                for (; s < h.pos;) {\n-                                    var v = Math.min(h.pos, s + 5e3);\n-                                    n(v, f), s = v;\n-                                }\n-                            }\n-                            u(Jn, \"runMode\");\n-\n-                            function fa(e, t, i) {\n-                                for (var r, n, l = e.doc, o = i ? -1 : t - (e.doc.mode.innerMode ? 1e3 : 100), a = t; a > o; --a) {\n-                                    if (a <= l.first) return l.first;\n-                                    var s = S(l, a - 1),\n-                                        f = s.stateAfter;\n-                                    if (f && (!i || a + (f instanceof Er ? f.lookAhead : 0) <= l.modeFrontier)) return a;\n-                                    var h = xe(s.text, null, e.options.tabSize);\n-                                    (n == null || r > h) && (n = a - 1, r = h);\n-                                }\n-                                return n;\n-                            }\n-                            u(fa, \"findStartLine\");\n-\n-                            function ha(e, t) {\n-                                if (e.modeFrontier = Math.min(e.modeFrontier, t), !(e.highlightFrontier < t - 10)) {\n-                                    for (var i = e.first, r = t - 1; r > i; r--) {\n-                                        var n = S(e, r).stateAfter;\n-                                        if (n && (!(n instanceof Er) || r + n.lookAhead < t)) {\n-                                            i = r + 1;\n-                                            break;\n-                                        }\n-                                    }\n-                                    e.highlightFrontier = Math.min(e.highlightFrontier, i);\n-                                }\n-                            }\n-                            u(ha, \"retreatFrontier\");\n-                            var jn = !1,\n-                                Ee = !1;\n+                // markdown-it default options\n \n-                            function ca() {\n-                                jn = !0;\n-                            }\n-                            u(ca, \"seeReadOnlySpans\");\n+                var cfg_default = {\n+                    options: {\n+                        // Enable HTML tags in source\n+                        html: false,\n+                        // Use '/' to close single tags (<br />)\n+                        xhtmlOut: false,\n+                        // Convert '\\n' in paragraphs into <br>\n+                        breaks: false,\n+                        // CSS language prefix for fenced blocks\n+                        langPrefix: 'language-',\n+                        // autoconvert URL-like texts to links\n+                        linkify: false,\n+                        // Enable some language-neutral replacements + quotes beautification\n+                        typographer: false,\n+                        // Double + single quotes replacement pairs, when typographer enabled,\n+                        // and smartquotes on. Could be either a String or an Array.\n+                        //\n+                        // For example, you can use '\u00ab\u00bb\u201e\u201c' for Russian, '\u201e\u201c\u201a\u2018' for German,\n+                        // and ['\u00ab\\xA0', '\\xA0\u00bb', '\u2039\\xA0', '\\xA0\u203a'] for French (including nbsp).\n+                        quotes: '\\u201c\\u201d\\u2018\\u2019',\n+                        /* \u201c\u201d\u2018\u2019 */\n \n-                            function da() {\n-                                Ee = !0;\n-                            }\n-                            u(da, \"seeCollapsedSpans\");\n+                        // Highlighter function. Should return escaped HTML,\n+                        // or '' if the source string is not changed and should be escaped externaly.\n+                        // If result starts with <pre... internal wrapper is skipped.\n+                        //\n+                        // function (/*str, lang*/) { return ''; }\n+                        //\n+                        highlight: null,\n+                        // Internal protection, recursion limit\n+                        maxNesting: 100\n+                    },\n+                    components: {\n+                        core: {},\n+                        block: {},\n+                        inline: {}\n+                    }\n+                };\n \n-                            function Ir(e, t, i) {\n-                                this.marker = e, this.from = t, this.to = i;\n-                            }\n-                            u(Ir, \"MarkedSpan\");\n+                // \"Zero\" preset, with nothing enabled. Useful for manual configuring of simple\n+                // modes. For example, to parse bold/italic only.\n \n-                            function Vt(e, t) {\n-                                if (e)\n-                                    for (var i = 0; i < e.length; ++i) {\n-                                        var r = e[i];\n-                                        if (r.marker == t) return r;\n-                                    }\n-                            }\n-                            u(Vt, \"getMarkedSpanFor\");\n+                var cfg_zero = {\n+                    options: {\n+                        // Enable HTML tags in source\n+                        html: false,\n+                        // Use '/' to close single tags (<br />)\n+                        xhtmlOut: false,\n+                        // Convert '\\n' in paragraphs into <br>\n+                        breaks: false,\n+                        // CSS language prefix for fenced blocks\n+                        langPrefix: 'language-',\n+                        // autoconvert URL-like texts to links\n+                        linkify: false,\n+                        // Enable some language-neutral replacements + quotes beautification\n+                        typographer: false,\n+                        // Double + single quotes replacement pairs, when typographer enabled,\n+                        // and smartquotes on. Could be either a String or an Array.\n+                        //\n+                        // For example, you can use '\u00ab\u00bb\u201e\u201c' for Russian, '\u201e\u201c\u201a\u2018' for German,\n+                        // and ['\u00ab\\xA0', '\\xA0\u00bb', '\u2039\\xA0', '\\xA0\u203a'] for French (including nbsp).\n+                        quotes: '\\u201c\\u201d\\u2018\\u2019',\n+                        /* \u201c\u201d\u2018\u2019 */\n \n-                            function pa(e, t) {\n-                                for (var i, r = 0; r < e.length; ++r) e[r] != t && (i || (i = [])).push(e[r]);\n-                                return i;\n-                            }\n-                            u(pa, \"removeMarkedSpan\");\n+                        // Highlighter function. Should return escaped HTML,\n+                        // or '' if the source string is not changed and should be escaped externaly.\n+                        // If result starts with <pre... internal wrapper is skipped.\n+                        //\n+                        // function (/*str, lang*/) { return ''; }\n+                        //\n+                        highlight: null,\n+                        // Internal protection, recursion limit\n+                        maxNesting: 20\n+                    },\n+                    components: {\n+                        core: {\n+                            rules: ['normalize', 'block', 'inline', 'text_join']\n+                        },\n+                        block: {\n+                            rules: ['paragraph']\n+                        },\n+                        inline: {\n+                            rules: ['text'],\n+                            rules2: ['balance_pairs', 'fragments_join']\n+                        }\n+                    }\n+                };\n \n-                            function va(e, t, i) {\n-                                var r = i && window.WeakSet && (i.markedSpans || (i.markedSpans = new WeakSet()));\n-                                r && e.markedSpans && r.has(e.markedSpans) ? e.markedSpans.push(t) : (e.markedSpans = e.markedSpans ? e.markedSpans.concat([t]) : [t], r && r.add(e.markedSpans)), t.marker.attachLine(e);\n-                            }\n-                            u(va, \"addMarkedSpan\");\n-\n-                            function ga(e, t, i) {\n-                                var r;\n-                                if (e)\n-                                    for (var n = 0; n < e.length; ++n) {\n-                                        var l = e[n],\n-                                            o = l.marker,\n-                                            a = l.from == null || (o.inclusiveLeft ? l.from <= t : l.from < t);\n-                                        if (a || l.from == t && o.type == \"bookmark\" && (!i || !l.marker.insertLeft)) {\n-                                            var s = l.to == null || (o.inclusiveRight ? l.to >= t : l.to > t);\n-                                            (r || (r = [])).push(new Ir(o, l.from, s ? null : l.to));\n-                                        }\n-                                    }\n-                                return r;\n-                            }\n-                            u(ga, \"markedSpansBefore\");\n+                // Commonmark default options\n \n-                            function ya(e, t, i) {\n-                                var r;\n-                                if (e)\n-                                    for (var n = 0; n < e.length; ++n) {\n-                                        var l = e[n],\n-                                            o = l.marker,\n-                                            a = l.to == null || (o.inclusiveRight ? l.to >= t : l.to > t);\n-                                        if (a || l.from == t && o.type == \"bookmark\" && (!i || l.marker.insertLeft)) {\n-                                            var s = l.from == null || (o.inclusiveLeft ? l.from <= t : l.from < t);\n-                                            (r || (r = [])).push(new Ir(o, s ? null : l.from - t, l.to == null ? null : l.to - t));\n-                                        }\n-                                    }\n-                                return r;\n-                            }\n-                            u(ya, \"markedSpansAfter\");\n+                var cfg_commonmark = {\n+                    options: {\n+                        // Enable HTML tags in source\n+                        html: true,\n+                        // Use '/' to close single tags (<br />)\n+                        xhtmlOut: true,\n+                        // Convert '\\n' in paragraphs into <br>\n+                        breaks: false,\n+                        // CSS language prefix for fenced blocks\n+                        langPrefix: 'language-',\n+                        // autoconvert URL-like texts to links\n+                        linkify: false,\n+                        // Enable some language-neutral replacements + quotes beautification\n+                        typographer: false,\n+                        // Double + single quotes replacement pairs, when typographer enabled,\n+                        // and smartquotes on. Could be either a String or an Array.\n+                        //\n+                        // For example, you can use '\u00ab\u00bb\u201e\u201c' for Russian, '\u201e\u201c\u201a\u2018' for German,\n+                        // and ['\u00ab\\xA0', '\\xA0\u00bb', '\u2039\\xA0', '\\xA0\u203a'] for French (including nbsp).\n+                        quotes: '\\u201c\\u201d\\u2018\\u2019',\n+                        /* \u201c\u201d\u2018\u2019 */\n \n-                            function Ei(e, t) {\n-                                if (t.full) return null;\n-                                var i = Jt(e, t.from.line) && S(e, t.from.line).markedSpans,\n-                                    r = Jt(e, t.to.line) && S(e, t.to.line).markedSpans;\n-                                if (!i && !r) return null;\n-                                var n = t.from.ch,\n-                                    l = t.to.ch,\n-                                    o = D(t.from, t.to) == 0,\n-                                    a = ga(i, n, o),\n-                                    s = ya(r, l, o),\n-                                    f = t.text.length == 1,\n-                                    h = H(t.text).length + (f ? n : 0);\n-                                if (a)\n-                                    for (var c = 0; c < a.length; ++c) {\n-                                        var p = a[c];\n-                                        if (p.to == null) {\n-                                            var d = Vt(s, p.marker);\n-                                            d ? f && (p.to = d.to == null ? null : d.to + h) : p.to = n;\n-                                        }\n-                                    }\n-                                if (s)\n-                                    for (var v = 0; v < s.length; ++v) {\n-                                        var g = s[v];\n-                                        if (g.to != null && (g.to += h), g.from == null) {\n-                                            var m = Vt(a, g.marker);\n-                                            m || (g.from = h, f && (a || (a = [])).push(g));\n-                                        } else g.from += h, f && (a || (a = [])).push(g);\n-                                    }\n-                                a && (a = Vn(a)), s && s != a && (s = Vn(s));\n-                                var b = [a];\n-                                if (!f) {\n-                                    var C = t.text.length - 2,\n-                                        x;\n-                                    if (C > 0 && a)\n-                                        for (var w = 0; w < a.length; ++w) a[w].to == null && (x || (x = [])).push(new Ir(a[w].marker, null, null));\n-                                    for (var k = 0; k < C; ++k) b.push(x);\n-                                    b.push(s);\n-                                }\n-                                return b;\n-                            }\n-                            u(Ei, \"stretchSpansOverChange\");\n-\n-                            function Vn(e) {\n-                                for (var t = 0; t < e.length; ++t) {\n-                                    var i = e[t];\n-                                    i.from != null && i.from == i.to && i.marker.clearWhenEmpty !== !1 && e.splice(t--, 1);\n-                                }\n-                                return e.length ? e : null;\n-                            }\n-                            u(Vn, \"clearEmptySpans\");\n-\n-                            function ma(e, t, i) {\n-                                var r = null;\n-                                if (e.iter(t.line, i.line + 1, function(d) {\n-                                        if (d.markedSpans)\n-                                            for (var v = 0; v < d.markedSpans.length; ++v) {\n-                                                var g = d.markedSpans[v].marker;\n-                                                g.readOnly && (!r || ee(r, g) == -1) && (r || (r = [])).push(g);\n-                                            }\n-                                    }), !r) return null;\n-                                for (var n = [{\n-                                        from: t,\n-                                        to: i\n-                                    }], l = 0; l < r.length; ++l)\n-                                    for (var o = r[l], a = o.find(0), s = 0; s < n.length; ++s) {\n-                                        var f = n[s];\n-                                        if (!(D(f.to, a.from) < 0 || D(f.from, a.to) > 0)) {\n-                                            var h = [s, 1],\n-                                                c = D(f.from, a.from),\n-                                                p = D(f.to, a.to);\n-                                            (c < 0 || !o.inclusiveLeft && !c) && h.push({\n-                                                from: f.from,\n-                                                to: a.from\n-                                            }), (p > 0 || !o.inclusiveRight && !p) && h.push({\n-                                                from: a.to,\n-                                                to: f.to\n-                                            }), n.splice.apply(n, h), s += h.length - 3;\n-                                        }\n-                                    }\n-                                return n;\n-                            }\n-                            u(ma, \"removeReadOnlyRanges\");\n+                        // Highlighter function. Should return escaped HTML,\n+                        // or '' if the source string is not changed and should be escaped externaly.\n+                        // If result starts with <pre... internal wrapper is skipped.\n+                        //\n+                        // function (/*str, lang*/) { return ''; }\n+                        //\n+                        highlight: null,\n+                        // Internal protection, recursion limit\n+                        maxNesting: 20\n+                    },\n+                    components: {\n+                        core: {\n+                            rules: ['normalize', 'block', 'inline', 'text_join']\n+                        },\n+                        block: {\n+                            rules: ['blockquote', 'code', 'fence', 'heading', 'hr', 'html_block', 'lheading', 'list', 'reference', 'paragraph']\n+                        },\n+                        inline: {\n+                            rules: ['autolink', 'backticks', 'emphasis', 'entity', 'escape', 'html_inline', 'image', 'link', 'newline', 'text'],\n+                            rules2: ['balance_pairs', 'emphasis', 'fragments_join']\n+                        }\n+                    }\n+                };\n \n-                            function $n(e) {\n-                                var t = e.markedSpans;\n-                                if (t) {\n-                                    for (var i = 0; i < t.length; ++i) t[i].marker.detachLine(e);\n-                                    e.markedSpans = null;\n-                                }\n-                            }\n-                            u($n, \"detachMarkedSpans\");\n+                // Main parser class\n \n-                            function el(e, t) {\n-                                if (t) {\n-                                    for (var i = 0; i < t.length; ++i) t[i].marker.attachLine(e);\n-                                    e.markedSpans = t;\n-                                }\n-                            }\n-                            u(el, \"attachMarkedSpans\");\n+                const config = {\n+                    default: cfg_default,\n+                    zero: cfg_zero,\n+                    commonmark: cfg_commonmark\n+                };\n \n-                            function Rr(e) {\n-                                return e.inclusiveLeft ? -1 : 0;\n-                            }\n-                            u(Rr, \"extraLeft\");\n+                //\n+                // This validator can prohibit more than really needed to prevent XSS. It's a\n+                // tradeoff to keep code simple and to be secure by default.\n+                //\n+                // If you need different setup - override validator method as you wish. Or\n+                // replace it with dummy function and use external sanitizer.\n+                //\n \n-                            function Br(e) {\n-                                return e.inclusiveRight ? 1 : 0;\n-                            }\n-                            u(Br, \"extraRight\");\n+                const BAD_PROTO_RE = /^(vbscript|javascript|file|data):/;\n+                const GOOD_DATA_RE = /^data:image\\/(gif|png|jpeg|webp);/;\n \n-                            function Ii(e, t) {\n-                                var i = e.lines.length - t.lines.length;\n-                                if (i != 0) return i;\n-                                var r = e.find(),\n-                                    n = t.find(),\n-                                    l = D(r.from, n.from) || Rr(e) - Rr(t);\n-                                if (l) return -l;\n-                                var o = D(r.to, n.to) || Br(e) - Br(t);\n-                                return o || t.id - e.id;\n-                            }\n-                            u(Ii, \"compareCollapsedMarkers\");\n+                function validateLink(url) {\n+                    // url should be normalized at this point, and existing entities are decoded\n+                    const str = url.trim().toLowerCase();\n+                    return BAD_PROTO_RE.test(str) ? GOOD_DATA_RE.test(str) : true;\n+                }\n+                const RECODE_HOSTNAME_FOR = ['http:', 'https:', 'mailto:'];\n \n-                            function tl(e, t) {\n-                                var i = Ee && e.markedSpans,\n-                                    r;\n-                                if (i)\n-                                    for (var n = void 0, l = 0; l < i.length; ++l) n = i[l], n.marker.collapsed && (t ? n.from : n.to) == null && (!r || Ii(r, n.marker) < 0) && (r = n.marker);\n-                                return r;\n-                            }\n-                            u(tl, \"collapsedSpanAtSide\");\n+                function normalizeLink(url) {\n+                    const parsed = mdurl__namespace.parse(url, true);\n+                    if (parsed.hostname) {\n+                        // Encode hostnames in urls like:\n+                        // `http://host/`, `https://host/`, `mailto:user@host`, `//host/`\n+                        //\n+                        // We don't encode unknown schemas, because it's likely that we encode\n+                        // something we shouldn't (e.g. `skype:name` treated as `skype:host`)\n+                        //\n+                        if (!parsed.protocol || RECODE_HOSTNAME_FOR.indexOf(parsed.protocol) >= 0) {\n+                            try {\n+                                parsed.hostname = punycode.toASCII(parsed.hostname);\n+                            } catch (er) {\n+                                /**/ }\n+                        }\n+                    }\n+                    return mdurl__namespace.encode(mdurl__namespace.format(parsed));\n+                }\n \n-                            function rl(e) {\n-                                return tl(e, !0);\n-                            }\n-                            u(rl, \"collapsedSpanAtStart\");\n+                function normalizeLinkText(url) {\n+                    const parsed = mdurl__namespace.parse(url, true);\n+                    if (parsed.hostname) {\n+                        // Encode hostnames in urls like:\n+                        // `http://host/`, `https://host/`, `mailto:user@host`, `//host/`\n+                        //\n+                        // We don't encode unknown schemas, because it's likely that we encode\n+                        // something we shouldn't (e.g. `skype:name` treated as `skype:host`)\n+                        //\n+                        if (!parsed.protocol || RECODE_HOSTNAME_FOR.indexOf(parsed.protocol) >= 0) {\n+                            try {\n+                                parsed.hostname = punycode.toUnicode(parsed.hostname);\n+                            } catch (er) {\n+                                /**/ }\n+                        }\n+                    }\n \n-                            function zr(e) {\n-                                return tl(e, !1);\n-                            }\n-                            u(zr, \"collapsedSpanAtEnd\");\n+                    // add '%' to exclude list because of https://github.com/markdown-it/markdown-it/issues/720\n+                    return mdurl__namespace.decode(mdurl__namespace.format(parsed), mdurl__namespace.decode.defaultChars + '%');\n+                }\n \n-                            function ba(e, t) {\n-                                var i = Ee && e.markedSpans,\n-                                    r;\n-                                if (i)\n-                                    for (var n = 0; n < i.length; ++n) {\n-                                        var l = i[n];\n-                                        l.marker.collapsed && (l.from == null || l.from < t) && (l.to == null || l.to > t) && (!r || Ii(r, l.marker) < 0) && (r = l.marker);\n-                                    }\n-                                return r;\n-                            }\n-                            u(ba, \"collapsedSpanAround\");\n+                /**\n+                 * class MarkdownIt\n+                 *\n+                 * Main parser/renderer class.\n+                 *\n+                 * ##### Usage\n+                 *\n+                 * ```javascript\n+                 * // node.js, \"classic\" way:\n+                 * var MarkdownIt = require('markdown-it'),\n+                 *     md = new MarkdownIt();\n+                 * var result = md.render('# markdown-it rulezz!');\n+                 *\n+                 * // node.js, the same, but with sugar:\n+                 * var md = require('markdown-it')();\n+                 * var result = md.render('# markdown-it rulezz!');\n+                 *\n+                 * // browser without AMD, added to \"window\" on script load\n+                 * // Note, there are no dash.\n+                 * var md = window.markdownit();\n+                 * var result = md.render('# markdown-it rulezz!');\n+                 * ```\n+                 *\n+                 * Single line rendering, without paragraph wrap:\n+                 *\n+                 * ```javascript\n+                 * var md = require('markdown-it')();\n+                 * var result = md.renderInline('__markdown-it__ rulezz!');\n+                 * ```\n+                 **/\n \n-                            function il(e, t, i, r, n) {\n-                                var l = S(e, t),\n-                                    o = Ee && l.markedSpans;\n-                                if (o)\n-                                    for (var a = 0; a < o.length; ++a) {\n-                                        var s = o[a];\n-                                        if (s.marker.collapsed) {\n-                                            var f = s.marker.find(0),\n-                                                h = D(f.from, i) || Rr(s.marker) - Rr(n),\n-                                                c = D(f.to, r) || Br(s.marker) - Br(n);\n-                                            if (!(h >= 0 && c <= 0 || h <= 0 && c >= 0) && (h <= 0 && (s.marker.inclusiveRight && n.inclusiveLeft ? D(f.to, i) >= 0 : D(f.to, i) > 0) || h >= 0 && (s.marker.inclusiveRight && n.inclusiveLeft ? D(f.from, r) <= 0 : D(f.from, r) < 0))) return !0;\n-                                        }\n-                                    }\n-                            }\n-                            u(il, \"conflictingCollapsedRange\");\n+                /**\n+                 * new MarkdownIt([presetName, options])\n+                 * - presetName (String): optional, `commonmark` / `zero`\n+                 * - options (Object)\n+                 *\n+                 * Creates parser instanse with given config. Can be called without `new`.\n+                 *\n+                 * ##### presetName\n+                 *\n+                 * MarkdownIt provides named presets as a convenience to quickly\n+                 * enable/disable active syntax rules and options for common use cases.\n+                 *\n+                 * - [\"commonmark\"](https://github.com/markdown-it/markdown-it/blob/master/lib/presets/commonmark.mjs) -\n+                 *   configures parser to strict [CommonMark](http://commonmark.org/) mode.\n+                 * - [default](https://github.com/markdown-it/markdown-it/blob/master/lib/presets/default.mjs) -\n+                 *   similar to GFM, used when no preset name given. Enables all available rules,\n+                 *   but still without html, typographer & autolinker.\n+                 * - [\"zero\"](https://github.com/markdown-it/markdown-it/blob/master/lib/presets/zero.mjs) -\n+                 *   all rules disabled. Useful to quickly setup your config via `.enable()`.\n+                 *   For example, when you need only `bold` and `italic` markup and nothing else.\n+                 *\n+                 * ##### options:\n+                 *\n+                 * - __html__ - `false`. Set `true` to enable HTML tags in source. Be careful!\n+                 *   That's not safe! You may need external sanitizer to protect output from XSS.\n+                 *   It's better to extend features via plugins, instead of enabling HTML.\n+                 * - __xhtmlOut__ - `false`. Set `true` to add '/' when closing single tags\n+                 *   (`<br />`). This is needed only for full CommonMark compatibility. In real\n+                 *   world you will need HTML output.\n+                 * - __breaks__ - `false`. Set `true` to convert `\\n` in paragraphs into `<br>`.\n+                 * - __langPrefix__ - `language-`. CSS language class prefix for fenced blocks.\n+                 *   Can be useful for external highlighters.\n+                 * - __linkify__ - `false`. Set `true` to autoconvert URL-like text to links.\n+                 * - __typographer__  - `false`. Set `true` to enable [some language-neutral\n+                 *   replacement](https://github.com/markdown-it/markdown-it/blob/master/lib/rules_core/replacements.mjs) +\n+                 *   quotes beautification (smartquotes).\n+                 * - __quotes__ - `\u201c\u201d\u2018\u2019`, String or Array. Double + single quotes replacement\n+                 *   pairs, when typographer enabled and smartquotes on. For example, you can\n+                 *   use `'\u00ab\u00bb\u201e\u201c'` for Russian, `'\u201e\u201c\u201a\u2018'` for German, and\n+                 *   `['\u00ab\\xA0', '\\xA0\u00bb', '\u2039\\xA0', '\\xA0\u203a']` for French (including nbsp).\n+                 * - __highlight__ - `null`. Highlighter function for fenced code blocks.\n+                 *   Highlighter `function (str, lang)` should return escaped HTML. It can also\n+                 *   return empty string if the source was not changed and should be escaped\n+                 *   externaly. If result starts with <pre... internal wrapper is skipped.\n+                 *\n+                 * ##### Example\n+                 *\n+                 * ```javascript\n+                 * // commonmark mode\n+                 * var md = require('markdown-it')('commonmark');\n+                 *\n+                 * // default mode\n+                 * var md = require('markdown-it')();\n+                 *\n+                 * // enable everything\n+                 * var md = require('markdown-it')({\n+                 *   html: true,\n+                 *   linkify: true,\n+                 *   typographer: true\n+                 * });\n+                 * ```\n+                 *\n+                 * ##### Syntax highlighting\n+                 *\n+                 * ```js\n+                 * var hljs = require('highlight.js') // https://highlightjs.org/\n+                 *\n+                 * var md = require('markdown-it')({\n+                 *   highlight: function (str, lang) {\n+                 *     if (lang && hljs.getLanguage(lang)) {\n+                 *       try {\n+                 *         return hljs.highlight(str, { language: lang, ignoreIllegals: true }).value;\n+                 *       } catch (__) {}\n+                 *     }\n+                 *\n+                 *     return ''; // use external default escaping\n+                 *   }\n+                 * });\n+                 * ```\n+                 *\n+                 * Or with full wrapper override (if you need assign class to `<pre>` or `<code>`):\n+                 *\n+                 * ```javascript\n+                 * var hljs = require('highlight.js') // https://highlightjs.org/\n+                 *\n+                 * // Actual default values\n+                 * var md = require('markdown-it')({\n+                 *   highlight: function (str, lang) {\n+                 *     if (lang && hljs.getLanguage(lang)) {\n+                 *       try {\n+                 *         return '<pre><code class=\"hljs\">' +\n+                 *                hljs.highlight(str, { language: lang, ignoreIllegals: true }).value +\n+                 *                '</code></pre>';\n+                 *       } catch (__) {}\n+                 *     }\n+                 *\n+                 *     return '<pre><code class=\"hljs\">' + md.utils.escapeHtml(str) + '</code></pre>';\n+                 *   }\n+                 * });\n+                 * ```\n+                 *\n+                 **/\n+                function MarkdownIt(presetName, options) {\n+                    if (!(this instanceof MarkdownIt)) {\n+                        return new MarkdownIt(presetName, options);\n+                    }\n+                    if (!options) {\n+                        if (!isString(presetName)) {\n+                            options = presetName || {};\n+                            presetName = 'default';\n+                        }\n+                    }\n \n-                            function Se(e) {\n-                                for (var t; t = rl(e);) e = t.find(-1, !0).line;\n-                                return e;\n-                            }\n-                            u(Se, \"visualLine\");\n+                    /**\n+                     * MarkdownIt#inline -> ParserInline\n+                     *\n+                     * Instance of [[ParserInline]]. You may need it to add new rules when\n+                     * writing plugins. For simple rules control use [[MarkdownIt.disable]] and\n+                     * [[MarkdownIt.enable]].\n+                     **/\n+                    this.inline = new ParserInline();\n \n-                            function xa(e) {\n-                                for (var t; t = zr(e);) e = t.find(1, !0).line;\n-                                return e;\n-                            }\n-                            u(xa, \"visualLineEnd\");\n+                    /**\n+                     * MarkdownIt#block -> ParserBlock\n+                     *\n+                     * Instance of [[ParserBlock]]. You may need it to add new rules when\n+                     * writing plugins. For simple rules control use [[MarkdownIt.disable]] and\n+                     * [[MarkdownIt.enable]].\n+                     **/\n+                    this.block = new ParserBlock();\n \n-                            function Ca(e) {\n-                                for (var t, i; t = zr(e);) e = t.find(1, !0).line, (i || (i = [])).push(e);\n-                                return i;\n-                            }\n-                            u(Ca, \"visualLineContinued\");\n+                    /**\n+                     * MarkdownIt#core -> Core\n+                     *\n+                     * Instance of [[Core]] chain executor. You may need it to add new rules when\n+                     * writing plugins. For simple rules control use [[MarkdownIt.disable]] and\n+                     * [[MarkdownIt.enable]].\n+                     **/\n+                    this.core = new Core();\n \n-                            function Ri(e, t) {\n-                                var i = S(e, t),\n-                                    r = Se(i);\n-                                return i == r ? t : F(r);\n-                            }\n-                            u(Ri, \"visualLineNo\");\n-\n-                            function nl(e, t) {\n-                                if (t > e.lastLine()) return t;\n-                                var i = S(e, t),\n-                                    r;\n-                                if (!Xe(e, i)) return t;\n-                                for (; r = zr(i);) i = r.find(1, !0).line;\n-                                return F(i) + 1;\n-                            }\n-                            u(nl, \"visualLineEndNo\");\n-\n-                            function Xe(e, t) {\n-                                var i = Ee && t.markedSpans;\n-                                if (i) {\n-                                    for (var r = void 0, n = 0; n < i.length; ++n)\n-                                        if (r = i[n], !!r.marker.collapsed) {\n-                                            if (r.from == null) return !0;\n-                                            if (!r.marker.widgetNode && r.from == 0 && r.marker.inclusiveLeft && Bi(e, t, r)) return !0;\n-                                        }\n-                                }\n-                            }\n-                            u(Xe, \"lineIsHidden\");\n+                    /**\n+                     * MarkdownIt#renderer -> Renderer\n+                     *\n+                     * Instance of [[Renderer]]. Use it to modify output look. Or to add rendering\n+                     * rules for new token types, generated by plugins.\n+                     *\n+                     * ##### Example\n+                     *\n+                     * ```javascript\n+                     * var md = require('markdown-it')();\n+                     *\n+                     * function myToken(tokens, idx, options, env, self) {\n+                     *   //...\n+                     *   return result;\n+                     * };\n+                     *\n+                     * md.renderer.rules['my_token'] = myToken\n+                     * ```\n+                     *\n+                     * See [[Renderer]] docs and [source code](https://github.com/markdown-it/markdown-it/blob/master/lib/renderer.mjs).\n+                     **/\n+                    this.renderer = new Renderer();\n \n-                            function Bi(e, t, i) {\n-                                if (i.to == null) {\n-                                    var r = i.marker.find(1, !0);\n-                                    return Bi(e, r.line, Vt(r.line.markedSpans, i.marker));\n-                                }\n-                                if (i.marker.inclusiveRight && i.to == t.text.length) return !0;\n-                                for (var n = void 0, l = 0; l < t.markedSpans.length; ++l)\n-                                    if (n = t.markedSpans[l], n.marker.collapsed && !n.marker.widgetNode && n.from == i.to && (n.to == null || n.to != i.from) && (n.marker.inclusiveLeft || i.marker.inclusiveRight) && Bi(e, t, n)) return !0;\n-                            }\n-                            u(Bi, \"lineIsHiddenInner\");\n-\n-                            function Ie(e) {\n-                                e = Se(e);\n-                                for (var t = 0, i = e.parent, r = 0; r < i.lines.length; ++r) {\n-                                    var n = i.lines[r];\n-                                    if (n == e) break;\n-                                    t += n.height;\n-                                }\n-                                for (var l = i.parent; l; i = l, l = i.parent)\n-                                    for (var o = 0; o < l.children.length; ++o) {\n-                                        var a = l.children[o];\n-                                        if (a == i) break;\n-                                        t += a.height;\n-                                    }\n-                                return t;\n-                            }\n-                            u(Ie, \"heightAtLine\");\n-\n-                            function Gr(e) {\n-                                if (e.height == 0) return 0;\n-                                for (var t = e.text.length, i, r = e; i = rl(r);) {\n-                                    var n = i.find(0, !0);\n-                                    r = n.from.line, t += n.from.ch - n.to.ch;\n-                                }\n-                                for (r = e; i = zr(r);) {\n-                                    var l = i.find(0, !0);\n-                                    t -= r.text.length - l.from.ch, r = l.to.line, t += r.text.length - l.to.ch;\n-                                }\n-                                return t;\n-                            }\n-                            u(Gr, \"lineLength\");\n-\n-                            function zi(e) {\n-                                var t = e.display,\n-                                    i = e.doc;\n-                                t.maxLine = S(i, i.first), t.maxLineLength = Gr(t.maxLine), t.maxLineChanged = !0, i.iter(function(r) {\n-                                    var n = Gr(r);\n-                                    n > t.maxLineLength && (t.maxLineLength = n, t.maxLine = r);\n-                                });\n-                            }\n-                            u(zi, \"findMaxLine\");\n-                            var St = u(function(e, t, i) {\n-                                this.text = e, el(this, t), this.height = i ? i(this) : 1;\n-                            }, \"Line\");\n-                            St.prototype.lineNo = function() {\n-                                return F(this);\n-                            }, xt(St);\n-\n-                            function wa(e, t, i, r) {\n-                                e.text = t, e.stateAfter && (e.stateAfter = null), e.styles && (e.styles = null), e.order != null && (e.order = null), $n(e), el(e, i);\n-                                var n = r ? r(e) : 1;\n-                                n != e.height && De(e, n);\n-                            }\n-                            u(wa, \"updateLine\");\n-\n-                            function Sa(e) {\n-                                e.parent = null, $n(e);\n-                            }\n-                            u(Sa, \"cleanUpLine\");\n-                            var La = {},\n-                                ka = {};\n-\n-                            function ll(e, t) {\n-                                if (!e || /^\\s*$/.test(e)) return null;\n-                                var i = t.addModeClass ? ka : La;\n-                                return i[e] || (i[e] = e.replace(/\\S+/g, \"cm-$&\"));\n-                            }\n-                            u(ll, \"interpretTokenStyle\");\n-\n-                            function ol(e, t) {\n-                                var i = bt(\"span\", null, null, ne ? \"padding-right: .1px\" : null),\n-                                    r = {\n-                                        pre: bt(\"pre\", [i], \"CodeMirror-line\"),\n-                                        content: i,\n-                                        col: 0,\n-                                        pos: 0,\n-                                        cm: e,\n-                                        trailingSpace: !1,\n-                                        splitSpaces: e.getOption(\"lineWrapping\")\n-                                    };\n-                                t.measure = {};\n-                                for (var n = 0; n <= (t.rest ? t.rest.length : 0); n++) {\n-                                    var l = n ? t.rest[n - 1] : t.line,\n-                                        o = void 0;\n-                                    r.pos = 0, r.addToken = Ma, ra(e.display.measure) && (o = Pe(l, e.doc.direction)) && (r.addToken = Na(r.addToken, o)), r.map = [];\n-                                    var a = t != e.display.externalMeasured && F(l);\n-                                    Aa(l, r, Xn(e, l, a)), l.styleClasses && (l.styleClasses.bgClass && (r.bgClass = di(l.styleClasses.bgClass, r.bgClass || \"\")), l.styleClasses.textClass && (r.textClass = di(l.styleClasses.textClass, r.textClass || \"\"))), r.map.length == 0 && r.map.push(0, 0, r.content.appendChild(ta(e.display.measure))), n == 0 ? (t.measure.map = r.map, t.measure.cache = {}) : ((t.measure.maps || (t.measure.maps = [])).push(r.map), (t.measure.caches || (t.measure.caches = [])).push({}));\n-                                }\n-                                if (ne) {\n-                                    var s = r.content.lastChild;\n-                                    (/\\bcm-tab\\b/.test(s.className) || s.querySelector && s.querySelector(\".cm-tab\")) && (r.content.className = \"cm-tab-wrap-hack\");\n-                                }\n-                                return U(e, \"renderLine\", e, t.line, r.pre), r.pre.className && (r.textClass = di(r.pre.className, r.textClass || \"\")), r;\n-                            }\n-                            u(ol, \"buildLineContent\");\n-\n-                            function Ta(e) {\n-                                var t = T(\"span\", \"\u2022\", \"cm-invalidchar\");\n-                                return t.title = \"\\\\u\" + e.charCodeAt(0).toString(16), t.setAttribute(\"aria-label\", t.title), t;\n-                            }\n-                            u(Ta, \"defaultSpecialCharPlaceholder\");\n-\n-                            function Ma(e, t, i, r, n, l, o) {\n-                                if (t) {\n-                                    var a = e.splitSpaces ? Da(t, e.trailingSpace) : t,\n-                                        s = e.cm.state.specialChars,\n-                                        f = !1,\n-                                        h;\n-                                    if (!s.test(t)) e.col += t.length, h = document.createTextNode(a), e.map.push(e.pos, e.pos + t.length, h), O && I < 9 && (f = !0), e.pos += t.length;\n-                                    else {\n-                                        h = document.createDocumentFragment();\n-                                        for (var c = 0;;) {\n-                                            s.lastIndex = c;\n-                                            var p = s.exec(t),\n-                                                d = p ? p.index - c : t.length - c;\n-                                            if (d) {\n-                                                var v = document.createTextNode(a.slice(c, c + d));\n-                                                O && I < 9 ? h.appendChild(T(\"span\", [v])) : h.appendChild(v), e.map.push(e.pos, e.pos + d, v), e.col += d, e.pos += d;\n-                                            }\n-                                            if (!p) break;\n-                                            c += d + 1;\n-                                            var g = void 0;\n-                                            if (p[0] == \"\t\") {\n-                                                var m = e.cm.options.tabSize,\n-                                                    b = m - e.col % m;\n-                                                g = h.appendChild(T(\"span\", yi(b), \"cm-tab\")), g.setAttribute(\"role\", \"presentation\"), g.setAttribute(\"cm-text\", \"\t\"), e.col += b;\n-                                            } else p[0] == \"\\r\" || p[0] == `\n-` ? (g = h.appendChild(T(\"span\", p[0] == \"\\r\" ? \"\u240d\" : \"\u2424\", \"cm-invalidchar\")), g.setAttribute(\"cm-text\", p[0]), e.col += 1) : (g = e.cm.options.specialCharPlaceholder(p[0]), g.setAttribute(\"cm-text\", p[0]), O && I < 9 ? h.appendChild(T(\"span\", [g])) : h.appendChild(g), e.col += 1);\n-                                            e.map.push(e.pos, e.pos + 1, g), e.pos++;\n-                                        }\n-                                    }\n-                                    if (e.trailingSpace = a.charCodeAt(t.length - 1) == 32, i || r || n || f || l || o) {\n-                                        var C = i || \"\";\n-                                        r && (C += r), n && (C += n);\n-                                        var x = T(\"span\", [h], C, l);\n-                                        if (o)\n-                                            for (var w in o) o.hasOwnProperty(w) && w != \"style\" && w != \"class\" && x.setAttribute(w, o[w]);\n-                                        return e.content.appendChild(x);\n-                                    }\n-                                    e.content.appendChild(h);\n-                                }\n-                            }\n-                            u(Ma, \"buildToken\");\n-\n-                            function Da(e, t) {\n-                                if (e.length > 1 && !/  /.test(e)) return e;\n-                                for (var i = t, r = \"\", n = 0; n < e.length; n++) {\n-                                    var l = e.charAt(n);\n-                                    l == \" \" && i && (n == e.length - 1 || e.charCodeAt(n + 1) == 32) && (l = \"\u00a0\"), r += l, i = l == \" \";\n-                                }\n-                                return r;\n-                            }\n-                            u(Da, \"splitSpaces\");\n+                    /**\n+                     * MarkdownIt#linkify -> LinkifyIt\n+                     *\n+                     * [linkify-it](https://github.com/markdown-it/linkify-it) instance.\n+                     * Used by [linkify](https://github.com/markdown-it/markdown-it/blob/master/lib/rules_core/linkify.mjs)\n+                     * rule.\n+                     **/\n+                    this.linkify = new LinkifyIt();\n \n-                            function Na(e, t) {\n-                                return function(i, r, n, l, o, a, s) {\n-                                    n = n ? n + \" cm-force-border\" : \"cm-force-border\";\n-                                    for (var f = i.pos, h = f + r.length;;) {\n-                                        for (var c = void 0, p = 0; p < t.length && (c = t[p], !(c.to > f && c.from <= f)); p++);\n-                                        if (c.to >= h) return e(i, r, n, l, o, a, s);\n-                                        e(i, r.slice(0, c.to - f), n, l, null, a, s), l = null, r = r.slice(c.to - f), f = c.to;\n-                                    }\n-                                };\n-                            }\n-                            u(Na, \"buildTokenBadBidi\");\n+                    /**\n+                     * MarkdownIt#validateLink(url) -> Boolean\n+                     *\n+                     * Link validation function. CommonMark allows too much in links. By default\n+                     * we disable `javascript:`, `vbscript:`, `file:` schemas, and almost all `data:...` schemas\n+                     * except some embedded image types.\n+                     *\n+                     * You can change this behaviour:\n+                     *\n+                     * ```javascript\n+                     * var md = require('markdown-it')();\n+                     * // enable everything\n+                     * md.validateLink = function () { return true; }\n+                     * ```\n+                     **/\n+                    this.validateLink = validateLink;\n \n-                            function al(e, t, i, r) {\n-                                var n = !r && i.widgetNode;\n-                                n && e.map.push(e.pos, e.pos + t, n), !r && e.cm.display.input.needsContentAttribute && (n || (n = e.content.appendChild(document.createElement(\"span\"))), n.setAttribute(\"cm-marker\", i.id)), n && (e.cm.display.input.setUneditable(n), e.content.appendChild(n)), e.pos += t, e.trailingSpace = !1;\n-                            }\n-                            u(al, \"buildCollapsedSpan\");\n-\n-                            function Aa(e, t, i) {\n-                                var r = e.markedSpans,\n-                                    n = e.text,\n-                                    l = 0;\n-                                if (!r) {\n-                                    for (var o = 1; o < i.length; o += 2) t.addToken(t, n.slice(l, l = i[o]), ll(i[o + 1], t.cm.options));\n-                                    return;\n-                                }\n-                                for (var a = n.length, s = 0, f = 1, h = \"\", c, p, d = 0, v, g, m, b, C;;) {\n-                                    if (d == s) {\n-                                        v = g = m = p = \"\", C = null, b = null, d = 1 / 0;\n-                                        for (var x = [], w = void 0, k = 0; k < r.length; ++k) {\n-                                            var L = r[k],\n-                                                A = L.marker;\n-                                            if (A.type == \"bookmark\" && L.from == s && A.widgetNode) x.push(A);\n-                                            else if (L.from <= s && (L.to == null || L.to > s || A.collapsed && L.to == s && L.from == s)) {\n-                                                if (L.to != null && L.to != s && d > L.to && (d = L.to, g = \"\"), A.className && (v += \" \" + A.className), A.css && (p = (p ? p + \";\" : \"\") + A.css), A.startStyle && L.from == s && (m += \" \" + A.startStyle), A.endStyle && L.to == d && (w || (w = [])).push(A.endStyle, L.to), A.title && ((C || (C = {})).title = A.title), A.attributes)\n-                                                    for (var E in A.attributes)(C || (C = {}))[E] = A.attributes[E];\n-                                                A.collapsed && (!b || Ii(b.marker, A) < 0) && (b = L);\n-                                            } else L.from > s && d > L.from && (d = L.from);\n-                                        }\n-                                        if (w)\n-                                            for (var j = 0; j < w.length; j += 2) w[j + 1] == d && (g += \" \" + w[j]);\n-                                        if (!b || b.from == s)\n-                                            for (var B = 0; B < x.length; ++B) al(t, 0, x[B]);\n-                                        if (b && (b.from || 0) == s) {\n-                                            if (al(t, (b.to == null ? a + 1 : b.to) - s, b.marker, b.from == null), b.to == null) return;\n-                                            b.to == s && (b = !1);\n-                                        }\n-                                    }\n-                                    if (s >= a) break;\n-                                    for (var pe = Math.min(a, d);;) {\n-                                        if (h) {\n-                                            var fe = s + h.length;\n-                                            if (!b) {\n-                                                var _ = fe > pe ? h.slice(0, pe - s) : h;\n-                                                t.addToken(t, _, c ? c + v : v, m, s + _.length == d ? g : \"\", p, C);\n-                                            }\n-                                            if (fe >= pe) {\n-                                                h = h.slice(pe - s), s = pe;\n-                                                break;\n-                                            }\n-                                            s = fe, m = \"\";\n-                                        }\n-                                        h = n.slice(l, l = i[f++]), c = ll(i[f++], t.cm.options);\n-                                    }\n-                                }\n-                            }\n-                            u(Aa, \"insertLineContent\");\n+                    /**\n+                     * MarkdownIt#normalizeLink(url) -> String\n+                     *\n+                     * Function used to encode link url to a machine-readable format,\n+                     * which includes url-encoding, punycode, etc.\n+                     **/\n+                    this.normalizeLink = normalizeLink;\n \n-                            function sl(e, t, i) {\n-                                this.line = t, this.rest = Ca(t), this.size = this.rest ? F(H(this.rest)) - i + 1 : 1, this.node = this.text = null, this.hidden = Xe(e, t);\n-                            }\n-                            u(sl, \"LineView\");\n+                    /**\n+                     * MarkdownIt#normalizeLinkText(url) -> String\n+                     *\n+                     * Function used to decode link url to a human-readable format`\n+                     **/\n+                    this.normalizeLinkText = normalizeLinkText;\n \n-                            function Ur(e, t, i) {\n-                                for (var r = [], n, l = t; l < i; l = n) {\n-                                    var o = new sl(e.doc, S(e.doc, l), l);\n-                                    n = l + o.size, r.push(o);\n-                                }\n-                                return r;\n-                            }\n-                            u(Ur, \"buildViewArray\");\n-                            var Lt = null;\n+                    // Expose utils & helpers for easy acces from plugins\n \n-                            function Oa(e) {\n-                                Lt ? Lt.ops.push(e) : e.ownsGroup = Lt = {\n-                                    ops: [e],\n-                                    delayedCallbacks: []\n-                                };\n-                            }\n-                            u(Oa, \"pushOperation\");\n+                    /**\n+                     * MarkdownIt#utils -> utils\n+                     *\n+                     * Assorted utility functions, useful to write plugins. See details\n+                     * [here](https://github.com/markdown-it/markdown-it/blob/master/lib/common/utils.mjs).\n+                     **/\n+                    this.utils = utils;\n \n-                            function Wa(e) {\n-                                var t = e.delayedCallbacks,\n-                                    i = 0;\n-                                do {\n-                                    for (; i < t.length; i++) t[i].call(null);\n-                                    for (var r = 0; r < e.ops.length; r++) {\n-                                        var n = e.ops[r];\n-                                        if (n.cursorActivityHandlers)\n-                                            for (; n.cursorActivityCalled < n.cursorActivityHandlers.length;) n.cursorActivityHandlers[n.cursorActivityCalled++].call(null, n.cm);\n-                                    }\n-                                } while (i < t.length);\n-                            }\n-                            u(Wa, \"fireCallbacksForOps\");\n-\n-                            function Ha(e, t) {\n-                                var i = e.ownsGroup;\n-                                if (i) try {\n-                                    Wa(i);\n-                                } finally {\n-                                    Lt = null, t(i);\n-                                }\n+                    /**\n+                     * MarkdownIt#helpers -> helpers\n+                     *\n+                     * Link components parser functions, useful to write plugins. See details\n+                     * [here](https://github.com/markdown-it/markdown-it/blob/master/lib/helpers).\n+                     **/\n+                    this.helpers = assign({}, helpers);\n+                    this.options = {};\n+                    this.configure(presetName);\n+                    if (options) {\n+                        this.set(options);\n+                    }\n+                }\n+\n+                /** chainable\n+                 * MarkdownIt.set(options)\n+                 *\n+                 * Set parser options (in the same format as in constructor). Probably, you\n+                 * will never need it, but you can change options after constructor call.\n+                 *\n+                 * ##### Example\n+                 *\n+                 * ```javascript\n+                 * var md = require('markdown-it')()\n+                 *             .set({ html: true, breaks: true })\n+                 *             .set({ typographer, true });\n+                 * ```\n+                 *\n+                 * __Note:__ To achieve the best possible performance, don't modify a\n+                 * `markdown-it` instance options on the fly. If you need multiple configurations\n+                 * it's best to create multiple instances and initialize each with separate\n+                 * config.\n+                 **/\n+                MarkdownIt.prototype.set = function(options) {\n+                    assign(this.options, options);\n+                    return this;\n+                };\n+\n+                /** chainable, internal\n+                 * MarkdownIt.configure(presets)\n+                 *\n+                 * Batch load of all options and compenent settings. This is internal method,\n+                 * and you probably will not need it. But if you will - see available presets\n+                 * and data structure [here](https://github.com/markdown-it/markdown-it/tree/master/lib/presets)\n+                 *\n+                 * We strongly recommend to use presets instead of direct config loads. That\n+                 * will give better compatibility with next versions.\n+                 **/\n+                MarkdownIt.prototype.configure = function(presets) {\n+                    const self = this;\n+                    if (isString(presets)) {\n+                        const presetName = presets;\n+                        presets = config[presetName];\n+                        if (!presets) {\n+                            throw new Error('Wrong `markdown-it` preset \"' + presetName + '\", check name');\n+                        }\n+                    }\n+                    if (!presets) {\n+                        throw new Error('Wrong `markdown-it` preset, can\\'t be empty');\n+                    }\n+                    if (presets.options) {\n+                        self.set(presets.options);\n+                    }\n+                    if (presets.components) {\n+                        Object.keys(presets.components).forEach(function(name) {\n+                            if (presets.components[name].rules) {\n+                                self[name].ruler.enableOnly(presets.components[name].rules);\n+                            }\n+                            if (presets.components[name].rules2) {\n+                                self[name].ruler2.enableOnly(presets.components[name].rules2);\n                             }\n-                            u(Ha, \"finishOperation\");\n-                            var $t = null;\n+                        });\n+                    }\n+                    return this;\n+                };\n+\n+                /** chainable\n+                 * MarkdownIt.enable(list, ignoreInvalid)\n+                 * - list (String|Array): rule name or list of rule names to enable\n+                 * - ignoreInvalid (Boolean): set `true` to ignore errors when rule not found.\n+                 *\n+                 * Enable list or rules. It will automatically find appropriate components,\n+                 * containing rules with given names. If rule not found, and `ignoreInvalid`\n+                 * not set - throws exception.\n+                 *\n+                 * ##### Example\n+                 *\n+                 * ```javascript\n+                 * var md = require('markdown-it')()\n+                 *             .enable(['sub', 'sup'])\n+                 *             .disable('smartquotes');\n+                 * ```\n+                 **/\n+                MarkdownIt.prototype.enable = function(list, ignoreInvalid) {\n+                    let result = [];\n+                    if (!Array.isArray(list)) {\n+                        list = [list];\n+                    }\n+                    ['core', 'block', 'inline'].forEach(function(chain) {\n+                        result = result.concat(this[chain].ruler.enable(list, true));\n+                    }, this);\n+                    result = result.concat(this.inline.ruler2.enable(list, true));\n+                    const missed = list.filter(function(name) {\n+                        return result.indexOf(name) < 0;\n+                    });\n+                    if (missed.length && !ignoreInvalid) {\n+                        throw new Error('MarkdownIt. Failed to enable unknown rule(s): ' + missed);\n+                    }\n+                    return this;\n+                };\n+\n+                /** chainable\n+                 * MarkdownIt.disable(list, ignoreInvalid)\n+                 * - list (String|Array): rule name or list of rule names to disable.\n+                 * - ignoreInvalid (Boolean): set `true` to ignore errors when rule not found.\n+                 *\n+                 * The same as [[MarkdownIt.enable]], but turn specified rules off.\n+                 **/\n+                MarkdownIt.prototype.disable = function(list, ignoreInvalid) {\n+                    let result = [];\n+                    if (!Array.isArray(list)) {\n+                        list = [list];\n+                    }\n+                    ['core', 'block', 'inline'].forEach(function(chain) {\n+                        result = result.concat(this[chain].ruler.disable(list, true));\n+                    }, this);\n+                    result = result.concat(this.inline.ruler2.disable(list, true));\n+                    const missed = list.filter(function(name) {\n+                        return result.indexOf(name) < 0;\n+                    });\n+                    if (missed.length && !ignoreInvalid) {\n+                        throw new Error('MarkdownIt. Failed to disable unknown rule(s): ' + missed);\n+                    }\n+                    return this;\n+                };\n \n-                            function Z(e, t) {\n-                                var i = xi(e, t);\n-                                if (i.length) {\n-                                    var r = Array.prototype.slice.call(arguments, 2),\n-                                        n;\n-                                    Lt ? n = Lt.delayedCallbacks : $t ? n = $t : (n = $t = [], setTimeout(Fa, 0));\n-                                    for (var l = u(function(a) {\n-                                            n.push(function() {\n-                                                return i[a].apply(null, r);\n-                                            });\n-                                        }, \"loop\"), o = 0; o < i.length; ++o) l(o);\n-                                }\n-                            }\n-                            u(Z, \"signalLater\");\n+                /** chainable\n+                 * MarkdownIt.use(plugin, params)\n+                 *\n+                 * Load specified plugin with given params into current parser instance.\n+                 * It's just a sugar to call `plugin(md, params)` with curring.\n+                 *\n+                 * ##### Example\n+                 *\n+                 * ```javascript\n+                 * var iterator = require('markdown-it-for-inline');\n+                 * var md = require('markdown-it')()\n+                 *             .use(iterator, 'foo_replace', 'text', function (tokens, idx) {\n+                 *               tokens[idx].content = tokens[idx].content.replace(/foo/g, 'bar');\n+                 *             });\n+                 * ```\n+                 **/\n+                MarkdownIt.prototype.use = function(plugin /*, params, ... */ ) {\n+                    const args = [this].concat(Array.prototype.slice.call(arguments, 1));\n+                    plugin.apply(plugin, args);\n+                    return this;\n+                };\n \n-                            function Fa() {\n-                                var e = $t;\n-                                $t = null;\n-                                for (var t = 0; t < e.length; ++t) e[t]();\n-                            }\n-                            u(Fa, \"fireOrphanDelayed\");\n+                /** internal\n+                 * MarkdownIt.parse(src, env) -> Array\n+                 * - src (String): source string\n+                 * - env (Object): environment sandbox\n+                 *\n+                 * Parse input string and return list of block tokens (special token type\n+                 * \"inline\" will contain list of inline tokens). You should not call this\n+                 * method directly, until you write custom renderer (for example, to produce\n+                 * AST).\n+                 *\n+                 * `env` is used to pass data between \"distributed\" rules and return additional\n+                 * metadata like reference info, needed for the renderer. It also can be used to\n+                 * inject data in specific cases. Usually, you will be ok to pass `{}`,\n+                 * and then pass updated object to renderer.\n+                 **/\n+                MarkdownIt.prototype.parse = function(src, env) {\n+                    if (typeof src !== 'string') {\n+                        throw new Error('Input data should be a String');\n+                    }\n+                    const state = new this.core.State(src, this, env);\n+                    this.core.process(state);\n+                    return state.tokens;\n+                };\n \n-                            function ul(e, t, i, r) {\n-                                for (var n = 0; n < t.changes.length; n++) {\n-                                    var l = t.changes[n];\n-                                    l == \"text\" ? Ea(e, t) : l == \"gutter\" ? hl(e, t, i, r) : l == \"class\" ? Gi(e, t) : l == \"widget\" && Ia(e, t, r);\n-                                }\n-                                t.changes = null;\n-                            }\n-                            u(ul, \"updateLineForChanges\");\n+                /**\n+                 * MarkdownIt.render(src [, env]) -> String\n+                 * - src (String): source string\n+                 * - env (Object): environment sandbox\n+                 *\n+                 * Render markdown string into html. It does all magic for you :).\n+                 *\n+                 * `env` can be used to inject additional metadata (`{}` by default).\n+                 * But you will not need it with high probability. See also comment\n+                 * in [[MarkdownIt.parse]].\n+                 **/\n+                MarkdownIt.prototype.render = function(src, env) {\n+                    env = env || {};\n+                    return this.renderer.render(this.parse(src, env), this.options, env);\n+                };\n \n-                            function er(e) {\n-                                return e.node == e.text && (e.node = T(\"div\", null, null, \"position: relative\"), e.text.parentNode && e.text.parentNode.replaceChild(e.node, e.text), e.node.appendChild(e.text), O && I < 8 && (e.node.style.zIndex = 2)), e.node;\n-                            }\n-                            u(er, \"ensureLineWrapped\");\n+                /** internal\n+                 * MarkdownIt.parseInline(src, env) -> Array\n+                 * - src (String): source string\n+                 * - env (Object): environment sandbox\n+                 *\n+                 * The same as [[MarkdownIt.parse]] but skip all block rules. It returns the\n+                 * block tokens list with the single `inline` element, containing parsed inline\n+                 * tokens in `children` property. Also updates `env` object.\n+                 **/\n+                MarkdownIt.prototype.parseInline = function(src, env) {\n+                    const state = new this.core.State(src, this, env);\n+                    state.inlineMode = true;\n+                    this.core.process(state);\n+                    return state.tokens;\n+                };\n \n-                            function Pa(e, t) {\n-                                var i = t.bgClass ? t.bgClass + \" \" + (t.line.bgClass || \"\") : t.line.bgClass;\n-                                if (i && (i += \" CodeMirror-linebackground\"), t.background) i ? t.background.className = i : (t.background.parentNode.removeChild(t.background), t.background = null);\n-                                else if (i) {\n-                                    var r = er(t);\n-                                    t.background = r.insertBefore(T(\"div\", null, i), r.firstChild), e.display.input.setUneditable(t.background);\n-                                }\n-                            }\n-                            u(Pa, \"updateLineBackground\");\n+                /**\n+                 * MarkdownIt.renderInline(src [, env]) -> String\n+                 * - src (String): source string\n+                 * - env (Object): environment sandbox\n+                 *\n+                 * Similar to [[MarkdownIt.render]] but for single paragraph content. Result\n+                 * will NOT be wrapped into `<p>` tags.\n+                 **/\n+                MarkdownIt.prototype.renderInline = function(src, env) {\n+                    env = env || {};\n+                    return this.renderer.render(this.parseInline(src, env), this.options, env);\n+                };\n+                module.exports = MarkdownIt;\n \n-                            function fl(e, t) {\n-                                var i = e.display.externalMeasured;\n-                                return i && i.line == t.line ? (e.display.externalMeasured = null, t.measure = i.measure, i.built) : ol(e, t);\n-                            }\n-                            u(fl, \"getLineContent\");\n+                /***/\n+            }),\n \n-                            function Ea(e, t) {\n-                                var i = t.text.className,\n-                                    r = fl(e, t);\n-                                t.text == t.node && (t.node = r.pre), t.text.parentNode.replaceChild(r.pre, t.text), t.text = r.pre, r.bgClass != t.bgClass || r.textClass != t.textClass ? (t.bgClass = r.bgClass, t.textClass = r.textClass, Gi(e, t)) : i && (t.text.className = i);\n-                            }\n-                            u(Ea, \"updateLineText\");\n+        /***/\n+        \"../../../node_modules/mdurl/build/index.cjs.js\":\n+            /*!******************************************************!*\\\n+              !*** ../../../node_modules/mdurl/build/index.cjs.js ***!\n+              \\******************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports) {\n \n-                            function Gi(e, t) {\n-                                Pa(e, t), t.line.wrapClass ? er(t).className = t.line.wrapClass : t.node != t.text && (t.node.className = \"\");\n-                                var i = t.textClass ? t.textClass + \" \" + (t.line.textClass || \"\") : t.line.textClass;\n-                                t.text.className = i || \"\";\n-                            }\n-                            u(Gi, \"updateLineClasses\");\n+                \"use strict\";\n \n-                            function hl(e, t, i, r) {\n-                                if (t.gutter && (t.node.removeChild(t.gutter), t.gutter = null), t.gutterBackground && (t.node.removeChild(t.gutterBackground), t.gutterBackground = null), t.line.gutterClass) {\n-                                    var n = er(t);\n-                                    t.gutterBackground = T(\"div\", null, \"CodeMirror-gutter-background \" + t.line.gutterClass, \"left: \" + (e.options.fixedGutter ? r.fixedPos : -r.gutterTotalWidth) + \"px; width: \" + r.gutterTotalWidth + \"px\"), e.display.input.setUneditable(t.gutterBackground), n.insertBefore(t.gutterBackground, t.text);\n-                                }\n-                                var l = t.line.gutterMarkers;\n-                                if (e.options.lineNumbers || l) {\n-                                    var o = er(t),\n-                                        a = t.gutter = T(\"div\", null, \"CodeMirror-gutter-wrapper\", \"left: \" + (e.options.fixedGutter ? r.fixedPos : -r.gutterTotalWidth) + \"px\");\n-                                    if (a.setAttribute(\"aria-hidden\", \"true\"), e.display.input.setUneditable(a), o.insertBefore(a, t.text), t.line.gutterClass && (a.className += \" \" + t.line.gutterClass), e.options.lineNumbers && (!l || !l[\"CodeMirror-linenumbers\"]) && (t.lineNumber = a.appendChild(T(\"div\", Oi(e.options, i), \"CodeMirror-linenumber CodeMirror-gutter-elt\", \"left: \" + r.gutterLeft[\"CodeMirror-linenumbers\"] + \"px; width: \" + e.display.lineNumInnerWidth + \"px\"))), l)\n-                                        for (var s = 0; s < e.display.gutterSpecs.length; ++s) {\n-                                            var f = e.display.gutterSpecs[s].className,\n-                                                h = l.hasOwnProperty(f) && l[f];\n-                                            h && a.appendChild(T(\"div\", [h], \"CodeMirror-gutter-elt\", \"left: \" + r.gutterLeft[f] + \"px; width: \" + r.gutterWidth[f] + \"px\"));\n-                                        }\n-                                }\n-                            }\n-                            u(hl, \"updateLineGutter\");\n \n-                            function Ia(e, t, i) {\n-                                t.alignable && (t.alignable = null);\n-                                for (var r = mt(\"CodeMirror-linewidget\"), n = t.node.firstChild, l = void 0; n; n = l) l = n.nextSibling, r.test(n.className) && t.node.removeChild(n);\n-                                cl(e, t, i);\n-                            }\n-                            u(Ia, \"updateLineWidgets\");\n+                /* eslint-disable no-bitwise */\n+                const decodeCache = {};\n \n-                            function Ra(e, t, i, r) {\n-                                var n = fl(e, t);\n-                                return t.text = t.node = n.pre, n.bgClass && (t.bgClass = n.bgClass), n.textClass && (t.textClass = n.textClass), Gi(e, t), hl(e, t, i, r), cl(e, t, r), t.node;\n-                            }\n-                            u(Ra, \"buildLineElement\");\n+                function getDecodeCache(exclude) {\n+                    let cache = decodeCache[exclude];\n+                    if (cache) {\n+                        return cache;\n+                    }\n+                    cache = decodeCache[exclude] = [];\n+                    for (let i = 0; i < 128; i++) {\n+                        const ch = String.fromCharCode(i);\n+                        cache.push(ch);\n+                    }\n+                    for (let i = 0; i < exclude.length; i++) {\n+                        const ch = exclude.charCodeAt(i);\n+                        cache[ch] = '%' + ('0' + ch.toString(16).toUpperCase()).slice(-2);\n+                    }\n+                    return cache;\n+                }\n \n-                            function cl(e, t, i) {\n-                                if (dl(e, t.line, t, i, !0), t.rest)\n-                                    for (var r = 0; r < t.rest.length; r++) dl(e, t.rest[r], t, i, !1);\n+                // Decode percent-encoded string.\n+                //\n+                function decode(string, exclude) {\n+                    if (typeof exclude !== 'string') {\n+                        exclude = decode.defaultChars;\n+                    }\n+                    const cache = getDecodeCache(exclude);\n+                    return string.replace(/(%[a-f0-9]{2})+/gi, function(seq) {\n+                        let result = '';\n+                        for (let i = 0, l = seq.length; i < l; i += 3) {\n+                            const b1 = parseInt(seq.slice(i + 1, i + 3), 16);\n+                            if (b1 < 0x80) {\n+                                result += cache[b1];\n+                                continue;\n                             }\n-                            u(cl, \"insertLineWidgets\");\n-\n-                            function dl(e, t, i, r, n) {\n-                                if (t.widgets)\n-                                    for (var l = er(i), o = 0, a = t.widgets; o < a.length; ++o) {\n-                                        var s = a[o],\n-                                            f = T(\"div\", [s.node], \"CodeMirror-linewidget\" + (s.className ? \" \" + s.className : \"\"));\n-                                        s.handleMouseEvents || f.setAttribute(\"cm-ignore-events\", \"true\"), Ba(s, f, i, r), e.display.input.setUneditable(f), n && s.above ? l.insertBefore(f, i.gutter || i.text) : l.appendChild(f), Z(s, \"redraw\");\n+                            if ((b1 & 0xE0) === 0xC0 && i + 3 < l) {\n+                                // 110xxxxx 10xxxxxx\n+                                const b2 = parseInt(seq.slice(i + 4, i + 6), 16);\n+                                if ((b2 & 0xC0) === 0x80) {\n+                                    const chr = b1 << 6 & 0x7C0 | b2 & 0x3F;\n+                                    if (chr < 0x80) {\n+                                        result += '\\ufffd\\ufffd';\n+                                    } else {\n+                                        result += String.fromCharCode(chr);\n                                     }\n-                            }\n-                            u(dl, \"insertLineWidgetsFor\");\n-\n-                            function Ba(e, t, i, r) {\n-                                if (e.noHScroll) {\n-                                    (i.alignable || (i.alignable = [])).push(t);\n-                                    var n = r.wrapperWidth;\n-                                    t.style.left = r.fixedPos + \"px\", e.coverGutter || (n -= r.gutterTotalWidth, t.style.paddingLeft = r.gutterTotalWidth + \"px\"), t.style.width = n + \"px\";\n-                                }\n-                                e.coverGutter && (t.style.zIndex = 5, t.style.position = \"relative\", e.noHScroll || (t.style.marginLeft = -r.gutterTotalWidth + \"px\"));\n-                            }\n-                            u(Ba, \"positionLineWidget\");\n-\n-                            function tr(e) {\n-                                if (e.height != null) return e.height;\n-                                var t = e.doc.cm;\n-                                if (!t) return 0;\n-                                if (!Ke(document.body, e.node)) {\n-                                    var i = \"position: relative;\";\n-                                    e.coverGutter && (i += \"margin-left: -\" + t.display.gutters.offsetWidth + \"px;\"), e.noHScroll && (i += \"width: \" + t.display.wrapper.clientWidth + \"px;\"), ve(t.display.measure, T(\"div\", [e.node], null, i));\n+                                    i += 3;\n+                                    continue;\n                                 }\n-                                return e.height = e.node.parentNode.offsetHeight;\n-                            }\n-                            u(tr, \"widgetHeight\");\n-\n-                            function Re(e, t) {\n-                                for (var i = wi(t); i != e.wrapper; i = i.parentNode)\n-                                    if (!i || i.nodeType == 1 && i.getAttribute(\"cm-ignore-events\") == \"true\" || i.parentNode == e.sizer && i != e.mover) return !0;\n-                            }\n-                            u(Re, \"eventInWidget\");\n-\n-                            function Kr(e) {\n-                                return e.lineSpace.offsetTop;\n-                            }\n-                            u(Kr, \"paddingTop\");\n-\n-                            function Ui(e) {\n-                                return e.mover.offsetHeight - e.lineSpace.offsetHeight;\n-                            }\n-                            u(Ui, \"paddingVert\");\n-\n-                            function pl(e) {\n-                                if (e.cachedPaddingH) return e.cachedPaddingH;\n-                                var t = ve(e.measure, T(\"pre\", \"x\", \"CodeMirror-line-like\")),\n-                                    i = window.getComputedStyle ? window.getComputedStyle(t) : t.currentStyle,\n-                                    r = {\n-                                        left: parseInt(i.paddingLeft),\n-                                        right: parseInt(i.paddingRight)\n-                                    };\n-                                return !isNaN(r.left) && !isNaN(r.right) && (e.cachedPaddingH = r), r;\n-                            }\n-                            u(pl, \"paddingH\");\n-\n-                            function Ae(e) {\n-                                return Wn - e.display.nativeBarWidth;\n                             }\n-                            u(Ae, \"scrollGap\");\n-\n-                            function st(e) {\n-                                return e.display.scroller.clientWidth - Ae(e) - e.display.barWidth;\n-                            }\n-                            u(st, \"displayWidth\");\n-\n-                            function Ki(e) {\n-                                return e.display.scroller.clientHeight - Ae(e) - e.display.barHeight;\n-                            }\n-                            u(Ki, \"displayHeight\");\n-\n-                            function za(e, t, i) {\n-                                var r = e.options.lineWrapping,\n-                                    n = r && st(e);\n-                                if (!t.measure.heights || r && t.measure.width != n) {\n-                                    var l = t.measure.heights = [];\n-                                    if (r) {\n-                                        t.measure.width = n;\n-                                        for (var o = t.text.firstChild.getClientRects(), a = 0; a < o.length - 1; a++) {\n-                                            var s = o[a],\n-                                                f = o[a + 1];\n-                                            Math.abs(s.bottom - f.bottom) > 2 && l.push((s.bottom + f.top) / 2 - i.top);\n-                                        }\n+                            if ((b1 & 0xF0) === 0xE0 && i + 6 < l) {\n+                                // 1110xxxx 10xxxxxx 10xxxxxx\n+                                const b2 = parseInt(seq.slice(i + 4, i + 6), 16);\n+                                const b3 = parseInt(seq.slice(i + 7, i + 9), 16);\n+                                if ((b2 & 0xC0) === 0x80 && (b3 & 0xC0) === 0x80) {\n+                                    const chr = b1 << 12 & 0xF000 | b2 << 6 & 0xFC0 | b3 & 0x3F;\n+                                    if (chr < 0x800 || chr >= 0xD800 && chr <= 0xDFFF) {\n+                                        result += '\\ufffd\\ufffd\\ufffd';\n+                                    } else {\n+                                        result += String.fromCharCode(chr);\n                                     }\n-                                    l.push(i.bottom - i.top);\n+                                    i += 6;\n+                                    continue;\n                                 }\n                             }\n-                            u(za, \"ensureLineHeights\");\n-\n-                            function vl(e, t, i) {\n-                                if (e.line == t) return {\n-                                    map: e.measure.map,\n-                                    cache: e.measure.cache\n-                                };\n-                                if (e.rest) {\n-                                    for (var r = 0; r < e.rest.length; r++)\n-                                        if (e.rest[r] == t) return {\n-                                            map: e.measure.maps[r],\n-                                            cache: e.measure.caches[r]\n-                                        };\n-                                    for (var n = 0; n < e.rest.length; n++)\n-                                        if (F(e.rest[n]) > i) return {\n-                                            map: e.measure.maps[n],\n-                                            cache: e.measure.caches[n],\n-                                            before: !0\n-                                        };\n+                            if ((b1 & 0xF8) === 0xF0 && i + 9 < l) {\n+                                // 111110xx 10xxxxxx 10xxxxxx 10xxxxxx\n+                                const b2 = parseInt(seq.slice(i + 4, i + 6), 16);\n+                                const b3 = parseInt(seq.slice(i + 7, i + 9), 16);\n+                                const b4 = parseInt(seq.slice(i + 10, i + 12), 16);\n+                                if ((b2 & 0xC0) === 0x80 && (b3 & 0xC0) === 0x80 && (b4 & 0xC0) === 0x80) {\n+                                    let chr = b1 << 18 & 0x1C0000 | b2 << 12 & 0x3F000 | b3 << 6 & 0xFC0 | b4 & 0x3F;\n+                                    if (chr < 0x10000 || chr > 0x10FFFF) {\n+                                        result += '\\ufffd\\ufffd\\ufffd\\ufffd';\n+                                    } else {\n+                                        chr -= 0x10000;\n+                                        result += String.fromCharCode(0xD800 + (chr >> 10), 0xDC00 + (chr & 0x3FF));\n+                                    }\n+                                    i += 9;\n+                                    continue;\n                                 }\n                             }\n-                            u(vl, \"mapFromLineView\");\n+                            result += '\\ufffd';\n+                        }\n+                        return result;\n+                    });\n+                }\n+                decode.defaultChars = ';/?:@&=+$,#';\n+                decode.componentChars = '';\n+                const encodeCache = {};\n \n-                            function Ga(e, t) {\n-                                t = Se(t);\n-                                var i = F(t),\n-                                    r = e.display.externalMeasured = new sl(e.doc, t, i);\n-                                r.lineN = i;\n-                                var n = r.built = ol(e, r);\n-                                return r.text = n.pre, ve(e.display.lineMeasure, n.pre), r;\n-                            }\n-                            u(Ga, \"updateExternalMeasurement\");\n-\n-                            function gl(e, t, i, r) {\n-                                return Oe(e, kt(e, t), i, r);\n-                            }\n-                            u(gl, \"measureChar\");\n-\n-                            function _i(e, t) {\n-                                if (t >= e.display.viewFrom && t < e.display.viewTo) return e.display.view[ht(e, t)];\n-                                var i = e.display.externalMeasured;\n-                                if (i && t >= i.lineN && t < i.lineN + i.size) return i;\n-                            }\n-                            u(_i, \"findViewForLine\");\n-\n-                            function kt(e, t) {\n-                                var i = F(t),\n-                                    r = _i(e, i);\n-                                r && !r.text ? r = null : r && r.changes && (ul(e, r, i, Qi(e)), e.curOp.forceUpdate = !0), r || (r = Ga(e, t));\n-                                var n = vl(r, t, i);\n-                                return {\n-                                    line: t,\n-                                    view: r,\n-                                    rect: null,\n-                                    map: n.map,\n-                                    cache: n.cache,\n-                                    before: n.before,\n-                                    hasHeights: !1\n-                                };\n-                            }\n-                            u(kt, \"prepareMeasureForLine\");\n+                // Create a lookup array where anything but characters in `chars` string\n+                // and alphanumeric chars is percent-encoded.\n+                //\n+                function getEncodeCache(exclude) {\n+                    let cache = encodeCache[exclude];\n+                    if (cache) {\n+                        return cache;\n+                    }\n+                    cache = encodeCache[exclude] = [];\n+                    for (let i = 0; i < 128; i++) {\n+                        const ch = String.fromCharCode(i);\n+                        if (/^[0-9a-z]$/i.test(ch)) {\n+                            // always allow unencoded alphanumeric characters\n+                            cache.push(ch);\n+                        } else {\n+                            cache.push('%' + ('0' + i.toString(16).toUpperCase()).slice(-2));\n+                        }\n+                    }\n+                    for (let i = 0; i < exclude.length; i++) {\n+                        cache[exclude.charCodeAt(i)] = exclude[i];\n+                    }\n+                    return cache;\n+                }\n \n-                            function Oe(e, t, i, r, n) {\n-                                t.before && (i = -1);\n-                                var l = i + (r || \"\"),\n-                                    o;\n-                                return t.cache.hasOwnProperty(l) ? o = t.cache[l] : (t.rect || (t.rect = t.view.text.getBoundingClientRect()), t.hasHeights || (za(e, t.view, t.rect), t.hasHeights = !0), o = Ka(e, t, i, r), o.bogus || (t.cache[l] = o)), {\n-                                    left: o.left,\n-                                    right: o.right,\n-                                    top: n ? o.rtop : o.top,\n-                                    bottom: n ? o.rbottom : o.bottom\n-                                };\n+                // Encode unsafe characters with percent-encoding, skipping already\n+                // encoded sequences.\n+                //\n+                //  - string       - string to encode\n+                //  - exclude      - list of characters to ignore (in addition to a-zA-Z0-9)\n+                //  - keepEscaped  - don't encode '%' in a correct escape sequence (default: true)\n+                //\n+                function encode(string, exclude, keepEscaped) {\n+                    if (typeof exclude !== 'string') {\n+                        // encode(string, keepEscaped)\n+                        keepEscaped = exclude;\n+                        exclude = encode.defaultChars;\n+                    }\n+                    if (typeof keepEscaped === 'undefined') {\n+                        keepEscaped = true;\n+                    }\n+                    const cache = getEncodeCache(exclude);\n+                    let result = '';\n+                    for (let i = 0, l = string.length; i < l; i++) {\n+                        const code = string.charCodeAt(i);\n+                        if (keepEscaped && code === 0x25 /* % */ && i + 2 < l) {\n+                            if (/^[0-9a-f]{2}$/i.test(string.slice(i + 1, i + 3))) {\n+                                result += string.slice(i, i + 3);\n+                                i += 2;\n+                                continue;\n                             }\n-                            u(Oe, \"measureCharPrepared\");\n-                            var yl = {\n-                                left: 0,\n-                                right: 0,\n-                                top: 0,\n-                                bottom: 0\n-                            };\n-\n-                            function ml(e, t, i) {\n-                                for (var r, n, l, o, a, s, f = 0; f < e.length; f += 3)\n-                                    if (a = e[f], s = e[f + 1], t < a ? (n = 0, l = 1, o = \"left\") : t < s ? (n = t - a, l = n + 1) : (f == e.length - 3 || t == s && e[f + 3] > t) && (l = s - a, n = l - 1, t >= s && (o = \"right\")), n != null) {\n-                                        if (r = e[f + 2], a == s && i == (r.insertLeft ? \"left\" : \"right\") && (o = i), i == \"left\" && n == 0)\n-                                            for (; f && e[f - 2] == e[f - 3] && e[f - 1].insertLeft;) r = e[(f -= 3) + 2], o = \"left\";\n-                                        if (i == \"right\" && n == s - a)\n-                                            for (; f < e.length - 3 && e[f + 3] == e[f + 4] && !e[f + 5].insertLeft;) r = e[(f += 3) + 2], o = \"right\";\n-                                        break;\n-                                    }\n-                                return {\n-                                    node: r,\n-                                    start: n,\n-                                    end: l,\n-                                    collapse: o,\n-                                    coverStart: a,\n-                                    coverEnd: s\n-                                };\n+                        }\n+                        if (code < 128) {\n+                            result += cache[code];\n+                            continue;\n+                        }\n+                        if (code >= 0xD800 && code <= 0xDFFF) {\n+                            if (code >= 0xD800 && code <= 0xDBFF && i + 1 < l) {\n+                                const nextCode = string.charCodeAt(i + 1);\n+                                if (nextCode >= 0xDC00 && nextCode <= 0xDFFF) {\n+                                    result += encodeURIComponent(string[i] + string[i + 1]);\n+                                    i++;\n+                                    continue;\n+                                }\n                             }\n-                            u(ml, \"nodeAndOffsetInLineMap\");\n+                            result += '%EF%BF%BD';\n+                            continue;\n+                        }\n+                        result += encodeURIComponent(string[i]);\n+                    }\n+                    return result;\n+                }\n+                encode.defaultChars = \";/?:@&=+$,-_.!~*'()#\";\n+                encode.componentChars = \"-_.!~*'()\";\n \n-                            function Ua(e, t) {\n-                                var i = yl;\n-                                if (t == \"left\")\n-                                    for (var r = 0; r < e.length && (i = e[r]).left == i.right; r++);\n-                                else\n-                                    for (var n = e.length - 1; n >= 0 && (i = e[n]).left == i.right; n--);\n-                                return i;\n-                            }\n-                            u(Ua, \"getUsefulRect\");\n+                function format(url) {\n+                    let result = '';\n+                    result += url.protocol || '';\n+                    result += url.slashes ? '//' : '';\n+                    result += url.auth ? url.auth + '@' : '';\n+                    if (url.hostname && url.hostname.indexOf(':') !== -1) {\n+                        // ipv6 address\n+                        result += '[' + url.hostname + ']';\n+                    } else {\n+                        result += url.hostname || '';\n+                    }\n+                    result += url.port ? ':' + url.port : '';\n+                    result += url.pathname || '';\n+                    result += url.search || '';\n+                    result += url.hash || '';\n+                    return result;\n+                }\n \n-                            function Ka(e, t, i, r) {\n-                                var n = ml(t.map, i, r),\n-                                    l = n.node,\n-                                    o = n.start,\n-                                    a = n.end,\n-                                    s = n.collapse,\n-                                    f;\n-                                if (l.nodeType == 3) {\n-                                    for (var h = 0; h < 4; h++) {\n-                                        for (; o && bi(t.line.text.charAt(n.coverStart + o));) --o;\n-                                        for (; n.coverStart + a < n.coverEnd && bi(t.line.text.charAt(n.coverStart + a));) ++a;\n-                                        if (O && I < 9 && o == 0 && a == n.coverEnd - n.coverStart ? f = l.parentNode.getBoundingClientRect() : f = Ua(rt(l, o, a).getClientRects(), r), f.left || f.right || o == 0) break;\n-                                        a = o, o = o - 1, s = \"right\";\n-                                    }\n-                                    O && I < 11 && (f = _a(e.display.measure, f));\n-                                } else {\n-                                    o > 0 && (s = r = \"right\");\n-                                    var c;\n-                                    e.options.lineWrapping && (c = l.getClientRects()).length > 1 ? f = c[r == \"right\" ? c.length - 1 : 0] : f = l.getBoundingClientRect();\n-                                }\n-                                if (O && I < 9 && !o && (!f || !f.left && !f.right)) {\n-                                    var p = l.parentNode.getClientRects()[0];\n-                                    p ? f = {\n-                                        left: p.left,\n-                                        right: p.left + Mt(e.display),\n-                                        top: p.top,\n-                                        bottom: p.bottom\n-                                    } : f = yl;\n-                                }\n-                                for (var d = f.top - t.rect.top, v = f.bottom - t.rect.top, g = (d + v) / 2, m = t.view.measure.heights, b = 0; b < m.length - 1 && !(g < m[b]); b++);\n-                                var C = b ? m[b - 1] : 0,\n-                                    x = m[b],\n-                                    w = {\n-                                        left: (s == \"right\" ? f.right : f.left) - t.rect.left,\n-                                        right: (s == \"left\" ? f.left : f.right) - t.rect.left,\n-                                        top: C,\n-                                        bottom: x\n-                                    };\n-                                return !f.left && !f.right && (w.bogus = !0), e.options.singleCursorHeightPerLine || (w.rtop = d, w.rbottom = v), w;\n-                            }\n-                            u(Ka, \"measureCharInner\");\n+                // Copyright Joyent, Inc. and other Node contributors.\n+                //\n+                // Permission is hereby granted, free of charge, to any person obtaining a\n+                // copy of this software and associated documentation files (the\n+                // \"Software\"), to deal in the Software without restriction, including\n+                // without limitation the rights to use, copy, modify, merge, publish,\n+                // distribute, sublicense, and/or sell copies of the Software, and to permit\n+                // persons to whom the Software is furnished to do so, subject to the\n+                // following conditions:\n+                //\n+                // The above copyright notice and this permission notice shall be included\n+                // in all copies or substantial portions of the Software.\n+                //\n+                // THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n+                // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n+                // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n+                // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n+                // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n+                // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n+                // USE OR OTHER DEALINGS IN THE SOFTWARE.\n \n-                            function _a(e, t) {\n-                                if (!window.screen || screen.logicalXDPI == null || screen.logicalXDPI == screen.deviceXDPI || !la(e)) return t;\n-                                var i = screen.logicalXDPI / screen.deviceXDPI,\n-                                    r = screen.logicalYDPI / screen.deviceYDPI;\n-                                return {\n-                                    left: t.left * i,\n-                                    right: t.right * i,\n-                                    top: t.top * r,\n-                                    bottom: t.bottom * r\n-                                };\n-                            }\n-                            u(_a, \"maybeUpdateRectForZooming\");\n+                //\n+                // Changes from joyent/node:\n+                //\n+                // 1. No leading slash in paths,\n+                //    e.g. in `url.parse('http://foo?bar')` pathname is ``, not `/`\n+                //\n+                // 2. Backslashes are not replaced with slashes,\n+                //    so `http:\\\\example.org\\` is treated like a relative path\n+                //\n+                // 3. Trailing colon is treated like a part of the path,\n+                //    i.e. in `http://example.org:foo` pathname is `:foo`\n+                //\n+                // 4. Nothing is URL-encoded in the resulting object,\n+                //    (in joyent/node some chars in auth and paths are encoded)\n+                //\n+                // 5. `url.parse()` does not have `parseQueryString` argument\n+                //\n+                // 6. Removed extraneous result properties: `host`, `path`, `query`, etc.,\n+                //    which can be constructed using other parts of the url.\n+                //\n \n-                            function bl(e) {\n-                                if (e.measure && (e.measure.cache = {}, e.measure.heights = null, e.rest))\n-                                    for (var t = 0; t < e.rest.length; t++) e.measure.caches[t] = {};\n-                            }\n-                            u(bl, \"clearLineMeasurementCacheFor\");\n+                function Url() {\n+                    this.protocol = null;\n+                    this.slashes = null;\n+                    this.auth = null;\n+                    this.port = null;\n+                    this.hostname = null;\n+                    this.hash = null;\n+                    this.search = null;\n+                    this.pathname = null;\n+                }\n \n-                            function xl(e) {\n-                                e.display.externalMeasure = null, Ue(e.display.lineMeasure);\n-                                for (var t = 0; t < e.display.view.length; t++) bl(e.display.view[t]);\n-                            }\n-                            u(xl, \"clearLineMeasurementCache\");\n+                // Reference: RFC 3986, RFC 1808, RFC 2396\n \n-                            function rr(e) {\n-                                xl(e), e.display.cachedCharWidth = e.display.cachedTextHeight = e.display.cachedPaddingH = null, e.options.lineWrapping || (e.display.maxLineChanged = !0), e.display.lineNumChars = null;\n-                            }\n-                            u(rr, \"clearCaches\");\n+                // define these here so at least they only have to be\n+                // compiled once on the first module load.\n+                const protocolPattern = /^([a-z0-9.+-]+:)/i;\n+                const portPattern = /:[0-9]*$/;\n \n-                            function Cl() {\n-                                return Tr && Dr ? -(document.body.getBoundingClientRect().left - parseInt(getComputedStyle(document.body).marginLeft)) : window.pageXOffset || (document.documentElement || document.body).scrollLeft;\n-                            }\n-                            u(Cl, \"pageScrollX\");\n+                // Special case for a simple path URL\n+                /* eslint-disable-next-line no-useless-escape */\n+                const simplePathPattern = /^(\\/\\/?(?!\\/)[^\\?\\s]*)(\\?[^\\s]*)?$/;\n \n-                            function wl() {\n-                                return Tr && Dr ? -(document.body.getBoundingClientRect().top - parseInt(getComputedStyle(document.body).marginTop)) : window.pageYOffset || (document.documentElement || document.body).scrollTop;\n-                            }\n-                            u(wl, \"pageScrollY\");\n+                // RFC 2396: characters reserved for delimiting URLs.\n+                // We actually just auto-escape these.\n+                const delims = ['<', '>', '\"', '`', ' ', '\\r', '\\n', '\\t'];\n \n-                            function Xi(e) {\n-                                var t = Se(e),\n-                                    i = t.widgets,\n-                                    r = 0;\n-                                if (i)\n-                                    for (var n = 0; n < i.length; ++n) i[n].above && (r += tr(i[n]));\n-                                return r;\n-                            }\n-                            u(Xi, \"widgetTopHeight\");\n+                // RFC 2396: characters not allowed for various reasons.\n+                const unwise = ['{', '}', '|', '\\\\', '^', '`'].concat(delims);\n \n-                            function _r(e, t, i, r, n) {\n-                                if (!n) {\n-                                    var l = Xi(t);\n-                                    i.top += l, i.bottom += l;\n-                                }\n-                                if (r == \"line\") return i;\n-                                r || (r = \"local\");\n-                                var o = Ie(t);\n-                                if (r == \"local\" ? o += Kr(e.display) : o -= e.display.viewOffset, r == \"page\" || r == \"window\") {\n-                                    var a = e.display.lineSpace.getBoundingClientRect();\n-                                    o += a.top + (r == \"window\" ? 0 : wl());\n-                                    var s = a.left + (r == \"window\" ? 0 : Cl());\n-                                    i.left += s, i.right += s;\n-                                }\n-                                return i.top += o, i.bottom += o, i;\n-                            }\n-                            u(_r, \"intoCoordSystem\");\n-\n-                            function Sl(e, t, i) {\n-                                if (i == \"div\") return t;\n-                                var r = t.left,\n-                                    n = t.top;\n-                                if (i == \"page\") r -= Cl(), n -= wl();\n-                                else if (i == \"local\" || !i) {\n-                                    var l = e.display.sizer.getBoundingClientRect();\n-                                    r += l.left, n += l.top;\n-                                }\n-                                var o = e.display.lineSpace.getBoundingClientRect();\n-                                return {\n-                                    left: r - o.left,\n-                                    top: n - o.top\n-                                };\n-                            }\n-                            u(Sl, \"fromCoordSystem\");\n+                // Allowed by RFCs, but cause of XSS attacks.  Always escape these.\n+                const autoEscape = ['\\''].concat(unwise);\n+                // Characters that are never ever allowed in a hostname.\n+                // Note that any invalid chars are also handled, but these\n+                // are the ones that are *expected* to be seen, so we fast-path\n+                // them.\n+                const nonHostChars = ['%', '/', '?', ';', '#'].concat(autoEscape);\n+                const hostEndingChars = ['/', '?', '#'];\n+                const hostnameMaxLen = 255;\n+                const hostnamePartPattern = /^[+a-z0-9A-Z_-]{0,63}$/;\n+                const hostnamePartStart = /^([+a-z0-9A-Z_-]{0,63})(.*)$/;\n+                // protocols that can allow \"unsafe\" and \"unwise\" chars.\n+                // protocols that never have a hostname.\n+                const hostlessProtocol = {\n+                    javascript: true,\n+                    'javascript:': true\n+                };\n+                // protocols that always contain a // bit.\n+                const slashedProtocol = {\n+                    http: true,\n+                    https: true,\n+                    ftp: true,\n+                    gopher: true,\n+                    file: true,\n+                    'http:': true,\n+                    'https:': true,\n+                    'ftp:': true,\n+                    'gopher:': true,\n+                    'file:': true\n+                };\n \n-                            function Xr(e, t, i, r, n) {\n-                                return r || (r = S(e.doc, t.line)), _r(e, r, gl(e, r, t.ch, n), i);\n-                            }\n-                            u(Xr, \"charCoords\");\n+                function urlParse(url, slashesDenoteHost) {\n+                    if (url && url instanceof Url) return url;\n+                    const u = new Url();\n+                    u.parse(url, slashesDenoteHost);\n+                    return u;\n+                }\n+                Url.prototype.parse = function(url, slashesDenoteHost) {\n+                    let lowerProto, hec, slashes;\n+                    let rest = url;\n \n-                            function Le(e, t, i, r, n, l) {\n-                                r = r || S(e.doc, t.line), n || (n = kt(e, r));\n-\n-                                function o(v, g) {\n-                                    var m = Oe(e, n, v, g ? \"right\" : \"left\", l);\n-                                    return g ? m.left = m.right : m.right = m.left, _r(e, r, m, i);\n-                                }\n-                                u(o, \"get\");\n-                                var a = Pe(r, e.doc.direction),\n-                                    s = t.ch,\n-                                    f = t.sticky;\n-                                if (s >= r.text.length ? (s = r.text.length, f = \"before\") : s <= 0 && (s = 0, f = \"after\"), !a) return o(f == \"before\" ? s - 1 : s, f == \"before\");\n-\n-                                function h(v, g, m) {\n-                                    var b = a[g],\n-                                        C = b.level == 1;\n-                                    return o(m ? v - 1 : v, C != m);\n-                                }\n-                                u(h, \"getBidi\");\n-                                var c = Zt(a, s, f),\n-                                    p = qt,\n-                                    d = h(s, c, f == \"before\");\n-                                return p != null && (d.other = h(s, p, f != \"before\")), d;\n-                            }\n-                            u(Le, \"cursorCoords\");\n-\n-                            function Ll(e, t) {\n-                                var i = 0;\n-                                t = N(e.doc, t), e.options.lineWrapping || (i = Mt(e.display) * t.ch);\n-                                var r = S(e.doc, t.line),\n-                                    n = Ie(r) + Kr(e.display);\n-                                return {\n-                                    left: i,\n-                                    right: i,\n-                                    top: n,\n-                                    bottom: n + r.height\n-                                };\n+                    // trim before proceeding.\n+                    // This is to support parse stuff like \"  http://foo.com  \\n\"\n+                    rest = rest.trim();\n+                    if (!slashesDenoteHost && url.split('#').length === 1) {\n+                        // Try fast path regexp\n+                        const simplePath = simplePathPattern.exec(rest);\n+                        if (simplePath) {\n+                            this.pathname = simplePath[1];\n+                            if (simplePath[2]) {\n+                                this.search = simplePath[2];\n                             }\n-                            u(Ll, \"estimateCoords\");\n+                            return this;\n+                        }\n+                    }\n+                    let proto = protocolPattern.exec(rest);\n+                    if (proto) {\n+                        proto = proto[0];\n+                        lowerProto = proto.toLowerCase();\n+                        this.protocol = proto;\n+                        rest = rest.substr(proto.length);\n+                    }\n \n-                            function Yi(e, t, i, r, n) {\n-                                var l = y(e, t, i);\n-                                return l.xRel = n, r && (l.outside = r), l;\n-                            }\n-                            u(Yi, \"PosWithInfo\");\n-\n-                            function qi(e, t, i) {\n-                                var r = e.doc;\n-                                if (i += e.display.viewOffset, i < 0) return Yi(r.first, 0, null, -1, -1);\n-                                var n = at(r, i),\n-                                    l = r.first + r.size - 1;\n-                                if (n > l) return Yi(r.first + r.size - 1, S(r, l).text.length, null, 1, 1);\n-                                t < 0 && (t = 0);\n-                                for (var o = S(r, n);;) {\n-                                    var a = Xa(e, o, n, t, i),\n-                                        s = ba(o, a.ch + (a.xRel > 0 || a.outside > 0 ? 1 : 0));\n-                                    if (!s) return a;\n-                                    var f = s.find(1);\n-                                    if (f.line == n) return f;\n-                                    o = S(r, n = f.line);\n-                                }\n-                            }\n-                            u(qi, \"coordsChar\");\n-\n-                            function kl(e, t, i, r) {\n-                                r -= Xi(t);\n-                                var n = t.text.length,\n-                                    l = Yt(function(o) {\n-                                        return Oe(e, i, o - 1).bottom <= r;\n-                                    }, n, 0);\n-                                return n = Yt(function(o) {\n-                                    return Oe(e, i, o).top > r;\n-                                }, l, n), {\n-                                    begin: l,\n-                                    end: n\n-                                };\n-                            }\n-                            u(kl, \"wrappedLineExtent\");\n+                    // figure out if it's got a host\n+                    // user@server is *always* interpreted as a hostname, and url\n+                    // resolution will treat //foo/bar as host=foo,path=bar because that's\n+                    // how the browser resolves relative URLs.\n+                    /* eslint-disable-next-line no-useless-escape */\n+                    if (slashesDenoteHost || proto || rest.match(/^\\/\\/[^@\\/]+@[^@\\/]+/)) {\n+                        slashes = rest.substr(0, 2) === '//';\n+                        if (slashes && !(proto && hostlessProtocol[proto])) {\n+                            rest = rest.substr(2);\n+                            this.slashes = true;\n+                        }\n+                    }\n+                    if (!hostlessProtocol[proto] && (slashes || proto && !slashedProtocol[proto])) {\n+                        // there's a hostname.\n+                        // the first instance of /, ?, ;, or # ends the host.\n+                        //\n+                        // If there is an @ in the hostname, then non-host chars *are* allowed\n+                        // to the left of the last @ sign, unless some host-ending character\n+                        // comes *before* the @-sign.\n+                        // URLs are obnoxious.\n+                        //\n+                        // ex:\n+                        // http://a@b@c/ => user:a@b host:c\n+                        // http://a@b?@c => user:a host:c path:/?@c\n \n-                            function Tl(e, t, i, r) {\n-                                i || (i = kt(e, t));\n-                                var n = _r(e, t, Oe(e, i, r), \"line\").top;\n-                                return kl(e, t, i, n);\n-                            }\n-                            u(Tl, \"wrappedLineExtentChar\");\n-\n-                            function Zi(e, t, i, r) {\n-                                return e.bottom <= i ? !1 : e.top > i ? !0 : (r ? e.left : e.right) > t;\n-                            }\n-                            u(Zi, \"boxIsAfter\");\n-\n-                            function Xa(e, t, i, r, n) {\n-                                n -= Ie(t);\n-                                var l = kt(e, t),\n-                                    o = Xi(t),\n-                                    a = 0,\n-                                    s = t.text.length,\n-                                    f = !0,\n-                                    h = Pe(t, e.doc.direction);\n-                                if (h) {\n-                                    var c = (e.options.lineWrapping ? qa : Ya)(e, t, i, l, h, r, n);\n-                                    f = c.level != 1, a = f ? c.from : c.to - 1, s = f ? c.to : c.from - 1;\n-                                }\n-                                var p = null,\n-                                    d = null,\n-                                    v = Yt(function(k) {\n-                                        var L = Oe(e, l, k);\n-                                        return L.top += o, L.bottom += o, Zi(L, r, n, !1) ? (L.top <= n && L.left <= r && (p = k, d = L), !0) : !1;\n-                                    }, a, s),\n-                                    g,\n-                                    m,\n-                                    b = !1;\n-                                if (d) {\n-                                    var C = r - d.left < d.right - r,\n-                                        x = C == f;\n-                                    v = p + (x ? 0 : 1), m = x ? \"after\" : \"before\", g = C ? d.left : d.right;\n-                                } else {\n-                                    !f && (v == s || v == a) && v++, m = v == 0 ? \"after\" : v == t.text.length ? \"before\" : Oe(e, l, v - (f ? 1 : 0)).bottom + o <= n == f ? \"after\" : \"before\";\n-                                    var w = Le(e, y(i, v, m), \"line\", t, l);\n-                                    g = w.left, b = n < w.top ? -1 : n >= w.bottom ? 1 : 0;\n-                                }\n-                                return v = En(t.text, v, 1), Yi(i, v, m, b, r - g);\n-                            }\n-                            u(Xa, \"coordsCharInner\");\n-\n-                            function Ya(e, t, i, r, n, l, o) {\n-                                var a = Yt(function(c) {\n-                                        var p = n[c],\n-                                            d = p.level != 1;\n-                                        return Zi(Le(e, y(i, d ? p.to : p.from, d ? \"before\" : \"after\"), \"line\", t, r), l, o, !0);\n-                                    }, 0, n.length - 1),\n-                                    s = n[a];\n-                                if (a > 0) {\n-                                    var f = s.level != 1,\n-                                        h = Le(e, y(i, f ? s.from : s.to, f ? \"after\" : \"before\"), \"line\", t, r);\n-                                    Zi(h, l, o, !0) && h.top > o && (s = n[a - 1]);\n-                                }\n-                                return s;\n-                            }\n-                            u(Ya, \"coordsBidiPart\");\n-\n-                            function qa(e, t, i, r, n, l, o) {\n-                                var a = kl(e, t, r, o),\n-                                    s = a.begin,\n-                                    f = a.end;\n-                                /\\s/.test(t.text.charAt(f - 1)) && f--;\n-                                for (var h = null, c = null, p = 0; p < n.length; p++) {\n-                                    var d = n[p];\n-                                    if (!(d.from >= f || d.to <= s)) {\n-                                        var v = d.level != 1,\n-                                            g = Oe(e, r, v ? Math.min(f, d.to) - 1 : Math.max(s, d.from)).right,\n-                                            m = g < l ? l - g + 1e9 : g - l;\n-                                        (!h || c > m) && (h = d, c = m);\n-                                    }\n-                                }\n-                                return h || (h = n[n.length - 1]), h.from < s && (h = {\n-                                    from: s,\n-                                    to: h.to,\n-                                    level: h.level\n-                                }), h.to > f && (h = {\n-                                    from: h.from,\n-                                    to: f,\n-                                    level: h.level\n-                                }), h;\n-                            }\n-                            u(qa, \"coordsBidiPartWrapped\");\n-                            var ut;\n-\n-                            function Tt(e) {\n-                                if (e.cachedTextHeight != null) return e.cachedTextHeight;\n-                                if (ut == null) {\n-                                    ut = T(\"pre\", null, \"CodeMirror-line-like\");\n-                                    for (var t = 0; t < 49; ++t) ut.appendChild(document.createTextNode(\"x\")), ut.appendChild(T(\"br\"));\n-                                    ut.appendChild(document.createTextNode(\"x\"));\n-                                }\n-                                ve(e.measure, ut);\n-                                var i = ut.offsetHeight / 50;\n-                                return i > 3 && (e.cachedTextHeight = i), Ue(e.measure), i || 1;\n-                            }\n-                            u(Tt, \"textHeight\");\n-\n-                            function Mt(e) {\n-                                if (e.cachedCharWidth != null) return e.cachedCharWidth;\n-                                var t = T(\"span\", \"xxxxxxxxxx\"),\n-                                    i = T(\"pre\", [t], \"CodeMirror-line-like\");\n-                                ve(e.measure, i);\n-                                var r = t.getBoundingClientRect(),\n-                                    n = (r.right - r.left) / 10;\n-                                return n > 2 && (e.cachedCharWidth = n), n || 10;\n-                            }\n-                            u(Mt, \"charWidth\");\n-\n-                            function Qi(e) {\n-                                for (var t = e.display, i = {}, r = {}, n = t.gutters.clientLeft, l = t.gutters.firstChild, o = 0; l; l = l.nextSibling, ++o) {\n-                                    var a = e.display.gutterSpecs[o].className;\n-                                    i[a] = l.offsetLeft + l.clientLeft + n, r[a] = l.clientWidth;\n-                                }\n-                                return {\n-                                    fixedPos: Ji(t),\n-                                    gutterTotalWidth: t.gutters.offsetWidth,\n-                                    gutterLeft: i,\n-                                    gutterWidth: r,\n-                                    wrapperWidth: t.wrapper.clientWidth\n-                                };\n-                            }\n-                            u(Qi, \"getDimensions\");\n+                        // v0.12 TODO(isaacs): This is not quite how Chrome does things.\n+                        // Review our test case against browsers more comprehensively.\n \n-                            function Ji(e) {\n-                                return e.scroller.getBoundingClientRect().left - e.sizer.getBoundingClientRect().left;\n+                        // find the first instance of any hostEndingChars\n+                        let hostEnd = -1;\n+                        for (let i = 0; i < hostEndingChars.length; i++) {\n+                            hec = rest.indexOf(hostEndingChars[i]);\n+                            if (hec !== -1 && (hostEnd === -1 || hec < hostEnd)) {\n+                                hostEnd = hec;\n                             }\n-                            u(Ji, \"compensateForHScroll\");\n+                        }\n \n-                            function Ml(e) {\n-                                var t = Tt(e.display),\n-                                    i = e.options.lineWrapping,\n-                                    r = i && Math.max(5, e.display.scroller.clientWidth / Mt(e.display) - 3);\n-                                return function(n) {\n-                                    if (Xe(e.doc, n)) return 0;\n-                                    var l = 0;\n-                                    if (n.widgets)\n-                                        for (var o = 0; o < n.widgets.length; o++) n.widgets[o].height && (l += n.widgets[o].height);\n-                                    return i ? l + (Math.ceil(n.text.length / r) || 1) * t : l + t;\n-                                };\n-                            }\n-                            u(Ml, \"estimateHeight\");\n+                        // at this point, either we have an explicit point where the\n+                        // auth portion cannot go past, or the last @ char is the decider.\n+                        let auth, atSign;\n+                        if (hostEnd === -1) {\n+                            // atSign can be anywhere.\n+                            atSign = rest.lastIndexOf('@');\n+                        } else {\n+                            // atSign must be in auth portion.\n+                            // http://a@b/c@d => host:b auth:a path:/c@d\n+                            atSign = rest.lastIndexOf('@', hostEnd);\n+                        }\n \n-                            function ji(e) {\n-                                var t = e.doc,\n-                                    i = Ml(e);\n-                                t.iter(function(r) {\n-                                    var n = i(r);\n-                                    n != r.height && De(r, n);\n-                                });\n-                            }\n-                            u(ji, \"estimateLineHeights\");\n+                        // Now we have a portion which is definitely the auth.\n+                        // Pull that off.\n+                        if (atSign !== -1) {\n+                            auth = rest.slice(0, atSign);\n+                            rest = rest.slice(atSign + 1);\n+                            this.auth = auth;\n+                        }\n \n-                            function ft(e, t, i, r) {\n-                                var n = e.display;\n-                                if (!i && wi(t).getAttribute(\"cm-not-content\") == \"true\") return null;\n-                                var l,\n-                                    o,\n-                                    a = n.lineSpace.getBoundingClientRect();\n-                                try {\n-                                    l = t.clientX - a.left, o = t.clientY - a.top;\n-                                } catch {\n-                                    return null;\n-                                }\n-                                var s = qi(e, l, o),\n-                                    f;\n-                                if (r && s.xRel > 0 && (f = S(e.doc, s.line).text).length == s.ch) {\n-                                    var h = xe(f, f.length, e.options.tabSize) - f.length;\n-                                    s = y(s.line, Math.max(0, Math.round((l - pl(e.display).left) / Mt(e.display)) - h));\n-                                }\n-                                return s;\n-                            }\n-                            u(ft, \"posFromMouse\");\n-\n-                            function ht(e, t) {\n-                                if (t >= e.display.viewTo || (t -= e.display.viewFrom, t < 0)) return null;\n-                                for (var i = e.display.view, r = 0; r < i.length; r++)\n-                                    if (t -= i[r].size, t < 0) return r;\n-                            }\n-                            u(ht, \"findViewIndex\");\n-\n-                            function se(e, t, i, r) {\n-                                t == null && (t = e.doc.first), i == null && (i = e.doc.first + e.doc.size), r || (r = 0);\n-                                var n = e.display;\n-                                if (r && i < n.viewTo && (n.updateLineNumbers == null || n.updateLineNumbers > t) && (n.updateLineNumbers = t), e.curOp.viewChanged = !0, t >= n.viewTo) Ee && Ri(e.doc, t) < n.viewTo && qe(e);\n-                                else if (i <= n.viewFrom) Ee && nl(e.doc, i + r) > n.viewFrom ? qe(e) : (n.viewFrom += r, n.viewTo += r);\n-                                else if (t <= n.viewFrom && i >= n.viewTo) qe(e);\n-                                else if (t <= n.viewFrom) {\n-                                    var l = Yr(e, i, i + r, 1);\n-                                    l ? (n.view = n.view.slice(l.index), n.viewFrom = l.lineN, n.viewTo += r) : qe(e);\n-                                } else if (i >= n.viewTo) {\n-                                    var o = Yr(e, t, t, -1);\n-                                    o ? (n.view = n.view.slice(0, o.index), n.viewTo = o.lineN) : qe(e);\n-                                } else {\n-                                    var a = Yr(e, t, t, -1),\n-                                        s = Yr(e, i, i + r, 1);\n-                                    a && s ? (n.view = n.view.slice(0, a.index).concat(Ur(e, a.lineN, s.lineN)).concat(n.view.slice(s.index)), n.viewTo += r) : qe(e);\n-                                }\n-                                var f = n.externalMeasured;\n-                                f && (i < f.lineN ? f.lineN += r : t < f.lineN + f.size && (n.externalMeasured = null));\n+                        // the host is the remaining to the left of the first non-host char\n+                        hostEnd = -1;\n+                        for (let i = 0; i < nonHostChars.length; i++) {\n+                            hec = rest.indexOf(nonHostChars[i]);\n+                            if (hec !== -1 && (hostEnd === -1 || hec < hostEnd)) {\n+                                hostEnd = hec;\n                             }\n-                            u(se, \"regChange\");\n+                        }\n+                        // if we still have not hit it, then the entire thing is a host.\n+                        if (hostEnd === -1) {\n+                            hostEnd = rest.length;\n+                        }\n+                        if (rest[hostEnd - 1] === ':') {\n+                            hostEnd--;\n+                        }\n+                        const host = rest.slice(0, hostEnd);\n+                        rest = rest.slice(hostEnd);\n \n-                            function Ye(e, t, i) {\n-                                e.curOp.viewChanged = !0;\n-                                var r = e.display,\n-                                    n = e.display.externalMeasured;\n-                                if (n && t >= n.lineN && t < n.lineN + n.size && (r.externalMeasured = null), !(t < r.viewFrom || t >= r.viewTo)) {\n-                                    var l = r.view[ht(e, t)];\n-                                    if (l.node != null) {\n-                                        var o = l.changes || (l.changes = []);\n-                                        ee(o, i) == -1 && o.push(i);\n-                                    }\n-                                }\n-                            }\n-                            u(Ye, \"regLineChange\");\n+                        // pull out port.\n+                        this.parseHost(host);\n \n-                            function qe(e) {\n-                                e.display.viewFrom = e.display.viewTo = e.doc.first, e.display.view = [], e.display.viewOffset = 0;\n-                            }\n-                            u(qe, \"resetView\");\n+                        // we've indicated that there is a hostname,\n+                        // so even if it's empty, it has to be present.\n+                        this.hostname = this.hostname || '';\n \n-                            function Yr(e, t, i, r) {\n-                                var n = ht(e, t),\n-                                    l,\n-                                    o = e.display.view;\n-                                if (!Ee || i == e.doc.first + e.doc.size) return {\n-                                    index: n,\n-                                    lineN: i\n-                                };\n-                                for (var a = e.display.viewFrom, s = 0; s < n; s++) a += o[s].size;\n-                                if (a != t) {\n-                                    if (r > 0) {\n-                                        if (n == o.length - 1) return null;\n-                                        l = a + o[n].size - t, n++;\n-                                    } else l = a - t;\n-                                    t += l, i += l;\n-                                }\n-                                for (; Ri(e.doc, i) != i;) {\n-                                    if (n == (r < 0 ? 0 : o.length - 1)) return null;\n-                                    i += r * o[n - (r < 0 ? 1 : 0)].size, n += r;\n-                                }\n-                                return {\n-                                    index: n,\n-                                    lineN: i\n-                                };\n-                            }\n-                            u(Yr, \"viewCuttingPoint\");\n+                        // if hostname begins with [ and ends with ]\n+                        // assume that it's an IPv6 address.\n+                        const ipv6Hostname = this.hostname[0] === '[' && this.hostname[this.hostname.length - 1] === ']';\n \n-                            function Za(e, t, i) {\n-                                var r = e.display,\n-                                    n = r.view;\n-                                n.length == 0 || t >= r.viewTo || i <= r.viewFrom ? (r.view = Ur(e, t, i), r.viewFrom = t) : (r.viewFrom > t ? r.view = Ur(e, t, r.viewFrom).concat(r.view) : r.viewFrom < t && (r.view = r.view.slice(ht(e, t))), r.viewFrom = t, r.viewTo < i ? r.view = r.view.concat(Ur(e, r.viewTo, i)) : r.viewTo > i && (r.view = r.view.slice(0, ht(e, i)))), r.viewTo = i;\n-                            }\n-                            u(Za, \"adjustView\");\n-\n-                            function Dl(e) {\n-                                for (var t = e.display.view, i = 0, r = 0; r < t.length; r++) {\n-                                    var n = t[r];\n-                                    !n.hidden && (!n.node || n.changes) && ++i;\n+                        // validate a little.\n+                        if (!ipv6Hostname) {\n+                            const hostparts = this.hostname.split(/\\./);\n+                            for (let i = 0, l = hostparts.length; i < l; i++) {\n+                                const part = hostparts[i];\n+                                if (!part) {\n+                                    continue;\n                                 }\n-                                return i;\n-                            }\n-                            u(Dl, \"countDirtyView\");\n-\n-                            function ir(e) {\n-                                e.display.input.showSelection(e.display.input.prepareSelection());\n-                            }\n-                            u(ir, \"updateSelection\");\n-\n-                            function Nl(e, t) {\n-                                t === void 0 && (t = !0);\n-                                var i = e.doc,\n-                                    r = {},\n-                                    n = r.cursors = document.createDocumentFragment(),\n-                                    l = r.selection = document.createDocumentFragment(),\n-                                    o = e.options.$customCursor;\n-                                o && (t = !0);\n-                                for (var a = 0; a < i.sel.ranges.length; a++)\n-                                    if (!(!t && a == i.sel.primIndex)) {\n-                                        var s = i.sel.ranges[a];\n-                                        if (!(s.from().line >= e.display.viewTo || s.to().line < e.display.viewFrom)) {\n-                                            var f = s.empty();\n-                                            if (o) {\n-                                                var h = o(e, s);\n-                                                h && Vi(e, h, n);\n-                                            } else(f || e.options.showCursorWhenSelecting) && Vi(e, s.head, n);\n-                                            f || Qa(e, s, l);\n-                                        }\n-                                    }\n-                                return r;\n-                            }\n-                            u(Nl, \"prepareSelection\");\n-\n-                            function Vi(e, t, i) {\n-                                var r = Le(e, t, \"div\", null, null, !e.options.singleCursorHeightPerLine),\n-                                    n = i.appendChild(T(\"div\", \"\u00a0\", \"CodeMirror-cursor\"));\n-                                if (n.style.left = r.left + \"px\", n.style.top = r.top + \"px\", n.style.height = Math.max(0, r.bottom - r.top) * e.options.cursorHeight + \"px\", /\\bcm-fat-cursor\\b/.test(e.getWrapperElement().className)) {\n-                                    var l = Xr(e, t, \"div\", null, null),\n-                                        o = l.right - l.left;\n-                                    n.style.width = (o > 0 ? o : e.defaultCharWidth()) + \"px\";\n-                                }\n-                                if (r.other) {\n-                                    var a = i.appendChild(T(\"div\", \"\u00a0\", \"CodeMirror-cursor CodeMirror-secondarycursor\"));\n-                                    a.style.display = \"\", a.style.left = r.other.left + \"px\", a.style.top = r.other.top + \"px\", a.style.height = (r.other.bottom - r.other.top) * .85 + \"px\";\n-                                }\n-                            }\n-                            u(Vi, \"drawSelectionCursor\");\n-\n-                            function qr(e, t) {\n-                                return e.top - t.top || e.left - t.left;\n-                            }\n-                            u(qr, \"cmpCoords\");\n-\n-                            function Qa(e, t, i) {\n-                                var r = e.display,\n-                                    n = e.doc,\n-                                    l = document.createDocumentFragment(),\n-                                    o = pl(e.display),\n-                                    a = o.left,\n-                                    s = Math.max(r.sizerWidth, st(e) - r.sizer.offsetLeft) - o.right,\n-                                    f = n.direction == \"ltr\";\n-\n-                                function h(x, w, k, L) {\n-                                    w < 0 && (w = 0), w = Math.round(w), L = Math.round(L), l.appendChild(T(\"div\", null, \"CodeMirror-selected\", \"position: absolute; left: \" + x + `px;\n-                             top: ` + w + \"px; width: \" + (k !== null && k !== void 0 ? k : s - x) + `px;\n-                             height: ` + (L - w) + \"px\"));\n-                                }\n-                                u(h, \"add\");\n-\n-                                function c(x, w, k) {\n-                                    var L = S(n, x),\n-                                        A = L.text.length,\n-                                        E,\n-                                        j;\n-\n-                                    function B(_, he) {\n-                                        return Xr(e, y(x, _), \"div\", L, he);\n-                                    }\n-                                    u(B, \"coords\");\n-\n-                                    function pe(_, he, $) {\n-                                        var Y = Tl(e, L, null, _),\n-                                            X = he == \"ltr\" == ($ == \"after\") ? \"left\" : \"right\",\n-                                            z = $ == \"after\" ? Y.begin : Y.end - (/\\s/.test(L.text.charAt(Y.end - 1)) ? 2 : 1);\n-                                        return B(z, X)[X];\n-                                    }\n-                                    u(pe, \"wrapX\");\n-                                    var fe = Pe(L, n.direction);\n-                                    return Vo(fe, w || 0, k !== null && k !== void 0 ? k : A, function(_, he, $, Y) {\n-                                        var X = $ == \"ltr\",\n-                                            z = B(_, X ? \"left\" : \"right\"),\n-                                            ce = B(he - 1, X ? \"right\" : \"left\"),\n-                                            zt = w == null && _ == 0,\n-                                            $e = k == null && he == A,\n-                                            re = Y == 0,\n-                                            We = !fe || Y == fe.length - 1;\n-                                        if (ce.top - z.top <= 3) {\n-                                            var V = (f ? zt : $e) && re,\n-                                                kn = (f ? $e : zt) && We,\n-                                                Ge = V ? a : (X ? z : ce).left,\n-                                                gt = kn ? s : (X ? ce : z).right;\n-                                            h(Ge, z.top, gt - Ge, z.bottom);\n+                                if (!part.match(hostnamePartPattern)) {\n+                                    let newpart = '';\n+                                    for (let j = 0, k = part.length; j < k; j++) {\n+                                        if (part.charCodeAt(j) > 127) {\n+                                            // we replace non-ASCII char with a temporary placeholder\n+                                            // we need this to make sure size of hostname is not\n+                                            // broken by replacing non-ASCII by nothing\n+                                            newpart += 'x';\n                                         } else {\n-                                            var yt, oe, Gt, Tn;\n-                                            X ? (yt = f && zt && re ? a : z.left, oe = f ? s : pe(_, $, \"before\"), Gt = f ? a : pe(he, $, \"after\"), Tn = f && $e && We ? s : ce.right) : (yt = f ? pe(_, $, \"before\") : a, oe = !f && zt && re ? s : z.right, Gt = !f && $e && We ? a : ce.left, Tn = f ? pe(he, $, \"after\") : s), h(yt, z.top, oe - yt, z.bottom), z.bottom < ce.top && h(a, z.bottom, null, ce.top), h(Gt, ce.top, Tn - Gt, ce.bottom);\n+                                            newpart += part[j];\n                                         }\n-                                        (!E || qr(z, E) < 0) && (E = z), qr(ce, E) < 0 && (E = ce), (!j || qr(z, j) < 0) && (j = z), qr(ce, j) < 0 && (j = ce);\n-                                    }), {\n-                                        start: E,\n-                                        end: j\n-                                    };\n-                                }\n-                                u(c, \"drawForLine\");\n-                                var p = t.from(),\n-                                    d = t.to();\n-                                if (p.line == d.line) c(p.line, p.ch, d.ch);\n-                                else {\n-                                    var v = S(n, p.line),\n-                                        g = S(n, d.line),\n-                                        m = Se(v) == Se(g),\n-                                        b = c(p.line, p.ch, m ? v.text.length + 1 : null).end,\n-                                        C = c(d.line, m ? 0 : null, d.ch).start;\n-                                    m && (b.top < C.top - 2 ? (h(b.right, b.top, null, b.bottom), h(a, C.top, C.left, C.bottom)) : h(b.right, b.top, C.left - b.right, b.bottom)), b.bottom < C.top && h(a, b.bottom, null, C.top);\n-                                }\n-                                i.appendChild(l);\n-                            }\n-                            u(Qa, \"drawSelectionRange\");\n-\n-                            function $i(e) {\n-                                if (e.state.focused) {\n-                                    var t = e.display;\n-                                    clearInterval(t.blinker);\n-                                    var i = !0;\n-                                    t.cursorDiv.style.visibility = \"\", e.options.cursorBlinkRate > 0 ? t.blinker = setInterval(function() {\n-                                        e.hasFocus() || Dt(e), t.cursorDiv.style.visibility = (i = !i) ? \"\" : \"hidden\";\n-                                    }, e.options.cursorBlinkRate) : e.options.cursorBlinkRate < 0 && (t.cursorDiv.style.visibility = \"hidden\");\n-                                }\n-                            }\n-                            u($i, \"restartBlink\");\n-\n-                            function Al(e) {\n-                                e.hasFocus() || (e.display.input.focus(), e.state.focused || tn(e));\n-                            }\n-                            u(Al, \"ensureFocus\");\n-\n-                            function en(e) {\n-                                e.state.delayingBlurEvent = !0, setTimeout(function() {\n-                                    e.state.delayingBlurEvent && (e.state.delayingBlurEvent = !1, e.state.focused && Dt(e));\n-                                }, 100);\n-                            }\n-                            u(en, \"delayBlurEvent\");\n-\n-                            function tn(e, t) {\n-                                e.state.delayingBlurEvent && !e.state.draggingText && (e.state.delayingBlurEvent = !1), e.options.readOnly != \"nocursor\" && (e.state.focused || (U(e, \"focus\", e, t), e.state.focused = !0, it(e.display.wrapper, \"CodeMirror-focused\"), !e.curOp && e.display.selForContextMenu != e.doc.sel && (e.display.input.reset(), ne && setTimeout(function() {\n-                                    return e.display.input.reset(!0);\n-                                }, 20)), e.display.input.receivedFocus()), $i(e));\n-                            }\n-                            u(tn, \"onFocus\");\n-\n-                            function Dt(e, t) {\n-                                e.state.delayingBlurEvent || (e.state.focused && (U(e, \"blur\", e, t), e.state.focused = !1, tt(e.display.wrapper, \"CodeMirror-focused\")), clearInterval(e.display.blinker), setTimeout(function() {\n-                                    e.state.focused || (e.display.shift = !1);\n-                                }, 150));\n-                            }\n-                            u(Dt, \"onBlur\");\n-\n-                            function Zr(e) {\n-                                for (var t = e.display, i = t.lineDiv.offsetTop, r = Math.max(0, t.scroller.getBoundingClientRect().top), n = t.lineDiv.getBoundingClientRect().top, l = 0, o = 0; o < t.view.length; o++) {\n-                                    var a = t.view[o],\n-                                        s = e.options.lineWrapping,\n-                                        f = void 0,\n-                                        h = 0;\n-                                    if (!a.hidden) {\n-                                        if (n += a.line.height, O && I < 8) {\n-                                            var c = a.node.offsetTop + a.node.offsetHeight;\n-                                            f = c - i, i = c;\n-                                        } else {\n-                                            var p = a.node.getBoundingClientRect();\n-                                            f = p.bottom - p.top, !s && a.text.firstChild && (h = a.text.firstChild.getBoundingClientRect().right - p.left - 1);\n+                                    }\n+                                    // we test again with ASCII char only\n+                                    if (!newpart.match(hostnamePartPattern)) {\n+                                        const validParts = hostparts.slice(0, i);\n+                                        const notHost = hostparts.slice(i + 1);\n+                                        const bit = part.match(hostnamePartStart);\n+                                        if (bit) {\n+                                            validParts.push(bit[1]);\n+                                            notHost.unshift(bit[2]);\n                                         }\n-                                        var d = a.line.height - f;\n-                                        if ((d > .005 || d < -.005) && (n < r && (l -= d), De(a.line, f), Ol(a.line), a.rest))\n-                                            for (var v = 0; v < a.rest.length; v++) Ol(a.rest[v]);\n-                                        if (h > e.display.sizerWidth) {\n-                                            var g = Math.ceil(h / Mt(e.display));\n-                                            g > e.display.maxLineLength && (e.display.maxLineLength = g, e.display.maxLine = a.line, e.display.maxLineChanged = !0);\n+                                        if (notHost.length) {\n+                                            rest = notHost.join('.') + rest;\n                                         }\n+                                        this.hostname = validParts.join('.');\n+                                        break;\n                                     }\n                                 }\n-                                Math.abs(l) > 2 && (t.scroller.scrollTop += l);\n-                            }\n-                            u(Zr, \"updateHeightsInViewport\");\n-\n-                            function Ol(e) {\n-                                if (e.widgets)\n-                                    for (var t = 0; t < e.widgets.length; ++t) {\n-                                        var i = e.widgets[t],\n-                                            r = i.node.parentNode;\n-                                        r && (i.height = r.offsetHeight);\n-                                    }\n-                            }\n-                            u(Ol, \"updateWidgetHeight\");\n-\n-                            function Qr(e, t, i) {\n-                                var r = i && i.top != null ? Math.max(0, i.top) : e.scroller.scrollTop;\n-                                r = Math.floor(r - Kr(e));\n-                                var n = i && i.bottom != null ? i.bottom : r + e.wrapper.clientHeight,\n-                                    l = at(t, r),\n-                                    o = at(t, n);\n-                                if (i && i.ensure) {\n-                                    var a = i.ensure.from.line,\n-                                        s = i.ensure.to.line;\n-                                    a < l ? (l = a, o = at(t, Ie(S(t, a)) + e.wrapper.clientHeight)) : Math.min(s, t.lastLine()) >= o && (l = at(t, Ie(S(t, s)) - e.wrapper.clientHeight), o = s);\n-                                }\n-                                return {\n-                                    from: l,\n-                                    to: Math.max(o, l + 1)\n-                                };\n-                            }\n-                            u(Qr, \"visibleLines\");\n-\n-                            function Ja(e, t) {\n-                                if (!q(e, \"scrollCursorIntoView\")) {\n-                                    var i = e.display,\n-                                        r = i.sizer.getBoundingClientRect(),\n-                                        n = null;\n-                                    if (t.top + r.top < 0 ? n = !0 : t.bottom + r.top > (window.innerHeight || document.documentElement.clientHeight) && (n = !1), n != null && !Yo) {\n-                                        var l = T(\"div\", \"\u200b\", null, `position: absolute;\n-                         top: ` + (t.top - i.viewOffset - Kr(e.display)) + `px;\n-                         height: ` + (t.bottom - t.top + Ae(e) + i.barHeight) + `px;\n-                         left: ` + t.left + \"px; width: \" + Math.max(2, t.right - t.left) + \"px;\");\n-                                        e.display.lineSpace.appendChild(l), l.scrollIntoView(n), e.display.lineSpace.removeChild(l);\n-                                    }\n-                                }\n-                            }\n-                            u(Ja, \"maybeScrollWindow\");\n-\n-                            function ja(e, t, i, r) {\n-                                r == null && (r = 0);\n-                                var n;\n-                                !e.options.lineWrapping && t == i && (i = t.sticky == \"before\" ? y(t.line, t.ch + 1, \"before\") : t, t = t.ch ? y(t.line, t.sticky == \"before\" ? t.ch - 1 : t.ch, \"after\") : t);\n-                                for (var l = 0; l < 5; l++) {\n-                                    var o = !1,\n-                                        a = Le(e, t),\n-                                        s = !i || i == t ? a : Le(e, i);\n-                                    n = {\n-                                        left: Math.min(a.left, s.left),\n-                                        top: Math.min(a.top, s.top) - r,\n-                                        right: Math.max(a.left, s.left),\n-                                        bottom: Math.max(a.bottom, s.bottom) + r\n-                                    };\n-                                    var f = rn(e, n),\n-                                        h = e.doc.scrollTop,\n-                                        c = e.doc.scrollLeft;\n-                                    if (f.scrollTop != null && (lr(e, f.scrollTop), Math.abs(e.doc.scrollTop - h) > 1 && (o = !0)), f.scrollLeft != null && (ct(e, f.scrollLeft), Math.abs(e.doc.scrollLeft - c) > 1 && (o = !0)), !o) break;\n-                                }\n-                                return n;\n-                            }\n-                            u(ja, \"scrollPosIntoView\");\n-\n-                            function Va(e, t) {\n-                                var i = rn(e, t);\n-                                i.scrollTop != null && lr(e, i.scrollTop), i.scrollLeft != null && ct(e, i.scrollLeft);\n-                            }\n-                            u(Va, \"scrollIntoView\");\n-\n-                            function rn(e, t) {\n-                                var i = e.display,\n-                                    r = Tt(e.display);\n-                                t.top < 0 && (t.top = 0);\n-                                var n = e.curOp && e.curOp.scrollTop != null ? e.curOp.scrollTop : i.scroller.scrollTop,\n-                                    l = Ki(e),\n-                                    o = {};\n-                                t.bottom - t.top > l && (t.bottom = t.top + l);\n-                                var a = e.doc.height + Ui(i),\n-                                    s = t.top < r,\n-                                    f = t.bottom > a - r;\n-                                if (t.top < n) o.scrollTop = s ? 0 : t.top;\n-                                else if (t.bottom > n + l) {\n-                                    var h = Math.min(t.top, (f ? a : t.bottom) - l);\n-                                    h != n && (o.scrollTop = h);\n-                                }\n-                                var c = e.options.fixedGutter ? 0 : i.gutters.offsetWidth,\n-                                    p = e.curOp && e.curOp.scrollLeft != null ? e.curOp.scrollLeft : i.scroller.scrollLeft - c,\n-                                    d = st(e) - i.gutters.offsetWidth,\n-                                    v = t.right - t.left > d;\n-                                return v && (t.right = t.left + d), t.left < 10 ? o.scrollLeft = 0 : t.left < p ? o.scrollLeft = Math.max(0, t.left + c - (v ? 0 : 10)) : t.right > d + p - 3 && (o.scrollLeft = t.right + (v ? 0 : 10) - d), o;\n-                            }\n-                            u(rn, \"calculateScrollPos\");\n-\n-                            function nn(e, t) {\n-                                t != null && (Jr(e), e.curOp.scrollTop = (e.curOp.scrollTop == null ? e.doc.scrollTop : e.curOp.scrollTop) + t);\n-                            }\n-                            u(nn, \"addToScrollTop\");\n-\n-                            function Nt(e) {\n-                                Jr(e);\n-                                var t = e.getCursor();\n-                                e.curOp.scrollToPos = {\n-                                    from: t,\n-                                    to: t,\n-                                    margin: e.options.cursorScrollMargin\n-                                };\n                             }\n-                            u(Nt, \"ensureCursorVisible\");\n+                        }\n+                        if (this.hostname.length > hostnameMaxLen) {\n+                            this.hostname = '';\n+                        }\n \n-                            function nr(e, t, i) {\n-                                (t != null || i != null) && Jr(e), t != null && (e.curOp.scrollLeft = t), i != null && (e.curOp.scrollTop = i);\n-                            }\n-                            u(nr, \"scrollToCoords\");\n+                        // strip [ and ] from the hostname\n+                        // the host field still retains them, though\n+                        if (ipv6Hostname) {\n+                            this.hostname = this.hostname.substr(1, this.hostname.length - 2);\n+                        }\n+                    }\n \n-                            function $a(e, t) {\n-                                Jr(e), e.curOp.scrollToPos = t;\n-                            }\n-                            u($a, \"scrollToRange\");\n+                    // chop off from the tail first.\n+                    const hash = rest.indexOf('#');\n+                    if (hash !== -1) {\n+                        // got a fragment string.\n+                        this.hash = rest.substr(hash);\n+                        rest = rest.slice(0, hash);\n+                    }\n+                    const qm = rest.indexOf('?');\n+                    if (qm !== -1) {\n+                        this.search = rest.substr(qm);\n+                        rest = rest.slice(0, qm);\n+                    }\n+                    if (rest) {\n+                        this.pathname = rest;\n+                    }\n+                    if (slashedProtocol[lowerProto] && this.hostname && !this.pathname) {\n+                        this.pathname = '';\n+                    }\n+                    return this;\n+                };\n+                Url.prototype.parseHost = function(host) {\n+                    let port = portPattern.exec(host);\n+                    if (port) {\n+                        port = port[0];\n+                        if (port !== ':') {\n+                            this.port = port.substr(1);\n+                        }\n+                        host = host.substr(0, host.length - port.length);\n+                    }\n+                    if (host) {\n+                        this.hostname = host;\n+                    }\n+                };\n+                exports.decode = decode;\n+                exports.encode = encode;\n+                exports.format = format;\n+                exports.parse = urlParse;\n \n-                            function Jr(e) {\n-                                var t = e.curOp.scrollToPos;\n-                                if (t) {\n-                                    e.curOp.scrollToPos = null;\n-                                    var i = Ll(e, t.from),\n-                                        r = Ll(e, t.to);\n-                                    Wl(e, i, r, t.margin);\n-                                }\n-                            }\n-                            u(Jr, \"resolveScrollToPos\");\n+                /***/\n+            }),\n \n-                            function Wl(e, t, i, r) {\n-                                var n = rn(e, {\n-                                    left: Math.min(t.left, i.left),\n-                                    top: Math.min(t.top, i.top) - r,\n-                                    right: Math.max(t.right, i.right),\n-                                    bottom: Math.max(t.bottom, i.bottom) + r\n-                                });\n-                                nr(e, n.scrollLeft, n.scrollTop);\n-                            }\n-                            u(Wl, \"scrollToCoordsRange\");\n+        /***/\n+        \"../../../node_modules/meros/browser/index.js\":\n+            /*!****************************************************!*\\\n+              !*** ../../../node_modules/meros/browser/index.js ***!\n+              \\****************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports) {\n \n-                            function lr(e, t) {\n-                                Math.abs(e.doc.scrollTop - t) < 2 || (Fe || on(e, {\n-                                    top: t\n-                                }), Hl(e, t, !0), Fe && on(e), sr(e, 100));\n-                            }\n-                            u(lr, \"updateScrollTop\");\n+                \"use strict\";\n \n-                            function Hl(e, t, i) {\n-                                t = Math.max(0, Math.min(e.display.scroller.scrollHeight - e.display.scroller.clientHeight, t)), !(e.display.scroller.scrollTop == t && !i) && (e.doc.scrollTop = t, e.display.scrollbars.setScrollTop(t), e.display.scroller.scrollTop != t && (e.display.scroller.scrollTop = t));\n-                            }\n-                            u(Hl, \"setScrollTop\");\n \n-                            function ct(e, t, i, r) {\n-                                t = Math.max(0, Math.min(t, e.display.scroller.scrollWidth - e.display.scroller.clientWidth)), !((i ? t == e.doc.scrollLeft : Math.abs(e.doc.scrollLeft - t) < 2) && !r) && (e.doc.scrollLeft = t, Rl(e), e.display.scroller.scrollLeft != t && (e.display.scroller.scrollLeft = t), e.display.scrollbars.setScrollLeft(t));\n+                var e = new TextDecoder();\n+                async function t(t, n) {\n+                    if (!t.ok || !t.body || t.bodyUsed) return t;\n+                    let i = t.headers.get(\"content-type\");\n+                    if (!i || !~i.indexOf(\"multipart/\")) return t;\n+                    let l = i.indexOf(\"boundary=\"),\n+                        r = \"-\";\n+                    if (~l) {\n+                        let e = l + 9,\n+                            t = i.indexOf(\";\", e);\n+                        r = i.slice(e, t > -1 ? t : void 0).trim().replace(/\"/g, \"\");\n+                    }\n+                    return async function*(t, n, i) {\n+                        let l,\n+                            r,\n+                            d,\n+                            o = t.getReader(),\n+                            a = !i || !i.multiple,\n+                            f = n.length,\n+                            s = \"\",\n+                            c = [];\n+                        try {\n+                            let t;\n+                            e: for (; !(t = await o.read()).done;) {\n+                                let i = e.decode(t.value);\n+                                l = s.length, s += i;\n+                                let o = i.indexOf(n);\n+                                for (~o ? l += o : l = s.indexOf(n), c = []; ~l;) {\n+                                    let e = s.slice(0, l),\n+                                        t = s.slice(l + f);\n+                                    if (r) {\n+                                        let n = e.indexOf(\"\\r\\n\\r\\n\") + 4,\n+                                            i = e.lastIndexOf(\"\\r\\n\", n),\n+                                            l = !1,\n+                                            r = e.slice(n, i > -1 ? void 0 : i),\n+                                            o = String(e.slice(0, n)).trim().split(\"\\r\\n\"),\n+                                            f = {},\n+                                            s = o.length;\n+                                        for (; d = o[--s]; d = d.split(\": \"), f[d.shift().toLowerCase()] = d.join(\": \"));\n+                                        if (d = f[\"content-type\"], d && ~d.indexOf(\"application/json\")) try {\n+                                            r = JSON.parse(r), l = !0;\n+                                        } catch (e) {}\n+                                        if (d = {\n+                                                headers: f,\n+                                                body: r,\n+                                                json: l\n+                                            }, a ? yield d: c.push(d), \"--\" === t.slice(0, 2)) break e;\n+                                    } else n = \"\\r\\n\" + n, r = f += 2;\n+                                    s = t, l = s.indexOf(n);\n+                                }\n+                                c.length && (yield c);\n                             }\n-                            u(ct, \"setScrollLeft\");\n+                        } finally {\n+                            c.length && (yield c), await o.cancel();\n+                        }\n+                    }(t.body, `--${r}`, n);\n+                }\n+                exports.meros = t;\n \n-                            function or(e) {\n-                                var t = e.display,\n-                                    i = t.gutters.offsetWidth,\n-                                    r = Math.round(e.doc.height + Ui(e.display));\n-                                return {\n-                                    clientHeight: t.scroller.clientHeight,\n-                                    viewHeight: t.wrapper.clientHeight,\n-                                    scrollWidth: t.scroller.scrollWidth,\n-                                    clientWidth: t.scroller.clientWidth,\n-                                    viewWidth: t.wrapper.clientWidth,\n-                                    barLeft: e.options.fixedGutter ? i : 0,\n-                                    docHeight: r,\n-                                    scrollHeight: r + Ae(e) + t.barHeight,\n-                                    nativeBarWidth: t.nativeBarWidth,\n-                                    gutterWidth: i\n-                                };\n-                            }\n-                            u(or, \"measureForScrollbars\");\n-                            var dt = u(function(e, t, i) {\n-                                this.cm = i;\n-                                var r = this.vert = T(\"div\", [T(\"div\", null, null, \"min-width: 1px\")], \"CodeMirror-vscrollbar\"),\n-                                    n = this.horiz = T(\"div\", [T(\"div\", null, null, \"height: 100%; min-height: 1px\")], \"CodeMirror-hscrollbar\");\n-                                r.tabIndex = n.tabIndex = -1, e(r), e(n), M(r, \"scroll\", function() {\n-                                    r.clientHeight && t(r.scrollTop, \"vertical\");\n-                                }), M(n, \"scroll\", function() {\n-                                    n.clientWidth && t(n.scrollLeft, \"horizontal\");\n-                                }), this.checkedZeroWidth = !1, O && I < 8 && (this.horiz.style.minHeight = this.vert.style.minWidth = \"18px\");\n-                            }, \"NativeScrollbars\");\n-                            dt.prototype.update = function(e) {\n-                                var t = e.scrollWidth > e.clientWidth + 1,\n-                                    i = e.scrollHeight > e.clientHeight + 1,\n-                                    r = e.nativeBarWidth;\n-                                if (i) {\n-                                    this.vert.style.display = \"block\", this.vert.style.bottom = t ? r + \"px\" : \"0\";\n-                                    var n = e.viewHeight - (t ? r : 0);\n-                                    this.vert.firstChild.style.height = Math.max(0, e.scrollHeight - e.clientHeight + n) + \"px\";\n-                                } else this.vert.scrollTop = 0, this.vert.style.display = \"\", this.vert.firstChild.style.height = \"0\";\n-                                if (t) {\n-                                    this.horiz.style.display = \"block\", this.horiz.style.right = i ? r + \"px\" : \"0\", this.horiz.style.left = e.barLeft + \"px\";\n-                                    var l = e.viewWidth - e.barLeft - (i ? r : 0);\n-                                    this.horiz.firstChild.style.width = Math.max(0, e.scrollWidth - e.clientWidth + l) + \"px\";\n-                                } else this.horiz.style.display = \"\", this.horiz.firstChild.style.width = \"0\";\n-                                return !this.checkedZeroWidth && e.clientHeight > 0 && (r == 0 && this.zeroWidthHack(), this.checkedZeroWidth = !0), {\n-                                    right: i ? r : 0,\n-                                    bottom: t ? r : 0\n-                                };\n-                            }, dt.prototype.setScrollLeft = function(e) {\n-                                this.horiz.scrollLeft != e && (this.horiz.scrollLeft = e), this.disableHoriz && this.enableZeroWidthBar(this.horiz, this.disableHoriz, \"horiz\");\n-                            }, dt.prototype.setScrollTop = function(e) {\n-                                this.vert.scrollTop != e && (this.vert.scrollTop = e), this.disableVert && this.enableZeroWidthBar(this.vert, this.disableVert, \"vert\");\n-                            }, dt.prototype.zeroWidthHack = function() {\n-                                var e = me && !Xo ? \"12px\" : \"18px\";\n-                                this.horiz.style.height = this.vert.style.width = e, this.horiz.style.pointerEvents = this.vert.style.pointerEvents = \"none\", this.disableHoriz = new _e(), this.disableVert = new _e();\n-                            }, dt.prototype.enableZeroWidthBar = function(e, t, i) {\n-                                e.style.pointerEvents = \"auto\";\n-\n-                                function r() {\n-                                    var n = e.getBoundingClientRect(),\n-                                        l = i == \"vert\" ? document.elementFromPoint(n.right - 1, (n.top + n.bottom) / 2) : document.elementFromPoint((n.right + n.left) / 2, n.bottom - 1);\n-                                    l != e ? e.style.pointerEvents = \"none\" : t.set(1e3, r);\n-                                }\n-                                u(r, \"maybeDisable\"), t.set(1e3, r);\n-                            }, dt.prototype.clear = function() {\n-                                var e = this.horiz.parentNode;\n-                                e.removeChild(this.horiz), e.removeChild(this.vert);\n-                            };\n-                            var ar = u(function() {}, \"NullScrollbars\");\n-                            ar.prototype.update = function() {\n-                                return {\n-                                    bottom: 0,\n-                                    right: 0\n-                                };\n-                            }, ar.prototype.setScrollLeft = function() {}, ar.prototype.setScrollTop = function() {}, ar.prototype.clear = function() {};\n+                /***/\n+            }),\n \n-                            function At(e, t) {\n-                                t || (t = or(e));\n-                                var i = e.display.barWidth,\n-                                    r = e.display.barHeight;\n-                                Fl(e, t);\n-                                for (var n = 0; n < 4 && i != e.display.barWidth || r != e.display.barHeight; n++) i != e.display.barWidth && e.options.lineWrapping && Zr(e), Fl(e, or(e)), i = e.display.barWidth, r = e.display.barHeight;\n-                            }\n-                            u(At, \"updateScrollbars\");\n-\n-                            function Fl(e, t) {\n-                                var i = e.display,\n-                                    r = i.scrollbars.update(t);\n-                                i.sizer.style.paddingRight = (i.barWidth = r.right) + \"px\", i.sizer.style.paddingBottom = (i.barHeight = r.bottom) + \"px\", i.heightForcer.style.borderBottom = r.bottom + \"px solid transparent\", r.right && r.bottom ? (i.scrollbarFiller.style.display = \"block\", i.scrollbarFiller.style.height = r.bottom + \"px\", i.scrollbarFiller.style.width = r.right + \"px\") : i.scrollbarFiller.style.display = \"\", r.bottom && e.options.coverGutterNextToScrollbar && e.options.fixedGutter ? (i.gutterFiller.style.display = \"block\", i.gutterFiller.style.height = r.bottom + \"px\", i.gutterFiller.style.width = t.gutterWidth + \"px\") : i.gutterFiller.style.display = \"\";\n-                            }\n-                            u(Fl, \"updateScrollbarsInner\");\n-                            var Pl = {\n-                                native: dt,\n-                                null: ar\n-                            };\n-\n-                            function El(e) {\n-                                e.display.scrollbars && (e.display.scrollbars.clear(), e.display.scrollbars.addClass && tt(e.display.wrapper, e.display.scrollbars.addClass)), e.display.scrollbars = new Pl[e.options.scrollbarStyle](function(t) {\n-                                    e.display.wrapper.insertBefore(t, e.display.scrollbarFiller), M(t, \"mousedown\", function() {\n-                                        e.state.focused && setTimeout(function() {\n-                                            return e.display.input.focus();\n-                                        }, 0);\n-                                    }), t.setAttribute(\"cm-not-content\", \"true\");\n-                                }, function(t, i) {\n-                                    i == \"horizontal\" ? ct(e, t) : lr(e, t);\n-                                }, e), e.display.scrollbars.addClass && it(e.display.wrapper, e.display.scrollbars.addClass);\n-                            }\n-                            u(El, \"initScrollbars\");\n-                            var es = 0;\n-\n-                            function pt(e) {\n-                                e.curOp = {\n-                                    cm: e,\n-                                    viewChanged: !1,\n-                                    startHeight: e.doc.height,\n-                                    forceUpdate: !1,\n-                                    updateInput: 0,\n-                                    typing: !1,\n-                                    changeObjs: null,\n-                                    cursorActivityHandlers: null,\n-                                    cursorActivityCalled: 0,\n-                                    selectionChanged: !1,\n-                                    updateMaxLine: !1,\n-                                    scrollLeft: null,\n-                                    scrollTop: null,\n-                                    scrollToPos: null,\n-                                    focus: !1,\n-                                    id: ++es,\n-                                    markArrays: null\n-                                }, Oa(e.curOp);\n-                            }\n-                            u(pt, \"startOperation\");\n-\n-                            function vt(e) {\n-                                var t = e.curOp;\n-                                t && Ha(t, function(i) {\n-                                    for (var r = 0; r < i.ops.length; r++) i.ops[r].cm.curOp = null;\n-                                    ts(i);\n-                                });\n-                            }\n-                            u(vt, \"endOperation\");\n+        /***/\n+        \"../../../node_modules/nullthrows/nullthrows.js\":\n+            /*!******************************************************!*\\\n+              !*** ../../../node_modules/nullthrows/nullthrows.js ***!\n+              \\******************************************************/\n+            /***/\n+            (function(module) {\n \n-                            function ts(e) {\n-                                for (var t = e.ops, i = 0; i < t.length; i++) rs(t[i]);\n-                                for (var r = 0; r < t.length; r++) is(t[r]);\n-                                for (var n = 0; n < t.length; n++) ns(t[n]);\n-                                for (var l = 0; l < t.length; l++) ls(t[l]);\n-                                for (var o = 0; o < t.length; o++) os(t[o]);\n-                            }\n-                            u(ts, \"endOperations\");\n-\n-                            function rs(e) {\n-                                var t = e.cm,\n-                                    i = t.display;\n-                                ss(t), e.updateMaxLine && zi(t), e.mustUpdate = e.viewChanged || e.forceUpdate || e.scrollTop != null || e.scrollToPos && (e.scrollToPos.from.line < i.viewFrom || e.scrollToPos.to.line >= i.viewTo) || i.maxLineChanged && t.options.lineWrapping, e.update = e.mustUpdate && new jr(t, e.mustUpdate && {\n-                                    top: e.scrollTop,\n-                                    ensure: e.scrollToPos\n-                                }, e.forceUpdate);\n-                            }\n-                            u(rs, \"endOperation_R1\");\n-\n-                            function is(e) {\n-                                e.updatedDisplay = e.mustUpdate && ln(e.cm, e.update);\n-                            }\n-                            u(is, \"endOperation_W1\");\n-\n-                            function ns(e) {\n-                                var t = e.cm,\n-                                    i = t.display;\n-                                e.updatedDisplay && Zr(t), e.barMeasure = or(t), i.maxLineChanged && !t.options.lineWrapping && (e.adjustWidthTo = gl(t, i.maxLine, i.maxLine.text.length).left + 3, t.display.sizerWidth = e.adjustWidthTo, e.barMeasure.scrollWidth = Math.max(i.scroller.clientWidth, i.sizer.offsetLeft + e.adjustWidthTo + Ae(t) + t.display.barWidth), e.maxScrollLeft = Math.max(0, i.sizer.offsetLeft + e.adjustWidthTo - st(t))), (e.updatedDisplay || e.selectionChanged) && (e.preparedSelection = i.input.prepareSelection());\n-                            }\n-                            u(ns, \"endOperation_R2\");\n-\n-                            function ls(e) {\n-                                var t = e.cm;\n-                                e.adjustWidthTo != null && (t.display.sizer.style.minWidth = e.adjustWidthTo + \"px\", e.maxScrollLeft < t.doc.scrollLeft && ct(t, Math.min(t.display.scroller.scrollLeft, e.maxScrollLeft), !0), t.display.maxLineChanged = !1);\n-                                var i = e.focus && e.focus == be();\n-                                e.preparedSelection && t.display.input.showSelection(e.preparedSelection, i), (e.updatedDisplay || e.startHeight != t.doc.height) && At(t, e.barMeasure), e.updatedDisplay && sn(t, e.barMeasure), e.selectionChanged && $i(t), t.state.focused && e.updateInput && t.display.input.reset(e.typing), i && Al(e.cm);\n-                            }\n-                            u(ls, \"endOperation_W2\");\n-\n-                            function os(e) {\n-                                var t = e.cm,\n-                                    i = t.display,\n-                                    r = t.doc;\n-                                if (e.updatedDisplay && Il(t, e.update), i.wheelStartX != null && (e.scrollTop != null || e.scrollLeft != null || e.scrollToPos) && (i.wheelStartX = i.wheelStartY = null), e.scrollTop != null && Hl(t, e.scrollTop, e.forceScroll), e.scrollLeft != null && ct(t, e.scrollLeft, !0, !0), e.scrollToPos) {\n-                                    var n = ja(t, N(r, e.scrollToPos.from), N(r, e.scrollToPos.to), e.scrollToPos.margin);\n-                                    Ja(t, n);\n-                                }\n-                                var l = e.maybeHiddenMarkers,\n-                                    o = e.maybeUnhiddenMarkers;\n-                                if (l)\n-                                    for (var a = 0; a < l.length; ++a) l[a].lines.length || U(l[a], \"hide\");\n-                                if (o)\n-                                    for (var s = 0; s < o.length; ++s) o[s].lines.length && U(o[s], \"unhide\");\n-                                i.wrapper.offsetHeight && (r.scrollTop = t.display.scroller.scrollTop), e.changeObjs && U(t, \"changes\", t, e.changeObjs), e.update && e.update.finish();\n-                            }\n-                            u(os, \"endOperation_finish\");\n-\n-                            function de(e, t) {\n-                                if (e.curOp) return t();\n-                                pt(e);\n-                                try {\n-                                    return t();\n-                                } finally {\n-                                    vt(e);\n-                                }\n-                            }\n-                            u(de, \"runInOp\");\n+                \"use strict\";\n \n-                            function Q(e, t) {\n-                                return function() {\n-                                    if (e.curOp) return t.apply(e, arguments);\n-                                    pt(e);\n-                                    try {\n-                                        return t.apply(e, arguments);\n-                                    } finally {\n-                                        vt(e);\n-                                    }\n-                                };\n-                            }\n-                            u(Q, \"operation\");\n \n-                            function le(e) {\n-                                return function() {\n-                                    if (this.curOp) return e.apply(this, arguments);\n-                                    pt(this);\n-                                    try {\n-                                        return e.apply(this, arguments);\n-                                    } finally {\n-                                        vt(this);\n-                                    }\n-                                };\n-                            }\n-                            u(le, \"methodOp\");\n+                function nullthrows(x, message) {\n+                    if (x != null) {\n+                        return x;\n+                    }\n+                    var error = new Error(message !== undefined ? message : 'Got unexpected ' + x);\n+                    error.framesToPop = 1; // Skip nullthrows's own stack frame.\n+                    throw error;\n+                }\n+                module.exports = nullthrows;\n+                module.exports[\"default\"] = nullthrows;\n+                Object.defineProperty(module.exports, \"__esModule\", ({\n+                    value: true\n+                }));\n \n-                            function J(e) {\n-                                return function() {\n-                                    var t = this.cm;\n-                                    if (!t || t.curOp) return e.apply(this, arguments);\n-                                    pt(t);\n-                                    try {\n-                                        return e.apply(this, arguments);\n-                                    } finally {\n-                                        vt(t);\n-                                    }\n-                                };\n-                            }\n-                            u(J, \"docMethodOp\");\n+                /***/\n+            }),\n \n-                            function sr(e, t) {\n-                                e.doc.highlightFrontier < e.display.viewTo && e.state.highlight.set(t, pi(as, e));\n-                            }\n-                            u(sr, \"startWorker\");\n+        /***/\n+        \"../../../node_modules/popmotion/dist/popmotion.cjs.js\":\n+            /*!*************************************************************!*\\\n+              !*** ../../../node_modules/popmotion/dist/popmotion.cjs.js ***!\n+              \\*************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                            function as(e) {\n-                                var t = e.doc;\n-                                if (!(t.highlightFrontier >= e.display.viewTo)) {\n-                                    var i = +new Date() + e.options.workTime,\n-                                        r = jt(e, t.highlightFrontier),\n-                                        n = [];\n-                                    t.iter(r.line, Math.min(t.first + t.size, e.display.viewTo + 500), function(l) {\n-                                        if (r.line >= e.display.viewFrom) {\n-                                            var o = l.styles,\n-                                                a = l.text.length > e.options.maxHighlightLength ? lt(t.mode, r.state) : null,\n-                                                s = _n(e, l, r, !0);\n-                                            a && (r.state = a), l.styles = s.styles;\n-                                            var f = l.styleClasses,\n-                                                h = s.classes;\n-                                            h ? l.styleClasses = h : f && (l.styleClasses = null);\n-                                            for (var c = !o || o.length != l.styles.length || f != h && (!f || !h || f.bgClass != h.bgClass || f.textClass != h.textClass), p = 0; !c && p < o.length; ++p) c = o[p] != l.styles[p];\n-                                            c && n.push(r.line), l.stateAfter = r.save(), r.nextLine();\n-                                        } else l.text.length <= e.options.maxHighlightLength && Fi(e, l.text, r), l.stateAfter = r.line % 5 == 0 ? r.save() : null, r.nextLine();\n-                                        if (+new Date() > i) return sr(e, e.options.workDelay), !0;\n-                                    }), t.highlightFrontier = r.line, t.modeFrontier = Math.max(t.modeFrontier, r.line), n.length && de(e, function() {\n-                                        for (var l = 0; l < n.length; l++) Ye(e, n[l], \"text\");\n-                                    });\n-                                }\n-                            }\n-                            u(as, \"highlightWorker\");\n-                            var jr = u(function(e, t, i) {\n-                                var r = e.display;\n-                                this.viewport = t, this.visible = Qr(r, e.doc, t), this.editorIsHidden = !r.wrapper.offsetWidth, this.wrapperHeight = r.wrapper.clientHeight, this.wrapperWidth = r.wrapper.clientWidth, this.oldDisplayWidth = st(e), this.force = i, this.dims = Qi(e), this.events = [];\n-                            }, \"DisplayUpdate\");\n-                            jr.prototype.signal = function(e, t) {\n-                                Ce(e, t) && this.events.push(arguments);\n-                            }, jr.prototype.finish = function() {\n-                                for (var e = 0; e < this.events.length; e++) U.apply(null, this.events[e]);\n-                            };\n-\n-                            function ss(e) {\n-                                var t = e.display;\n-                                !t.scrollbarsClipped && t.scroller.offsetWidth && (t.nativeBarWidth = t.scroller.offsetWidth - t.scroller.clientWidth, t.heightForcer.style.height = Ae(e) + \"px\", t.sizer.style.marginBottom = -t.nativeBarWidth + \"px\", t.sizer.style.borderRightWidth = Ae(e) + \"px\", t.scrollbarsClipped = !0);\n-                            }\n-                            u(ss, \"maybeClipScrollbars\");\n-\n-                            function us(e) {\n-                                if (e.hasFocus()) return null;\n-                                var t = be();\n-                                if (!t || !Ke(e.display.lineDiv, t)) return null;\n-                                var i = {\n-                                    activeElt: t\n-                                };\n-                                if (window.getSelection) {\n-                                    var r = window.getSelection();\n-                                    r.anchorNode && r.extend && Ke(e.display.lineDiv, r.anchorNode) && (i.anchorNode = r.anchorNode, i.anchorOffset = r.anchorOffset, i.focusNode = r.focusNode, i.focusOffset = r.focusOffset);\n-                                }\n-                                return i;\n-                            }\n-                            u(us, \"selectionSnapshot\");\n+                \"use strict\";\n \n-                            function fs(e) {\n-                                if (!(!e || !e.activeElt || e.activeElt == be()) && (e.activeElt.focus(), !/^(INPUT|TEXTAREA)$/.test(e.activeElt.nodeName) && e.anchorNode && Ke(document.body, e.anchorNode) && Ke(document.body, e.focusNode))) {\n-                                    var t = window.getSelection(),\n-                                        i = document.createRange();\n-                                    i.setEnd(e.anchorNode, e.anchorOffset), i.collapse(!1), t.removeAllRanges(), t.addRange(i), t.extend(e.focusNode, e.focusOffset);\n-                                }\n-                            }\n-                            u(fs, \"restoreSelection\");\n-\n-                            function ln(e, t) {\n-                                var i = e.display,\n-                                    r = e.doc;\n-                                if (t.editorIsHidden) return qe(e), !1;\n-                                if (!t.force && t.visible.from >= i.viewFrom && t.visible.to <= i.viewTo && (i.updateLineNumbers == null || i.updateLineNumbers >= i.viewTo) && i.renderedView == i.view && Dl(e) == 0) return !1;\n-                                Bl(e) && (qe(e), t.dims = Qi(e));\n-                                var n = r.first + r.size,\n-                                    l = Math.max(t.visible.from - e.options.viewportMargin, r.first),\n-                                    o = Math.min(n, t.visible.to + e.options.viewportMargin);\n-                                i.viewFrom < l && l - i.viewFrom < 20 && (l = Math.max(r.first, i.viewFrom)), i.viewTo > o && i.viewTo - o < 20 && (o = Math.min(n, i.viewTo)), Ee && (l = Ri(e.doc, l), o = nl(e.doc, o));\n-                                var a = l != i.viewFrom || o != i.viewTo || i.lastWrapHeight != t.wrapperHeight || i.lastWrapWidth != t.wrapperWidth;\n-                                Za(e, l, o), i.viewOffset = Ie(S(e.doc, i.viewFrom)), e.display.mover.style.top = i.viewOffset + \"px\";\n-                                var s = Dl(e);\n-                                if (!a && s == 0 && !t.force && i.renderedView == i.view && (i.updateLineNumbers == null || i.updateLineNumbers >= i.viewTo)) return !1;\n-                                var f = us(e);\n-                                return s > 4 && (i.lineDiv.style.display = \"none\"), hs(e, i.updateLineNumbers, t.dims), s > 4 && (i.lineDiv.style.display = \"\"), i.renderedView = i.view, fs(f), Ue(i.cursorDiv), Ue(i.selectionDiv), i.gutters.style.height = i.sizer.style.minHeight = 0, a && (i.lastWrapHeight = t.wrapperHeight, i.lastWrapWidth = t.wrapperWidth, sr(e, 400)), i.updateLineNumbers = null, !0;\n-                            }\n-                            u(ln, \"updateDisplayIfNeeded\");\n-\n-                            function Il(e, t) {\n-                                for (var i = t.viewport, r = !0;; r = !1) {\n-                                    if (!r || !e.options.lineWrapping || t.oldDisplayWidth == st(e)) {\n-                                        if (i && i.top != null && (i = {\n-                                                top: Math.min(e.doc.height + Ui(e.display) - Ki(e), i.top)\n-                                            }), t.visible = Qr(e.display, e.doc, i), t.visible.from >= e.display.viewFrom && t.visible.to <= e.display.viewTo) break;\n-                                    } else r && (t.visible = Qr(e.display, e.doc, i));\n-                                    if (!ln(e, t)) break;\n-                                    Zr(e);\n-                                    var n = or(e);\n-                                    ir(e), At(e, n), sn(e, n), t.force = !1;\n-                                }\n-                                t.signal(e, \"update\", e), (e.display.viewFrom != e.display.reportedViewFrom || e.display.viewTo != e.display.reportedViewTo) && (t.signal(e, \"viewportChange\", e, e.display.viewFrom, e.display.viewTo), e.display.reportedViewFrom = e.display.viewFrom, e.display.reportedViewTo = e.display.viewTo);\n-                            }\n-                            u(Il, \"postUpdateDisplay\");\n-\n-                            function on(e, t) {\n-                                var i = new jr(e, t);\n-                                if (ln(e, i)) {\n-                                    Zr(e), Il(e, i);\n-                                    var r = or(e);\n-                                    ir(e), At(e, r), sn(e, r), i.finish();\n-                                }\n-                            }\n-                            u(on, \"updateDisplaySimple\");\n-\n-                            function hs(e, t, i) {\n-                                var r = e.display,\n-                                    n = e.options.lineNumbers,\n-                                    l = r.lineDiv,\n-                                    o = l.firstChild;\n-\n-                                function a(v) {\n-                                    var g = v.nextSibling;\n-                                    return ne && me && e.display.currentWheelTarget == v ? v.style.display = \"none\" : v.parentNode.removeChild(v), g;\n-                                }\n-                                u(a, \"rm\");\n-                                for (var s = r.view, f = r.viewFrom, h = 0; h < s.length; h++) {\n-                                    var c = s[h];\n-                                    if (!c.hidden)\n-                                        if (!c.node || c.node.parentNode != l) {\n-                                            var p = Ra(e, c, f, i);\n-                                            l.insertBefore(p, o);\n-                                        } else {\n-                                            for (; o != c.node;) o = a(o);\n-                                            var d = n && t != null && t <= f && c.lineNumber;\n-                                            c.changes && (ee(c.changes, \"gutter\") > -1 && (d = !1), ul(e, c, f, i)), d && (Ue(c.lineNumber), c.lineNumber.appendChild(document.createTextNode(Oi(e.options, f)))), o = c.node.nextSibling;\n-                                        }\n-                                    f += c.size;\n-                                }\n-                                for (; o;) o = a(o);\n-                            }\n-                            u(hs, \"patchDisplay\");\n \n-                            function an(e) {\n-                                var t = e.gutters.offsetWidth;\n-                                e.sizer.style.marginLeft = t + \"px\", Z(e, \"gutterChanged\", e);\n-                            }\n-                            u(an, \"updateGutterSpace\");\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                var tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.mjs\");\n+                var heyListen = __webpack_require__( /*! hey-listen */ \"../../../node_modules/hey-listen/dist/hey-listen.es.js\");\n+                var styleValueTypes = __webpack_require__( /*! style-value-types */ \"../../../node_modules/style-value-types/dist/valueTypes.cjs.js\");\n+                var sync = __webpack_require__( /*! framesync */ \"../../../node_modules/framesync/dist/framesync.cjs.js\");\n \n-                            function sn(e, t) {\n-                                e.display.sizer.style.minHeight = t.docHeight + \"px\", e.display.heightForcer.style.top = t.docHeight + \"px\", e.display.gutters.style.height = t.docHeight + e.display.barHeight + Ae(e) + \"px\";\n-                            }\n-                            u(sn, \"setDocumentHeight\");\n+                function _interopDefaultLegacy(e) {\n+                    return e && typeof e === 'object' && 'default' in e ? e : {\n+                        'default': e\n+                    };\n+                }\n+                var sync__default = /*#__PURE__*/ _interopDefaultLegacy(sync);\n+                const clamp = (min, max, v) => Math.min(Math.max(v, min), max);\n+                const safeMin = 0.001;\n+                const minDuration = 0.01;\n+                const maxDuration = 10.0;\n+                const minDamping = 0.05;\n+                const maxDamping = 1;\n \n-                            function Rl(e) {\n-                                var t = e.display,\n-                                    i = t.view;\n-                                if (!(!t.alignWidgets && (!t.gutters.firstChild || !e.options.fixedGutter))) {\n-                                    for (var r = Ji(t) - t.scroller.scrollLeft + e.doc.scrollLeft, n = t.gutters.offsetWidth, l = r + \"px\", o = 0; o < i.length; o++)\n-                                        if (!i[o].hidden) {\n-                                            e.options.fixedGutter && (i[o].gutter && (i[o].gutter.style.left = l), i[o].gutterBackground && (i[o].gutterBackground.style.left = l));\n-                                            var a = i[o].alignable;\n-                                            if (a)\n-                                                for (var s = 0; s < a.length; s++) a[s].style.left = l;\n-                                        }\n-                                    e.options.fixedGutter && (t.gutters.style.left = r + n + \"px\");\n-                                }\n-                            }\n-                            u(Rl, \"alignHorizontally\");\n+                function findSpring({\n+                    duration = 800,\n+                    bounce = 0.25,\n+                    velocity = 0,\n+                    mass = 1\n+                }) {\n+                    let envelope;\n+                    let derivative;\n+                    heyListen.warning(duration <= maxDuration * 1000, \"Spring duration must be 10 seconds or less\");\n+                    let dampingRatio = 1 - bounce;\n+                    dampingRatio = clamp(minDamping, maxDamping, dampingRatio);\n+                    duration = clamp(minDuration, maxDuration, duration / 1000);\n+                    if (dampingRatio < 1) {\n+                        envelope = undampedFreq => {\n+                            const exponentialDecay = undampedFreq * dampingRatio;\n+                            const delta = exponentialDecay * duration;\n+                            const a = exponentialDecay - velocity;\n+                            const b = calcAngularFreq(undampedFreq, dampingRatio);\n+                            const c = Math.exp(-delta);\n+                            return safeMin - a / b * c;\n+                        };\n+                        derivative = undampedFreq => {\n+                            const exponentialDecay = undampedFreq * dampingRatio;\n+                            const delta = exponentialDecay * duration;\n+                            const d = delta * velocity + velocity;\n+                            const e = Math.pow(dampingRatio, 2) * Math.pow(undampedFreq, 2) * duration;\n+                            const f = Math.exp(-delta);\n+                            const g = calcAngularFreq(Math.pow(undampedFreq, 2), dampingRatio);\n+                            const factor = -envelope(undampedFreq) + safeMin > 0 ? -1 : 1;\n+                            return factor * ((d - e) * f) / g;\n+                        };\n+                    } else {\n+                        envelope = undampedFreq => {\n+                            const a = Math.exp(-undampedFreq * duration);\n+                            const b = (undampedFreq - velocity) * duration + 1;\n+                            return -safeMin + a * b;\n+                        };\n+                        derivative = undampedFreq => {\n+                            const a = Math.exp(-undampedFreq * duration);\n+                            const b = (velocity - undampedFreq) * (duration * duration);\n+                            return a * b;\n+                        };\n+                    }\n+                    const initialGuess = 5 / duration;\n+                    const undampedFreq = approximateRoot(envelope, derivative, initialGuess);\n+                    duration = duration * 1000;\n+                    if (isNaN(undampedFreq)) {\n+                        return {\n+                            stiffness: 100,\n+                            damping: 10,\n+                            duration\n+                        };\n+                    } else {\n+                        const stiffness = Math.pow(undampedFreq, 2) * mass;\n+                        return {\n+                            stiffness,\n+                            damping: dampingRatio * 2 * Math.sqrt(mass * stiffness),\n+                            duration\n+                        };\n+                    }\n+                }\n+                const rootIterations = 12;\n \n-                            function Bl(e) {\n-                                if (!e.options.lineNumbers) return !1;\n-                                var t = e.doc,\n-                                    i = Oi(e.options, t.first + t.size - 1),\n-                                    r = e.display;\n-                                if (i.length != r.lineNumChars) {\n-                                    var n = r.measure.appendChild(T(\"div\", [T(\"div\", i)], \"CodeMirror-linenumber CodeMirror-gutter-elt\")),\n-                                        l = n.firstChild.offsetWidth,\n-                                        o = n.offsetWidth - l;\n-                                    return r.lineGutter.style.width = \"\", r.lineNumInnerWidth = Math.max(l, r.lineGutter.offsetWidth - o) + 1, r.lineNumWidth = r.lineNumInnerWidth + o, r.lineNumChars = r.lineNumInnerWidth ? i.length : -1, r.lineGutter.style.width = r.lineNumWidth + \"px\", an(e.display), !0;\n-                                }\n-                                return !1;\n-                            }\n-                            u(Bl, \"maybeUpdateLineNumberWidth\");\n-\n-                            function un(e, t) {\n-                                for (var i = [], r = !1, n = 0; n < e.length; n++) {\n-                                    var l = e[n],\n-                                        o = null;\n-                                    if (typeof l != \"string\" && (o = l.style, l = l.className), l == \"CodeMirror-linenumbers\")\n-                                        if (t) r = !0;\n-                                        else continue;\n-                                    i.push({\n-                                        className: l,\n-                                        style: o\n-                                    });\n-                                }\n-                                return t && !r && i.push({\n-                                    className: \"CodeMirror-linenumbers\",\n-                                    style: null\n-                                }), i;\n-                            }\n-                            u(un, \"getGutters\");\n-\n-                            function zl(e) {\n-                                var t = e.gutters,\n-                                    i = e.gutterSpecs;\n-                                Ue(t), e.lineGutter = null;\n-                                for (var r = 0; r < i.length; ++r) {\n-                                    var n = i[r],\n-                                        l = n.className,\n-                                        o = n.style,\n-                                        a = t.appendChild(T(\"div\", null, \"CodeMirror-gutter \" + l));\n-                                    o && (a.style.cssText = o), l == \"CodeMirror-linenumbers\" && (e.lineGutter = a, a.style.width = (e.lineNumWidth || 1) + \"px\");\n-                                }\n-                                t.style.display = i.length ? \"\" : \"none\", an(e);\n-                            }\n-                            u(zl, \"renderGutters\");\n-\n-                            function ur(e) {\n-                                zl(e.display), se(e), Rl(e);\n-                            }\n-                            u(ur, \"updateGutters\");\n-\n-                            function cs(e, t, i, r) {\n-                                var n = this;\n-                                this.input = i, n.scrollbarFiller = T(\"div\", null, \"CodeMirror-scrollbar-filler\"), n.scrollbarFiller.setAttribute(\"cm-not-content\", \"true\"), n.gutterFiller = T(\"div\", null, \"CodeMirror-gutter-filler\"), n.gutterFiller.setAttribute(\"cm-not-content\", \"true\"), n.lineDiv = bt(\"div\", null, \"CodeMirror-code\"), n.selectionDiv = T(\"div\", null, null, \"position: relative; z-index: 1\"), n.cursorDiv = T(\"div\", null, \"CodeMirror-cursors\"), n.measure = T(\"div\", null, \"CodeMirror-measure\"), n.lineMeasure = T(\"div\", null, \"CodeMirror-measure\"), n.lineSpace = bt(\"div\", [n.measure, n.lineMeasure, n.selectionDiv, n.cursorDiv, n.lineDiv], null, \"position: relative; outline: none\");\n-                                var l = bt(\"div\", [n.lineSpace], \"CodeMirror-lines\");\n-                                n.mover = T(\"div\", [l], null, \"position: relative\"), n.sizer = T(\"div\", [n.mover], \"CodeMirror-sizer\"), n.sizerWidth = null, n.heightForcer = T(\"div\", null, null, \"position: absolute; height: \" + Wn + \"px; width: 1px;\"), n.gutters = T(\"div\", null, \"CodeMirror-gutters\"), n.lineGutter = null, n.scroller = T(\"div\", [n.sizer, n.heightForcer, n.gutters], \"CodeMirror-scroll\"), n.scroller.setAttribute(\"tabIndex\", \"-1\"), n.wrapper = T(\"div\", [n.scrollbarFiller, n.gutterFiller, n.scroller], \"CodeMirror\"), n.wrapper.setAttribute(\"translate\", \"no\"), O && I < 8 && (n.gutters.style.zIndex = -1, n.scroller.style.paddingRight = 0), !ne && !(Fe && Kt) && (n.scroller.draggable = !0), e && (e.appendChild ? e.appendChild(n.wrapper) : e(n.wrapper)), n.viewFrom = n.viewTo = t.first, n.reportedViewFrom = n.reportedViewTo = t.first, n.view = [], n.renderedView = null, n.externalMeasured = null, n.viewOffset = 0, n.lastWrapHeight = n.lastWrapWidth = 0, n.updateLineNumbers = null, n.nativeBarWidth = n.barHeight = n.barWidth = 0, n.scrollbarsClipped = !1, n.lineNumWidth = n.lineNumInnerWidth = n.lineNumChars = null, n.alignWidgets = !1, n.cachedCharWidth = n.cachedTextHeight = n.cachedPaddingH = null, n.maxLine = null, n.maxLineLength = 0, n.maxLineChanged = !1, n.wheelDX = n.wheelDY = n.wheelStartX = n.wheelStartY = null, n.shift = !1, n.selForContextMenu = null, n.activeTouch = null, n.gutterSpecs = un(r.gutters, r.lineNumbers), zl(n), i.init(n);\n-                            }\n-                            u(cs, \"Display\");\n-                            var Vr = 0,\n-                                Be = null;\n-                            O ? Be = -.53 : Fe ? Be = 15 : Tr ? Be = -.7 : Mr && (Be = -1 / 3);\n-\n-                            function Gl(e) {\n-                                var t = e.wheelDeltaX,\n-                                    i = e.wheelDeltaY;\n-                                return t == null && e.detail && e.axis == e.HORIZONTAL_AXIS && (t = e.detail), i == null && e.detail && e.axis == e.VERTICAL_AXIS ? i = e.detail : i == null && (i = e.wheelDelta), {\n-                                    x: t,\n-                                    y: i\n-                                };\n-                            }\n-                            u(Gl, \"wheelEventDelta\");\n+                function approximateRoot(envelope, derivative, initialGuess) {\n+                    let result = initialGuess;\n+                    for (let i = 1; i < rootIterations; i++) {\n+                        result = result - envelope(result) / derivative(result);\n+                    }\n+                    return result;\n+                }\n \n-                            function ds(e) {\n-                                var t = Gl(e);\n-                                return t.x *= Be, t.y *= Be, t;\n-                            }\n-                            u(ds, \"wheelEventPixels\");\n-\n-                            function Ul(e, t) {\n-                                var i = Gl(t),\n-                                    r = i.x,\n-                                    n = i.y,\n-                                    l = Be;\n-                                t.deltaMode === 0 && (r = t.deltaX, n = t.deltaY, l = 1);\n-                                var o = e.display,\n-                                    a = o.scroller,\n-                                    s = a.scrollWidth > a.clientWidth,\n-                                    f = a.scrollHeight > a.clientHeight;\n-                                if (r && s || n && f) {\n-                                    if (n && me && ne) {\n-                                        e: for (var h = t.target, c = o.view; h != a; h = h.parentNode)\n-                                            for (var p = 0; p < c.length; p++)\n-                                                if (c[p].node == h) {\n-                                                    e.display.currentWheelTarget = h;\n-                                                    break e;\n-                                                }\n-                                    }\n-                                    if (r && !Fe && !we && l != null) {\n-                                        n && f && lr(e, Math.max(0, a.scrollTop + n * l)), ct(e, Math.max(0, a.scrollLeft + r * l)), (!n || n && f) && ae(t), o.wheelStartX = null;\n-                                        return;\n-                                    }\n-                                    if (n && l != null) {\n-                                        var d = n * l,\n-                                            v = e.doc.scrollTop,\n-                                            g = v + o.wrapper.clientHeight;\n-                                        d < 0 ? v = Math.max(0, v + d - 50) : g = Math.min(e.doc.height, g + d + 50), on(e, {\n-                                            top: v,\n-                                            bottom: g\n-                                        });\n-                                    }\n-                                    Vr < 20 && t.deltaMode !== 0 && (o.wheelStartX == null ? (o.wheelStartX = a.scrollLeft, o.wheelStartY = a.scrollTop, o.wheelDX = r, o.wheelDY = n, setTimeout(function() {\n-                                        if (o.wheelStartX != null) {\n-                                            var m = a.scrollLeft - o.wheelStartX,\n-                                                b = a.scrollTop - o.wheelStartY,\n-                                                C = b && o.wheelDY && b / o.wheelDY || m && o.wheelDX && m / o.wheelDX;\n-                                            o.wheelStartX = o.wheelStartY = null, C && (Be = (Be * Vr + C) / (Vr + 1), ++Vr);\n-                                        }\n-                                    }, 200)) : (o.wheelDX += r, o.wheelDY += n));\n-                                }\n-                            }\n-                            u(Ul, \"onScrollWheel\");\n-                            var ye = u(function(e, t) {\n-                                this.ranges = e, this.primIndex = t;\n-                            }, \"Selection\");\n-                            ye.prototype.primary = function() {\n-                                return this.ranges[this.primIndex];\n-                            }, ye.prototype.equals = function(e) {\n-                                if (e == this) return !0;\n-                                if (e.primIndex != this.primIndex || e.ranges.length != this.ranges.length) return !1;\n-                                for (var t = 0; t < this.ranges.length; t++) {\n-                                    var i = this.ranges[t],\n-                                        r = e.ranges[t];\n-                                    if (!Wi(i.anchor, r.anchor) || !Wi(i.head, r.head)) return !1;\n-                                }\n-                                return !0;\n-                            }, ye.prototype.deepCopy = function() {\n-                                for (var e = [], t = 0; t < this.ranges.length; t++) e[t] = new W(Hi(this.ranges[t].anchor), Hi(this.ranges[t].head));\n-                                return new ye(e, this.primIndex);\n-                            }, ye.prototype.somethingSelected = function() {\n-                                for (var e = 0; e < this.ranges.length; e++)\n-                                    if (!this.ranges[e].empty()) return !0;\n-                                return !1;\n-                            }, ye.prototype.contains = function(e, t) {\n-                                t || (t = e);\n-                                for (var i = 0; i < this.ranges.length; i++) {\n-                                    var r = this.ranges[i];\n-                                    if (D(t, r.from()) >= 0 && D(e, r.to()) <= 0) return i;\n-                                }\n-                                return -1;\n-                            };\n-                            var W = u(function(e, t) {\n-                                this.anchor = e, this.head = t;\n-                            }, \"Range\");\n-                            W.prototype.from = function() {\n-                                return Pr(this.anchor, this.head);\n-                            }, W.prototype.to = function() {\n-                                return Fr(this.anchor, this.head);\n-                            }, W.prototype.empty = function() {\n-                                return this.head.line == this.anchor.line && this.head.ch == this.anchor.ch;\n-                            };\n-\n-                            function ke(e, t, i) {\n-                                var r = e && e.options.selectionsMayTouch,\n-                                    n = t[i];\n-                                t.sort(function(p, d) {\n-                                    return D(p.from(), d.from());\n-                                }), i = ee(t, n);\n-                                for (var l = 1; l < t.length; l++) {\n-                                    var o = t[l],\n-                                        a = t[l - 1],\n-                                        s = D(a.to(), o.from());\n-                                    if (r && !o.empty() ? s > 0 : s >= 0) {\n-                                        var f = Pr(a.from(), o.from()),\n-                                            h = Fr(a.to(), o.to()),\n-                                            c = a.empty() ? o.from() == o.head : a.from() == a.head;\n-                                        l <= i && --i, t.splice(--l, 2, new W(c ? h : f, c ? f : h));\n-                                    }\n-                                }\n-                                return new ye(t, i);\n-                            }\n-                            u(ke, \"normalizeSelection\");\n-\n-                            function Ze(e, t) {\n-                                return new ye([new W(e, t || e)], 0);\n-                            }\n-                            u(Ze, \"simpleSelection\");\n-\n-                            function Qe(e) {\n-                                return e.text ? y(e.from.line + e.text.length - 1, H(e.text).length + (e.text.length == 1 ? e.from.ch : 0)) : e.to;\n-                            }\n-                            u(Qe, \"changeEnd\");\n-\n-                            function Kl(e, t) {\n-                                if (D(e, t.from) < 0) return e;\n-                                if (D(e, t.to) <= 0) return Qe(t);\n-                                var i = e.line + t.text.length - (t.to.line - t.from.line) - 1,\n-                                    r = e.ch;\n-                                return e.line == t.to.line && (r += Qe(t).ch - t.to.ch), y(i, r);\n-                            }\n-                            u(Kl, \"adjustForChange\");\n-\n-                            function fn(e, t) {\n-                                for (var i = [], r = 0; r < e.sel.ranges.length; r++) {\n-                                    var n = e.sel.ranges[r];\n-                                    i.push(new W(Kl(n.anchor, t), Kl(n.head, t)));\n-                                }\n-                                return ke(e.cm, i, e.sel.primIndex);\n-                            }\n-                            u(fn, \"computeSelAfterChange\");\n-\n-                            function _l(e, t, i) {\n-                                return e.line == t.line ? y(i.line, e.ch - t.ch + i.ch) : y(i.line + (e.line - t.line), e.ch);\n-                            }\n-                            u(_l, \"offsetPos\");\n-\n-                            function ps(e, t, i) {\n-                                for (var r = [], n = y(e.first, 0), l = n, o = 0; o < t.length; o++) {\n-                                    var a = t[o],\n-                                        s = _l(a.from, n, l),\n-                                        f = _l(Qe(a), n, l);\n-                                    if (n = a.to, l = f, i == \"around\") {\n-                                        var h = e.sel.ranges[o],\n-                                            c = D(h.head, h.anchor) < 0;\n-                                        r[o] = new W(c ? f : s, c ? s : f);\n-                                    } else r[o] = new W(s, s);\n-                                }\n-                                return new ye(r, e.sel.primIndex);\n-                            }\n-                            u(ps, \"computeReplacedSel\");\n-\n-                            function hn(e) {\n-                                e.doc.mode = Di(e.options, e.doc.modeOption), fr(e);\n-                            }\n-                            u(hn, \"loadMode\");\n-\n-                            function fr(e) {\n-                                e.doc.iter(function(t) {\n-                                    t.stateAfter && (t.stateAfter = null), t.styles && (t.styles = null);\n-                                }), e.doc.modeFrontier = e.doc.highlightFrontier = e.doc.first, sr(e, 100), e.state.modeGen++, e.curOp && se(e);\n-                            }\n-                            u(fr, \"resetModeState\");\n-\n-                            function Xl(e, t) {\n-                                return t.from.ch == 0 && t.to.ch == 0 && H(t.text) == \"\" && (!e.cm || e.cm.options.wholeLineUpdateBefore);\n-                            }\n-                            u(Xl, \"isWholeLineUpdate\");\n-\n-                            function cn(e, t, i, r) {\n-                                function n(C) {\n-                                    return i ? i[C] : null;\n-                                }\n-                                u(n, \"spansFor\");\n-\n-                                function l(C, x, w) {\n-                                    wa(C, x, w, r), Z(C, \"change\", C, t);\n-                                }\n-                                u(l, \"update\");\n-\n-                                function o(C, x) {\n-                                    for (var w = [], k = C; k < x; ++k) w.push(new St(f[k], n(k), r));\n-                                    return w;\n-                                }\n-                                u(o, \"linesFor\");\n-                                var a = t.from,\n-                                    s = t.to,\n-                                    f = t.text,\n-                                    h = S(e, a.line),\n-                                    c = S(e, s.line),\n-                                    p = H(f),\n-                                    d = n(f.length - 1),\n-                                    v = s.line - a.line;\n-                                if (t.full) e.insert(0, o(0, f.length)), e.remove(f.length, e.size - f.length);\n-                                else if (Xl(e, t)) {\n-                                    var g = o(0, f.length - 1);\n-                                    l(c, c.text, d), v && e.remove(a.line, v), g.length && e.insert(a.line, g);\n-                                } else if (h == c) {\n-                                    if (f.length == 1) l(h, h.text.slice(0, a.ch) + p + h.text.slice(s.ch), d);\n-                                    else {\n-                                        var m = o(1, f.length - 1);\n-                                        m.push(new St(p + h.text.slice(s.ch), d, r)), l(h, h.text.slice(0, a.ch) + f[0], n(0)), e.insert(a.line + 1, m);\n-                                    }\n-                                } else if (f.length == 1) l(h, h.text.slice(0, a.ch) + f[0] + c.text.slice(s.ch), n(0)), e.remove(a.line + 1, v);\n-                                else {\n-                                    l(h, h.text.slice(0, a.ch) + f[0], n(0)), l(c, p + c.text.slice(s.ch), d);\n-                                    var b = o(1, f.length - 1);\n-                                    v > 1 && e.remove(a.line + 1, v - 1), e.insert(a.line + 1, b);\n-                                }\n-                                Z(e, \"change\", e, t);\n-                            }\n-                            u(cn, \"updateDoc\");\n-\n-                            function Je(e, t, i) {\n-                                function r(n, l, o) {\n-                                    if (n.linked)\n-                                        for (var a = 0; a < n.linked.length; ++a) {\n-                                            var s = n.linked[a];\n-                                            if (s.doc != l) {\n-                                                var f = o && s.sharedHist;\n-                                                i && !f || (t(s.doc, f), r(s.doc, n, f));\n-                                            }\n-                                        }\n-                                }\n-                                u(r, \"propagate\"), r(e, null, !0);\n-                            }\n-                            u(Je, \"linkedDocs\");\n+                function calcAngularFreq(undampedFreq, dampingRatio) {\n+                    return undampedFreq * Math.sqrt(1 - dampingRatio * dampingRatio);\n+                }\n+                const durationKeys = [\"duration\", \"bounce\"];\n+                const physicsKeys = [\"stiffness\", \"damping\", \"mass\"];\n \n-                            function Yl(e, t) {\n-                                if (t.cm) throw new Error(\"This document is already in use.\");\n-                                e.doc = t, t.cm = e, ji(e), hn(e), ql(e), e.options.direction = t.direction, e.options.lineWrapping || zi(e), e.options.mode = t.modeOption, se(e);\n-                            }\n-                            u(Yl, \"attachDoc\");\n+                function isSpringType(options, keys) {\n+                    return keys.some(key => options[key] !== undefined);\n+                }\n \n-                            function ql(e) {\n-                                (e.doc.direction == \"rtl\" ? it : tt)(e.display.lineDiv, \"CodeMirror-rtl\");\n-                            }\n-                            u(ql, \"setDirectionClass\");\n+                function getSpringOptions(options) {\n+                    let springOptions = Object.assign({\n+                        velocity: 0.0,\n+                        stiffness: 100,\n+                        damping: 10,\n+                        mass: 1.0,\n+                        isResolvedFromDuration: false\n+                    }, options);\n+                    if (!isSpringType(options, physicsKeys) && isSpringType(options, durationKeys)) {\n+                        const derived = findSpring(options);\n+                        springOptions = Object.assign(Object.assign(Object.assign({}, springOptions), derived), {\n+                            velocity: 0.0,\n+                            mass: 1.0\n+                        });\n+                        springOptions.isResolvedFromDuration = true;\n+                    }\n+                    return springOptions;\n+                }\n \n-                            function vs(e) {\n-                                de(e, function() {\n-                                    ql(e), se(e);\n-                                });\n-                            }\n-                            u(vs, \"directionChanged\");\n+                function spring(_a) {\n+                    var {\n+                        from = 0.0,\n+                            to = 1.0,\n+                            restSpeed = 2,\n+                            restDelta\n+                    } = _a,\n+                    options = tslib.__rest(_a, [\"from\", \"to\", \"restSpeed\", \"restDelta\"]);\n+                    const state = {\n+                        done: false,\n+                        value: from\n+                    };\n+                    let {\n+                        stiffness,\n+                        damping,\n+                        mass,\n+                        velocity,\n+                        duration,\n+                        isResolvedFromDuration\n+                    } = getSpringOptions(options);\n+                    let resolveSpring = zero;\n+                    let resolveVelocity = zero;\n \n-                            function $r(e) {\n-                                this.done = [], this.undone = [], this.undoDepth = e ? e.undoDepth : 1 / 0, this.lastModTime = this.lastSelTime = 0, this.lastOp = this.lastSelOp = null, this.lastOrigin = this.lastSelOrigin = null, this.generation = this.maxGeneration = e ? e.maxGeneration : 1;\n+                    function createSpring() {\n+                        const initialVelocity = velocity ? -(velocity / 1000) : 0.0;\n+                        const initialDelta = to - from;\n+                        const dampingRatio = damping / (2 * Math.sqrt(stiffness * mass));\n+                        const undampedAngularFreq = Math.sqrt(stiffness / mass) / 1000;\n+                        if (restDelta === undefined) {\n+                            restDelta = Math.min(Math.abs(to - from) / 100, 0.4);\n+                        }\n+                        if (dampingRatio < 1) {\n+                            const angularFreq = calcAngularFreq(undampedAngularFreq, dampingRatio);\n+                            resolveSpring = t => {\n+                                const envelope = Math.exp(-dampingRatio * undampedAngularFreq * t);\n+                                return to - envelope * ((initialVelocity + dampingRatio * undampedAngularFreq * initialDelta) / angularFreq * Math.sin(angularFreq * t) + initialDelta * Math.cos(angularFreq * t));\n+                            };\n+                            resolveVelocity = t => {\n+                                const envelope = Math.exp(-dampingRatio * undampedAngularFreq * t);\n+                                return dampingRatio * undampedAngularFreq * envelope * (Math.sin(angularFreq * t) * (initialVelocity + dampingRatio * undampedAngularFreq * initialDelta) / angularFreq + initialDelta * Math.cos(angularFreq * t)) - envelope * (Math.cos(angularFreq * t) * (initialVelocity + dampingRatio * undampedAngularFreq * initialDelta) - angularFreq * initialDelta * Math.sin(angularFreq * t));\n+                            };\n+                        } else if (dampingRatio === 1) {\n+                            resolveSpring = t => to - Math.exp(-undampedAngularFreq * t) * (initialDelta + (initialVelocity + undampedAngularFreq * initialDelta) * t);\n+                        } else {\n+                            const dampedAngularFreq = undampedAngularFreq * Math.sqrt(dampingRatio * dampingRatio - 1);\n+                            resolveSpring = t => {\n+                                const envelope = Math.exp(-dampingRatio * undampedAngularFreq * t);\n+                                const freqForT = Math.min(dampedAngularFreq * t, 300);\n+                                return to - envelope * ((initialVelocity + dampingRatio * undampedAngularFreq * initialDelta) * Math.sinh(freqForT) + dampedAngularFreq * initialDelta * Math.cosh(freqForT)) / dampedAngularFreq;\n+                            };\n+                        }\n+                    }\n+                    createSpring();\n+                    return {\n+                        next: t => {\n+                            const current = resolveSpring(t);\n+                            if (!isResolvedFromDuration) {\n+                                const currentVelocity = resolveVelocity(t) * 1000;\n+                                const isBelowVelocityThreshold = Math.abs(currentVelocity) <= restSpeed;\n+                                const isBelowDisplacementThreshold = Math.abs(to - current) <= restDelta;\n+                                state.done = isBelowVelocityThreshold && isBelowDisplacementThreshold;\n+                            } else {\n+                                state.done = t >= duration;\n                             }\n-                            u($r, \"History\");\n+                            state.value = state.done ? to : current;\n+                            return state;\n+                        },\n+                        flipTarget: () => {\n+                            velocity = -velocity;\n+                            [from, to] = [to, from];\n+                            createSpring();\n+                        }\n+                    };\n+                }\n+                spring.needsInterpolation = (a, b) => typeof a === \"string\" || typeof b === \"string\";\n+                const zero = _t => 0;\n+                const progress = (from, to, value) => {\n+                    const toFromDifference = to - from;\n+                    return toFromDifference === 0 ? 1 : (value - from) / toFromDifference;\n+                };\n+                const mix = (from, to, progress) => -progress * from + progress * to + from;\n \n-                            function dn(e, t) {\n-                                var i = {\n-                                    from: Hi(t.from),\n-                                    to: Qe(t),\n-                                    text: ot(e, t.from, t.to)\n-                                };\n-                                return Jl(e, i, t.from.line, t.to.line + 1), Je(e, function(r) {\n-                                    return Jl(r, i, t.from.line, t.to.line + 1);\n-                                }, !0), i;\n-                            }\n-                            u(dn, \"historyChangeFromChange\");\n-\n-                            function Zl(e) {\n-                                for (; e.length;) {\n-                                    var t = H(e);\n-                                    if (t.ranges) e.pop();\n-                                    else break;\n-                                }\n-                            }\n-                            u(Zl, \"clearSelectionEvents\");\n-\n-                            function gs(e, t) {\n-                                if (t) return Zl(e.done), H(e.done);\n-                                if (e.done.length && !H(e.done).ranges) return H(e.done);\n-                                if (e.done.length > 1 && !e.done[e.done.length - 2].ranges) return e.done.pop(), H(e.done);\n-                            }\n-                            u(gs, \"lastChangeEvent\");\n-\n-                            function Ql(e, t, i, r) {\n-                                var n = e.history;\n-                                n.undone.length = 0;\n-                                var l = +new Date(),\n-                                    o,\n-                                    a;\n-                                if ((n.lastOp == r || n.lastOrigin == t.origin && t.origin && (t.origin.charAt(0) == \"+\" && n.lastModTime > l - (e.cm ? e.cm.options.historyEventDelay : 500) || t.origin.charAt(0) == \"*\")) && (o = gs(n, n.lastOp == r))) a = H(o.changes), D(t.from, t.to) == 0 && D(t.from, a.to) == 0 ? a.to = Qe(t) : o.changes.push(dn(e, t));\n-                                else {\n-                                    var s = H(n.done);\n-                                    for ((!s || !s.ranges) && ei(e.sel, n.done), o = {\n-                                            changes: [dn(e, t)],\n-                                            generation: n.generation\n-                                        }, n.done.push(o); n.done.length > n.undoDepth;) n.done.shift(), n.done[0].ranges || n.done.shift();\n-                                }\n-                                n.done.push(i), n.generation = ++n.maxGeneration, n.lastModTime = n.lastSelTime = l, n.lastOp = n.lastSelOp = r, n.lastOrigin = n.lastSelOrigin = t.origin, a || U(e, \"historyAdded\");\n-                            }\n-                            u(Ql, \"addChangeToHistory\");\n+                function hueToRgb(p, q, t) {\n+                    if (t < 0) t += 1;\n+                    if (t > 1) t -= 1;\n+                    if (t < 1 / 6) return p + (q - p) * 6 * t;\n+                    if (t < 1 / 2) return q;\n+                    if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6;\n+                    return p;\n+                }\n \n-                            function ys(e, t, i, r) {\n-                                var n = t.charAt(0);\n-                                return n == \"*\" || n == \"+\" && i.ranges.length == r.ranges.length && i.somethingSelected() == r.somethingSelected() && new Date() - e.history.lastSelTime <= (e.cm ? e.cm.options.historyEventDelay : 500);\n+                function hslaToRgba({\n+                    hue,\n+                    saturation,\n+                    lightness,\n+                    alpha\n+                }) {\n+                    hue /= 360;\n+                    saturation /= 100;\n+                    lightness /= 100;\n+                    let red = 0;\n+                    let green = 0;\n+                    let blue = 0;\n+                    if (!saturation) {\n+                        red = green = blue = lightness;\n+                    } else {\n+                        const q = lightness < 0.5 ? lightness * (1 + saturation) : lightness + saturation - lightness * saturation;\n+                        const p = 2 * lightness - q;\n+                        red = hueToRgb(p, q, hue + 1 / 3);\n+                        green = hueToRgb(p, q, hue);\n+                        blue = hueToRgb(p, q, hue - 1 / 3);\n+                    }\n+                    return {\n+                        red: Math.round(red * 255),\n+                        green: Math.round(green * 255),\n+                        blue: Math.round(blue * 255),\n+                        alpha\n+                    };\n+                }\n+                const mixLinearColor = (from, to, v) => {\n+                    const fromExpo = from * from;\n+                    const toExpo = to * to;\n+                    return Math.sqrt(Math.max(0, v * (toExpo - fromExpo) + fromExpo));\n+                };\n+                const colorTypes = [styleValueTypes.hex, styleValueTypes.rgba, styleValueTypes.hsla];\n+                const getColorType = v => colorTypes.find(type => type.test(v));\n+                const notAnimatable = color => `'${color}' is not an animatable color. Use the equivalent color code instead.`;\n+                const mixColor = (from, to) => {\n+                    let fromColorType = getColorType(from);\n+                    let toColorType = getColorType(to);\n+                    heyListen.invariant(!!fromColorType, notAnimatable(from));\n+                    heyListen.invariant(!!toColorType, notAnimatable(to));\n+                    let fromColor = fromColorType.parse(from);\n+                    let toColor = toColorType.parse(to);\n+                    if (fromColorType === styleValueTypes.hsla) {\n+                        fromColor = hslaToRgba(fromColor);\n+                        fromColorType = styleValueTypes.rgba;\n+                    }\n+                    if (toColorType === styleValueTypes.hsla) {\n+                        toColor = hslaToRgba(toColor);\n+                        toColorType = styleValueTypes.rgba;\n+                    }\n+                    const blended = Object.assign({}, fromColor);\n+                    return v => {\n+                        for (const key in blended) {\n+                            if (key !== \"alpha\") {\n+                                blended[key] = mixLinearColor(fromColor[key], toColor[key], v);\n                             }\n-                            u(ys, \"selectionEventCanBeMerged\");\n+                        }\n+                        blended.alpha = mix(fromColor.alpha, toColor.alpha, v);\n+                        return fromColorType.transform(blended);\n+                    };\n+                };\n+                const zeroPoint = {\n+                    x: 0,\n+                    y: 0,\n+                    z: 0\n+                };\n+                const isNum = v => typeof v === 'number';\n+                const combineFunctions = (a, b) => v => b(a(v));\n+                const pipe = (...transformers) => transformers.reduce(combineFunctions);\n \n-                            function ms(e, t, i, r) {\n-                                var n = e.history,\n-                                    l = r && r.origin;\n-                                i == n.lastSelOp || l && n.lastSelOrigin == l && (n.lastModTime == n.lastSelTime && n.lastOrigin == l || ys(e, l, H(n.done), t)) ? n.done[n.done.length - 1] = t : ei(t, n.done), n.lastSelTime = +new Date(), n.lastSelOrigin = l, n.lastSelOp = i, r && r.clearRedo !== !1 && Zl(n.undone);\n-                            }\n-                            u(ms, \"addSelectionToHistory\");\n+                function getMixer(origin, target) {\n+                    if (isNum(origin)) {\n+                        return v => mix(origin, target, v);\n+                    } else if (styleValueTypes.color.test(origin)) {\n+                        return mixColor(origin, target);\n+                    } else {\n+                        return mixComplex(origin, target);\n+                    }\n+                }\n+                const mixArray = (from, to) => {\n+                    const output = [...from];\n+                    const numValues = output.length;\n+                    const blendValue = from.map((fromThis, i) => getMixer(fromThis, to[i]));\n+                    return v => {\n+                        for (let i = 0; i < numValues; i++) {\n+                            output[i] = blendValue[i](v);\n+                        }\n+                        return output;\n+                    };\n+                };\n+                const mixObject = (origin, target) => {\n+                    const output = Object.assign(Object.assign({}, origin), target);\n+                    const blendValue = {};\n+                    for (const key in output) {\n+                        if (origin[key] !== undefined && target[key] !== undefined) {\n+                            blendValue[key] = getMixer(origin[key], target[key]);\n+                        }\n+                    }\n+                    return v => {\n+                        for (const key in blendValue) {\n+                            output[key] = blendValue[key](v);\n+                        }\n+                        return output;\n+                    };\n+                };\n \n-                            function ei(e, t) {\n-                                var i = H(t);\n-                                i && i.ranges && i.equals(e) || t.push(e);\n+                function analyse(value) {\n+                    const parsed = styleValueTypes.complex.parse(value);\n+                    const numValues = parsed.length;\n+                    let numNumbers = 0;\n+                    let numRGB = 0;\n+                    let numHSL = 0;\n+                    for (let i = 0; i < numValues; i++) {\n+                        if (numNumbers || typeof parsed[i] === \"number\") {\n+                            numNumbers++;\n+                        } else {\n+                            if (parsed[i].hue !== undefined) {\n+                                numHSL++;\n+                            } else {\n+                                numRGB++;\n                             }\n-                            u(ei, \"pushSelectionToHistory\");\n+                        }\n+                    }\n+                    return {\n+                        parsed,\n+                        numNumbers,\n+                        numRGB,\n+                        numHSL\n+                    };\n+                }\n+                const mixComplex = (origin, target) => {\n+                    const template = styleValueTypes.complex.createTransformer(target);\n+                    const originStats = analyse(origin);\n+                    const targetStats = analyse(target);\n+                    const canInterpolate = originStats.numHSL === targetStats.numHSL && originStats.numRGB === targetStats.numRGB && originStats.numNumbers >= targetStats.numNumbers;\n+                    if (canInterpolate) {\n+                        return pipe(mixArray(originStats.parsed, targetStats.parsed), template);\n+                    } else {\n+                        heyListen.warning(true, `Complex values '${origin}' and '${target}' too different to mix. Ensure all colors are of the same type, and that each contains the same quantity of number and color values. Falling back to instant transition.`);\n+                        return p => `${p > 0 ? target : origin}`;\n+                    }\n+                };\n+                const mixNumber = (from, to) => p => mix(from, to, p);\n \n-                            function Jl(e, t, i, r) {\n-                                var n = t[\"spans_\" + e.id],\n-                                    l = 0;\n-                                e.iter(Math.max(e.first, i), Math.min(e.first + e.size, r), function(o) {\n-                                    o.markedSpans && ((n || (n = t[\"spans_\" + e.id] = {}))[l] = o.markedSpans), ++l;\n-                                });\n-                            }\n-                            u(Jl, \"attachLocalSpans\");\n+                function detectMixerFactory(v) {\n+                    if (typeof v === 'number') {\n+                        return mixNumber;\n+                    } else if (typeof v === 'string') {\n+                        if (styleValueTypes.color.test(v)) {\n+                            return mixColor;\n+                        } else {\n+                            return mixComplex;\n+                        }\n+                    } else if (Array.isArray(v)) {\n+                        return mixArray;\n+                    } else if (typeof v === 'object') {\n+                        return mixObject;\n+                    }\n+                }\n \n-                            function bs(e) {\n-                                if (!e) return null;\n-                                for (var t, i = 0; i < e.length; ++i) e[i].marker.explicitlyCleared ? t || (t = e.slice(0, i)) : t && t.push(e[i]);\n-                                return t ? t.length ? t : null : e;\n-                            }\n-                            u(bs, \"removeClearedSpans\");\n-\n-                            function xs(e, t) {\n-                                var i = t[\"spans_\" + e.id];\n-                                if (!i) return null;\n-                                for (var r = [], n = 0; n < t.text.length; ++n) r.push(bs(i[n]));\n-                                return r;\n-                            }\n-                            u(xs, \"getOldSpans\");\n+                function createMixers(output, ease, customMixer) {\n+                    const mixers = [];\n+                    const mixerFactory = customMixer || detectMixerFactory(output[0]);\n+                    const numMixers = output.length - 1;\n+                    for (let i = 0; i < numMixers; i++) {\n+                        let mixer = mixerFactory(output[i], output[i + 1]);\n+                        if (ease) {\n+                            const easingFunction = Array.isArray(ease) ? ease[i] : ease;\n+                            mixer = pipe(easingFunction, mixer);\n+                        }\n+                        mixers.push(mixer);\n+                    }\n+                    return mixers;\n+                }\n \n-                            function jl(e, t) {\n-                                var i = xs(e, t),\n-                                    r = Ei(e, t);\n-                                if (!i) return r;\n-                                if (!r) return i;\n-                                for (var n = 0; n < i.length; ++n) {\n-                                    var l = i[n],\n-                                        o = r[n];\n-                                    if (l && o) e: for (var a = 0; a < o.length; ++a) {\n-                                        for (var s = o[a], f = 0; f < l.length; ++f)\n-                                            if (l[f].marker == s.marker) continue e;\n-                                        l.push(s);\n-                                    } else o && (i[n] = o);\n-                                }\n-                                return i;\n-                            }\n-                            u(jl, \"mergeOldSpans\");\n+                function fastInterpolate([from, to], [mixer]) {\n+                    return v => mixer(progress(from, to, v));\n+                }\n \n-                            function Ot(e, t, i) {\n-                                for (var r = [], n = 0; n < e.length; ++n) {\n-                                    var l = e[n];\n-                                    if (l.ranges) {\n-                                        r.push(i ? ye.prototype.deepCopy.call(l) : l);\n-                                        continue;\n-                                    }\n-                                    var o = l.changes,\n-                                        a = [];\n-                                    r.push({\n-                                        changes: a\n-                                    });\n-                                    for (var s = 0; s < o.length; ++s) {\n-                                        var f = o[s],\n-                                            h = void 0;\n-                                        if (a.push({\n-                                                from: f.from,\n-                                                to: f.to,\n-                                                text: f.text\n-                                            }), t)\n-                                            for (var c in f)(h = c.match(/^spans_(\\d+)$/)) && ee(t, Number(h[1])) > -1 && (H(a)[c] = f[c], delete f[c]);\n-                                    }\n+                function slowInterpolate(input, mixers) {\n+                    const inputLength = input.length;\n+                    const lastInputIndex = inputLength - 1;\n+                    return v => {\n+                        let mixerIndex = 0;\n+                        let foundMixerIndex = false;\n+                        if (v <= input[0]) {\n+                            foundMixerIndex = true;\n+                        } else if (v >= input[lastInputIndex]) {\n+                            mixerIndex = lastInputIndex - 1;\n+                            foundMixerIndex = true;\n+                        }\n+                        if (!foundMixerIndex) {\n+                            let i = 1;\n+                            for (; i < inputLength; i++) {\n+                                if (input[i] > v || i === lastInputIndex) {\n+                                    break;\n                                 }\n-                                return r;\n                             }\n-                            u(Ot, \"copyHistoryArray\");\n-\n-                            function pn(e, t, i, r) {\n-                                if (r) {\n-                                    var n = e.anchor;\n-                                    if (i) {\n-                                        var l = D(t, n) < 0;\n-                                        l != D(i, n) < 0 ? (n = t, t = i) : l != D(t, i) < 0 && (t = i);\n-                                    }\n-                                    return new W(n, t);\n-                                } else return new W(i || t, t);\n-                            }\n-                            u(pn, \"extendRange\");\n-\n-                            function ti(e, t, i, r, n) {\n-                                n == null && (n = e.cm && (e.cm.display.shift || e.extend)), te(e, new ye([pn(e.sel.primary(), t, i, n)], 0), r);\n-                            }\n-                            u(ti, \"extendSelection\");\n+                            mixerIndex = i - 1;\n+                        }\n+                        const progressInRange = progress(input[mixerIndex], input[mixerIndex + 1], v);\n+                        return mixers[mixerIndex](progressInRange);\n+                    };\n+                }\n \n-                            function Vl(e, t, i) {\n-                                for (var r = [], n = e.cm && (e.cm.display.shift || e.extend), l = 0; l < e.sel.ranges.length; l++) r[l] = pn(e.sel.ranges[l], t[l], null, n);\n-                                var o = ke(e.cm, r, e.sel.primIndex);\n-                                te(e, o, i);\n-                            }\n-                            u(Vl, \"extendSelections\");\n+                function interpolate(input, output, {\n+                    clamp: isClamp = true,\n+                    ease,\n+                    mixer\n+                } = {}) {\n+                    const inputLength = input.length;\n+                    heyListen.invariant(inputLength === output.length, 'Both input and output ranges must be the same length');\n+                    heyListen.invariant(!ease || !Array.isArray(ease) || ease.length === inputLength - 1, 'Array of easing functions must be of length `input.length - 1`, as it applies to the transitions **between** the defined values.');\n+                    if (input[0] > input[inputLength - 1]) {\n+                        input = [].concat(input);\n+                        output = [].concat(output);\n+                        input.reverse();\n+                        output.reverse();\n+                    }\n+                    const mixers = createMixers(output, ease, mixer);\n+                    const interpolator = inputLength === 2 ? fastInterpolate(input, mixers) : slowInterpolate(input, mixers);\n+                    return isClamp ? v => interpolator(clamp(input[0], input[inputLength - 1], v)) : interpolator;\n+                }\n+                const reverseEasing = easing => p => 1 - easing(1 - p);\n+                const mirrorEasing = easing => p => p <= 0.5 ? easing(2 * p) / 2 : (2 - easing(2 * (1 - p))) / 2;\n+                const createExpoIn = power => p => Math.pow(p, power);\n+                const createBackIn = power => p => p * p * ((power + 1) * p - power);\n+                const createAnticipate = power => {\n+                    const backEasing = createBackIn(power);\n+                    return p => (p *= 2) < 1 ? 0.5 * backEasing(p) : 0.5 * (2 - Math.pow(2, -10 * (p - 1)));\n+                };\n+                const DEFAULT_OVERSHOOT_STRENGTH = 1.525;\n+                const BOUNCE_FIRST_THRESHOLD = 4.0 / 11.0;\n+                const BOUNCE_SECOND_THRESHOLD = 8.0 / 11.0;\n+                const BOUNCE_THIRD_THRESHOLD = 9.0 / 10.0;\n+                const linear = p => p;\n+                const easeIn = createExpoIn(2);\n+                const easeOut = reverseEasing(easeIn);\n+                const easeInOut = mirrorEasing(easeIn);\n+                const circIn = p => 1 - Math.sin(Math.acos(p));\n+                const circOut = reverseEasing(circIn);\n+                const circInOut = mirrorEasing(circOut);\n+                const backIn = createBackIn(DEFAULT_OVERSHOOT_STRENGTH);\n+                const backOut = reverseEasing(backIn);\n+                const backInOut = mirrorEasing(backIn);\n+                const anticipate = createAnticipate(DEFAULT_OVERSHOOT_STRENGTH);\n+                const ca = 4356.0 / 361.0;\n+                const cb = 35442.0 / 1805.0;\n+                const cc = 16061.0 / 1805.0;\n+                const bounceOut = p => {\n+                    if (p === 1 || p === 0) return p;\n+                    const p2 = p * p;\n+                    return p < BOUNCE_FIRST_THRESHOLD ? 7.5625 * p2 : p < BOUNCE_SECOND_THRESHOLD ? 9.075 * p2 - 9.9 * p + 3.4 : p < BOUNCE_THIRD_THRESHOLD ? ca * p2 - cb * p + cc : 10.8 * p * p - 20.52 * p + 10.72;\n+                };\n+                const bounceIn = reverseEasing(bounceOut);\n+                const bounceInOut = p => p < 0.5 ? 0.5 * (1.0 - bounceOut(1.0 - p * 2.0)) : 0.5 * bounceOut(p * 2.0 - 1.0) + 0.5;\n \n-                            function vn(e, t, i, r) {\n-                                var n = e.sel.ranges.slice(0);\n-                                n[t] = i, te(e, ke(e.cm, n, e.sel.primIndex), r);\n-                            }\n-                            u(vn, \"replaceOneSelection\");\n+                function defaultEasing(values, easing) {\n+                    return values.map(() => easing || easeInOut).splice(0, values.length - 1);\n+                }\n \n-                            function $l(e, t, i, r) {\n-                                te(e, Ze(t, i), r);\n-                            }\n-                            u($l, \"setSimpleSelection\");\n+                function defaultOffset(values) {\n+                    const numValues = values.length;\n+                    return values.map((_value, i) => i !== 0 ? i / (numValues - 1) : 0);\n+                }\n \n-                            function Cs(e, t, i) {\n-                                var r = {\n-                                    ranges: t.ranges,\n-                                    update: function(n) {\n-                                        this.ranges = [];\n-                                        for (var l = 0; l < n.length; l++) this.ranges[l] = new W(N(e, n[l].anchor), N(e, n[l].head));\n-                                    },\n-                                    origin: i && i.origin\n-                                };\n-                                return U(e, \"beforeSelectionChange\", e, r), e.cm && U(e.cm, \"beforeSelectionChange\", e.cm, r), r.ranges != t.ranges ? ke(e.cm, r.ranges, r.ranges.length - 1) : t;\n-                            }\n-                            u(Cs, \"filterSelectionChange\");\n+                function convertOffsetToTimes(offset, duration) {\n+                    return offset.map(o => o * duration);\n+                }\n \n-                            function eo(e, t, i) {\n-                                var r = e.history.done,\n-                                    n = H(r);\n-                                n && n.ranges ? (r[r.length - 1] = t, ri(e, t, i)) : te(e, t, i);\n-                            }\n-                            u(eo, \"setSelectionReplaceHistory\");\n-\n-                            function te(e, t, i) {\n-                                ri(e, t, i), ms(e, e.sel, e.cm ? e.cm.curOp.id : NaN, i);\n-                            }\n-                            u(te, \"setSelection\");\n-\n-                            function ri(e, t, i) {\n-                                (Ce(e, \"beforeSelectionChange\") || e.cm && Ce(e.cm, \"beforeSelectionChange\")) && (t = Cs(e, t, i));\n-                                var r = i && i.bias || (D(t.primary().head, e.sel.primary().head) < 0 ? -1 : 1);\n-                                to(e, io(e, t, r, !0)), !(i && i.scroll === !1) && e.cm && e.cm.getOption(\"readOnly\") != \"nocursor\" && Nt(e.cm);\n-                            }\n-                            u(ri, \"setSelectionNoUndo\");\n-\n-                            function to(e, t) {\n-                                t.equals(e.sel) || (e.sel = t, e.cm && (e.cm.curOp.updateInput = 1, e.cm.curOp.selectionChanged = !0, Rn(e.cm)), Z(e, \"cursorActivity\", e));\n-                            }\n-                            u(to, \"setSelectionInner\");\n-\n-                            function ro(e) {\n-                                to(e, io(e, e.sel, null, !1));\n-                            }\n-                            u(ro, \"reCheckSelection\");\n-\n-                            function io(e, t, i, r) {\n-                                for (var n, l = 0; l < t.ranges.length; l++) {\n-                                    var o = t.ranges[l],\n-                                        a = t.ranges.length == e.sel.ranges.length && e.sel.ranges[l],\n-                                        s = ii(e, o.anchor, a && a.anchor, i, r),\n-                                        f = ii(e, o.head, a && a.head, i, r);\n-                                    (n || s != o.anchor || f != o.head) && (n || (n = t.ranges.slice(0, l)), n[l] = new W(s, f));\n-                                }\n-                                return n ? ke(e.cm, n, t.primIndex) : t;\n-                            }\n-                            u(io, \"skipAtomicInSelection\");\n-\n-                            function Wt(e, t, i, r, n) {\n-                                var l = S(e, t.line);\n-                                if (l.markedSpans)\n-                                    for (var o = 0; o < l.markedSpans.length; ++o) {\n-                                        var a = l.markedSpans[o],\n-                                            s = a.marker,\n-                                            f = \"selectLeft\" in s ? !s.selectLeft : s.inclusiveLeft,\n-                                            h = \"selectRight\" in s ? !s.selectRight : s.inclusiveRight;\n-                                        if ((a.from == null || (f ? a.from <= t.ch : a.from < t.ch)) && (a.to == null || (h ? a.to >= t.ch : a.to > t.ch))) {\n-                                            if (n && (U(s, \"beforeCursorEnter\"), s.explicitlyCleared))\n-                                                if (l.markedSpans) {\n-                                                    --o;\n-                                                    continue;\n-                                                } else break;\n-                                            if (!s.atomic) continue;\n-                                            if (i) {\n-                                                var c = s.find(r < 0 ? 1 : -1),\n-                                                    p = void 0;\n-                                                if ((r < 0 ? h : f) && (c = no(e, c, -r, c && c.line == t.line ? l : null)), c && c.line == t.line && (p = D(c, i)) && (r < 0 ? p < 0 : p > 0)) return Wt(e, c, t, r, n);\n-                                            }\n-                                            var d = s.find(r < 0 ? -1 : 1);\n-                                            return (r < 0 ? f : h) && (d = no(e, d, r, d.line == t.line ? l : null)), d ? Wt(e, d, t, r, n) : null;\n-                                        }\n-                                    }\n-                                return t;\n-                            }\n-                            u(Wt, \"skipAtomicInner\");\n+                function keyframes({\n+                    from = 0,\n+                    to = 1,\n+                    ease,\n+                    offset,\n+                    duration = 300\n+                }) {\n+                    const state = {\n+                        done: false,\n+                        value: from\n+                    };\n+                    const values = Array.isArray(to) ? to : [from, to];\n+                    const times = convertOffsetToTimes(offset && offset.length === values.length ? offset : defaultOffset(values), duration);\n \n-                            function ii(e, t, i, r, n) {\n-                                var l = r || 1,\n-                                    o = Wt(e, t, i, l, n) || !n && Wt(e, t, i, l, !0) || Wt(e, t, i, -l, n) || !n && Wt(e, t, i, -l, !0);\n-                                return o || (e.cantEdit = !0, y(e.first, 0));\n-                            }\n-                            u(ii, \"skipAtomic\");\n+                    function createInterpolator() {\n+                        return interpolate(times, values, {\n+                            ease: Array.isArray(ease) ? ease : defaultEasing(values, ease)\n+                        });\n+                    }\n+                    let interpolator = createInterpolator();\n+                    return {\n+                        next: t => {\n+                            state.value = interpolator(t);\n+                            state.done = t >= duration;\n+                            return state;\n+                        },\n+                        flipTarget: () => {\n+                            values.reverse();\n+                            interpolator = createInterpolator();\n+                        }\n+                    };\n+                }\n \n-                            function no(e, t, i, r) {\n-                                return i < 0 && t.ch == 0 ? t.line > e.first ? N(e, y(t.line - 1)) : null : i > 0 && t.ch == (r || S(e, t.line)).text.length ? t.line < e.first + e.size - 1 ? y(t.line + 1, 0) : null : new y(t.line, t.ch + i);\n-                            }\n-                            u(no, \"movePos\");\n+                function decay({\n+                    velocity = 0,\n+                    from = 0,\n+                    power = 0.8,\n+                    timeConstant = 350,\n+                    restDelta = 0.5,\n+                    modifyTarget\n+                }) {\n+                    const state = {\n+                        done: false,\n+                        value: from\n+                    };\n+                    let amplitude = power * velocity;\n+                    const ideal = from + amplitude;\n+                    const target = modifyTarget === undefined ? ideal : modifyTarget(ideal);\n+                    if (target !== ideal) amplitude = target - from;\n+                    return {\n+                        next: t => {\n+                            const delta = -amplitude * Math.exp(-t / timeConstant);\n+                            state.done = !(delta > restDelta || delta < -restDelta);\n+                            state.value = state.done ? target : target + delta;\n+                            return state;\n+                        },\n+                        flipTarget: () => {}\n+                    };\n+                }\n+                const types = {\n+                    keyframes,\n+                    spring,\n+                    decay\n+                };\n \n-                            function lo(e) {\n-                                e.setSelection(y(e.firstLine(), 0), y(e.lastLine()), Me);\n-                            }\n-                            u(lo, \"selectAll\");\n+                function detectAnimationFromOptions(config) {\n+                    if (Array.isArray(config.to)) {\n+                        return keyframes;\n+                    } else if (types[config.type]) {\n+                        return types[config.type];\n+                    }\n+                    const keys = new Set(Object.keys(config));\n+                    if (keys.has(\"ease\") || keys.has(\"duration\") && !keys.has(\"dampingRatio\")) {\n+                        return keyframes;\n+                    } else if (keys.has(\"dampingRatio\") || keys.has(\"stiffness\") || keys.has(\"mass\") || keys.has(\"damping\") || keys.has(\"restSpeed\") || keys.has(\"restDelta\")) {\n+                        return spring;\n+                    }\n+                    return keyframes;\n+                }\n \n-                            function oo(e, t, i) {\n-                                var r = {\n-                                    canceled: !1,\n-                                    from: t.from,\n-                                    to: t.to,\n-                                    text: t.text,\n-                                    origin: t.origin,\n-                                    cancel: function() {\n-                                        return r.canceled = !0;\n-                                    }\n-                                };\n-                                return i && (r.update = function(n, l, o, a) {\n-                                    n && (r.from = N(e, n)), l && (r.to = N(e, l)), o && (r.text = o), a !== void 0 && (r.origin = a);\n-                                }), U(e, \"beforeChange\", e, r), e.cm && U(e.cm, \"beforeChange\", e.cm, r), r.canceled ? (e.cm && (e.cm.curOp.updateInput = 2), null) : {\n-                                    from: r.from,\n-                                    to: r.to,\n-                                    text: r.text,\n-                                    origin: r.origin\n-                                };\n-                            }\n-                            u(oo, \"filterChange\");\n+                function loopElapsed(elapsed, duration, delay = 0) {\n+                    return elapsed - duration - delay;\n+                }\n \n-                            function Ht(e, t, i) {\n-                                if (e.cm) {\n-                                    if (!e.cm.curOp) return Q(e.cm, Ht)(e, t, i);\n-                                    if (e.cm.state.suppressEdits) return;\n-                                }\n-                                if (!((Ce(e, \"beforeChange\") || e.cm && Ce(e.cm, \"beforeChange\")) && (t = oo(e, t, !0), !t))) {\n-                                    var r = jn && !i && ma(e, t.from, t.to);\n-                                    if (r)\n-                                        for (var n = r.length - 1; n >= 0; --n) ao(e, {\n-                                            from: r[n].from,\n-                                            to: r[n].to,\n-                                            text: n ? [\"\"] : t.text,\n-                                            origin: t.origin\n-                                        });\n-                                    else ao(e, t);\n-                                }\n-                            }\n-                            u(Ht, \"makeChange\");\n+                function reverseElapsed(elapsed, duration, delay = 0, isForwardPlayback = true) {\n+                    return isForwardPlayback ? loopElapsed(duration + -elapsed, duration, delay) : duration - (elapsed - duration) + delay;\n+                }\n \n-                            function ao(e, t) {\n-                                if (!(t.text.length == 1 && t.text[0] == \"\" && D(t.from, t.to) == 0)) {\n-                                    var i = fn(e, t);\n-                                    Ql(e, t, i, e.cm ? e.cm.curOp.id : NaN), hr(e, t, i, Ei(e, t));\n-                                    var r = [];\n-                                    Je(e, function(n, l) {\n-                                        !l && ee(r, n.history) == -1 && (ho(n.history, t), r.push(n.history)), hr(n, t, null, Ei(n, t));\n-                                    });\n-                                }\n-                            }\n-                            u(ao, \"makeChangeInner\");\n+                function hasRepeatDelayElapsed(elapsed, duration, delay, isForwardPlayback) {\n+                    return isForwardPlayback ? elapsed >= duration + delay : elapsed <= -delay;\n+                }\n+                const framesync = update => {\n+                    const passTimestamp = ({\n+                        delta\n+                    }) => update(delta);\n+                    return {\n+                        start: () => sync__default[\"default\"].update(passTimestamp, true),\n+                        stop: () => sync.cancelSync.update(passTimestamp)\n+                    };\n+                };\n \n-                            function ni(e, t, i) {\n-                                var r = e.cm && e.cm.state.suppressEdits;\n-                                if (!(r && !i)) {\n-                                    for (var n = e.history, l, o = e.sel, a = t == \"undo\" ? n.done : n.undone, s = t == \"undo\" ? n.undone : n.done, f = 0; f < a.length && (l = a[f], !(i ? l.ranges && !l.equals(e.sel) : !l.ranges)); f++);\n-                                    if (f != a.length) {\n-                                        for (n.lastOrigin = n.lastSelOrigin = null;;)\n-                                            if (l = a.pop(), l.ranges) {\n-                                                if (ei(l, s), i && !l.equals(e.sel)) {\n-                                                    te(e, l, {\n-                                                        clearRedo: !1\n-                                                    });\n-                                                    return;\n-                                                }\n-                                                o = l;\n-                                            } else if (r) {\n-                                            a.push(l);\n-                                            return;\n-                                        } else break;\n-                                        var h = [];\n-                                        ei(o, s), s.push({\n-                                            changes: h,\n-                                            generation: n.generation\n-                                        }), n.generation = l.generation || ++n.maxGeneration;\n-                                        for (var c = Ce(e, \"beforeChange\") || e.cm && Ce(e.cm, \"beforeChange\"), p = u(function(g) {\n-                                                var m = l.changes[g];\n-                                                if (m.origin = t, c && !oo(e, m, !1)) return a.length = 0, {};\n-                                                h.push(dn(e, m));\n-                                                var b = g ? fn(e, m) : H(a);\n-                                                hr(e, m, b, jl(e, m)), !g && e.cm && e.cm.scrollIntoView({\n-                                                    from: m.from,\n-                                                    to: Qe(m)\n-                                                });\n-                                                var C = [];\n-                                                Je(e, function(x, w) {\n-                                                    !w && ee(C, x.history) == -1 && (ho(x.history, m), C.push(x.history)), hr(x, m, null, jl(x, m));\n-                                                });\n-                                            }, \"loop\"), d = l.changes.length - 1; d >= 0; --d) {\n-                                            var v = p(d);\n-                                            if (v) return v.v;\n-                                        }\n-                                    }\n-                                }\n-                            }\n-                            u(ni, \"makeChangeFromHistory\");\n+                function animate(_a) {\n+                    var _b, _c;\n+                    var {\n+                        from,\n+                        autoplay = true,\n+                        driver = framesync,\n+                        elapsed = 0,\n+                        repeat: repeatMax = 0,\n+                        repeatType = \"loop\",\n+                        repeatDelay = 0,\n+                        onPlay,\n+                        onStop,\n+                        onComplete,\n+                        onRepeat,\n+                        onUpdate\n+                    } = _a,\n+                    options = tslib.__rest(_a, [\"from\", \"autoplay\", \"driver\", \"elapsed\", \"repeat\", \"repeatType\", \"repeatDelay\", \"onPlay\", \"onStop\", \"onComplete\", \"onRepeat\", \"onUpdate\"]);\n+                    let {\n+                        to\n+                    } = options;\n+                    let driverControls;\n+                    let repeatCount = 0;\n+                    let computedDuration = options.duration;\n+                    let latest;\n+                    let isComplete = false;\n+                    let isForwardPlayback = true;\n+                    let interpolateFromNumber;\n+                    const animator = detectAnimationFromOptions(options);\n+                    if ((_c = (_b = animator).needsInterpolation) === null || _c === void 0 ? void 0 : _c.call(_b, from, to)) {\n+                        interpolateFromNumber = interpolate([0, 100], [from, to], {\n+                            clamp: false\n+                        });\n+                        from = 0;\n+                        to = 100;\n+                    }\n+                    const animation = animator(Object.assign(Object.assign({}, options), {\n+                        from,\n+                        to\n+                    }));\n \n-                            function so(e, t) {\n-                                if (t != 0 && (e.first += t, e.sel = new ye(Or(e.sel.ranges, function(n) {\n-                                        return new W(y(n.anchor.line + t, n.anchor.ch), y(n.head.line + t, n.head.ch));\n-                                    }), e.sel.primIndex), e.cm)) {\n-                                    se(e.cm, e.first, e.first - t, t);\n-                                    for (var i = e.cm.display, r = i.viewFrom; r < i.viewTo; r++) Ye(e.cm, r, \"gutter\");\n-                                }\n-                            }\n-                            u(so, \"shiftDoc\");\n-\n-                            function hr(e, t, i, r) {\n-                                if (e.cm && !e.cm.curOp) return Q(e.cm, hr)(e, t, i, r);\n-                                if (t.to.line < e.first) {\n-                                    so(e, t.text.length - 1 - (t.to.line - t.from.line));\n-                                    return;\n-                                }\n-                                if (!(t.from.line > e.lastLine())) {\n-                                    if (t.from.line < e.first) {\n-                                        var n = t.text.length - 1 - (e.first - t.from.line);\n-                                        so(e, n), t = {\n-                                            from: y(e.first, 0),\n-                                            to: y(t.to.line + n, t.to.ch),\n-                                            text: [H(t.text)],\n-                                            origin: t.origin\n-                                        };\n-                                    }\n-                                    var l = e.lastLine();\n-                                    t.to.line > l && (t = {\n-                                        from: t.from,\n-                                        to: y(l, S(e, l).text.length),\n-                                        text: [t.text[0]],\n-                                        origin: t.origin\n-                                    }), t.removed = ot(e, t.from, t.to), i || (i = fn(e, t)), e.cm ? ws(e.cm, t, r) : cn(e, t, r), ri(e, i, Me), e.cantEdit && ii(e, y(e.firstLine(), 0)) && (e.cantEdit = !1);\n-                                }\n-                            }\n-                            u(hr, \"makeChangeSingleDoc\");\n-\n-                            function ws(e, t, i) {\n-                                var r = e.doc,\n-                                    n = e.display,\n-                                    l = t.from,\n-                                    o = t.to,\n-                                    a = !1,\n-                                    s = l.line;\n-                                e.options.lineWrapping || (s = F(Se(S(r, l.line))), r.iter(s, o.line + 1, function(d) {\n-                                    if (d == n.maxLine) return a = !0, !0;\n-                                })), r.sel.contains(t.from, t.to) > -1 && Rn(e), cn(r, t, i, Ml(e)), e.options.lineWrapping || (r.iter(s, l.line + t.text.length, function(d) {\n-                                    var v = Gr(d);\n-                                    v > n.maxLineLength && (n.maxLine = d, n.maxLineLength = v, n.maxLineChanged = !0, a = !1);\n-                                }), a && (e.curOp.updateMaxLine = !0)), ha(r, l.line), sr(e, 400);\n-                                var f = t.text.length - (o.line - l.line) - 1;\n-                                t.full ? se(e) : l.line == o.line && t.text.length == 1 && !Xl(e.doc, t) ? Ye(e, l.line, \"text\") : se(e, l.line, o.line + 1, f);\n-                                var h = Ce(e, \"changes\"),\n-                                    c = Ce(e, \"change\");\n-                                if (c || h) {\n-                                    var p = {\n-                                        from: l,\n-                                        to: o,\n-                                        text: t.text,\n-                                        removed: t.removed,\n-                                        origin: t.origin\n-                                    };\n-                                    c && Z(e, \"change\", e, p), h && (e.curOp.changeObjs || (e.curOp.changeObjs = [])).push(p);\n-                                }\n-                                e.display.selForContextMenu = null;\n-                            }\n-                            u(ws, \"makeChangeSingleDocInEditor\");\n+                    function repeat() {\n+                        repeatCount++;\n+                        if (repeatType === \"reverse\") {\n+                            isForwardPlayback = repeatCount % 2 === 0;\n+                            elapsed = reverseElapsed(elapsed, computedDuration, repeatDelay, isForwardPlayback);\n+                        } else {\n+                            elapsed = loopElapsed(elapsed, computedDuration, repeatDelay);\n+                            if (repeatType === \"mirror\") animation.flipTarget();\n+                        }\n+                        isComplete = false;\n+                        onRepeat && onRepeat();\n+                    }\n \n-                            function Ft(e, t, i, r, n) {\n-                                var l;\n-                                r || (r = i), D(r, i) < 0 && (l = [r, i], i = l[0], r = l[1]), typeof t == \"string\" && (t = e.splitLines(t)), Ht(e, {\n-                                    from: i,\n-                                    to: r,\n-                                    text: t,\n-                                    origin: n\n-                                });\n-                            }\n-                            u(Ft, \"replaceRange\");\n+                    function complete() {\n+                        driverControls.stop();\n+                        onComplete && onComplete();\n+                    }\n \n-                            function uo(e, t, i, r) {\n-                                i < e.line ? e.line += r : t < e.line && (e.line = t, e.ch = 0);\n+                    function update(delta) {\n+                        if (!isForwardPlayback) delta = -delta;\n+                        elapsed += delta;\n+                        if (!isComplete) {\n+                            const state = animation.next(Math.max(0, elapsed));\n+                            latest = state.value;\n+                            if (interpolateFromNumber) latest = interpolateFromNumber(latest);\n+                            isComplete = isForwardPlayback ? state.done : elapsed <= 0;\n+                        }\n+                        onUpdate === null || onUpdate === void 0 ? void 0 : onUpdate(latest);\n+                        if (isComplete) {\n+                            if (repeatCount === 0) computedDuration !== null && computedDuration !== void 0 ? computedDuration : computedDuration = elapsed;\n+                            if (repeatCount < repeatMax) {\n+                                hasRepeatDelayElapsed(elapsed, computedDuration, repeatDelay, isForwardPlayback) && repeat();\n+                            } else {\n+                                complete();\n                             }\n-                            u(uo, \"rebaseHistSelSingle\");\n+                        }\n+                    }\n \n-                            function fo(e, t, i, r) {\n-                                for (var n = 0; n < e.length; ++n) {\n-                                    var l = e[n],\n-                                        o = !0;\n-                                    if (l.ranges) {\n-                                        l.copied || (l = e[n] = l.deepCopy(), l.copied = !0);\n-                                        for (var a = 0; a < l.ranges.length; a++) uo(l.ranges[a].anchor, t, i, r), uo(l.ranges[a].head, t, i, r);\n-                                        continue;\n-                                    }\n-                                    for (var s = 0; s < l.changes.length; ++s) {\n-                                        var f = l.changes[s];\n-                                        if (i < f.from.line) f.from = y(f.from.line + r, f.from.ch), f.to = y(f.to.line + r, f.to.ch);\n-                                        else if (t <= f.to.line) {\n-                                            o = !1;\n-                                            break;\n-                                        }\n-                                    }\n-                                    o || (e.splice(0, n + 1), n = 0);\n-                                }\n-                            }\n-                            u(fo, \"rebaseHistArray\");\n+                    function play() {\n+                        onPlay === null || onPlay === void 0 ? void 0 : onPlay();\n+                        driverControls = driver(update);\n+                        driverControls.start();\n+                    }\n+                    autoplay && play();\n+                    return {\n+                        stop: () => {\n+                            onStop === null || onStop === void 0 ? void 0 : onStop();\n+                            driverControls.stop();\n+                        }\n+                    };\n+                }\n \n-                            function ho(e, t) {\n-                                var i = t.from.line,\n-                                    r = t.to.line,\n-                                    n = t.text.length - (r - i) - 1;\n-                                fo(e.done, i, r, n), fo(e.undone, i, r, n);\n-                            }\n-                            u(ho, \"rebaseHist\");\n+                function velocityPerSecond(velocity, frameDuration) {\n+                    return frameDuration ? velocity * (1000 / frameDuration) : 0;\n+                }\n \n-                            function cr(e, t, i, r) {\n-                                var n = t,\n-                                    l = t;\n-                                return typeof t == \"number\" ? l = S(e, Un(e, t)) : n = F(t), n == null ? null : (r(l, n) && e.cm && Ye(e.cm, n, i), l);\n-                            }\n-                            u(cr, \"changeLine\");\n+                function inertia({\n+                    from = 0,\n+                    velocity = 0,\n+                    min,\n+                    max,\n+                    power = 0.8,\n+                    timeConstant = 750,\n+                    bounceStiffness = 500,\n+                    bounceDamping = 10,\n+                    restDelta = 1,\n+                    modifyTarget,\n+                    driver,\n+                    onUpdate,\n+                    onComplete,\n+                    onStop\n+                }) {\n+                    let currentAnimation;\n \n-                            function dr(e) {\n-                                this.lines = e, this.parent = null;\n-                                for (var t = 0, i = 0; i < e.length; ++i) e[i].parent = this, t += e[i].height;\n-                                this.height = t;\n-                            }\n-                            u(dr, \"LeafChunk\"), dr.prototype = {\n-                                chunkSize: function() {\n-                                    return this.lines.length;\n-                                },\n-                                removeInner: function(e, t) {\n-                                    for (var i = e, r = e + t; i < r; ++i) {\n-                                        var n = this.lines[i];\n-                                        this.height -= n.height, Sa(n), Z(n, \"delete\");\n-                                    }\n-                                    this.lines.splice(e, t);\n-                                },\n-                                collapse: function(e) {\n-                                    e.push.apply(e, this.lines);\n-                                },\n-                                insertInner: function(e, t, i) {\n-                                    this.height += i, this.lines = this.lines.slice(0, e).concat(t).concat(this.lines.slice(e));\n-                                    for (var r = 0; r < t.length; ++r) t[r].parent = this;\n-                                },\n-                                iterN: function(e, t, i) {\n-                                    for (var r = e + t; e < r; ++e)\n-                                        if (i(this.lines[e])) return !0;\n-                                }\n-                            };\n+                    function isOutOfBounds(v) {\n+                        return min !== undefined && v < min || max !== undefined && v > max;\n+                    }\n \n-                            function pr(e) {\n-                                this.children = e;\n-                                for (var t = 0, i = 0, r = 0; r < e.length; ++r) {\n-                                    var n = e[r];\n-                                    t += n.chunkSize(), i += n.height, n.parent = this;\n-                                }\n-                                this.size = t, this.height = i, this.parent = null;\n-                            }\n-                            u(pr, \"BranchChunk\"), pr.prototype = {\n-                                chunkSize: function() {\n-                                    return this.size;\n-                                },\n-                                removeInner: function(e, t) {\n-                                    this.size -= t;\n-                                    for (var i = 0; i < this.children.length; ++i) {\n-                                        var r = this.children[i],\n-                                            n = r.chunkSize();\n-                                        if (e < n) {\n-                                            var l = Math.min(t, n - e),\n-                                                o = r.height;\n-                                            if (r.removeInner(e, l), this.height -= o - r.height, n == l && (this.children.splice(i--, 1), r.parent = null), (t -= l) == 0) break;\n-                                            e = 0;\n-                                        } else e -= n;\n-                                    }\n-                                    if (this.size - t < 25 && (this.children.length > 1 || !(this.children[0] instanceof dr))) {\n-                                        var a = [];\n-                                        this.collapse(a), this.children = [new dr(a)], this.children[0].parent = this;\n-                                    }\n-                                },\n-                                collapse: function(e) {\n-                                    for (var t = 0; t < this.children.length; ++t) this.children[t].collapse(e);\n-                                },\n-                                insertInner: function(e, t, i) {\n-                                    this.size += t.length, this.height += i;\n-                                    for (var r = 0; r < this.children.length; ++r) {\n-                                        var n = this.children[r],\n-                                            l = n.chunkSize();\n-                                        if (e <= l) {\n-                                            if (n.insertInner(e, t, i), n.lines && n.lines.length > 50) {\n-                                                for (var o = n.lines.length % 25 + 25, a = o; a < n.lines.length;) {\n-                                                    var s = new dr(n.lines.slice(a, a += 25));\n-                                                    n.height -= s.height, this.children.splice(++r, 0, s), s.parent = this;\n-                                                }\n-                                                n.lines = n.lines.slice(0, o), this.maybeSpill();\n-                                            }\n-                                            break;\n-                                        }\n-                                        e -= l;\n-                                    }\n-                                },\n-                                maybeSpill: function() {\n-                                    if (!(this.children.length <= 10)) {\n-                                        var e = this;\n-                                        do {\n-                                            var t = e.children.splice(e.children.length - 5, 5),\n-                                                i = new pr(t);\n-                                            if (e.parent) {\n-                                                e.size -= i.size, e.height -= i.height;\n-                                                var n = ee(e.parent.children, e);\n-                                                e.parent.children.splice(n + 1, 0, i);\n-                                            } else {\n-                                                var r = new pr(e.children);\n-                                                r.parent = e, e.children = [r, i], e = r;\n-                                            }\n-                                            i.parent = e.parent;\n-                                        } while (e.children.length > 10);\n-                                        e.parent.maybeSpill();\n-                                    }\n-                                },\n-                                iterN: function(e, t, i) {\n-                                    for (var r = 0; r < this.children.length; ++r) {\n-                                        var n = this.children[r],\n-                                            l = n.chunkSize();\n-                                        if (e < l) {\n-                                            var o = Math.min(t, l - e);\n-                                            if (n.iterN(e, o, i)) return !0;\n-                                            if ((t -= o) == 0) break;\n-                                            e = 0;\n-                                        } else e -= l;\n-                                    }\n-                                }\n-                            };\n-                            var vr = u(function(e, t, i) {\n-                                if (i)\n-                                    for (var r in i) i.hasOwnProperty(r) && (this[r] = i[r]);\n-                                this.doc = e, this.node = t;\n-                            }, \"LineWidget\");\n-                            vr.prototype.clear = function() {\n-                                var e = this.doc.cm,\n-                                    t = this.line.widgets,\n-                                    i = this.line,\n-                                    r = F(i);\n-                                if (!(r == null || !t)) {\n-                                    for (var n = 0; n < t.length; ++n) t[n] == this && t.splice(n--, 1);\n-                                    t.length || (i.widgets = null);\n-                                    var l = tr(this);\n-                                    De(i, Math.max(0, i.height - l)), e && (de(e, function() {\n-                                        co(e, i, -l), Ye(e, r, \"widget\");\n-                                    }), Z(e, \"lineWidgetCleared\", e, this, r));\n-                                }\n-                            }, vr.prototype.changed = function() {\n-                                var e = this,\n-                                    t = this.height,\n-                                    i = this.doc.cm,\n-                                    r = this.line;\n-                                this.height = null;\n-                                var n = tr(this) - t;\n-                                n && (Xe(this.doc, r) || De(r, r.height + n), i && de(i, function() {\n-                                    i.curOp.forceUpdate = !0, co(i, r, n), Z(i, \"lineWidgetChanged\", i, e, F(r));\n-                                }));\n-                            }, xt(vr);\n+                    function boundaryNearest(v) {\n+                        if (min === undefined) return max;\n+                        if (max === undefined) return min;\n+                        return Math.abs(min - v) < Math.abs(max - v) ? min : max;\n+                    }\n \n-                            function co(e, t, i) {\n-                                Ie(t) < (e.curOp && e.curOp.scrollTop || e.doc.scrollTop) && nn(e, i);\n-                            }\n-                            u(co, \"adjustScrollWhenAboveVisible\");\n+                    function startAnimation(options) {\n+                        currentAnimation === null || currentAnimation === void 0 ? void 0 : currentAnimation.stop();\n+                        currentAnimation = animate(Object.assign(Object.assign({}, options), {\n+                            driver,\n+                            onUpdate: v => {\n+                                var _a;\n+                                onUpdate === null || onUpdate === void 0 ? void 0 : onUpdate(v);\n+                                (_a = options.onUpdate) === null || _a === void 0 ? void 0 : _a.call(options, v);\n+                            },\n+                            onComplete,\n+                            onStop\n+                        }));\n+                    }\n \n-                            function Ss(e, t, i, r) {\n-                                var n = new vr(e, i, r),\n-                                    l = e.cm;\n-                                return l && n.noHScroll && (l.display.alignWidgets = !0), cr(e, t, \"widget\", function(o) {\n-                                    var a = o.widgets || (o.widgets = []);\n-                                    if (n.insertAt == null ? a.push(n) : a.splice(Math.min(a.length, Math.max(0, n.insertAt)), 0, n), n.line = o, l && !Xe(e, o)) {\n-                                        var s = Ie(o) < e.scrollTop;\n-                                        De(o, o.height + tr(n)), s && nn(l, n.height), l.curOp.forceUpdate = !0;\n-                                    }\n-                                    return !0;\n-                                }), l && Z(l, \"lineWidgetAdded\", l, n, typeof t == \"number\" ? t : F(t)), n;\n-                            }\n-                            u(Ss, \"addLineWidget\");\n-                            var po = 0,\n-                                je = u(function(e, t) {\n-                                    this.lines = [], this.type = t, this.doc = e, this.id = ++po;\n-                                }, \"TextMarker\");\n-                            je.prototype.clear = function() {\n-                                if (!this.explicitlyCleared) {\n-                                    var e = this.doc.cm,\n-                                        t = e && !e.curOp;\n-                                    if (t && pt(e), Ce(this, \"clear\")) {\n-                                        var i = this.find();\n-                                        i && Z(this, \"clear\", i.from, i.to);\n-                                    }\n-                                    for (var r = null, n = null, l = 0; l < this.lines.length; ++l) {\n-                                        var o = this.lines[l],\n-                                            a = Vt(o.markedSpans, this);\n-                                        e && !this.collapsed ? Ye(e, F(o), \"text\") : e && (a.to != null && (n = F(o)), a.from != null && (r = F(o))), o.markedSpans = pa(o.markedSpans, a), a.from == null && this.collapsed && !Xe(this.doc, o) && e && De(o, Tt(e.display));\n-                                    }\n-                                    if (e && this.collapsed && !e.options.lineWrapping)\n-                                        for (var s = 0; s < this.lines.length; ++s) {\n-                                            var f = Se(this.lines[s]),\n-                                                h = Gr(f);\n-                                            h > e.display.maxLineLength && (e.display.maxLine = f, e.display.maxLineLength = h, e.display.maxLineChanged = !0);\n-                                        }\n-                                    r != null && e && this.collapsed && se(e, r, n + 1), this.lines.length = 0, this.explicitlyCleared = !0, this.atomic && this.doc.cantEdit && (this.doc.cantEdit = !1, e && ro(e.doc)), e && Z(e, \"markerCleared\", e, this, r, n), t && vt(e), this.parent && this.parent.clear();\n-                                }\n-                            }, je.prototype.find = function(e, t) {\n-                                e == null && this.type == \"bookmark\" && (e = 1);\n-                                for (var i, r, n = 0; n < this.lines.length; ++n) {\n-                                    var l = this.lines[n],\n-                                        o = Vt(l.markedSpans, this);\n-                                    if (o.from != null && (i = y(t ? l : F(l), o.from), e == -1)) return i;\n-                                    if (o.to != null && (r = y(t ? l : F(l), o.to), e == 1)) return r;\n-                                }\n-                                return i && {\n-                                    from: i,\n-                                    to: r\n-                                };\n-                            }, je.prototype.changed = function() {\n-                                var e = this,\n-                                    t = this.find(-1, !0),\n-                                    i = this,\n-                                    r = this.doc.cm;\n-                                !t || !r || de(r, function() {\n-                                    var n = t.line,\n-                                        l = F(t.line),\n-                                        o = _i(r, l);\n-                                    if (o && (bl(o), r.curOp.selectionChanged = r.curOp.forceUpdate = !0), r.curOp.updateMaxLine = !0, !Xe(i.doc, n) && i.height != null) {\n-                                        var a = i.height;\n-                                        i.height = null;\n-                                        var s = tr(i) - a;\n-                                        s && De(n, n.height + s);\n-                                    }\n-                                    Z(r, \"markerChanged\", r, e);\n-                                });\n-                            }, je.prototype.attachLine = function(e) {\n-                                if (!this.lines.length && this.doc.cm) {\n-                                    var t = this.doc.cm.curOp;\n-                                    (!t.maybeHiddenMarkers || ee(t.maybeHiddenMarkers, this) == -1) && (t.maybeUnhiddenMarkers || (t.maybeUnhiddenMarkers = [])).push(this);\n-                                }\n-                                this.lines.push(e);\n-                            }, je.prototype.detachLine = function(e) {\n-                                if (this.lines.splice(ee(this.lines, e), 1), !this.lines.length && this.doc.cm) {\n-                                    var t = this.doc.cm.curOp;\n-                                    (t.maybeHiddenMarkers || (t.maybeHiddenMarkers = [])).push(this);\n-                                }\n-                            }, xt(je);\n-\n-                            function Pt(e, t, i, r, n) {\n-                                if (r && r.shared) return Ls(e, t, i, r, n);\n-                                if (e.cm && !e.cm.curOp) return Q(e.cm, Pt)(e, t, i, r, n);\n-                                var l = new je(e, n),\n-                                    o = D(t, i);\n-                                if (r && nt(r, l, !1), o > 0 || o == 0 && l.clearWhenEmpty !== !1) return l;\n-                                if (l.replacedWith && (l.collapsed = !0, l.widgetNode = bt(\"span\", [l.replacedWith], \"CodeMirror-widget\"), r.handleMouseEvents || l.widgetNode.setAttribute(\"cm-ignore-events\", \"true\"), r.insertLeft && (l.widgetNode.insertLeft = !0)), l.collapsed) {\n-                                    if (il(e, t.line, t, i, l) || t.line != i.line && il(e, i.line, t, i, l)) throw new Error(\"Inserting collapsed marker partially overlapping an existing one\");\n-                                    da();\n-                                }\n-                                l.addToHistory && Ql(e, {\n-                                    from: t,\n-                                    to: i,\n-                                    origin: \"markText\"\n-                                }, e.sel, NaN);\n-                                var a = t.line,\n-                                    s = e.cm,\n-                                    f;\n-                                if (e.iter(a, i.line + 1, function(c) {\n-                                        s && l.collapsed && !s.options.lineWrapping && Se(c) == s.display.maxLine && (f = !0), l.collapsed && a != t.line && De(c, 0), va(c, new Ir(l, a == t.line ? t.ch : null, a == i.line ? i.ch : null), e.cm && e.cm.curOp), ++a;\n-                                    }), l.collapsed && e.iter(t.line, i.line + 1, function(c) {\n-                                        Xe(e, c) && De(c, 0);\n-                                    }), l.clearOnEnter && M(l, \"beforeCursorEnter\", function() {\n-                                        return l.clear();\n-                                    }), l.readOnly && (ca(), (e.history.done.length || e.history.undone.length) && e.clearHistory()), l.collapsed && (l.id = ++po, l.atomic = !0), s) {\n-                                    if (f && (s.curOp.updateMaxLine = !0), l.collapsed) se(s, t.line, i.line + 1);\n-                                    else if (l.className || l.startStyle || l.endStyle || l.css || l.attributes || l.title)\n-                                        for (var h = t.line; h <= i.line; h++) Ye(s, h, \"text\");\n-                                    l.atomic && ro(s.doc), Z(s, \"markerAdded\", s, l);\n-                                }\n-                                return l;\n-                            }\n-                            u(Pt, \"markText\");\n-                            var gr = u(function(e, t) {\n-                                this.markers = e, this.primary = t;\n-                                for (var i = 0; i < e.length; ++i) e[i].parent = this;\n-                            }, \"SharedTextMarker\");\n-                            gr.prototype.clear = function() {\n-                                if (!this.explicitlyCleared) {\n-                                    this.explicitlyCleared = !0;\n-                                    for (var e = 0; e < this.markers.length; ++e) this.markers[e].clear();\n-                                    Z(this, \"clear\");\n-                                }\n-                            }, gr.prototype.find = function(e, t) {\n-                                return this.primary.find(e, t);\n-                            }, xt(gr);\n-\n-                            function Ls(e, t, i, r, n) {\n-                                r = nt(r), r.shared = !1;\n-                                var l = [Pt(e, t, i, r, n)],\n-                                    o = l[0],\n-                                    a = r.widgetNode;\n-                                return Je(e, function(s) {\n-                                    a && (r.widgetNode = a.cloneNode(!0)), l.push(Pt(s, N(s, t), N(s, i), r, n));\n-                                    for (var f = 0; f < s.linked.length; ++f)\n-                                        if (s.linked[f].isParent) return;\n-                                    o = H(l);\n-                                }), new gr(l, o);\n-                            }\n-                            u(Ls, \"markTextShared\");\n-\n-                            function vo(e) {\n-                                return e.findMarks(y(e.first, 0), e.clipPos(y(e.lastLine())), function(t) {\n-                                    return t.parent;\n+                    function startSpring(options) {\n+                        startAnimation(Object.assign({\n+                            type: \"spring\",\n+                            stiffness: bounceStiffness,\n+                            damping: bounceDamping,\n+                            restDelta\n+                        }, options));\n+                    }\n+                    if (isOutOfBounds(from)) {\n+                        startSpring({\n+                            from,\n+                            velocity,\n+                            to: boundaryNearest(from)\n+                        });\n+                    } else {\n+                        let target = power * velocity + from;\n+                        if (typeof modifyTarget !== \"undefined\") target = modifyTarget(target);\n+                        const boundary = boundaryNearest(target);\n+                        const heading = boundary === min ? -1 : 1;\n+                        let prev;\n+                        let current;\n+                        const checkBoundary = v => {\n+                            prev = current;\n+                            current = v;\n+                            velocity = velocityPerSecond(v - prev, sync.getFrameData().delta);\n+                            if (heading === 1 && v > boundary || heading === -1 && v < boundary) {\n+                                startSpring({\n+                                    from: v,\n+                                    to: boundary,\n+                                    velocity\n                                 });\n                             }\n-                            u(vo, \"findSharedMarkers\");\n-\n-                            function ks(e, t) {\n-                                for (var i = 0; i < t.length; i++) {\n-                                    var r = t[i],\n-                                        n = r.find(),\n-                                        l = e.clipPos(n.from),\n-                                        o = e.clipPos(n.to);\n-                                    if (D(l, o)) {\n-                                        var a = Pt(e, l, o, r.primary, r.primary.type);\n-                                        r.markers.push(a), a.parent = r;\n-                                    }\n-                                }\n-                            }\n-                            u(ks, \"copySharedMarkers\");\n-\n-                            function Ts(e) {\n-                                for (var t = u(function(r) {\n-                                        var n = e[r],\n-                                            l = [n.primary.doc];\n-                                        Je(n.primary.doc, function(s) {\n-                                            return l.push(s);\n-                                        });\n-                                        for (var o = 0; o < n.markers.length; o++) {\n-                                            var a = n.markers[o];\n-                                            ee(l, a.doc) == -1 && (a.parent = null, n.markers.splice(o--, 1));\n-                                        }\n-                                    }, \"loop\"), i = 0; i < e.length; i++) t(i);\n-                            }\n-                            u(Ts, \"detachSharedMarkers\");\n-                            var Ms = 0,\n-                                ue = u(function(e, t, i, r, n) {\n-                                    if (!(this instanceof ue)) return new ue(e, t, i, r, n);\n-                                    i == null && (i = 0), pr.call(this, [new dr([new St(\"\", null)])]), this.first = i, this.scrollTop = this.scrollLeft = 0, this.cantEdit = !1, this.cleanGeneration = 1, this.modeFrontier = this.highlightFrontier = i;\n-                                    var l = y(i, 0);\n-                                    this.sel = Ze(l), this.history = new $r(null), this.id = ++Ms, this.modeOption = t, this.lineSep = r, this.direction = n == \"rtl\" ? \"rtl\" : \"ltr\", this.extend = !1, typeof e == \"string\" && (e = this.splitLines(e)), cn(this, {\n-                                        from: l,\n-                                        to: l,\n-                                        text: e\n-                                    }), te(this, Ze(l), Me);\n-                                }, \"Doc\");\n-                            ue.prototype = Fn(pr.prototype, {\n-                                constructor: ue,\n-                                iter: function(e, t, i) {\n-                                    i ? this.iterN(e - this.first, t - e, i) : this.iterN(this.first, this.first + this.size, e);\n-                                },\n-                                insert: function(e, t) {\n-                                    for (var i = 0, r = 0; r < t.length; ++r) i += t[r].height;\n-                                    this.insertInner(e - this.first, t, i);\n-                                },\n-                                remove: function(e, t) {\n-                                    this.removeInner(e - this.first, t);\n-                                },\n-                                getValue: function(e) {\n-                                    var t = Ai(this, this.first, this.first + this.size);\n-                                    return e === !1 ? t : t.join(e || this.lineSeparator());\n-                                },\n-                                setValue: J(function(e) {\n-                                    var t = y(this.first, 0),\n-                                        i = this.first + this.size - 1;\n-                                    Ht(this, {\n-                                        from: t,\n-                                        to: y(i, S(this, i).text.length),\n-                                        text: this.splitLines(e),\n-                                        origin: \"setValue\",\n-                                        full: !0\n-                                    }, !0), this.cm && nr(this.cm, 0, 0), te(this, Ze(t), Me);\n-                                }),\n-                                replaceRange: function(e, t, i, r) {\n-                                    t = N(this, t), i = i ? N(this, i) : t, Ft(this, e, t, i, r);\n-                                },\n-                                getRange: function(e, t, i) {\n-                                    var r = ot(this, N(this, e), N(this, t));\n-                                    return i === !1 ? r : i === \"\" ? r.join(\"\") : r.join(i || this.lineSeparator());\n-                                },\n-                                getLine: function(e) {\n-                                    var t = this.getLineHandle(e);\n-                                    return t && t.text;\n-                                },\n-                                getLineHandle: function(e) {\n-                                    if (Jt(this, e)) return S(this, e);\n-                                },\n-                                getLineNumber: function(e) {\n-                                    return F(e);\n-                                },\n-                                getLineHandleVisualStart: function(e) {\n-                                    return typeof e == \"number\" && (e = S(this, e)), Se(e);\n-                                },\n-                                lineCount: function() {\n-                                    return this.size;\n-                                },\n-                                firstLine: function() {\n-                                    return this.first;\n-                                },\n-                                lastLine: function() {\n-                                    return this.first + this.size - 1;\n-                                },\n-                                clipPos: function(e) {\n-                                    return N(this, e);\n-                                },\n-                                getCursor: function(e) {\n-                                    var t = this.sel.primary(),\n-                                        i;\n-                                    return e == null || e == \"head\" ? i = t.head : e == \"anchor\" ? i = t.anchor : e == \"end\" || e == \"to\" || e === !1 ? i = t.to() : i = t.from(), i;\n-                                },\n-                                listSelections: function() {\n-                                    return this.sel.ranges;\n-                                },\n-                                somethingSelected: function() {\n-                                    return this.sel.somethingSelected();\n-                                },\n-                                setCursor: J(function(e, t, i) {\n-                                    $l(this, N(this, typeof e == \"number\" ? y(e, t || 0) : e), null, i);\n-                                }),\n-                                setSelection: J(function(e, t, i) {\n-                                    $l(this, N(this, e), N(this, t || e), i);\n-                                }),\n-                                extendSelection: J(function(e, t, i) {\n-                                    ti(this, N(this, e), t && N(this, t), i);\n-                                }),\n-                                extendSelections: J(function(e, t) {\n-                                    Vl(this, Kn(this, e), t);\n-                                }),\n-                                extendSelectionsBy: J(function(e, t) {\n-                                    var i = Or(this.sel.ranges, e);\n-                                    Vl(this, Kn(this, i), t);\n-                                }),\n-                                setSelections: J(function(e, t, i) {\n-                                    if (e.length) {\n-                                        for (var r = [], n = 0; n < e.length; n++) r[n] = new W(N(this, e[n].anchor), N(this, e[n].head || e[n].anchor));\n-                                        t == null && (t = Math.min(e.length - 1, this.sel.primIndex)), te(this, ke(this.cm, r, t), i);\n-                                    }\n-                                }),\n-                                addSelection: J(function(e, t, i) {\n-                                    var r = this.sel.ranges.slice(0);\n-                                    r.push(new W(N(this, e), N(this, t || e))), te(this, ke(this.cm, r, r.length - 1), i);\n-                                }),\n-                                getSelection: function(e) {\n-                                    for (var t = this.sel.ranges, i, r = 0; r < t.length; r++) {\n-                                        var n = ot(this, t[r].from(), t[r].to());\n-                                        i = i ? i.concat(n) : n;\n-                                    }\n-                                    return e === !1 ? i : i.join(e || this.lineSeparator());\n-                                },\n-                                getSelections: function(e) {\n-                                    for (var t = [], i = this.sel.ranges, r = 0; r < i.length; r++) {\n-                                        var n = ot(this, i[r].from(), i[r].to());\n-                                        e !== !1 && (n = n.join(e || this.lineSeparator())), t[r] = n;\n-                                    }\n-                                    return t;\n-                                },\n-                                replaceSelection: function(e, t, i) {\n-                                    for (var r = [], n = 0; n < this.sel.ranges.length; n++) r[n] = e;\n-                                    this.replaceSelections(r, t, i || \"+input\");\n-                                },\n-                                replaceSelections: J(function(e, t, i) {\n-                                    for (var r = [], n = this.sel, l = 0; l < n.ranges.length; l++) {\n-                                        var o = n.ranges[l];\n-                                        r[l] = {\n-                                            from: o.from(),\n-                                            to: o.to(),\n-                                            text: this.splitLines(e[l]),\n-                                            origin: i\n-                                        };\n-                                    }\n-                                    for (var a = t && t != \"end\" && ps(this, r, t), s = r.length - 1; s >= 0; s--) Ht(this, r[s]);\n-                                    a ? eo(this, a) : this.cm && Nt(this.cm);\n-                                }),\n-                                undo: J(function() {\n-                                    ni(this, \"undo\");\n-                                }),\n-                                redo: J(function() {\n-                                    ni(this, \"redo\");\n-                                }),\n-                                undoSelection: J(function() {\n-                                    ni(this, \"undo\", !0);\n-                                }),\n-                                redoSelection: J(function() {\n-                                    ni(this, \"redo\", !0);\n-                                }),\n-                                setExtending: function(e) {\n-                                    this.extend = e;\n-                                },\n-                                getExtending: function() {\n-                                    return this.extend;\n-                                },\n-                                historySize: function() {\n-                                    for (var e = this.history, t = 0, i = 0, r = 0; r < e.done.length; r++) e.done[r].ranges || ++t;\n-                                    for (var n = 0; n < e.undone.length; n++) e.undone[n].ranges || ++i;\n-                                    return {\n-                                        undo: t,\n-                                        redo: i\n-                                    };\n-                                },\n-                                clearHistory: function() {\n-                                    var e = this;\n-                                    this.history = new $r(this.history), Je(this, function(t) {\n-                                        return t.history = e.history;\n-                                    }, !0);\n-                                },\n-                                markClean: function() {\n-                                    this.cleanGeneration = this.changeGeneration(!0);\n-                                },\n-                                changeGeneration: function(e) {\n-                                    return e && (this.history.lastOp = this.history.lastSelOp = this.history.lastOrigin = null), this.history.generation;\n-                                },\n-                                isClean: function(e) {\n-                                    return this.history.generation == (e || this.cleanGeneration);\n-                                },\n-                                getHistory: function() {\n-                                    return {\n-                                        done: Ot(this.history.done),\n-                                        undone: Ot(this.history.undone)\n-                                    };\n-                                },\n-                                setHistory: function(e) {\n-                                    var t = this.history = new $r(this.history);\n-                                    t.done = Ot(e.done.slice(0), null, !0), t.undone = Ot(e.undone.slice(0), null, !0);\n-                                },\n-                                setGutterMarker: J(function(e, t, i) {\n-                                    return cr(this, e, \"gutter\", function(r) {\n-                                        var n = r.gutterMarkers || (r.gutterMarkers = {});\n-                                        return n[t] = i, !i && Pn(n) && (r.gutterMarkers = null), !0;\n-                                    });\n-                                }),\n-                                clearGutter: J(function(e) {\n-                                    var t = this;\n-                                    this.iter(function(i) {\n-                                        i.gutterMarkers && i.gutterMarkers[e] && cr(t, i, \"gutter\", function() {\n-                                            return i.gutterMarkers[e] = null, Pn(i.gutterMarkers) && (i.gutterMarkers = null), !0;\n-                                        });\n-                                    });\n-                                }),\n-                                lineInfo: function(e) {\n-                                    var t;\n-                                    if (typeof e == \"number\") {\n-                                        if (!Jt(this, e) || (t = e, e = S(this, e), !e)) return null;\n-                                    } else if (t = F(e), t == null) return null;\n-                                    return {\n-                                        line: t,\n-                                        handle: e,\n-                                        text: e.text,\n-                                        gutterMarkers: e.gutterMarkers,\n-                                        textClass: e.textClass,\n-                                        bgClass: e.bgClass,\n-                                        wrapClass: e.wrapClass,\n-                                        widgets: e.widgets\n-                                    };\n-                                },\n-                                addLineClass: J(function(e, t, i) {\n-                                    return cr(this, e, t == \"gutter\" ? \"gutter\" : \"class\", function(r) {\n-                                        var n = t == \"text\" ? \"textClass\" : t == \"background\" ? \"bgClass\" : t == \"gutter\" ? \"gutterClass\" : \"wrapClass\";\n-                                        if (!r[n]) r[n] = i;\n-                                        else {\n-                                            if (mt(i).test(r[n])) return !1;\n-                                            r[n] += \" \" + i;\n-                                        }\n-                                        return !0;\n-                                    });\n-                                }),\n-                                removeLineClass: J(function(e, t, i) {\n-                                    return cr(this, e, t == \"gutter\" ? \"gutter\" : \"class\", function(r) {\n-                                        var n = t == \"text\" ? \"textClass\" : t == \"background\" ? \"bgClass\" : t == \"gutter\" ? \"gutterClass\" : \"wrapClass\",\n-                                            l = r[n];\n-                                        if (l) {\n-                                            if (i == null) r[n] = null;\n-                                            else {\n-                                                var o = l.match(mt(i));\n-                                                if (!o) return !1;\n-                                                var a = o.index + o[0].length;\n-                                                r[n] = l.slice(0, o.index) + (!o.index || a == l.length ? \"\" : \" \") + l.slice(a) || null;\n-                                            }\n-                                        } else return !1;\n-                                        return !0;\n-                                    });\n-                                }),\n-                                addLineWidget: J(function(e, t, i) {\n-                                    return Ss(this, e, t, i);\n-                                }),\n-                                removeLineWidget: function(e) {\n-                                    e.clear();\n-                                },\n-                                markText: function(e, t, i) {\n-                                    return Pt(this, N(this, e), N(this, t), i, i && i.type || \"range\");\n-                                },\n-                                setBookmark: function(e, t) {\n-                                    var i = {\n-                                        replacedWith: t && (t.nodeType == null ? t.widget : t),\n-                                        insertLeft: t && t.insertLeft,\n-                                        clearWhenEmpty: !1,\n-                                        shared: t && t.shared,\n-                                        handleMouseEvents: t && t.handleMouseEvents\n-                                    };\n-                                    return e = N(this, e), Pt(this, e, e, i, \"bookmark\");\n-                                },\n-                                findMarksAt: function(e) {\n-                                    e = N(this, e);\n-                                    var t = [],\n-                                        i = S(this, e.line).markedSpans;\n-                                    if (i)\n-                                        for (var r = 0; r < i.length; ++r) {\n-                                            var n = i[r];\n-                                            (n.from == null || n.from <= e.ch) && (n.to == null || n.to >= e.ch) && t.push(n.marker.parent || n.marker);\n-                                        }\n-                                    return t;\n-                                },\n-                                findMarks: function(e, t, i) {\n-                                    e = N(this, e), t = N(this, t);\n-                                    var r = [],\n-                                        n = e.line;\n-                                    return this.iter(e.line, t.line + 1, function(l) {\n-                                        var o = l.markedSpans;\n-                                        if (o)\n-                                            for (var a = 0; a < o.length; a++) {\n-                                                var s = o[a];\n-                                                !(s.to != null && n == e.line && e.ch >= s.to || s.from == null && n != e.line || s.from != null && n == t.line && s.from >= t.ch) && (!i || i(s.marker)) && r.push(s.marker.parent || s.marker);\n-                                            }\n-                                            ++n;\n-                                    }), r;\n-                                },\n-                                getAllMarks: function() {\n-                                    var e = [];\n-                                    return this.iter(function(t) {\n-                                        var i = t.markedSpans;\n-                                        if (i)\n-                                            for (var r = 0; r < i.length; ++r) i[r].from != null && e.push(i[r].marker);\n-                                    }), e;\n-                                },\n-                                posFromIndex: function(e) {\n-                                    var t,\n-                                        i = this.first,\n-                                        r = this.lineSeparator().length;\n-                                    return this.iter(function(n) {\n-                                        var l = n.text.length + r;\n-                                        if (l > e) return t = e, !0;\n-                                        e -= l, ++i;\n-                                    }), N(this, y(i, t));\n-                                },\n-                                indexFromPos: function(e) {\n-                                    e = N(this, e);\n-                                    var t = e.ch;\n-                                    if (e.line < this.first || e.ch < 0) return 0;\n-                                    var i = this.lineSeparator().length;\n-                                    return this.iter(this.first, e.line, function(r) {\n-                                        t += r.text.length + i;\n-                                    }), t;\n-                                },\n-                                copy: function(e) {\n-                                    var t = new ue(Ai(this, this.first, this.first + this.size), this.modeOption, this.first, this.lineSep, this.direction);\n-                                    return t.scrollTop = this.scrollTop, t.scrollLeft = this.scrollLeft, t.sel = this.sel, t.extend = !1, e && (t.history.undoDepth = this.history.undoDepth, t.setHistory(this.getHistory())), t;\n-                                },\n-                                linkedDoc: function(e) {\n-                                    e || (e = {});\n-                                    var t = this.first,\n-                                        i = this.first + this.size;\n-                                    e.from != null && e.from > t && (t = e.from), e.to != null && e.to < i && (i = e.to);\n-                                    var r = new ue(Ai(this, t, i), e.mode || this.modeOption, t, this.lineSep, this.direction);\n-                                    return e.sharedHist && (r.history = this.history), (this.linked || (this.linked = [])).push({\n-                                        doc: r,\n-                                        sharedHist: e.sharedHist\n-                                    }), r.linked = [{\n-                                        doc: this,\n-                                        isParent: !0,\n-                                        sharedHist: e.sharedHist\n-                                    }], ks(r, vo(this)), r;\n-                                },\n-                                unlinkDoc: function(e) {\n-                                    if (e instanceof R && (e = e.doc), this.linked)\n-                                        for (var t = 0; t < this.linked.length; ++t) {\n-                                            var i = this.linked[t];\n-                                            if (i.doc == e) {\n-                                                this.linked.splice(t, 1), e.unlinkDoc(this), Ts(vo(this));\n-                                                break;\n-                                            }\n-                                        }\n-                                    if (e.history == this.history) {\n-                                        var r = [e.id];\n-                                        Je(e, function(n) {\n-                                            return r.push(n.id);\n-                                        }, !0), e.history = new $r(null), e.history.done = Ot(this.history.done, r), e.history.undone = Ot(this.history.undone, r);\n-                                    }\n-                                },\n-                                iterLinkedDocs: function(e) {\n-                                    Je(this, e);\n-                                },\n-                                getMode: function() {\n-                                    return this.mode;\n-                                },\n-                                getEditor: function() {\n-                                    return this.cm;\n-                                },\n-                                splitLines: function(e) {\n-                                    return this.lineSep ? e.split(this.lineSep) : ki(e);\n-                                },\n-                                lineSeparator: function() {\n-                                    return this.lineSep || `\n-`;\n-                                },\n-                                setDirection: J(function(e) {\n-                                    e != \"rtl\" && (e = \"ltr\"), e != this.direction && (this.direction = e, this.iter(function(t) {\n-                                        return t.order = null;\n-                                    }), this.cm && vs(this.cm));\n-                                })\n-                            }), ue.prototype.eachLine = ue.prototype.iter;\n-                            var go = 0;\n-\n-                            function Ds(e) {\n-                                var t = this;\n-                                if (yo(t), !(q(t, e) || Re(t.display, e))) {\n-                                    ae(e), O && (go = +new Date());\n-                                    var i = ft(t, e, !0),\n-                                        r = e.dataTransfer.files;\n-                                    if (!(!i || t.isReadOnly()))\n-                                        if (r && r.length && window.FileReader && window.File)\n-                                            for (var n = r.length, l = Array(n), o = 0, a = u(function() {\n-                                                    ++o == n && Q(t, function() {\n-                                                        i = N(t.doc, i);\n-                                                        var d = {\n-                                                            from: i,\n-                                                            to: i,\n-                                                            text: t.doc.splitLines(l.filter(function(v) {\n-                                                                return v != null;\n-                                                            }).join(t.doc.lineSeparator())),\n-                                                            origin: \"paste\"\n-                                                        };\n-                                                        Ht(t.doc, d), eo(t.doc, Ze(N(t.doc, i), N(t.doc, Qe(d))));\n-                                                    })();\n-                                                }, \"markAsReadAndPasteIfAllFilesAreRead\"), s = u(function(d, v) {\n-                                                    if (t.options.allowDropFileTypes && ee(t.options.allowDropFileTypes, d.type) == -1) {\n-                                                        a();\n-                                                        return;\n-                                                    }\n-                                                    var g = new FileReader();\n-                                                    g.onerror = function() {\n-                                                        return a();\n-                                                    }, g.onload = function() {\n-                                                        var m = g.result;\n-                                                        if (/[\\x00-\\x08\\x0e-\\x1f]{2}/.test(m)) {\n-                                                            a();\n-                                                            return;\n-                                                        }\n-                                                        l[v] = m, a();\n-                                                    }, g.readAsText(d);\n-                                                }, \"readTextFromFile\"), f = 0; f < r.length; f++) s(r[f], f);\n-                                        else {\n-                                            if (t.state.draggingText && t.doc.sel.contains(i) > -1) {\n-                                                t.state.draggingText(e), setTimeout(function() {\n-                                                    return t.display.input.focus();\n-                                                }, 20);\n-                                                return;\n-                                            }\n-                                            try {\n-                                                var h = e.dataTransfer.getData(\"Text\");\n-                                                if (h) {\n-                                                    var c;\n-                                                    if (t.state.draggingText && !t.state.draggingText.copy && (c = t.listSelections()), ri(t.doc, Ze(i, i)), c)\n-                                                        for (var p = 0; p < c.length; ++p) Ft(t.doc, \"\", c[p].anchor, c[p].head, \"drag\");\n-                                                    t.replaceSelection(h, \"around\", \"paste\"), t.display.input.focus();\n-                                                }\n-                                            } catch {}\n-                                        }\n-                                }\n-                            }\n-                            u(Ds, \"onDrop\");\n-\n-                            function Ns(e, t) {\n-                                if (O && (!e.state.draggingText || +new Date() - go < 100)) {\n-                                    Qt(t);\n-                                    return;\n-                                }\n-                                if (!(q(e, t) || Re(e.display, t)) && (t.dataTransfer.setData(\"Text\", e.getSelection()), t.dataTransfer.effectAllowed = \"copyMove\", t.dataTransfer.setDragImage && !Mr)) {\n-                                    var i = T(\"img\", null, null, \"position: fixed; left: 0; top: 0;\");\n-                                    i.src = \"data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==\", we && (i.width = i.height = 1, e.display.wrapper.appendChild(i), i._top = i.offsetTop), t.dataTransfer.setDragImage(i, 0, 0), we && i.parentNode.removeChild(i);\n-                                }\n-                            }\n-                            u(Ns, \"onDragStart\");\n-\n-                            function As(e, t) {\n-                                var i = ft(e, t);\n-                                if (i) {\n-                                    var r = document.createDocumentFragment();\n-                                    Vi(e, i, r), e.display.dragCursor || (e.display.dragCursor = T(\"div\", null, \"CodeMirror-cursors CodeMirror-dragcursors\"), e.display.lineSpace.insertBefore(e.display.dragCursor, e.display.cursorDiv)), ve(e.display.dragCursor, r);\n-                                }\n-                            }\n-                            u(As, \"onDragOver\");\n-\n-                            function yo(e) {\n-                                e.display.dragCursor && (e.display.lineSpace.removeChild(e.display.dragCursor), e.display.dragCursor = null);\n-                            }\n-                            u(yo, \"clearDragCursor\");\n+                        };\n+                        startAnimation({\n+                            type: \"decay\",\n+                            from,\n+                            velocity,\n+                            timeConstant,\n+                            power,\n+                            restDelta,\n+                            modifyTarget,\n+                            onUpdate: isOutOfBounds(target) ? checkBoundary : undefined\n+                        });\n+                    }\n+                    return {\n+                        stop: () => currentAnimation === null || currentAnimation === void 0 ? void 0 : currentAnimation.stop()\n+                    };\n+                }\n+                const radiansToDegrees = radians => radians * 180 / Math.PI;\n+                const angle = (a, b = zeroPoint) => radiansToDegrees(Math.atan2(b.y - a.y, b.x - a.x));\n+                const applyOffset = (from, to) => {\n+                    let hasReceivedFrom = true;\n+                    if (to === undefined) {\n+                        to = from;\n+                        hasReceivedFrom = false;\n+                    }\n+                    return v => {\n+                        if (hasReceivedFrom) {\n+                            return v - from + to;\n+                        } else {\n+                            from = v;\n+                            hasReceivedFrom = true;\n+                            return to;\n+                        }\n+                    };\n+                };\n+                const identity = v => v;\n+                const createAttractor = (alterDisplacement = identity) => (constant, origin, v) => {\n+                    const displacement = origin - v;\n+                    const springModifiedDisplacement = -(0 - constant + 1) * (0 - alterDisplacement(Math.abs(displacement)));\n+                    return displacement <= 0 ? origin + springModifiedDisplacement : origin - springModifiedDisplacement;\n+                };\n+                const attract = createAttractor();\n+                const attractExpo = createAttractor(Math.sqrt);\n+                const degreesToRadians = degrees => degrees * Math.PI / 180;\n+                const isPoint = point => point.hasOwnProperty('x') && point.hasOwnProperty('y');\n+                const isPoint3D = point => isPoint(point) && point.hasOwnProperty('z');\n+                const distance1D = (a, b) => Math.abs(a - b);\n \n-                            function mo(e) {\n-                                if (document.getElementsByClassName) {\n-                                    for (var t = document.getElementsByClassName(\"CodeMirror\"), i = [], r = 0; r < t.length; r++) {\n-                                        var n = t[r].CodeMirror;\n-                                        n && i.push(n);\n-                                    }\n-                                    i.length && i[0].operation(function() {\n-                                        for (var l = 0; l < i.length; l++) e(i[l]);\n-                                    });\n-                                }\n+                function distance(a, b) {\n+                    if (isNum(a) && isNum(b)) {\n+                        return distance1D(a, b);\n+                    } else if (isPoint(a) && isPoint(b)) {\n+                        const xDelta = distance1D(a.x, b.x);\n+                        const yDelta = distance1D(a.y, b.y);\n+                        const zDelta = isPoint3D(a) && isPoint3D(b) ? distance1D(a.z, b.z) : 0;\n+                        return Math.sqrt(Math.pow(xDelta, 2) + Math.pow(yDelta, 2) + Math.pow(zDelta, 2));\n+                    }\n+                }\n+                const pointFromVector = (origin, angle, distance) => {\n+                    angle = degreesToRadians(angle);\n+                    return {\n+                        x: distance * Math.cos(angle) + origin.x,\n+                        y: distance * Math.sin(angle) + origin.y\n+                    };\n+                };\n+                const toDecimal = (num, precision = 2) => {\n+                    precision = Math.pow(10, precision);\n+                    return Math.round(num * precision) / precision;\n+                };\n+                const smoothFrame = (prevValue, nextValue, duration, smoothing = 0) => toDecimal(prevValue + duration * (nextValue - prevValue) / Math.max(smoothing, duration));\n+                const smooth = (strength = 50) => {\n+                    let previousValue = 0;\n+                    let lastUpdated = 0;\n+                    return v => {\n+                        const currentFramestamp = sync.getFrameData().timestamp;\n+                        const timeDelta = currentFramestamp !== lastUpdated ? currentFramestamp - lastUpdated : 0;\n+                        const newValue = timeDelta ? smoothFrame(previousValue, v, timeDelta, strength) : previousValue;\n+                        lastUpdated = currentFramestamp;\n+                        previousValue = newValue;\n+                        return newValue;\n+                    };\n+                };\n+                const snap = points => {\n+                    if (typeof points === 'number') {\n+                        return v => Math.round(v / points) * points;\n+                    } else {\n+                        let i = 0;\n+                        const numPoints = points.length;\n+                        return v => {\n+                            let lastDistance = Math.abs(points[0] - v);\n+                            for (i = 1; i < numPoints; i++) {\n+                                const point = points[i];\n+                                const distance = Math.abs(point - v);\n+                                if (distance === 0) return point;\n+                                if (distance > lastDistance) return points[i - 1];\n+                                if (i === numPoints - 1) return point;\n+                                lastDistance = distance;\n                             }\n-                            u(mo, \"forEachCodeMirror\");\n-                            var bo = !1;\n+                        };\n+                    }\n+                };\n \n-                            function Os() {\n-                                bo || (Ws(), bo = !0);\n-                            }\n-                            u(Os, \"ensureGlobalHandlers\");\n+                function velocityPerFrame(xps, frameDuration) {\n+                    return xps / (1000 / frameDuration);\n+                }\n+                const wrap = (min, max, v) => {\n+                    const rangeSize = max - min;\n+                    return ((v - min) % rangeSize + rangeSize) % rangeSize + min;\n+                };\n+                const a = (a1, a2) => 1.0 - 3.0 * a2 + 3.0 * a1;\n+                const b = (a1, a2) => 3.0 * a2 - 6.0 * a1;\n+                const c = a1 => 3.0 * a1;\n+                const calcBezier = (t, a1, a2) => ((a(a1, a2) * t + b(a1, a2)) * t + c(a1)) * t;\n+                const getSlope = (t, a1, a2) => 3.0 * a(a1, a2) * t * t + 2.0 * b(a1, a2) * t + c(a1);\n+                const subdivisionPrecision = 0.0000001;\n+                const subdivisionMaxIterations = 10;\n \n-                            function Ws() {\n-                                var e;\n-                                M(window, \"resize\", function() {\n-                                    e == null && (e = setTimeout(function() {\n-                                        e = null, mo(Hs);\n-                                    }, 100));\n-                                }), M(window, \"blur\", function() {\n-                                    return mo(Dt);\n-                                });\n-                            }\n-                            u(Ws, \"registerGlobalHandlers\");\n+                function binarySubdivide(aX, aA, aB, mX1, mX2) {\n+                    let currentX;\n+                    let currentT;\n+                    let i = 0;\n+                    do {\n+                        currentT = aA + (aB - aA) / 2.0;\n+                        currentX = calcBezier(currentT, mX1, mX2) - aX;\n+                        if (currentX > 0.0) {\n+                            aB = currentT;\n+                        } else {\n+                            aA = currentT;\n+                        }\n+                    } while (Math.abs(currentX) > subdivisionPrecision && ++i < subdivisionMaxIterations);\n+                    return currentT;\n+                }\n+                const newtonIterations = 8;\n+                const newtonMinSlope = 0.001;\n \n-                            function Hs(e) {\n-                                var t = e.display;\n-                                t.cachedCharWidth = t.cachedTextHeight = t.cachedPaddingH = null, t.scrollbarsClipped = !1, e.setSize();\n-                            }\n-                            u(Hs, \"onResize\");\n-                            for (var Ve = {\n-                                    3: \"Pause\",\n-                                    8: \"Backspace\",\n-                                    9: \"Tab\",\n-                                    13: \"Enter\",\n-                                    16: \"Shift\",\n-                                    17: \"Ctrl\",\n-                                    18: \"Alt\",\n-                                    19: \"Pause\",\n-                                    20: \"CapsLock\",\n-                                    27: \"Esc\",\n-                                    32: \"Space\",\n-                                    33: \"PageUp\",\n-                                    34: \"PageDown\",\n-                                    35: \"End\",\n-                                    36: \"Home\",\n-                                    37: \"Left\",\n-                                    38: \"Up\",\n-                                    39: \"Right\",\n-                                    40: \"Down\",\n-                                    44: \"PrintScrn\",\n-                                    45: \"Insert\",\n-                                    46: \"Delete\",\n-                                    59: \";\",\n-                                    61: \"=\",\n-                                    91: \"Mod\",\n-                                    92: \"Mod\",\n-                                    93: \"Mod\",\n-                                    106: \"*\",\n-                                    107: \"=\",\n-                                    109: \"-\",\n-                                    110: \".\",\n-                                    111: \"/\",\n-                                    145: \"ScrollLock\",\n-                                    173: \"-\",\n-                                    186: \";\",\n-                                    187: \"=\",\n-                                    188: \",\",\n-                                    189: \"-\",\n-                                    190: \".\",\n-                                    191: \"/\",\n-                                    192: \"`\",\n-                                    219: \"[\",\n-                                    220: \"\\\\\",\n-                                    221: \"]\",\n-                                    222: \"'\",\n-                                    224: \"Mod\",\n-                                    63232: \"Up\",\n-                                    63233: \"Down\",\n-                                    63234: \"Left\",\n-                                    63235: \"Right\",\n-                                    63272: \"Delete\",\n-                                    63273: \"Home\",\n-                                    63275: \"End\",\n-                                    63276: \"PageUp\",\n-                                    63277: \"PageDown\",\n-                                    63302: \"Insert\"\n-                                }, yr = 0; yr < 10; yr++) Ve[yr + 48] = Ve[yr + 96] = String(yr);\n-                            for (var li = 65; li <= 90; li++) Ve[li] = String.fromCharCode(li);\n-                            for (var mr = 1; mr <= 12; mr++) Ve[mr + 111] = Ve[mr + 63235] = \"F\" + mr;\n-                            var ze = {};\n-                            ze.basic = {\n-                                Left: \"goCharLeft\",\n-                                Right: \"goCharRight\",\n-                                Up: \"goLineUp\",\n-                                Down: \"goLineDown\",\n-                                End: \"goLineEnd\",\n-                                Home: \"goLineStartSmart\",\n-                                PageUp: \"goPageUp\",\n-                                PageDown: \"goPageDown\",\n-                                Delete: \"delCharAfter\",\n-                                Backspace: \"delCharBefore\",\n-                                \"Shift-Backspace\": \"delCharBefore\",\n-                                Tab: \"defaultTab\",\n-                                \"Shift-Tab\": \"indentAuto\",\n-                                Enter: \"newlineAndIndent\",\n-                                Insert: \"toggleOverwrite\",\n-                                Esc: \"singleSelection\"\n-                            }, ze.pcDefault = {\n-                                \"Ctrl-A\": \"selectAll\",\n-                                \"Ctrl-D\": \"deleteLine\",\n-                                \"Ctrl-Z\": \"undo\",\n-                                \"Shift-Ctrl-Z\": \"redo\",\n-                                \"Ctrl-Y\": \"redo\",\n-                                \"Ctrl-Home\": \"goDocStart\",\n-                                \"Ctrl-End\": \"goDocEnd\",\n-                                \"Ctrl-Up\": \"goLineUp\",\n-                                \"Ctrl-Down\": \"goLineDown\",\n-                                \"Ctrl-Left\": \"goGroupLeft\",\n-                                \"Ctrl-Right\": \"goGroupRight\",\n-                                \"Alt-Left\": \"goLineStart\",\n-                                \"Alt-Right\": \"goLineEnd\",\n-                                \"Ctrl-Backspace\": \"delGroupBefore\",\n-                                \"Ctrl-Delete\": \"delGroupAfter\",\n-                                \"Ctrl-S\": \"save\",\n-                                \"Ctrl-F\": \"find\",\n-                                \"Ctrl-G\": \"findNext\",\n-                                \"Shift-Ctrl-G\": \"findPrev\",\n-                                \"Shift-Ctrl-F\": \"replace\",\n-                                \"Shift-Ctrl-R\": \"replaceAll\",\n-                                \"Ctrl-[\": \"indentLess\",\n-                                \"Ctrl-]\": \"indentMore\",\n-                                \"Ctrl-U\": \"undoSelection\",\n-                                \"Shift-Ctrl-U\": \"redoSelection\",\n-                                \"Alt-U\": \"redoSelection\",\n-                                fallthrough: \"basic\"\n-                            }, ze.emacsy = {\n-                                \"Ctrl-F\": \"goCharRight\",\n-                                \"Ctrl-B\": \"goCharLeft\",\n-                                \"Ctrl-P\": \"goLineUp\",\n-                                \"Ctrl-N\": \"goLineDown\",\n-                                \"Ctrl-A\": \"goLineStart\",\n-                                \"Ctrl-E\": \"goLineEnd\",\n-                                \"Ctrl-V\": \"goPageDown\",\n-                                \"Shift-Ctrl-V\": \"goPageUp\",\n-                                \"Ctrl-D\": \"delCharAfter\",\n-                                \"Ctrl-H\": \"delCharBefore\",\n-                                \"Alt-Backspace\": \"delWordBefore\",\n-                                \"Ctrl-K\": \"killLine\",\n-                                \"Ctrl-T\": \"transposeChars\",\n-                                \"Ctrl-O\": \"openLine\"\n-                            }, ze.macDefault = {\n-                                \"Cmd-A\": \"selectAll\",\n-                                \"Cmd-D\": \"deleteLine\",\n-                                \"Cmd-Z\": \"undo\",\n-                                \"Shift-Cmd-Z\": \"redo\",\n-                                \"Cmd-Y\": \"redo\",\n-                                \"Cmd-Home\": \"goDocStart\",\n-                                \"Cmd-Up\": \"goDocStart\",\n-                                \"Cmd-End\": \"goDocEnd\",\n-                                \"Cmd-Down\": \"goDocEnd\",\n-                                \"Alt-Left\": \"goGroupLeft\",\n-                                \"Alt-Right\": \"goGroupRight\",\n-                                \"Cmd-Left\": \"goLineLeft\",\n-                                \"Cmd-Right\": \"goLineRight\",\n-                                \"Alt-Backspace\": \"delGroupBefore\",\n-                                \"Ctrl-Alt-Backspace\": \"delGroupAfter\",\n-                                \"Alt-Delete\": \"delGroupAfter\",\n-                                \"Cmd-S\": \"save\",\n-                                \"Cmd-F\": \"find\",\n-                                \"Cmd-G\": \"findNext\",\n-                                \"Shift-Cmd-G\": \"findPrev\",\n-                                \"Cmd-Alt-F\": \"replace\",\n-                                \"Shift-Cmd-Alt-F\": \"replaceAll\",\n-                                \"Cmd-[\": \"indentLess\",\n-                                \"Cmd-]\": \"indentMore\",\n-                                \"Cmd-Backspace\": \"delWrappedLineLeft\",\n-                                \"Cmd-Delete\": \"delWrappedLineRight\",\n-                                \"Cmd-U\": \"undoSelection\",\n-                                \"Shift-Cmd-U\": \"redoSelection\",\n-                                \"Ctrl-Up\": \"goDocStart\",\n-                                \"Ctrl-Down\": \"goDocEnd\",\n-                                fallthrough: [\"basic\", \"emacsy\"]\n-                            }, ze.default = me ? ze.macDefault : ze.pcDefault;\n-\n-                            function Fs(e) {\n-                                var t = e.split(/-(?!$)/);\n-                                e = t[t.length - 1];\n-                                for (var i, r, n, l, o = 0; o < t.length - 1; o++) {\n-                                    var a = t[o];\n-                                    if (/^(cmd|meta|m)$/i.test(a)) l = !0;\n-                                    else if (/^a(lt)?$/i.test(a)) i = !0;\n-                                    else if (/^(c|ctrl|control)$/i.test(a)) r = !0;\n-                                    else if (/^s(hift)?$/i.test(a)) n = !0;\n-                                    else throw new Error(\"Unrecognized modifier name: \" + a);\n-                                }\n-                                return i && (e = \"Alt-\" + e), r && (e = \"Ctrl-\" + e), l && (e = \"Cmd-\" + e), n && (e = \"Shift-\" + e), e;\n-                            }\n-                            u(Fs, \"normalizeKeyName\");\n-\n-                            function Ps(e) {\n-                                var t = {};\n-                                for (var i in e)\n-                                    if (e.hasOwnProperty(i)) {\n-                                        var r = e[i];\n-                                        if (/^(name|fallthrough|(de|at)tach)$/.test(i)) continue;\n-                                        if (r == \"...\") {\n-                                            delete e[i];\n-                                            continue;\n-                                        }\n-                                        for (var n = Or(i.split(\" \"), Fs), l = 0; l < n.length; l++) {\n-                                            var o = void 0,\n-                                                a = void 0;\n-                                            l == n.length - 1 ? (a = n.join(\" \"), o = r) : (a = n.slice(0, l + 1).join(\" \"), o = \"...\");\n-                                            var s = t[a];\n-                                            if (!s) t[a] = o;\n-                                            else if (s != o) throw new Error(\"Inconsistent bindings for \" + a);\n-                                        }\n-                                        delete e[i];\n-                                    }\n-                                for (var f in t) e[f] = t[f];\n-                                return e;\n-                            }\n-                            u(Ps, \"normalizeKeyMap\");\n+                function newtonRaphsonIterate(aX, aGuessT, mX1, mX2) {\n+                    for (let i = 0; i < newtonIterations; ++i) {\n+                        const currentSlope = getSlope(aGuessT, mX1, mX2);\n+                        if (currentSlope === 0.0) {\n+                            return aGuessT;\n+                        }\n+                        const currentX = calcBezier(aGuessT, mX1, mX2) - aX;\n+                        aGuessT -= currentX / currentSlope;\n+                    }\n+                    return aGuessT;\n+                }\n+                const kSplineTableSize = 11;\n+                const kSampleStepSize = 1.0 / (kSplineTableSize - 1.0);\n \n-                            function Et(e, t, i, r) {\n-                                t = oi(t);\n-                                var n = t.call ? t.call(e, r) : t[e];\n-                                if (n === !1) return \"nothing\";\n-                                if (n === \"...\") return \"multi\";\n-                                if (n != null && i(n)) return \"handled\";\n-                                if (t.fallthrough) {\n-                                    if (Object.prototype.toString.call(t.fallthrough) != \"[object Array]\") return Et(e, t.fallthrough, i, r);\n-                                    for (var l = 0; l < t.fallthrough.length; l++) {\n-                                        var o = Et(e, t.fallthrough[l], i, r);\n-                                        if (o) return o;\n-                                    }\n-                                }\n-                            }\n-                            u(Et, \"lookupKey\");\n+                function cubicBezier(mX1, mY1, mX2, mY2) {\n+                    if (mX1 === mY1 && mX2 === mY2) return linear;\n+                    const sampleValues = new Float32Array(kSplineTableSize);\n+                    for (let i = 0; i < kSplineTableSize; ++i) {\n+                        sampleValues[i] = calcBezier(i * kSampleStepSize, mX1, mX2);\n+                    }\n \n-                            function xo(e) {\n-                                var t = typeof e == \"string\" ? e : Ve[e.keyCode];\n-                                return t == \"Ctrl\" || t == \"Alt\" || t == \"Shift\" || t == \"Mod\";\n-                            }\n-                            u(xo, \"isModifierKey\");\n+                    function getTForX(aX) {\n+                        let intervalStart = 0.0;\n+                        let currentSample = 1;\n+                        const lastSample = kSplineTableSize - 1;\n+                        for (; currentSample !== lastSample && sampleValues[currentSample] <= aX; ++currentSample) {\n+                            intervalStart += kSampleStepSize;\n+                        }\n+                        --currentSample;\n+                        const dist = (aX - sampleValues[currentSample]) / (sampleValues[currentSample + 1] - sampleValues[currentSample]);\n+                        const guessForT = intervalStart + dist * kSampleStepSize;\n+                        const initialSlope = getSlope(guessForT, mX1, mX2);\n+                        if (initialSlope >= newtonMinSlope) {\n+                            return newtonRaphsonIterate(aX, guessForT, mX1, mX2);\n+                        } else if (initialSlope === 0.0) {\n+                            return guessForT;\n+                        } else {\n+                            return binarySubdivide(aX, intervalStart, intervalStart + kSampleStepSize, mX1, mX2);\n+                        }\n+                    }\n+                    return t => t === 0 || t === 1 ? t : calcBezier(getTForX(t), mY1, mY2);\n+                }\n+                const steps = (steps, direction = 'end') => progress => {\n+                    progress = direction === 'end' ? Math.min(progress, 0.999) : Math.max(progress, 0.001);\n+                    const expanded = progress * steps;\n+                    const rounded = direction === 'end' ? Math.floor(expanded) : Math.ceil(expanded);\n+                    return clamp(0, 1, rounded / steps);\n+                };\n+                exports.angle = angle;\n+                exports.animate = animate;\n+                exports.anticipate = anticipate;\n+                exports.applyOffset = applyOffset;\n+                exports.attract = attract;\n+                exports.attractExpo = attractExpo;\n+                exports.backIn = backIn;\n+                exports.backInOut = backInOut;\n+                exports.backOut = backOut;\n+                exports.bounceIn = bounceIn;\n+                exports.bounceInOut = bounceInOut;\n+                exports.bounceOut = bounceOut;\n+                exports.circIn = circIn;\n+                exports.circInOut = circInOut;\n+                exports.circOut = circOut;\n+                exports.clamp = clamp;\n+                exports.createAnticipate = createAnticipate;\n+                exports.createAttractor = createAttractor;\n+                exports.createBackIn = createBackIn;\n+                exports.createExpoIn = createExpoIn;\n+                exports.cubicBezier = cubicBezier;\n+                exports.decay = decay;\n+                exports.degreesToRadians = degreesToRadians;\n+                exports.distance = distance;\n+                exports.easeIn = easeIn;\n+                exports.easeInOut = easeInOut;\n+                exports.easeOut = easeOut;\n+                exports.inertia = inertia;\n+                exports.interpolate = interpolate;\n+                exports.isPoint = isPoint;\n+                exports.isPoint3D = isPoint3D;\n+                exports.keyframes = keyframes;\n+                exports.linear = linear;\n+                exports.mirrorEasing = mirrorEasing;\n+                exports.mix = mix;\n+                exports.mixColor = mixColor;\n+                exports.mixComplex = mixComplex;\n+                exports.pipe = pipe;\n+                exports.pointFromVector = pointFromVector;\n+                exports.progress = progress;\n+                exports.radiansToDegrees = radiansToDegrees;\n+                exports.reverseEasing = reverseEasing;\n+                exports.smooth = smooth;\n+                exports.smoothFrame = smoothFrame;\n+                exports.snap = snap;\n+                exports.spring = spring;\n+                exports.steps = steps;\n+                exports.toDecimal = toDecimal;\n+                exports.velocityPerFrame = velocityPerFrame;\n+                exports.velocityPerSecond = velocityPerSecond;\n+                exports.wrap = wrap;\n \n-                            function Co(e, t, i) {\n-                                var r = e;\n-                                return t.altKey && r != \"Alt\" && (e = \"Alt-\" + e), (On ? t.metaKey : t.ctrlKey) && r != \"Ctrl\" && (e = \"Ctrl-\" + e), (On ? t.ctrlKey : t.metaKey) && r != \"Mod\" && (e = \"Cmd-\" + e), !i && t.shiftKey && r != \"Shift\" && (e = \"Shift-\" + e), e;\n-                            }\n-                            u(Co, \"addModifierNames\");\n+                /***/\n+            }),\n \n-                            function wo(e, t) {\n-                                if (we && e.keyCode == 34 && e.char) return !1;\n-                                var i = Ve[e.keyCode];\n-                                return i == null || e.altGraphKey ? !1 : (e.keyCode == 3 && e.code && (i = e.code), Co(i, e, t));\n-                            }\n-                            u(wo, \"keyName\");\n+        /***/\n+        \"../../../node_modules/punycode.js/punycode.es6.js\":\n+            /*!*********************************************************!*\\\n+              !*** ../../../node_modules/punycode.js/punycode.es6.js ***!\n+              \\*********************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports) {\n \n-                            function oi(e) {\n-                                return typeof e == \"string\" ? ze[e] : e;\n-                            }\n-                            u(oi, \"getKeyMap\");\n+                \"use strict\";\n \n-                            function It(e, t) {\n-                                for (var i = e.doc.sel.ranges, r = [], n = 0; n < i.length; n++) {\n-                                    for (var l = t(i[n]); r.length && D(l.from, H(r).to) <= 0;) {\n-                                        var o = r.pop();\n-                                        if (D(o.from, l.from) < 0) {\n-                                            l.from = o.from;\n-                                            break;\n-                                        }\n-                                    }\n-                                    r.push(l);\n-                                }\n-                                de(e, function() {\n-                                    for (var a = r.length - 1; a >= 0; a--) Ft(e.doc, \"\", r[a].from, r[a].to, \"+delete\");\n-                                    Nt(e);\n-                                });\n-                            }\n-                            u(It, \"deleteNearSelection\");\n \n-                            function gn(e, t, i) {\n-                                var r = En(e.text, t + i, i);\n-                                return r < 0 || r > e.text.length ? null : r;\n-                            }\n-                            u(gn, \"moveCharLogically\");\n-\n-                            function yn(e, t, i) {\n-                                var r = gn(e, t.ch, i);\n-                                return r == null ? null : new y(t.line, r, i < 0 ? \"after\" : \"before\");\n-                            }\n-                            u(yn, \"moveLogically\");\n-\n-                            function mn(e, t, i, r, n) {\n-                                if (e) {\n-                                    t.doc.direction == \"rtl\" && (n = -n);\n-                                    var l = Pe(i, t.doc.direction);\n-                                    if (l) {\n-                                        var o = n < 0 ? H(l) : l[0],\n-                                            a = n < 0 == (o.level == 1),\n-                                            s = a ? \"after\" : \"before\",\n-                                            f;\n-                                        if (o.level > 0 || t.doc.direction == \"rtl\") {\n-                                            var h = kt(t, i);\n-                                            f = n < 0 ? i.text.length - 1 : 0;\n-                                            var c = Oe(t, h, f).top;\n-                                            f = Yt(function(p) {\n-                                                return Oe(t, h, p).top == c;\n-                                            }, n < 0 == (o.level == 1) ? o.from : o.to - 1, f), s == \"before\" && (f = gn(i, f, 1));\n-                                        } else f = n < 0 ? o.to : o.from;\n-                                        return new y(r, f, s);\n-                                    }\n-                                }\n-                                return new y(r, n < 0 ? i.text.length : 0, n < 0 ? \"before\" : \"after\");\n-                            }\n-                            u(mn, \"endOfLine\");\n-\n-                            function Es(e, t, i, r) {\n-                                var n = Pe(t, e.doc.direction);\n-                                if (!n) return yn(t, i, r);\n-                                i.ch >= t.text.length ? (i.ch = t.text.length, i.sticky = \"before\") : i.ch <= 0 && (i.ch = 0, i.sticky = \"after\");\n-                                var l = Zt(n, i.ch, i.sticky),\n-                                    o = n[l];\n-                                if (e.doc.direction == \"ltr\" && o.level % 2 == 0 && (r > 0 ? o.to > i.ch : o.from < i.ch)) return yn(t, i, r);\n-                                var a = u(function(b, C) {\n-                                        return gn(t, b instanceof y ? b.ch : b, C);\n-                                    }, \"mv\"),\n-                                    s,\n-                                    f = u(function(b) {\n-                                        return e.options.lineWrapping ? (s = s || kt(e, t), Tl(e, t, s, b)) : {\n-                                            begin: 0,\n-                                            end: t.text.length\n-                                        };\n-                                    }, \"getWrappedLineExtent\"),\n-                                    h = f(i.sticky == \"before\" ? a(i, -1) : i.ch);\n-                                if (e.doc.direction == \"rtl\" || o.level == 1) {\n-                                    var c = o.level == 1 == r < 0,\n-                                        p = a(i, c ? 1 : -1);\n-                                    if (p != null && (c ? p <= o.to && p <= h.end : p >= o.from && p >= h.begin)) {\n-                                        var d = c ? \"before\" : \"after\";\n-                                        return new y(i.line, p, d);\n-                                    }\n-                                }\n-                                var v = u(function(b, C, x) {\n-                                        for (var w = u(function(E, j) {\n-                                                return j ? new y(i.line, a(E, 1), \"before\") : new y(i.line, E, \"after\");\n-                                            }, \"getRes\"); b >= 0 && b < n.length; b += C) {\n-                                            var k = n[b],\n-                                                L = C > 0 == (k.level != 1),\n-                                                A = L ? x.begin : a(x.end, -1);\n-                                            if (k.from <= A && A < k.to || (A = L ? k.from : a(k.to, -1), x.begin <= A && A < x.end)) return w(A, L);\n-                                        }\n-                                    }, \"searchInVisualLine\"),\n-                                    g = v(l + r, r, h);\n-                                if (g) return g;\n-                                var m = r > 0 ? h.end : a(h.begin, -1);\n-                                return m != null && !(r > 0 && m == t.text.length) && (g = v(r > 0 ? 0 : n.length - 1, r, f(m)), g) ? g : null;\n-                            }\n-                            u(Es, \"moveVisually\");\n-                            var br = {\n-                                selectAll: lo,\n-                                singleSelection: function(e) {\n-                                    return e.setSelection(e.getCursor(\"anchor\"), e.getCursor(\"head\"), Me);\n-                                },\n-                                killLine: function(e) {\n-                                    return It(e, function(t) {\n-                                        if (t.empty()) {\n-                                            var i = S(e.doc, t.head.line).text.length;\n-                                            return t.head.ch == i && t.head.line < e.lastLine() ? {\n-                                                from: t.head,\n-                                                to: y(t.head.line + 1, 0)\n-                                            } : {\n-                                                from: t.head,\n-                                                to: y(t.head.line, i)\n-                                            };\n-                                        } else return {\n-                                            from: t.from(),\n-                                            to: t.to()\n-                                        };\n-                                    });\n-                                },\n-                                deleteLine: function(e) {\n-                                    return It(e, function(t) {\n-                                        return {\n-                                            from: y(t.from().line, 0),\n-                                            to: N(e.doc, y(t.to().line + 1, 0))\n-                                        };\n-                                    });\n-                                },\n-                                delLineLeft: function(e) {\n-                                    return It(e, function(t) {\n-                                        return {\n-                                            from: y(t.from().line, 0),\n-                                            to: t.from()\n-                                        };\n-                                    });\n-                                },\n-                                delWrappedLineLeft: function(e) {\n-                                    return It(e, function(t) {\n-                                        var i = e.charCoords(t.head, \"div\").top + 5,\n-                                            r = e.coordsChar({\n-                                                left: 0,\n-                                                top: i\n-                                            }, \"div\");\n-                                        return {\n-                                            from: r,\n-                                            to: t.from()\n-                                        };\n-                                    });\n-                                },\n-                                delWrappedLineRight: function(e) {\n-                                    return It(e, function(t) {\n-                                        var i = e.charCoords(t.head, \"div\").top + 5,\n-                                            r = e.coordsChar({\n-                                                left: e.display.lineDiv.offsetWidth + 100,\n-                                                top: i\n-                                            }, \"div\");\n-                                        return {\n-                                            from: t.from(),\n-                                            to: r\n-                                        };\n-                                    });\n-                                },\n-                                undo: function(e) {\n-                                    return e.undo();\n-                                },\n-                                redo: function(e) {\n-                                    return e.redo();\n-                                },\n-                                undoSelection: function(e) {\n-                                    return e.undoSelection();\n-                                },\n-                                redoSelection: function(e) {\n-                                    return e.redoSelection();\n-                                },\n-                                goDocStart: function(e) {\n-                                    return e.extendSelection(y(e.firstLine(), 0));\n-                                },\n-                                goDocEnd: function(e) {\n-                                    return e.extendSelection(y(e.lastLine()));\n-                                },\n-                                goLineStart: function(e) {\n-                                    return e.extendSelectionsBy(function(t) {\n-                                        return So(e, t.head.line);\n-                                    }, {\n-                                        origin: \"+move\",\n-                                        bias: 1\n-                                    });\n-                                },\n-                                goLineStartSmart: function(e) {\n-                                    return e.extendSelectionsBy(function(t) {\n-                                        return Lo(e, t.head);\n-                                    }, {\n-                                        origin: \"+move\",\n-                                        bias: 1\n-                                    });\n-                                },\n-                                goLineEnd: function(e) {\n-                                    return e.extendSelectionsBy(function(t) {\n-                                        return Is(e, t.head.line);\n-                                    }, {\n-                                        origin: \"+move\",\n-                                        bias: -1\n-                                    });\n-                                },\n-                                goLineRight: function(e) {\n-                                    return e.extendSelectionsBy(function(t) {\n-                                        var i = e.cursorCoords(t.head, \"div\").top + 5;\n-                                        return e.coordsChar({\n-                                            left: e.display.lineDiv.offsetWidth + 100,\n-                                            top: i\n-                                        }, \"div\");\n-                                    }, Xt);\n-                                },\n-                                goLineLeft: function(e) {\n-                                    return e.extendSelectionsBy(function(t) {\n-                                        var i = e.cursorCoords(t.head, \"div\").top + 5;\n-                                        return e.coordsChar({\n-                                            left: 0,\n-                                            top: i\n-                                        }, \"div\");\n-                                    }, Xt);\n-                                },\n-                                goLineLeftSmart: function(e) {\n-                                    return e.extendSelectionsBy(function(t) {\n-                                        var i = e.cursorCoords(t.head, \"div\").top + 5,\n-                                            r = e.coordsChar({\n-                                                left: 0,\n-                                                top: i\n-                                            }, \"div\");\n-                                        return r.ch < e.getLine(r.line).search(/\\S/) ? Lo(e, t.head) : r;\n-                                    }, Xt);\n-                                },\n-                                goLineUp: function(e) {\n-                                    return e.moveV(-1, \"line\");\n-                                },\n-                                goLineDown: function(e) {\n-                                    return e.moveV(1, \"line\");\n-                                },\n-                                goPageUp: function(e) {\n-                                    return e.moveV(-1, \"page\");\n-                                },\n-                                goPageDown: function(e) {\n-                                    return e.moveV(1, \"page\");\n-                                },\n-                                goCharLeft: function(e) {\n-                                    return e.moveH(-1, \"char\");\n-                                },\n-                                goCharRight: function(e) {\n-                                    return e.moveH(1, \"char\");\n-                                },\n-                                goColumnLeft: function(e) {\n-                                    return e.moveH(-1, \"column\");\n-                                },\n-                                goColumnRight: function(e) {\n-                                    return e.moveH(1, \"column\");\n-                                },\n-                                goWordLeft: function(e) {\n-                                    return e.moveH(-1, \"word\");\n-                                },\n-                                goGroupRight: function(e) {\n-                                    return e.moveH(1, \"group\");\n-                                },\n-                                goGroupLeft: function(e) {\n-                                    return e.moveH(-1, \"group\");\n-                                },\n-                                goWordRight: function(e) {\n-                                    return e.moveH(1, \"word\");\n-                                },\n-                                delCharBefore: function(e) {\n-                                    return e.deleteH(-1, \"codepoint\");\n-                                },\n-                                delCharAfter: function(e) {\n-                                    return e.deleteH(1, \"char\");\n-                                },\n-                                delWordBefore: function(e) {\n-                                    return e.deleteH(-1, \"word\");\n-                                },\n-                                delWordAfter: function(e) {\n-                                    return e.deleteH(1, \"word\");\n-                                },\n-                                delGroupBefore: function(e) {\n-                                    return e.deleteH(-1, \"group\");\n-                                },\n-                                delGroupAfter: function(e) {\n-                                    return e.deleteH(1, \"group\");\n-                                },\n-                                indentAuto: function(e) {\n-                                    return e.indentSelection(\"smart\");\n-                                },\n-                                indentMore: function(e) {\n-                                    return e.indentSelection(\"add\");\n-                                },\n-                                indentLess: function(e) {\n-                                    return e.indentSelection(\"subtract\");\n-                                },\n-                                insertTab: function(e) {\n-                                    return e.replaceSelection(\"\t\");\n-                                },\n-                                insertSoftTab: function(e) {\n-                                    for (var t = [], i = e.listSelections(), r = e.options.tabSize, n = 0; n < i.length; n++) {\n-                                        var l = i[n].from(),\n-                                            o = xe(e.getLine(l.line), l.ch, r);\n-                                        t.push(yi(r - o % r));\n-                                    }\n-                                    e.replaceSelections(t);\n-                                },\n-                                defaultTab: function(e) {\n-                                    e.somethingSelected() ? e.indentSelection(\"add\") : e.execCommand(\"insertTab\");\n-                                },\n-                                transposeChars: function(e) {\n-                                    return de(e, function() {\n-                                        for (var t = e.listSelections(), i = [], r = 0; r < t.length; r++)\n-                                            if (t[r].empty()) {\n-                                                var n = t[r].head,\n-                                                    l = S(e.doc, n.line).text;\n-                                                if (l) {\n-                                                    if (n.ch == l.length && (n = new y(n.line, n.ch - 1)), n.ch > 0) n = new y(n.line, n.ch + 1), e.replaceRange(l.charAt(n.ch - 1) + l.charAt(n.ch - 2), y(n.line, n.ch - 2), n, \"+transpose\");\n-                                                    else if (n.line > e.doc.first) {\n-                                                        var o = S(e.doc, n.line - 1).text;\n-                                                        o && (n = new y(n.line, 1), e.replaceRange(l.charAt(0) + e.doc.lineSeparator() + o.charAt(o.length - 1), y(n.line - 1, o.length - 1), n, \"+transpose\"));\n-                                                    }\n-                                                }\n-                                                i.push(new W(n, n));\n-                                            }\n-                                        e.setSelections(i);\n-                                    });\n-                                },\n-                                newlineAndIndent: function(e) {\n-                                    return de(e, function() {\n-                                        for (var t = e.listSelections(), i = t.length - 1; i >= 0; i--) e.replaceRange(e.doc.lineSeparator(), t[i].anchor, t[i].head, \"+input\");\n-                                        t = e.listSelections();\n-                                        for (var r = 0; r < t.length; r++) e.indentLine(t[r].from().line, null, !0);\n-                                        Nt(e);\n-                                    });\n-                                },\n-                                openLine: function(e) {\n-                                    return e.replaceSelection(`\n-`, \"start\");\n-                                },\n-                                toggleOverwrite: function(e) {\n-                                    return e.toggleOverwrite();\n-                                }\n-                            };\n+                /** Highest positive signed 32-bit float value */\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.toUnicode = exports.toASCII = exports.encode = exports[\"default\"] = exports.decode = void 0;\n+                exports.ucs2decode = ucs2decode;\n+                exports.ucs2encode = void 0;\n+                const maxInt = 2147483647; // aka. 0x7FFFFFFF or 2^31-1\n \n-                            function So(e, t) {\n-                                var i = S(e.doc, t),\n-                                    r = Se(i);\n-                                return r != i && (t = F(r)), mn(!0, e, r, t, 1);\n-                            }\n-                            u(So, \"lineStart\");\n+                /** Bootstring parameters */\n+                const base = 36;\n+                const tMin = 1;\n+                const tMax = 26;\n+                const skew = 38;\n+                const damp = 700;\n+                const initialBias = 72;\n+                const initialN = 128; // 0x80\n+                const delimiter = '-'; // '\\x2D'\n \n-                            function Is(e, t) {\n-                                var i = S(e.doc, t),\n-                                    r = xa(i);\n-                                return r != i && (t = F(r)), mn(!0, e, i, t, -1);\n-                            }\n-                            u(Is, \"lineEnd\");\n+                /** Regular expressions */\n+                const regexPunycode = /^xn--/;\n+                const regexNonASCII = /[^\\0-\\x7F]/; // Note: U+007F DEL is excluded too.\n+                const regexSeparators = /[\\x2E\\u3002\\uFF0E\\uFF61]/g; // RFC 3490 separators\n \n-                            function Lo(e, t) {\n-                                var i = So(e, t.line),\n-                                    r = S(e.doc, i.line),\n-                                    n = Pe(r, e.doc.direction);\n-                                if (!n || n[0].level == 0) {\n-                                    var l = Math.max(i.ch, r.text.search(/\\S/)),\n-                                        o = t.line == i.line && t.ch <= l && t.ch;\n-                                    return y(i.line, o ? 0 : l, i.sticky);\n-                                }\n-                                return i;\n-                            }\n-                            u(Lo, \"lineStartSmart\");\n+                /** Error messages */\n+                const errors = {\n+                    'overflow': 'Overflow: input needs wider integers to process',\n+                    'not-basic': 'Illegal input >= 0x80 (not a basic code point)',\n+                    'invalid-input': 'Invalid input'\n+                };\n \n-                            function ai(e, t, i) {\n-                                if (typeof t == \"string\" && (t = br[t], !t)) return !1;\n-                                e.display.input.ensurePolled();\n-                                var r = e.display.shift,\n-                                    n = !1;\n-                                try {\n-                                    e.isReadOnly() && (e.state.suppressEdits = !0), i && (e.display.shift = !1), n = t(e) != Nr;\n-                                } finally {\n-                                    e.display.shift = r, e.state.suppressEdits = !1;\n-                                }\n-                                return n;\n-                            }\n-                            u(ai, \"doHandleBinding\");\n+                /** Convenience shortcuts */\n+                const baseMinusTMin = base - tMin;\n+                const floor = Math.floor;\n+                const stringFromCharCode = String.fromCharCode;\n \n-                            function Rs(e, t, i) {\n-                                for (var r = 0; r < e.state.keyMaps.length; r++) {\n-                                    var n = Et(t, e.state.keyMaps[r], i, e);\n-                                    if (n) return n;\n-                                }\n-                                return e.options.extraKeys && Et(t, e.options.extraKeys, i, e) || Et(t, e.options.keyMap, i, e);\n-                            }\n-                            u(Rs, \"lookupKeyForEditor\");\n-                            var Bs = new _e();\n+                /*--------------------------------------------------------------------------*/\n \n-                            function xr(e, t, i, r) {\n-                                var n = e.state.keySeq;\n-                                if (n) {\n-                                    if (xo(t)) return \"handled\";\n-                                    if (/\\'$/.test(t) ? e.state.keySeq = null : Bs.set(50, function() {\n-                                            e.state.keySeq == n && (e.state.keySeq = null, e.display.input.reset());\n-                                        }), ko(e, n + \" \" + t, i, r)) return !0;\n-                                }\n-                                return ko(e, t, i, r);\n-                            }\n-                            u(xr, \"dispatchKey\");\n+                /**\n+                 * A generic error utility function.\n+                 * @private\n+                 * @param {String} type The error type.\n+                 * @returns {Error} Throws a `RangeError` with the applicable error message.\n+                 */\n+                function error(type) {\n+                    throw new RangeError(errors[type]);\n+                }\n \n-                            function ko(e, t, i, r) {\n-                                var n = Rs(e, t, r);\n-                                return n == \"multi\" && (e.state.keySeq = t), n == \"handled\" && Z(e, \"keyHandled\", e, t, i), (n == \"handled\" || n == \"multi\") && (ae(i), $i(e)), !!n;\n-                            }\n-                            u(ko, \"dispatchKeyInner\");\n+                /**\n+                 * A generic `Array#map` utility function.\n+                 * @private\n+                 * @param {Array} array The array to iterate over.\n+                 * @param {Function} callback The function that gets called for every array\n+                 * item.\n+                 * @returns {Array} A new array of values returned by the callback function.\n+                 */\n+                function map(array, callback) {\n+                    const result = [];\n+                    let length = array.length;\n+                    while (length--) {\n+                        result[length] = callback(array[length]);\n+                    }\n+                    return result;\n+                }\n \n-                            function To(e, t) {\n-                                var i = wo(t, !0);\n-                                return i ? t.shiftKey && !e.state.keySeq ? xr(e, \"Shift-\" + i, t, function(r) {\n-                                    return ai(e, r, !0);\n-                                }) || xr(e, i, t, function(r) {\n-                                    if (typeof r == \"string\" ? /^go[A-Z]/.test(r) : r.motion) return ai(e, r);\n-                                }) : xr(e, i, t, function(r) {\n-                                    return ai(e, r);\n-                                }) : !1;\n-                            }\n-                            u(To, \"handleKeyBinding\");\n+                /**\n+                 * A simple `Array#map`-like wrapper to work with domain name strings or email\n+                 * addresses.\n+                 * @private\n+                 * @param {String} domain The domain name or email address.\n+                 * @param {Function} callback The function that gets called for every\n+                 * character.\n+                 * @returns {String} A new string of characters returned by the callback\n+                 * function.\n+                 */\n+                function mapDomain(domain, callback) {\n+                    const parts = domain.split('@');\n+                    let result = '';\n+                    if (parts.length > 1) {\n+                        // In email addresses, only the domain name should be punycoded. Leave\n+                        // the local part (i.e. everything up to `@`) intact.\n+                        result = parts[0] + '@';\n+                        domain = parts[1];\n+                    }\n+                    // Avoid `split(regex)` for IE8 compatibility. See #17.\n+                    domain = domain.replace(regexSeparators, '\\x2E');\n+                    const labels = domain.split('.');\n+                    const encoded = map(labels, callback).join('.');\n+                    return result + encoded;\n+                }\n \n-                            function zs(e, t, i) {\n-                                return xr(e, \"'\" + i + \"'\", t, function(r) {\n-                                    return ai(e, r, !0);\n-                                });\n+                /**\n+                 * Creates an array containing the numeric code points of each Unicode\n+                 * character in the string. While JavaScript uses UCS-2 internally,\n+                 * this function will convert a pair of surrogate halves (each of which\n+                 * UCS-2 exposes as separate characters) into a single code point,\n+                 * matching UTF-16.\n+                 * @see `punycode.ucs2.encode`\n+                 * @see <https://mathiasbynens.be/notes/javascript-encoding>\n+                 * @memberOf punycode.ucs2\n+                 * @name decode\n+                 * @param {String} string The Unicode input string (UCS-2).\n+                 * @returns {Array} The new array of code points.\n+                 */\n+                function ucs2decode(string) {\n+                    const output = [];\n+                    let counter = 0;\n+                    const length = string.length;\n+                    while (counter < length) {\n+                        const value = string.charCodeAt(counter++);\n+                        if (value >= 0xD800 && value <= 0xDBFF && counter < length) {\n+                            // It's a high surrogate, and there is a next character.\n+                            const extra = string.charCodeAt(counter++);\n+                            if ((extra & 0xFC00) == 0xDC00) {\n+                                // Low surrogate.\n+                                output.push(((value & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000);\n+                            } else {\n+                                // It's an unmatched surrogate; only append this code unit, in case the\n+                                // next code unit is the high surrogate of a surrogate pair.\n+                                output.push(value);\n+                                counter--;\n                             }\n-                            u(zs, \"handleCharBinding\");\n-                            var bn = null;\n+                        } else {\n+                            output.push(value);\n+                        }\n+                    }\n+                    return output;\n+                }\n \n-                            function Mo(e) {\n-                                var t = this;\n-                                if (!(e.target && e.target != t.display.input.getField()) && (t.curOp.focus = be(), !q(t, e))) {\n-                                    O && I < 11 && e.keyCode == 27 && (e.returnValue = !1);\n-                                    var i = e.keyCode;\n-                                    t.display.shift = i == 16 || e.shiftKey;\n-                                    var r = To(t, e);\n-                                    we && (bn = r ? i : null, !r && i == 88 && !na && (me ? e.metaKey : e.ctrlKey) && t.replaceSelection(\"\", null, \"cut\")), Fe && !me && !r && i == 46 && e.shiftKey && !e.ctrlKey && document.execCommand && document.execCommand(\"cut\"), i == 18 && !/\\bCodeMirror-crosshair\\b/.test(t.display.lineDiv.className) && Gs(t);\n-                                }\n-                            }\n-                            u(Mo, \"onKeyDown\");\n+                /**\n+                 * Creates a string based on an array of numeric code points.\n+                 * @see `punycode.ucs2.decode`\n+                 * @memberOf punycode.ucs2\n+                 * @name encode\n+                 * @param {Array} codePoints The array of numeric code points.\n+                 * @returns {String} The new Unicode string (UCS-2).\n+                 */\n+                const ucs2encode = codePoints => String.fromCodePoint(...codePoints);\n \n-                            function Gs(e) {\n-                                var t = e.display.lineDiv;\n-                                it(t, \"CodeMirror-crosshair\");\n+                /**\n+                 * Converts a basic code point into a digit/integer.\n+                 * @see `digitToBasic()`\n+                 * @private\n+                 * @param {Number} codePoint The basic numeric code point value.\n+                 * @returns {Number} The numeric value of a basic code point (for use in\n+                 * representing integers) in the range `0` to `base - 1`, or `base` if\n+                 * the code point does not represent a value.\n+                 */\n+                exports.ucs2encode = ucs2encode;\n+                const basicToDigit = function(codePoint) {\n+                    if (codePoint >= 0x30 && codePoint < 0x3A) {\n+                        return 26 + (codePoint - 0x30);\n+                    }\n+                    if (codePoint >= 0x41 && codePoint < 0x5B) {\n+                        return codePoint - 0x41;\n+                    }\n+                    if (codePoint >= 0x61 && codePoint < 0x7B) {\n+                        return codePoint - 0x61;\n+                    }\n+                    return base;\n+                };\n \n-                                function i(r) {\n-                                    (r.keyCode == 18 || !r.altKey) && (tt(t, \"CodeMirror-crosshair\"), ge(document, \"keyup\", i), ge(document, \"mouseover\", i));\n-                                }\n-                                u(i, \"up\"), M(document, \"keyup\", i), M(document, \"mouseover\", i);\n-                            }\n-                            u(Gs, \"showCrossHair\");\n+                /**\n+                 * Converts a digit/integer into a basic code point.\n+                 * @see `basicToDigit()`\n+                 * @private\n+                 * @param {Number} digit The numeric value of a basic code point.\n+                 * @returns {Number} The basic code point whose value (when used for\n+                 * representing integers) is `digit`, which needs to be in the range\n+                 * `0` to `base - 1`. If `flag` is non-zero, the uppercase form is\n+                 * used; else, the lowercase form is used. The behavior is undefined\n+                 * if `flag` is non-zero and `digit` has no uppercase form.\n+                 */\n+                const digitToBasic = function(digit, flag) {\n+                    //  0..25 map to ASCII a..z or A..Z\n+                    // 26..35 map to ASCII 0..9\n+                    return digit + 22 + 75 * (digit < 26) - ((flag != 0) << 5);\n+                };\n \n-                            function Do(e) {\n-                                e.keyCode == 16 && (this.doc.sel.shift = !1), q(this, e);\n-                            }\n-                            u(Do, \"onKeyUp\");\n+                /**\n+                 * Bias adaptation function as per section 3.4 of RFC 3492.\n+                 * https://tools.ietf.org/html/rfc3492#section-3.4\n+                 * @private\n+                 */\n+                const adapt = function(delta, numPoints, firstTime) {\n+                    let k = 0;\n+                    delta = firstTime ? floor(delta / damp) : delta >> 1;\n+                    delta += floor(delta / numPoints);\n+                    for /* no initialization */ (; delta > baseMinusTMin * tMax >> 1; k += base) {\n+                        delta = floor(delta / baseMinusTMin);\n+                    }\n+                    return floor(k + (baseMinusTMin + 1) * delta / (delta + skew));\n+                };\n \n-                            function No(e) {\n-                                var t = this;\n-                                if (!(e.target && e.target != t.display.input.getField()) && !(Re(t.display, e) || q(t, e) || e.ctrlKey && !e.altKey || me && e.metaKey)) {\n-                                    var i = e.keyCode,\n-                                        r = e.charCode;\n-                                    if (we && i == bn) {\n-                                        bn = null, ae(e);\n-                                        return;\n-                                    }\n-                                    if (!(we && (!e.which || e.which < 10) && To(t, e))) {\n-                                        var n = String.fromCharCode(r !== null && r !== void 0 ? r : i);\n-                                        n != \"\\b\" && (zs(t, e, n) || t.display.input.onKeyPress(e));\n-                                    }\n-                                }\n-                            }\n-                            u(No, \"onKeyPress\");\n-                            var Us = 400,\n-                                xn = u(function(e, t, i) {\n-                                    this.time = e, this.pos = t, this.button = i;\n-                                }, \"PastClick\");\n-                            xn.prototype.compare = function(e, t, i) {\n-                                return this.time + Us > e && D(t, this.pos) == 0 && i == this.button;\n-                            };\n-                            var Cr, wr;\n-\n-                            function Ks(e, t) {\n-                                var i = +new Date();\n-                                return wr && wr.compare(i, e, t) ? (Cr = wr = null, \"triple\") : Cr && Cr.compare(i, e, t) ? (wr = new xn(i, e, t), Cr = null, \"double\") : (Cr = new xn(i, e, t), wr = null, \"single\");\n-                            }\n-                            u(Ks, \"clickRepeat\");\n-\n-                            function Ao(e) {\n-                                var t = this,\n-                                    i = t.display;\n-                                if (!(q(t, e) || i.activeTouch && i.input.supportsTouch())) {\n-                                    if (i.input.ensurePolled(), i.shift = e.shiftKey, Re(i, e)) {\n-                                        ne || (i.scroller.draggable = !1, setTimeout(function() {\n-                                            return i.scroller.draggable = !0;\n-                                        }, 100));\n-                                        return;\n-                                    }\n-                                    if (!Cn(t, e)) {\n-                                        var r = ft(t, e),\n-                                            n = zn(e),\n-                                            l = r ? Ks(r, n) : \"single\";\n-                                        window.focus(), n == 1 && t.state.selectingText && t.state.selectingText(e), !(r && _s(t, n, r, l, e)) && (n == 1 ? r ? Ys(t, r, l, e) : wi(e) == i.scroller && ae(e) : n == 2 ? (r && ti(t.doc, r), setTimeout(function() {\n-                                            return i.input.focus();\n-                                        }, 20)) : n == 3 && (ci ? t.display.input.onContextMenu(e) : en(t)));\n-                                    }\n-                                }\n-                            }\n-                            u(Ao, \"onMouseDown\");\n-\n-                            function _s(e, t, i, r, n) {\n-                                var l = \"Click\";\n-                                return r == \"double\" ? l = \"Double\" + l : r == \"triple\" && (l = \"Triple\" + l), l = (t == 1 ? \"Left\" : t == 2 ? \"Middle\" : \"Right\") + l, xr(e, Co(l, n), n, function(o) {\n-                                    if (typeof o == \"string\" && (o = br[o]), !o) return !1;\n-                                    var a = !1;\n-                                    try {\n-                                        e.isReadOnly() && (e.state.suppressEdits = !0), a = o(e, i) != Nr;\n-                                    } finally {\n-                                        e.state.suppressEdits = !1;\n-                                    }\n-                                    return a;\n-                                });\n-                            }\n-                            u(_s, \"handleMappedButton\");\n+                /**\n+                 * Converts a Punycode string of ASCII-only symbols to a string of Unicode\n+                 * symbols.\n+                 * @memberOf punycode\n+                 * @param {String} input The Punycode string of ASCII-only symbols.\n+                 * @returns {String} The resulting string of Unicode symbols.\n+                 */\n+                const decode = function(input) {\n+                    // Don't use UCS-2.\n+                    const output = [];\n+                    const inputLength = input.length;\n+                    let i = 0;\n+                    let n = initialN;\n+                    let bias = initialBias;\n \n-                            function Xs(e, t, i) {\n-                                var r = e.getOption(\"configureMouse\"),\n-                                    n = r ? r(e, t, i) : {};\n-                                if (n.unit == null) {\n-                                    var l = qo ? i.shiftKey && i.metaKey : i.altKey;\n-                                    n.unit = l ? \"rectangle\" : t == \"single\" ? \"char\" : t == \"double\" ? \"word\" : \"line\";\n-                                }\n-                                return (n.extend == null || e.doc.extend) && (n.extend = e.doc.extend || i.shiftKey), n.addNew == null && (n.addNew = me ? i.metaKey : i.ctrlKey), n.moveOnDrag == null && (n.moveOnDrag = !(me ? i.altKey : i.ctrlKey)), n;\n-                            }\n-                            u(Xs, \"configureMouse\");\n-\n-                            function Ys(e, t, i, r) {\n-                                O ? setTimeout(pi(Al, e), 0) : e.curOp.focus = be();\n-                                var n = Xs(e, i, r),\n-                                    l = e.doc.sel,\n-                                    o;\n-                                e.options.dragDrop && ea && !e.isReadOnly() && i == \"single\" && (o = l.contains(t)) > -1 && (D((o = l.ranges[o]).from(), t) < 0 || t.xRel > 0) && (D(o.to(), t) > 0 || t.xRel < 0) ? qs(e, r, t, n) : Zs(e, r, t, n);\n-                            }\n-                            u(Ys, \"leftButtonDown\");\n-\n-                            function qs(e, t, i, r) {\n-                                var n = e.display,\n-                                    l = !1,\n-                                    o = Q(e, function(f) {\n-                                        ne && (n.scroller.draggable = !1), e.state.draggingText = !1, e.state.delayingBlurEvent && (e.hasFocus() ? e.state.delayingBlurEvent = !1 : en(e)), ge(n.wrapper.ownerDocument, \"mouseup\", o), ge(n.wrapper.ownerDocument, \"mousemove\", a), ge(n.scroller, \"dragstart\", s), ge(n.scroller, \"drop\", o), l || (ae(f), r.addNew || ti(e.doc, i, null, null, r.extend), ne && !Mr || O && I == 9 ? setTimeout(function() {\n-                                            n.wrapper.ownerDocument.body.focus({\n-                                                preventScroll: !0\n-                                            }), n.input.focus();\n-                                        }, 20) : n.input.focus());\n-                                    }),\n-                                    a = u(function(f) {\n-                                        l = l || Math.abs(t.clientX - f.clientX) + Math.abs(t.clientY - f.clientY) >= 10;\n-                                    }, \"mouseMove\"),\n-                                    s = u(function() {\n-                                        return l = !0;\n-                                    }, \"dragStart\");\n-                                ne && (n.scroller.draggable = !0), e.state.draggingText = o, o.copy = !r.moveOnDrag, M(n.wrapper.ownerDocument, \"mouseup\", o), M(n.wrapper.ownerDocument, \"mousemove\", a), M(n.scroller, \"dragstart\", s), M(n.scroller, \"drop\", o), e.state.delayingBlurEvent = !0, setTimeout(function() {\n-                                    return n.input.focus();\n-                                }, 20), n.scroller.dragDrop && n.scroller.dragDrop();\n-                            }\n-                            u(qs, \"leftButtonStartDrag\");\n-\n-                            function Oo(e, t, i) {\n-                                if (i == \"char\") return new W(t, t);\n-                                if (i == \"word\") return e.findWordAt(t);\n-                                if (i == \"line\") return new W(y(t.line, 0), N(e.doc, y(t.line + 1, 0)));\n-                                var r = i(e, t);\n-                                return new W(r.from, r.to);\n-                            }\n-                            u(Oo, \"rangeForUnit\");\n-\n-                            function Zs(e, t, i, r) {\n-                                O && en(e);\n-                                var n = e.display,\n-                                    l = e.doc;\n-                                ae(t);\n-                                var o,\n-                                    a,\n-                                    s = l.sel,\n-                                    f = s.ranges;\n-                                if (r.addNew && !r.extend ? (a = l.sel.contains(i), a > -1 ? o = f[a] : o = new W(i, i)) : (o = l.sel.primary(), a = l.sel.primIndex), r.unit == \"rectangle\") r.addNew || (o = new W(i, i)), i = ft(e, t, !0, !0), a = -1;\n-                                else {\n-                                    var h = Oo(e, i, r.unit);\n-                                    r.extend ? o = pn(o, h.anchor, h.head, r.extend) : o = h;\n-                                }\n-                                r.addNew ? a == -1 ? (a = f.length, te(l, ke(e, f.concat([o]), a), {\n-                                    scroll: !1,\n-                                    origin: \"*mouse\"\n-                                })) : f.length > 1 && f[a].empty() && r.unit == \"char\" && !r.extend ? (te(l, ke(e, f.slice(0, a).concat(f.slice(a + 1)), 0), {\n-                                    scroll: !1,\n-                                    origin: \"*mouse\"\n-                                }), s = l.sel) : vn(l, a, o, vi) : (a = 0, te(l, new ye([o], 0), vi), s = l.sel);\n-                                var c = i;\n-\n-                                function p(x) {\n-                                    if (D(c, x) != 0)\n-                                        if (c = x, r.unit == \"rectangle\") {\n-                                            for (var w = [], k = e.options.tabSize, L = xe(S(l, i.line).text, i.ch, k), A = xe(S(l, x.line).text, x.ch, k), E = Math.min(L, A), j = Math.max(L, A), B = Math.min(i.line, x.line), pe = Math.min(e.lastLine(), Math.max(i.line, x.line)); B <= pe; B++) {\n-                                                var fe = S(l, B).text,\n-                                                    _ = gi(fe, E, k);\n-                                                E == j ? w.push(new W(y(B, _), y(B, _))) : fe.length > _ && w.push(new W(y(B, _), y(B, gi(fe, j, k))));\n-                                            }\n-                                            w.length || w.push(new W(i, i)), te(l, ke(e, s.ranges.slice(0, a).concat(w), a), {\n-                                                origin: \"*mouse\",\n-                                                scroll: !1\n-                                            }), e.scrollIntoView(x);\n-                                        } else {\n-                                            var he = o,\n-                                                $ = Oo(e, x, r.unit),\n-                                                Y = he.anchor,\n-                                                X;\n-                                            D($.anchor, Y) > 0 ? (X = $.head, Y = Pr(he.from(), $.anchor)) : (X = $.anchor, Y = Fr(he.to(), $.head));\n-                                            var z = s.ranges.slice(0);\n-                                            z[a] = Qs(e, new W(N(l, Y), X)), te(l, ke(e, z, a), vi);\n-                                        }\n-                                }\n-                                u(p, \"extendTo\");\n-                                var d = n.wrapper.getBoundingClientRect(),\n-                                    v = 0;\n-\n-                                function g(x) {\n-                                    var w = ++v,\n-                                        k = ft(e, x, !0, r.unit == \"rectangle\");\n-                                    if (k)\n-                                        if (D(k, c) != 0) {\n-                                            e.curOp.focus = be(), p(k);\n-                                            var L = Qr(n, l);\n-                                            (k.line >= L.to || k.line < L.from) && setTimeout(Q(e, function() {\n-                                                v == w && g(x);\n-                                            }), 150);\n-                                        } else {\n-                                            var A = x.clientY < d.top ? -20 : x.clientY > d.bottom ? 20 : 0;\n-                                            A && setTimeout(Q(e, function() {\n-                                                v == w && (n.scroller.scrollTop += A, g(x));\n-                                            }), 50);\n-                                        }\n-                                }\n-                                u(g, \"extend\");\n+                    // Handle the basic code points: let `basic` be the number of input code\n+                    // points before the last delimiter, or `0` if there is none, then copy\n+                    // the first basic code points to the output.\n \n-                                function m(x) {\n-                                    e.state.selectingText = !1, v = 1 / 0, x && (ae(x), n.input.focus()), ge(n.wrapper.ownerDocument, \"mousemove\", b), ge(n.wrapper.ownerDocument, \"mouseup\", C), l.history.lastSelOrigin = null;\n-                                }\n-                                u(m, \"done\");\n-                                var b = Q(e, function(x) {\n-                                        x.buttons === 0 || !zn(x) ? m(x) : g(x);\n-                                    }),\n-                                    C = Q(e, m);\n-                                e.state.selectingText = C, M(n.wrapper.ownerDocument, \"mousemove\", b), M(n.wrapper.ownerDocument, \"mouseup\", C);\n-                            }\n-                            u(Zs, \"leftButtonSelect\");\n+                    let basic = input.lastIndexOf(delimiter);\n+                    if (basic < 0) {\n+                        basic = 0;\n+                    }\n+                    for (let j = 0; j < basic; ++j) {\n+                        // if it's not a basic code point\n+                        if (input.charCodeAt(j) >= 0x80) {\n+                            error('not-basic');\n+                        }\n+                        output.push(input.charCodeAt(j));\n+                    }\n \n-                            function Qs(e, t) {\n-                                var i = t.anchor,\n-                                    r = t.head,\n-                                    n = S(e.doc, i.line);\n-                                if (D(i, r) == 0 && i.sticky == r.sticky) return t;\n-                                var l = Pe(n);\n-                                if (!l) return t;\n-                                var o = Zt(l, i.ch, i.sticky),\n-                                    a = l[o];\n-                                if (a.from != i.ch && a.to != i.ch) return t;\n-                                var s = o + (a.from == i.ch == (a.level != 1) ? 0 : 1);\n-                                if (s == 0 || s == l.length) return t;\n-                                var f;\n-                                if (r.line != i.line) f = (r.line - i.line) * (e.doc.direction == \"ltr\" ? 1 : -1) > 0;\n-                                else {\n-                                    var h = Zt(l, r.ch, r.sticky),\n-                                        c = h - o || (r.ch - i.ch) * (a.level == 1 ? -1 : 1);\n-                                    h == s - 1 || h == s ? f = c < 0 : f = c > 0;\n-                                }\n-                                var p = l[s + (f ? -1 : 0)],\n-                                    d = f == (p.level == 1),\n-                                    v = d ? p.from : p.to,\n-                                    g = d ? \"after\" : \"before\";\n-                                return i.ch == v && i.sticky == g ? t : new W(new y(i.line, v, g), r);\n-                            }\n-                            u(Qs, \"bidiSimplify\");\n+                    // Main decoding loop: start just after the last delimiter if any basic code\n+                    // points were copied; start at the beginning otherwise.\n \n-                            function Wo(e, t, i, r) {\n-                                var n, l;\n-                                if (t.touches) n = t.touches[0].clientX, l = t.touches[0].clientY;\n-                                else try {\n-                                    n = t.clientX, l = t.clientY;\n-                                } catch {\n-                                    return !1;\n-                                }\n-                                if (n >= Math.floor(e.display.gutters.getBoundingClientRect().right)) return !1;\n-                                r && ae(t);\n-                                var o = e.display,\n-                                    a = o.lineDiv.getBoundingClientRect();\n-                                if (l > a.bottom || !Ce(e, i)) return Ci(t);\n-                                l -= a.top - o.viewOffset;\n-                                for (var s = 0; s < e.display.gutterSpecs.length; ++s) {\n-                                    var f = o.gutters.childNodes[s];\n-                                    if (f && f.getBoundingClientRect().right >= n) {\n-                                        var h = at(e.doc, l),\n-                                            c = e.display.gutterSpecs[s];\n-                                        return U(e, i, e, h, c.className, t), Ci(t);\n-                                    }\n-                                }\n+                    for /* no final expression */ (let index = basic > 0 ? basic + 1 : 0; index < inputLength;) {\n+                        // `index` is the index of the next character to be consumed.\n+                        // Decode a generalized variable-length integer into `delta`,\n+                        // which gets added to `i`. The overflow checking is easier\n+                        // if we increase `i` as we go, then subtract off its starting\n+                        // value at the end to obtain `delta`.\n+                        const oldi = i;\n+                        for /* no condition */ (let w = 1, k = base;; k += base) {\n+                            if (index >= inputLength) {\n+                                error('invalid-input');\n                             }\n-                            u(Wo, \"gutterEvent\");\n-\n-                            function Cn(e, t) {\n-                                return Wo(e, t, \"gutterClick\", !0);\n+                            const digit = basicToDigit(input.charCodeAt(index++));\n+                            if (digit >= base) {\n+                                error('invalid-input');\n                             }\n-                            u(Cn, \"clickInGutter\");\n-\n-                            function Ho(e, t) {\n-                                Re(e.display, t) || Js(e, t) || q(e, t, \"contextmenu\") || ci || e.display.input.onContextMenu(t);\n+                            if (digit > floor((maxInt - i) / w)) {\n+                                error('overflow');\n                             }\n-                            u(Ho, \"onContextMenu\");\n-\n-                            function Js(e, t) {\n-                                return Ce(e, \"gutterContextMenu\") ? Wo(e, t, \"gutterContextMenu\", !1) : !1;\n+                            i += digit * w;\n+                            const t = k <= bias ? tMin : k >= bias + tMax ? tMax : k - bias;\n+                            if (digit < t) {\n+                                break;\n                             }\n-                            u(Js, \"contextMenuInGutter\");\n-\n-                            function Fo(e) {\n-                                e.display.wrapper.className = e.display.wrapper.className.replace(/\\s*cm-s-\\S+/g, \"\") + e.options.theme.replace(/(^|\\s)\\s*/g, \" cm-s-\"), rr(e);\n+                            const baseMinusT = base - t;\n+                            if (w > floor(maxInt / baseMinusT)) {\n+                                error('overflow');\n                             }\n-                            u(Fo, \"themeChanged\");\n-                            var Rt = {\n-                                    toString: function() {\n-                                        return \"CodeMirror.Init\";\n-                                    }\n-                                },\n-                                Po = {},\n-                                si = {};\n+                            w *= baseMinusT;\n+                        }\n+                        const out = output.length + 1;\n+                        bias = adapt(i - oldi, out, oldi == 0);\n \n-                            function js(e) {\n-                                var t = e.optionHandlers;\n+                        // `i` was supposed to wrap around from `out` to `0`,\n+                        // incrementing `n` each time, so we'll fix that now:\n+                        if (floor(i / out) > maxInt - n) {\n+                            error('overflow');\n+                        }\n+                        n += floor(i / out);\n+                        i %= out;\n \n-                                function i(r, n, l, o) {\n-                                    e.defaults[r] = n, l && (t[r] = o ? function(a, s, f) {\n-                                        f != Rt && l(a, s, f);\n-                                    } : l);\n-                                }\n-                                u(i, \"option\"), e.defineOption = i, e.Init = Rt, i(\"value\", \"\", function(r, n) {\n-                                    return r.setValue(n);\n-                                }, !0), i(\"mode\", null, function(r, n) {\n-                                    r.doc.modeOption = n, hn(r);\n-                                }, !0), i(\"indentUnit\", 2, hn, !0), i(\"indentWithTabs\", !1), i(\"smartIndent\", !0), i(\"tabSize\", 4, function(r) {\n-                                    fr(r), rr(r), se(r);\n-                                }, !0), i(\"lineSeparator\", null, function(r, n) {\n-                                    if (r.doc.lineSep = n, !!n) {\n-                                        var l = [],\n-                                            o = r.doc.first;\n-                                        r.doc.iter(function(s) {\n-                                            for (var f = 0;;) {\n-                                                var h = s.text.indexOf(n, f);\n-                                                if (h == -1) break;\n-                                                f = h + n.length, l.push(y(o, h));\n-                                            }\n-                                            o++;\n-                                        });\n-                                        for (var a = l.length - 1; a >= 0; a--) Ft(r.doc, n, l[a], y(l[a].line, l[a].ch + n.length));\n-                                    }\n-                                }), i(\"specialChars\", /[\\u0000-\\u001f\\u007f-\\u009f\\u00ad\\u061c\\u200b\\u200e\\u200f\\u2028\\u2029\\ufeff\\ufff9-\\ufffc]/g, function(r, n, l) {\n-                                    r.state.specialChars = new RegExp(n.source + (n.test(\"\t\") ? \"\" : \"|\t\"), \"g\"), l != Rt && r.refresh();\n-                                }), i(\"specialCharPlaceholder\", Ta, function(r) {\n-                                    return r.refresh();\n-                                }, !0), i(\"electricChars\", !0), i(\"inputStyle\", Kt ? \"contenteditable\" : \"textarea\", function() {\n-                                    throw new Error(\"inputStyle can not (yet) be changed in a running editor\");\n-                                }, !0), i(\"spellcheck\", !1, function(r, n) {\n-                                    return r.getInputField().spellcheck = n;\n-                                }, !0), i(\"autocorrect\", !1, function(r, n) {\n-                                    return r.getInputField().autocorrect = n;\n-                                }, !0), i(\"autocapitalize\", !1, function(r, n) {\n-                                    return r.getInputField().autocapitalize = n;\n-                                }, !0), i(\"rtlMoveVisually\", !Zo), i(\"wholeLineUpdateBefore\", !0), i(\"theme\", \"default\", function(r) {\n-                                    Fo(r), ur(r);\n-                                }, !0), i(\"keyMap\", \"default\", function(r, n, l) {\n-                                    var o = oi(n),\n-                                        a = l != Rt && oi(l);\n-                                    a && a.detach && a.detach(r, o), o.attach && o.attach(r, a || null);\n-                                }), i(\"extraKeys\", null), i(\"configureMouse\", null), i(\"lineWrapping\", !1, $s, !0), i(\"gutters\", [], function(r, n) {\n-                                    r.display.gutterSpecs = un(n, r.options.lineNumbers), ur(r);\n-                                }, !0), i(\"fixedGutter\", !0, function(r, n) {\n-                                    r.display.gutters.style.left = n ? Ji(r.display) + \"px\" : \"0\", r.refresh();\n-                                }, !0), i(\"coverGutterNextToScrollbar\", !1, function(r) {\n-                                    return At(r);\n-                                }, !0), i(\"scrollbarStyle\", \"native\", function(r) {\n-                                    El(r), At(r), r.display.scrollbars.setScrollTop(r.doc.scrollTop), r.display.scrollbars.setScrollLeft(r.doc.scrollLeft);\n-                                }, !0), i(\"lineNumbers\", !1, function(r, n) {\n-                                    r.display.gutterSpecs = un(r.options.gutters, n), ur(r);\n-                                }, !0), i(\"firstLineNumber\", 1, ur, !0), i(\"lineNumberFormatter\", function(r) {\n-                                    return r;\n-                                }, ur, !0), i(\"showCursorWhenSelecting\", !1, ir, !0), i(\"resetSelectionOnContextMenu\", !0), i(\"lineWiseCopyCut\", !0), i(\"pasteLinesPerSelection\", !0), i(\"selectionsMayTouch\", !1), i(\"readOnly\", !1, function(r, n) {\n-                                    n == \"nocursor\" && (Dt(r), r.display.input.blur()), r.display.input.readOnlyChanged(n);\n-                                }), i(\"screenReaderLabel\", null, function(r, n) {\n-                                    n = n === \"\" ? null : n, r.display.input.screenReaderLabelChanged(n);\n-                                }), i(\"disableInput\", !1, function(r, n) {\n-                                    n || r.display.input.reset();\n-                                }, !0), i(\"dragDrop\", !0, Vs), i(\"allowDropFileTypes\", null), i(\"cursorBlinkRate\", 530), i(\"cursorScrollMargin\", 0), i(\"cursorHeight\", 1, ir, !0), i(\"singleCursorHeightPerLine\", !0, ir, !0), i(\"workTime\", 100), i(\"workDelay\", 100), i(\"flattenSpans\", !0, fr, !0), i(\"addModeClass\", !1, fr, !0), i(\"pollInterval\", 100), i(\"undoDepth\", 200, function(r, n) {\n-                                    return r.doc.history.undoDepth = n;\n-                                }), i(\"historyEventDelay\", 1250), i(\"viewportMargin\", 10, function(r) {\n-                                    return r.refresh();\n-                                }, !0), i(\"maxHighlightLength\", 1e4, fr, !0), i(\"moveInputWithCursor\", !0, function(r, n) {\n-                                    n || r.display.input.resetPosition();\n-                                }), i(\"tabindex\", null, function(r, n) {\n-                                    return r.display.input.getField().tabIndex = n || \"\";\n-                                }), i(\"autofocus\", null), i(\"direction\", \"ltr\", function(r, n) {\n-                                    return r.doc.setDirection(n);\n-                                }, !0), i(\"phrases\", null);\n-                            }\n-                            u(js, \"defineOptions\");\n-\n-                            function Vs(e, t, i) {\n-                                var r = i && i != Rt;\n-                                if (!t != !r) {\n-                                    var n = e.display.dragFunctions,\n-                                        l = t ? M : ge;\n-                                    l(e.display.scroller, \"dragstart\", n.start), l(e.display.scroller, \"dragenter\", n.enter), l(e.display.scroller, \"dragover\", n.over), l(e.display.scroller, \"dragleave\", n.leave), l(e.display.scroller, \"drop\", n.drop);\n-                                }\n-                            }\n-                            u(Vs, \"dragDropChanged\");\n-\n-                            function $s(e) {\n-                                e.options.lineWrapping ? (it(e.display.wrapper, \"CodeMirror-wrap\"), e.display.sizer.style.minWidth = \"\", e.display.sizerWidth = null) : (tt(e.display.wrapper, \"CodeMirror-wrap\"), zi(e)), ji(e), se(e), rr(e), setTimeout(function() {\n-                                    return At(e);\n-                                }, 100);\n-                            }\n-                            u($s, \"wrappingChanged\");\n+                        // Insert `n` at position `i` of the output.\n+                        output.splice(i++, 0, n);\n+                    }\n+                    return String.fromCodePoint(...output);\n+                };\n \n-                            function R(e, t) {\n-                                var i = this;\n-                                if (!(this instanceof R)) return new R(e, t);\n-                                this.options = t = t ? nt(t) : {}, nt(Po, t, !1);\n-                                var r = t.value;\n-                                typeof r == \"string\" ? r = new ue(r, t.mode, null, t.lineSeparator, t.direction) : t.mode && (r.modeOption = t.mode), this.doc = r;\n-                                var n = new R.inputStyles[t.inputStyle](this),\n-                                    l = this.display = new cs(e, r, n, t);\n-                                l.wrapper.CodeMirror = this, Fo(this), t.lineWrapping && (this.display.wrapper.className += \" CodeMirror-wrap\"), El(this), this.state = {\n-                                    keyMaps: [],\n-                                    overlays: [],\n-                                    modeGen: 0,\n-                                    overwrite: !1,\n-                                    delayingBlurEvent: !1,\n-                                    focused: !1,\n-                                    suppressEdits: !1,\n-                                    pasteIncoming: -1,\n-                                    cutIncoming: -1,\n-                                    selectingText: !1,\n-                                    draggingText: !1,\n-                                    highlight: new _e(),\n-                                    keySeq: null,\n-                                    specialChars: null\n-                                }, t.autofocus && !Kt && l.input.focus(), O && I < 11 && setTimeout(function() {\n-                                    return i.display.input.reset(!0);\n-                                }, 20), eu(this), Os(), pt(this), this.curOp.forceUpdate = !0, Yl(this, r), t.autofocus && !Kt || this.hasFocus() ? setTimeout(function() {\n-                                    i.hasFocus() && !i.state.focused && tn(i);\n-                                }, 20) : Dt(this);\n-                                for (var o in si) si.hasOwnProperty(o) && si[o](this, t[o], Rt);\n-                                Bl(this), t.finishInit && t.finishInit(this);\n-                                for (var a = 0; a < wn.length; ++a) wn[a](this);\n-                                vt(this), ne && t.lineWrapping && getComputedStyle(l.lineDiv).textRendering == \"optimizelegibility\" && (l.lineDiv.style.textRendering = \"auto\");\n-                            }\n-                            u(R, \"CodeMirror\"), R.defaults = Po, R.optionHandlers = si;\n-\n-                            function eu(e) {\n-                                var t = e.display;\n-                                M(t.scroller, \"mousedown\", Q(e, Ao)), O && I < 11 ? M(t.scroller, \"dblclick\", Q(e, function(s) {\n-                                    if (!q(e, s)) {\n-                                        var f = ft(e, s);\n-                                        if (!(!f || Cn(e, s) || Re(e.display, s))) {\n-                                            ae(s);\n-                                            var h = e.findWordAt(f);\n-                                            ti(e.doc, h.anchor, h.head);\n-                                        }\n-                                    }\n-                                })) : M(t.scroller, \"dblclick\", function(s) {\n-                                    return q(e, s) || ae(s);\n-                                }), M(t.scroller, \"contextmenu\", function(s) {\n-                                    return Ho(e, s);\n-                                }), M(t.input.getField(), \"contextmenu\", function(s) {\n-                                    t.scroller.contains(s.target) || Ho(e, s);\n-                                });\n-                                var i,\n-                                    r = {\n-                                        end: 0\n-                                    };\n+                /**\n+                 * Converts a string of Unicode symbols (e.g. a domain name label) to a\n+                 * Punycode string of ASCII-only symbols.\n+                 * @memberOf punycode\n+                 * @param {String} input The string of Unicode symbols.\n+                 * @returns {String} The resulting Punycode string of ASCII-only symbols.\n+                 */\n+                exports.decode = decode;\n+                const encode = function(input) {\n+                    const output = [];\n \n-                                function n() {\n-                                    t.activeTouch && (i = setTimeout(function() {\n-                                        return t.activeTouch = null;\n-                                    }, 1e3), r = t.activeTouch, r.end = +new Date());\n-                                }\n-                                u(n, \"finishTouch\");\n-\n-                                function l(s) {\n-                                    if (s.touches.length != 1) return !1;\n-                                    var f = s.touches[0];\n-                                    return f.radiusX <= 1 && f.radiusY <= 1;\n-                                }\n-                                u(l, \"isMouseLikeTouchEvent\");\n-\n-                                function o(s, f) {\n-                                    if (f.left == null) return !0;\n-                                    var h = f.left - s.left,\n-                                        c = f.top - s.top;\n-                                    return h * h + c * c > 20 * 20;\n-                                }\n-                                u(o, \"farAway\"), M(t.scroller, \"touchstart\", function(s) {\n-                                    if (!q(e, s) && !l(s) && !Cn(e, s)) {\n-                                        t.input.ensurePolled(), clearTimeout(i);\n-                                        var f = +new Date();\n-                                        t.activeTouch = {\n-                                            start: f,\n-                                            moved: !1,\n-                                            prev: f - r.end <= 300 ? r : null\n-                                        }, s.touches.length == 1 && (t.activeTouch.left = s.touches[0].pageX, t.activeTouch.top = s.touches[0].pageY);\n-                                    }\n-                                }), M(t.scroller, \"touchmove\", function() {\n-                                    t.activeTouch && (t.activeTouch.moved = !0);\n-                                }), M(t.scroller, \"touchend\", function(s) {\n-                                    var f = t.activeTouch;\n-                                    if (f && !Re(t, s) && f.left != null && !f.moved && new Date() - f.start < 300) {\n-                                        var h = e.coordsChar(t.activeTouch, \"page\"),\n-                                            c;\n-                                        !f.prev || o(f, f.prev) ? c = new W(h, h) : !f.prev.prev || o(f, f.prev.prev) ? c = e.findWordAt(h) : c = new W(y(h.line, 0), N(e.doc, y(h.line + 1, 0))), e.setSelection(c.anchor, c.head), e.focus(), ae(s);\n-                                    }\n-                                    n();\n-                                }), M(t.scroller, \"touchcancel\", n), M(t.scroller, \"scroll\", function() {\n-                                    t.scroller.clientHeight && (lr(e, t.scroller.scrollTop), ct(e, t.scroller.scrollLeft, !0), U(e, \"scroll\", e));\n-                                }), M(t.scroller, \"mousewheel\", function(s) {\n-                                    return Ul(e, s);\n-                                }), M(t.scroller, \"DOMMouseScroll\", function(s) {\n-                                    return Ul(e, s);\n-                                }), M(t.wrapper, \"scroll\", function() {\n-                                    return t.wrapper.scrollTop = t.wrapper.scrollLeft = 0;\n-                                }), t.dragFunctions = {\n-                                    enter: function(s) {\n-                                        q(e, s) || Qt(s);\n-                                    },\n-                                    over: function(s) {\n-                                        q(e, s) || (As(e, s), Qt(s));\n-                                    },\n-                                    start: function(s) {\n-                                        return Ns(e, s);\n-                                    },\n-                                    drop: Q(e, Ds),\n-                                    leave: function(s) {\n-                                        q(e, s) || yo(e);\n-                                    }\n-                                };\n-                                var a = t.input.getField();\n-                                M(a, \"keyup\", function(s) {\n-                                    return Do.call(e, s);\n-                                }), M(a, \"keydown\", Q(e, Mo)), M(a, \"keypress\", Q(e, No)), M(a, \"focus\", function(s) {\n-                                    return tn(e, s);\n-                                }), M(a, \"blur\", function(s) {\n-                                    return Dt(e, s);\n-                                });\n-                            }\n-                            u(eu, \"registerEventHandlers\");\n-                            var wn = [];\n-                            R.defineInitHook = function(e) {\n-                                return wn.push(e);\n-                            };\n-\n-                            function Sr(e, t, i, r) {\n-                                var n = e.doc,\n-                                    l;\n-                                i == null && (i = \"add\"), i == \"smart\" && (n.mode.indent ? l = jt(e, t).state : i = \"prev\");\n-                                var o = e.options.tabSize,\n-                                    a = S(n, t),\n-                                    s = xe(a.text, null, o);\n-                                a.stateAfter && (a.stateAfter = null);\n-                                var f = a.text.match(/^\\s*/)[0],\n-                                    h;\n-                                if (!r && !/\\S/.test(a.text)) h = 0, i = \"not\";\n-                                else if (i == \"smart\" && (h = n.mode.indent(l, a.text.slice(f.length), a.text), h == Nr || h > 150)) {\n-                                    if (!r) return;\n-                                    i = \"prev\";\n-                                }\n-                                i == \"prev\" ? t > n.first ? h = xe(S(n, t - 1).text, null, o) : h = 0 : i == \"add\" ? h = s + e.options.indentUnit : i == \"subtract\" ? h = s - e.options.indentUnit : typeof i == \"number\" && (h = s + i), h = Math.max(0, h);\n-                                var c = \"\",\n-                                    p = 0;\n-                                if (e.options.indentWithTabs)\n-                                    for (var d = Math.floor(h / o); d; --d) p += o, c += \"\t\";\n-                                if (p < h && (c += yi(h - p)), c != f) return Ft(n, c, y(t, 0), y(t, f.length), \"+input\"), a.stateAfter = null, !0;\n-                                for (var v = 0; v < n.sel.ranges.length; v++) {\n-                                    var g = n.sel.ranges[v];\n-                                    if (g.head.line == t && g.head.ch < f.length) {\n-                                        var m = y(t, f.length);\n-                                        vn(n, v, new W(m, m));\n-                                        break;\n-                                    }\n-                                }\n-                            }\n-                            u(Sr, \"indentLine\");\n-                            var Te = null;\n+                    // Convert the input in UCS-2 to an array of Unicode code points.\n+                    input = ucs2decode(input);\n \n-                            function ui(e) {\n-                                Te = e;\n-                            }\n-                            u(ui, \"setLastCopied\");\n+                    // Cache the length.\n+                    const inputLength = input.length;\n \n-                            function Sn(e, t, i, r, n) {\n-                                var l = e.doc;\n-                                e.display.shift = !1, r || (r = l.sel);\n-                                var o = +new Date() - 200,\n-                                    a = n == \"paste\" || e.state.pasteIncoming > o,\n-                                    s = ki(t),\n-                                    f = null;\n-                                if (a && r.ranges.length > 1)\n-                                    if (Te && Te.text.join(`\n-`) == t) {\n-                                        if (r.ranges.length % Te.text.length == 0) {\n-                                            f = [];\n-                                            for (var h = 0; h < Te.text.length; h++) f.push(l.splitLines(Te.text[h]));\n-                                        }\n-                                    } else s.length == r.ranges.length && e.options.pasteLinesPerSelection && (f = Or(s, function(b) {\n-                                        return [b];\n-                                    }));\n-                                for (var c = e.curOp.updateInput, p = r.ranges.length - 1; p >= 0; p--) {\n-                                    var d = r.ranges[p],\n-                                        v = d.from(),\n-                                        g = d.to();\n-                                    d.empty() && (i && i > 0 ? v = y(v.line, v.ch - i) : e.state.overwrite && !a ? g = y(g.line, Math.min(S(l, g.line).text.length, g.ch + H(s).length)) : a && Te && Te.lineWise && Te.text.join(`\n-`) == s.join(`\n-`) && (v = g = y(v.line, 0)));\n-                                    var m = {\n-                                        from: v,\n-                                        to: g,\n-                                        text: f ? f[p % f.length] : s,\n-                                        origin: n || (a ? \"paste\" : e.state.cutIncoming > o ? \"cut\" : \"+input\")\n-                                    };\n-                                    Ht(e.doc, m), Z(e, \"inputRead\", e, m);\n-                                }\n-                                t && !a && Io(e, t), Nt(e), e.curOp.updateInput < 2 && (e.curOp.updateInput = c), e.curOp.typing = !0, e.state.pasteIncoming = e.state.cutIncoming = -1;\n-                            }\n-                            u(Sn, \"applyTextInput\");\n+                    // Initialize the state.\n+                    let n = initialN;\n+                    let delta = 0;\n+                    let bias = initialBias;\n \n-                            function Eo(e, t) {\n-                                var i = e.clipboardData && e.clipboardData.getData(\"Text\");\n-                                if (i) return e.preventDefault(), !t.isReadOnly() && !t.options.disableInput && de(t, function() {\n-                                    return Sn(t, i, 0, null, \"paste\");\n-                                }), !0;\n-                            }\n-                            u(Eo, \"handlePaste\");\n-\n-                            function Io(e, t) {\n-                                if (!(!e.options.electricChars || !e.options.smartIndent))\n-                                    for (var i = e.doc.sel, r = i.ranges.length - 1; r >= 0; r--) {\n-                                        var n = i.ranges[r];\n-                                        if (!(n.head.ch > 100 || r && i.ranges[r - 1].head.line == n.head.line)) {\n-                                            var l = e.getModeAt(n.head),\n-                                                o = !1;\n-                                            if (l.electricChars) {\n-                                                for (var a = 0; a < l.electricChars.length; a++)\n-                                                    if (t.indexOf(l.electricChars.charAt(a)) > -1) {\n-                                                        o = Sr(e, n.head.line, \"smart\");\n-                                                        break;\n-                                                    }\n-                                            } else l.electricInput && l.electricInput.test(S(e.doc, n.head.line).text.slice(0, n.head.ch)) && (o = Sr(e, n.head.line, \"smart\"));\n-                                            o && Z(e, \"electricInput\", e, n.head.line);\n-                                        }\n-                                    }\n-                            }\n-                            u(Io, \"triggerElectric\");\n+                    // Handle the basic code points.\n+                    for (const currentValue of input) {\n+                        if (currentValue < 0x80) {\n+                            output.push(stringFromCharCode(currentValue));\n+                        }\n+                    }\n+                    const basicLength = output.length;\n+                    let handledCPCount = basicLength;\n \n-                            function Ro(e) {\n-                                for (var t = [], i = [], r = 0; r < e.doc.sel.ranges.length; r++) {\n-                                    var n = e.doc.sel.ranges[r].head.line,\n-                                        l = {\n-                                            anchor: y(n, 0),\n-                                            head: y(n + 1, 0)\n-                                        };\n-                                    i.push(l), t.push(e.getRange(l.anchor, l.head));\n-                                }\n-                                return {\n-                                    text: t,\n-                                    ranges: i\n-                                };\n-                            }\n-                            u(Ro, \"copyableRanges\");\n+                    // `handledCPCount` is the number of code points that have been handled;\n+                    // `basicLength` is the number of basic code points.\n \n-                            function Bo(e, t, i, r) {\n-                                e.setAttribute(\"autocorrect\", i ? \"\" : \"off\"), e.setAttribute(\"autocapitalize\", r ? \"\" : \"off\"), e.setAttribute(\"spellcheck\", !!t);\n-                            }\n-                            u(Bo, \"disableBrowserMagic\");\n+                    // Finish the basic string with a delimiter unless it's empty.\n+                    if (basicLength) {\n+                        output.push(delimiter);\n+                    }\n \n-                            function zo() {\n-                                var e = T(\"textarea\", null, null, \"position: absolute; bottom: -1em; padding: 0; width: 1px; height: 1em; min-height: 1em; outline: none\"),\n-                                    t = T(\"div\", [e], null, \"overflow: hidden; position: relative; width: 3px; height: 0px;\");\n-                                return ne ? e.style.width = \"1000px\" : e.setAttribute(\"wrap\", \"off\"), Ut && (e.style.border = \"1px solid black\"), Bo(e), t;\n-                            }\n-                            u(zo, \"hiddenTextarea\");\n-\n-                            function tu(e) {\n-                                var t = e.optionHandlers,\n-                                    i = e.helpers = {};\n-                                e.prototype = {\n-                                    constructor: e,\n-                                    focus: function() {\n-                                        window.focus(), this.display.input.focus();\n-                                    },\n-                                    setOption: function(r, n) {\n-                                        var l = this.options,\n-                                            o = l[r];\n-                                        l[r] == n && r != \"mode\" || (l[r] = n, t.hasOwnProperty(r) && Q(this, t[r])(this, n, o), U(this, \"optionChange\", this, r));\n-                                    },\n-                                    getOption: function(r) {\n-                                        return this.options[r];\n-                                    },\n-                                    getDoc: function() {\n-                                        return this.doc;\n-                                    },\n-                                    addKeyMap: function(r, n) {\n-                                        this.state.keyMaps[n ? \"push\" : \"unshift\"](oi(r));\n-                                    },\n-                                    removeKeyMap: function(r) {\n-                                        for (var n = this.state.keyMaps, l = 0; l < n.length; ++l)\n-                                            if (n[l] == r || n[l].name == r) return n.splice(l, 1), !0;\n-                                    },\n-                                    addOverlay: le(function(r, n) {\n-                                        var l = r.token ? r : e.getMode(this.options, r);\n-                                        if (l.startState) throw new Error(\"Overlays may not be stateful.\");\n-                                        Qo(this.state.overlays, {\n-                                            mode: l,\n-                                            modeSpec: r,\n-                                            opaque: n && n.opaque,\n-                                            priority: n && n.priority || 0\n-                                        }, function(o) {\n-                                            return o.priority;\n-                                        }), this.state.modeGen++, se(this);\n-                                    }),\n-                                    removeOverlay: le(function(r) {\n-                                        for (var n = this.state.overlays, l = 0; l < n.length; ++l) {\n-                                            var o = n[l].modeSpec;\n-                                            if (o == r || typeof r == \"string\" && o.name == r) {\n-                                                n.splice(l, 1), this.state.modeGen++, se(this);\n-                                                return;\n-                                            }\n-                                        }\n-                                    }),\n-                                    indentLine: le(function(r, n, l) {\n-                                        typeof n != \"string\" && typeof n != \"number\" && (n == null ? n = this.options.smartIndent ? \"smart\" : \"prev\" : n = n ? \"add\" : \"subtract\"), Jt(this.doc, r) && Sr(this, r, n, l);\n-                                    }),\n-                                    indentSelection: le(function(r) {\n-                                        for (var n = this.doc.sel.ranges, l = -1, o = 0; o < n.length; o++) {\n-                                            var a = n[o];\n-                                            if (a.empty()) a.head.line > l && (Sr(this, a.head.line, r, !0), l = a.head.line, o == this.doc.sel.primIndex && Nt(this));\n-                                            else {\n-                                                var s = a.from(),\n-                                                    f = a.to(),\n-                                                    h = Math.max(l, s.line);\n-                                                l = Math.min(this.lastLine(), f.line - (f.ch ? 0 : 1)) + 1;\n-                                                for (var c = h; c < l; ++c) Sr(this, c, r);\n-                                                var p = this.doc.sel.ranges;\n-                                                s.ch == 0 && n.length == p.length && p[o].from().ch > 0 && vn(this.doc, o, new W(s, p[o].to()), Me);\n-                                            }\n-                                        }\n-                                    }),\n-                                    getTokenAt: function(r, n) {\n-                                        return Zn(this, r, n);\n-                                    },\n-                                    getLineTokens: function(r, n) {\n-                                        return Zn(this, y(r), n, !0);\n-                                    },\n-                                    getTokenTypeAt: function(r) {\n-                                        r = N(this.doc, r);\n-                                        var n = Xn(this, S(this.doc, r.line)),\n-                                            l = 0,\n-                                            o = (n.length - 1) / 2,\n-                                            a = r.ch,\n-                                            s;\n-                                        if (a == 0) s = n[2];\n-                                        else\n-                                            for (;;) {\n-                                                var f = l + o >> 1;\n-                                                if ((f ? n[f * 2 - 1] : 0) >= a) o = f;\n-                                                else if (n[f * 2 + 1] < a) l = f + 1;\n-                                                else {\n-                                                    s = n[f * 2 + 2];\n-                                                    break;\n-                                                }\n-                                            }\n-                                        var h = s ? s.indexOf(\"overlay \") : -1;\n-                                        return h < 0 ? s : h == 0 ? null : s.slice(0, h - 1);\n-                                    },\n-                                    getModeAt: function(r) {\n-                                        var n = this.doc.mode;\n-                                        return n.innerMode ? e.innerMode(n, this.getTokenAt(r).state).mode : n;\n-                                    },\n-                                    getHelper: function(r, n) {\n-                                        return this.getHelpers(r, n)[0];\n-                                    },\n-                                    getHelpers: function(r, n) {\n-                                        var l = [];\n-                                        if (!i.hasOwnProperty(n)) return l;\n-                                        var o = i[n],\n-                                            a = this.getModeAt(r);\n-                                        if (typeof a[n] == \"string\") o[a[n]] && l.push(o[a[n]]);\n-                                        else if (a[n])\n-                                            for (var s = 0; s < a[n].length; s++) {\n-                                                var f = o[a[n][s]];\n-                                                f && l.push(f);\n-                                            } else a.helperType && o[a.helperType] ? l.push(o[a.helperType]) : o[a.name] && l.push(o[a.name]);\n-                                        for (var h = 0; h < o._global.length; h++) {\n-                                            var c = o._global[h];\n-                                            c.pred(a, this) && ee(l, c.val) == -1 && l.push(c.val);\n-                                        }\n-                                        return l;\n-                                    },\n-                                    getStateAfter: function(r, n) {\n-                                        var _r3;\n-                                        var l = this.doc;\n-                                        return r = Un(l, (_r3 = r) !== null && _r3 !== void 0 ? _r3 : l.first + l.size - 1), jt(this, r + 1, n).state;\n-                                    },\n-                                    cursorCoords: function(r, n) {\n-                                        var l,\n-                                            o = this.doc.sel.primary();\n-                                        return r == null ? l = o.head : typeof r == \"object\" ? l = N(this.doc, r) : l = r ? o.from() : o.to(), Le(this, l, n || \"page\");\n-                                    },\n-                                    charCoords: function(r, n) {\n-                                        return Xr(this, N(this.doc, r), n || \"page\");\n-                                    },\n-                                    coordsChar: function(r, n) {\n-                                        return r = Sl(this, r, n || \"page\"), qi(this, r.left, r.top);\n-                                    },\n-                                    lineAtHeight: function(r, n) {\n-                                        return r = Sl(this, {\n-                                            top: r,\n-                                            left: 0\n-                                        }, n || \"page\").top, at(this.doc, r + this.display.viewOffset);\n-                                    },\n-                                    heightAtLine: function(r, n, l) {\n-                                        var o = !1,\n-                                            a;\n-                                        if (typeof r == \"number\") {\n-                                            var s = this.doc.first + this.doc.size - 1;\n-                                            r < this.doc.first ? r = this.doc.first : r > s && (r = s, o = !0), a = S(this.doc, r);\n-                                        } else a = r;\n-                                        return _r(this, a, {\n-                                            top: 0,\n-                                            left: 0\n-                                        }, n || \"page\", l || o).top + (o ? this.doc.height - Ie(a) : 0);\n-                                    },\n-                                    defaultTextHeight: function() {\n-                                        return Tt(this.display);\n-                                    },\n-                                    defaultCharWidth: function() {\n-                                        return Mt(this.display);\n-                                    },\n-                                    getViewport: function() {\n-                                        return {\n-                                            from: this.display.viewFrom,\n-                                            to: this.display.viewTo\n-                                        };\n-                                    },\n-                                    addWidget: function(r, n, l, o, a) {\n-                                        var s = this.display;\n-                                        r = Le(this, N(this.doc, r));\n-                                        var f = r.bottom,\n-                                            h = r.left;\n-                                        if (n.style.position = \"absolute\", n.setAttribute(\"cm-ignore-events\", \"true\"), this.display.input.setUneditable(n), s.sizer.appendChild(n), o == \"over\") f = r.top;\n-                                        else if (o == \"above\" || o == \"near\") {\n-                                            var c = Math.max(s.wrapper.clientHeight, this.doc.height),\n-                                                p = Math.max(s.sizer.clientWidth, s.lineSpace.clientWidth);\n-                                            (o == \"above\" || r.bottom + n.offsetHeight > c) && r.top > n.offsetHeight ? f = r.top - n.offsetHeight : r.bottom + n.offsetHeight <= c && (f = r.bottom), h + n.offsetWidth > p && (h = p - n.offsetWidth);\n-                                        }\n-                                        n.style.top = f + \"px\", n.style.left = n.style.right = \"\", a == \"right\" ? (h = s.sizer.clientWidth - n.offsetWidth, n.style.right = \"0px\") : (a == \"left\" ? h = 0 : a == \"middle\" && (h = (s.sizer.clientWidth - n.offsetWidth) / 2), n.style.left = h + \"px\"), l && Va(this, {\n-                                            left: h,\n-                                            top: f,\n-                                            right: h + n.offsetWidth,\n-                                            bottom: f + n.offsetHeight\n-                                        });\n-                                    },\n-                                    triggerOnKeyDown: le(Mo),\n-                                    triggerOnKeyPress: le(No),\n-                                    triggerOnKeyUp: Do,\n-                                    triggerOnMouseDown: le(Ao),\n-                                    execCommand: function(r) {\n-                                        if (br.hasOwnProperty(r)) return br[r].call(null, this);\n-                                    },\n-                                    triggerElectric: le(function(r) {\n-                                        Io(this, r);\n-                                    }),\n-                                    findPosH: function(r, n, l, o) {\n-                                        var a = 1;\n-                                        n < 0 && (a = -1, n = -n);\n-                                        for (var s = N(this.doc, r), f = 0; f < n && (s = Ln(this.doc, s, a, l, o), !s.hitSide); ++f);\n-                                        return s;\n-                                    },\n-                                    moveH: le(function(r, n) {\n-                                        var l = this;\n-                                        this.extendSelectionsBy(function(o) {\n-                                            return l.display.shift || l.doc.extend || o.empty() ? Ln(l.doc, o.head, r, n, l.options.rtlMoveVisually) : r < 0 ? o.from() : o.to();\n-                                        }, Xt);\n-                                    }),\n-                                    deleteH: le(function(r, n) {\n-                                        var l = this.doc.sel,\n-                                            o = this.doc;\n-                                        l.somethingSelected() ? o.replaceSelection(\"\", null, \"+delete\") : It(this, function(a) {\n-                                            var s = Ln(o, a.head, r, n, !1);\n-                                            return r < 0 ? {\n-                                                from: s,\n-                                                to: a.head\n-                                            } : {\n-                                                from: a.head,\n-                                                to: s\n-                                            };\n-                                        });\n-                                    }),\n-                                    findPosV: function(r, n, l, o) {\n-                                        var a = 1,\n-                                            s = o;\n-                                        n < 0 && (a = -1, n = -n);\n-                                        for (var f = N(this.doc, r), h = 0; h < n; ++h) {\n-                                            var c = Le(this, f, \"div\");\n-                                            if (s == null ? s = c.left : c.left = s, f = Go(this, c, a, l), f.hitSide) break;\n-                                        }\n-                                        return f;\n-                                    },\n-                                    moveV: le(function(r, n) {\n-                                        var l = this,\n-                                            o = this.doc,\n-                                            a = [],\n-                                            s = !this.display.shift && !o.extend && o.sel.somethingSelected();\n-                                        if (o.extendSelectionsBy(function(h) {\n-                                                if (s) return r < 0 ? h.from() : h.to();\n-                                                var c = Le(l, h.head, \"div\");\n-                                                h.goalColumn != null && (c.left = h.goalColumn), a.push(c.left);\n-                                                var p = Go(l, c, r, n);\n-                                                return n == \"page\" && h == o.sel.primary() && nn(l, Xr(l, p, \"div\").top - c.top), p;\n-                                            }, Xt), a.length)\n-                                            for (var f = 0; f < o.sel.ranges.length; f++) o.sel.ranges[f].goalColumn = a[f];\n-                                    }),\n-                                    findWordAt: function(r) {\n-                                        var n = this.doc,\n-                                            l = S(n, r.line).text,\n-                                            o = r.ch,\n-                                            a = r.ch;\n-                                        if (l) {\n-                                            var s = this.getHelper(r, \"wordChars\");\n-                                            (r.sticky == \"before\" || a == l.length) && o ? --o : ++a;\n-                                            for (var f = l.charAt(o), h = Wr(f, s) ? function(c) {\n-                                                    return Wr(c, s);\n-                                                } : /\\s/.test(f) ? function(c) {\n-                                                    return /\\s/.test(c);\n-                                                } : function(c) {\n-                                                    return !/\\s/.test(c) && !Wr(c);\n-                                                }; o > 0 && h(l.charAt(o - 1));) --o;\n-                                            for (; a < l.length && h(l.charAt(a));) ++a;\n-                                        }\n-                                        return new W(y(r.line, o), y(r.line, a));\n-                                    },\n-                                    toggleOverwrite: function(r) {\n-                                        r != null && r == this.state.overwrite || ((this.state.overwrite = !this.state.overwrite) ? it(this.display.cursorDiv, \"CodeMirror-overwrite\") : tt(this.display.cursorDiv, \"CodeMirror-overwrite\"), U(this, \"overwriteToggle\", this, this.state.overwrite));\n-                                    },\n-                                    hasFocus: function() {\n-                                        return this.display.input.getField() == be();\n-                                    },\n-                                    isReadOnly: function() {\n-                                        return !!(this.options.readOnly || this.doc.cantEdit);\n-                                    },\n-                                    scrollTo: le(function(r, n) {\n-                                        nr(this, r, n);\n-                                    }),\n-                                    getScrollInfo: function() {\n-                                        var r = this.display.scroller;\n-                                        return {\n-                                            left: r.scrollLeft,\n-                                            top: r.scrollTop,\n-                                            height: r.scrollHeight - Ae(this) - this.display.barHeight,\n-                                            width: r.scrollWidth - Ae(this) - this.display.barWidth,\n-                                            clientHeight: Ki(this),\n-                                            clientWidth: st(this)\n-                                        };\n-                                    },\n-                                    scrollIntoView: le(function(r, n) {\n-                                        r == null ? (r = {\n-                                            from: this.doc.sel.primary().head,\n-                                            to: null\n-                                        }, n == null && (n = this.options.cursorScrollMargin)) : typeof r == \"number\" ? r = {\n-                                            from: y(r, 0),\n-                                            to: null\n-                                        } : r.from == null && (r = {\n-                                            from: r,\n-                                            to: null\n-                                        }), r.to || (r.to = r.from), r.margin = n || 0, r.from.line != null ? $a(this, r) : Wl(this, r.from, r.to, r.margin);\n-                                    }),\n-                                    setSize: le(function(r, n) {\n-                                        var l = this,\n-                                            o = u(function(s) {\n-                                                return typeof s == \"number\" || /^\\d+$/.test(String(s)) ? s + \"px\" : s;\n-                                            }, \"interpret\");\n-                                        r != null && (this.display.wrapper.style.width = o(r)), n != null && (this.display.wrapper.style.height = o(n)), this.options.lineWrapping && xl(this);\n-                                        var a = this.display.viewFrom;\n-                                        this.doc.iter(a, this.display.viewTo, function(s) {\n-                                            if (s.widgets) {\n-                                                for (var f = 0; f < s.widgets.length; f++)\n-                                                    if (s.widgets[f].noHScroll) {\n-                                                        Ye(l, a, \"widget\");\n-                                                        break;\n-                                                    }\n-                                            }\n-                                            ++a;\n-                                        }), this.curOp.forceUpdate = !0, U(this, \"refresh\", this);\n-                                    }),\n-                                    operation: function(r) {\n-                                        return de(this, r);\n-                                    },\n-                                    startOperation: function() {\n-                                        return pt(this);\n-                                    },\n-                                    endOperation: function() {\n-                                        return vt(this);\n-                                    },\n-                                    refresh: le(function() {\n-                                        var r = this.display.cachedTextHeight;\n-                                        se(this), this.curOp.forceUpdate = !0, rr(this), nr(this, this.doc.scrollLeft, this.doc.scrollTop), an(this.display), (r == null || Math.abs(r - Tt(this.display)) > .5 || this.options.lineWrapping) && ji(this), U(this, \"refresh\", this);\n-                                    }),\n-                                    swapDoc: le(function(r) {\n-                                        var n = this.doc;\n-                                        return n.cm = null, this.state.selectingText && this.state.selectingText(), Yl(this, r), rr(this), this.display.input.reset(), nr(this, r.scrollLeft, r.scrollTop), this.curOp.forceScroll = !0, Z(this, \"swapDoc\", this, n), n;\n-                                    }),\n-                                    phrase: function(r) {\n-                                        var n = this.options.phrases;\n-                                        return n && Object.prototype.hasOwnProperty.call(n, r) ? n[r] : r;\n-                                    },\n-                                    getInputField: function() {\n-                                        return this.display.input.getField();\n-                                    },\n-                                    getWrapperElement: function() {\n-                                        return this.display.wrapper;\n-                                    },\n-                                    getScrollerElement: function() {\n-                                        return this.display.scroller;\n-                                    },\n-                                    getGutterElement: function() {\n-                                        return this.display.gutters;\n-                                    }\n-                                }, xt(e), e.registerHelper = function(r, n, l) {\n-                                    i.hasOwnProperty(r) || (i[r] = e[r] = {\n-                                        _global: []\n-                                    }), i[r][n] = l;\n-                                }, e.registerGlobalHelper = function(r, n, l, o) {\n-                                    e.registerHelper(r, n, o), i[r]._global.push({\n-                                        pred: l,\n-                                        val: o\n-                                    });\n-                                };\n+                    // Main encoding loop:\n+                    while (handledCPCount < inputLength) {\n+                        // All non-basic code points < n have been handled already. Find the next\n+                        // larger one:\n+                        let m = maxInt;\n+                        for (const currentValue of input) {\n+                            if (currentValue >= n && currentValue < m) {\n+                                m = currentValue;\n                             }\n-                            u(tu, \"addEditorMethods\");\n+                        }\n \n-                            function Ln(e, t, i, r, n) {\n-                                var l = t,\n-                                    o = i,\n-                                    a = S(e, t.line),\n-                                    s = n && e.direction == \"rtl\" ? -i : i;\n-\n-                                function f() {\n-                                    var C = t.line + s;\n-                                    return C < e.first || C >= e.first + e.size ? !1 : (t = new y(C, t.ch, t.sticky), a = S(e, C));\n-                                }\n-                                u(f, \"findNextLine\");\n-\n-                                function h(C) {\n-                                    var x;\n-                                    if (r == \"codepoint\") {\n-                                        var w = a.text.charCodeAt(t.ch + (i > 0 ? 0 : -1));\n-                                        if (isNaN(w)) x = null;\n-                                        else {\n-                                            var k = i > 0 ? w >= 55296 && w < 56320 : w >= 56320 && w < 57343;\n-                                            x = new y(t.line, Math.max(0, Math.min(a.text.length, t.ch + i * (k ? 2 : 1))), -i);\n-                                        }\n-                                    } else n ? x = Es(e.cm, a, t, i) : x = yn(a, t, i);\n-                                    if (x == null) {\n-                                        if (!C && f()) t = mn(n, e.cm, a, t.line, s);\n-                                        else return !1;\n-                                    } else t = x;\n-                                    return !0;\n-                                }\n-                                if (u(h, \"moveOnce\"), r == \"char\" || r == \"codepoint\") h();\n-                                else if (r == \"column\") h(!0);\n-                                else if (r == \"word\" || r == \"group\")\n-                                    for (var c = null, p = r == \"group\", d = e.cm && e.cm.getHelper(t, \"wordChars\"), v = !0; !(i < 0 && !h(!v)); v = !1) {\n-                                        var g = a.text.charAt(t.ch) || `\n-`,\n-                                            m = Wr(g, d) ? \"w\" : p && g == `\n-` ? \"n\" : !p || /\\s/.test(g) ? null : \"p\";\n-                                        if (p && !v && !m && (m = \"s\"), c && c != m) {\n-                                            i < 0 && (i = 1, h(), t.sticky = \"after\");\n-                                            break;\n-                                        }\n-                                        if (m && (c = m), i > 0 && !h(!v)) break;\n-                                    }\n-                                var b = ii(e, t, l, o, !0);\n-                                return Wi(l, b) && (b.hitSide = !0), b;\n+                        // Increase `delta` enough to advance the decoder's <n,i> state to <m,0>,\n+                        // but guard against overflow.\n+                        const handledCPCountPlusOne = handledCPCount + 1;\n+                        if (m - n > floor((maxInt - delta) / handledCPCountPlusOne)) {\n+                            error('overflow');\n+                        }\n+                        delta += (m - n) * handledCPCountPlusOne;\n+                        n = m;\n+                        for (const currentValue of input) {\n+                            if (currentValue < n && ++delta > maxInt) {\n+                                error('overflow');\n                             }\n-                            u(Ln, \"findPosH\");\n-\n-                            function Go(e, t, i, r) {\n-                                var n = e.doc,\n-                                    l = t.left,\n-                                    o;\n-                                if (r == \"page\") {\n-                                    var a = Math.min(e.display.wrapper.clientHeight, window.innerHeight || document.documentElement.clientHeight),\n-                                        s = Math.max(a - .5 * Tt(e.display), 3);\n-                                    o = (i > 0 ? t.bottom : t.top) + i * s;\n-                                } else r == \"line\" && (o = i > 0 ? t.bottom + 3 : t.top - 3);\n-                                for (var f; f = qi(e, l, o), !!f.outside;) {\n-                                    if (i < 0 ? o <= 0 : o >= n.height) {\n-                                        f.hitSide = !0;\n+                            if (currentValue === n) {\n+                                // Represent delta as a generalized variable-length integer.\n+                                let q = delta;\n+                                for /* no condition */ (let k = base;; k += base) {\n+                                    const t = k <= bias ? tMin : k >= bias + tMax ? tMax : k - bias;\n+                                    if (q < t) {\n                                         break;\n                                     }\n-                                    o += i * 5;\n+                                    const qMinusT = q - t;\n+                                    const baseMinusT = base - t;\n+                                    output.push(stringFromCharCode(digitToBasic(t + qMinusT % baseMinusT, 0)));\n+                                    q = floor(qMinusT / baseMinusT);\n                                 }\n-                                return f;\n+                                output.push(stringFromCharCode(digitToBasic(q, 0)));\n+                                bias = adapt(delta, handledCPCountPlusOne, handledCPCount === basicLength);\n+                                delta = 0;\n+                                ++handledCPCount;\n                             }\n-                            u(Go, \"findPosV\");\n-                            var P = u(function(e) {\n-                                this.cm = e, this.lastAnchorNode = this.lastAnchorOffset = this.lastFocusNode = this.lastFocusOffset = null, this.polling = new _e(), this.composing = null, this.gracePeriod = !1, this.readDOMTimeout = null;\n-                            }, \"ContentEditableInput\");\n-                            P.prototype.init = function(e) {\n-                                var t = this,\n-                                    i = this,\n-                                    r = i.cm,\n-                                    n = i.div = e.lineDiv;\n-                                n.contentEditable = !0, Bo(n, r.options.spellcheck, r.options.autocorrect, r.options.autocapitalize);\n-\n-                                function l(a) {\n-                                    for (var s = a.target; s; s = s.parentNode) {\n-                                        if (s == n) return !0;\n-                                        if (/\\bCodeMirror-(?:line)?widget\\b/.test(s.className)) break;\n-                                    }\n-                                    return !1;\n-                                }\n-                                u(l, \"belongsToInput\"), M(n, \"paste\", function(a) {\n-                                    !l(a) || q(r, a) || Eo(a, r) || I <= 11 && setTimeout(Q(r, function() {\n-                                        return t.updateFromDOM();\n-                                    }), 20);\n-                                }), M(n, \"compositionstart\", function(a) {\n-                                    t.composing = {\n-                                        data: a.data,\n-                                        done: !1\n-                                    };\n-                                }), M(n, \"compositionupdate\", function(a) {\n-                                    t.composing || (t.composing = {\n-                                        data: a.data,\n-                                        done: !1\n-                                    });\n-                                }), M(n, \"compositionend\", function(a) {\n-                                    t.composing && (a.data != t.composing.data && t.readFromDOMSoon(), t.composing.done = !0);\n-                                }), M(n, \"touchstart\", function() {\n-                                    return i.forceCompositionEnd();\n-                                }), M(n, \"input\", function() {\n-                                    t.composing || t.readFromDOMSoon();\n-                                });\n-\n-                                function o(a) {\n-                                    if (!(!l(a) || q(r, a))) {\n-                                        if (r.somethingSelected()) ui({\n-                                            lineWise: !1,\n-                                            text: r.getSelections()\n-                                        }), a.type == \"cut\" && r.replaceSelection(\"\", null, \"cut\");\n-                                        else if (r.options.lineWiseCopyCut) {\n-                                            var s = Ro(r);\n-                                            ui({\n-                                                lineWise: !0,\n-                                                text: s.text\n-                                            }), a.type == \"cut\" && r.operation(function() {\n-                                                r.setSelections(s.ranges, 0, Me), r.replaceSelection(\"\", null, \"cut\");\n-                                            });\n-                                        } else return;\n-                                        if (a.clipboardData) {\n-                                            a.clipboardData.clearData();\n-                                            var f = Te.text.join(`\n-`);\n-                                            if (a.clipboardData.setData(\"Text\", f), a.clipboardData.getData(\"Text\") == f) {\n-                                                a.preventDefault();\n-                                                return;\n-                                            }\n-                                        }\n-                                        var h = zo(),\n-                                            c = h.firstChild;\n-                                        r.display.lineSpace.insertBefore(h, r.display.lineSpace.firstChild), c.value = Te.text.join(`\n-`);\n-                                        var p = be();\n-                                        _t(c), setTimeout(function() {\n-                                            r.display.lineSpace.removeChild(h), p.focus(), p == n && i.showPrimarySelection();\n-                                        }, 50);\n-                                    }\n-                                }\n-                                u(o, \"onCopyCut\"), M(n, \"copy\", o), M(n, \"cut\", o);\n-                            }, P.prototype.screenReaderLabelChanged = function(e) {\n-                                e ? this.div.setAttribute(\"aria-label\", e) : this.div.removeAttribute(\"aria-label\");\n-                            }, P.prototype.prepareSelection = function() {\n-                                var e = Nl(this.cm, !1);\n-                                return e.focus = be() == this.div, e;\n-                            }, P.prototype.showSelection = function(e, t) {\n-                                !e || !this.cm.display.view.length || ((e.focus || t) && this.showPrimarySelection(), this.showMultipleSelections(e));\n-                            }, P.prototype.getSelection = function() {\n-                                return this.cm.display.wrapper.ownerDocument.getSelection();\n-                            }, P.prototype.showPrimarySelection = function() {\n-                                var e = this.getSelection(),\n-                                    t = this.cm,\n-                                    i = t.doc.sel.primary(),\n-                                    r = i.from(),\n-                                    n = i.to();\n-                                if (t.display.viewTo == t.display.viewFrom || r.line >= t.display.viewTo || n.line < t.display.viewFrom) {\n-                                    e.removeAllRanges();\n-                                    return;\n-                                }\n-                                var l = fi(t, e.anchorNode, e.anchorOffset),\n-                                    o = fi(t, e.focusNode, e.focusOffset);\n-                                if (!(l && !l.bad && o && !o.bad && D(Pr(l, o), r) == 0 && D(Fr(l, o), n) == 0)) {\n-                                    var a = t.display.view,\n-                                        s = r.line >= t.display.viewFrom && Uo(t, r) || {\n-                                            node: a[0].measure.map[2],\n-                                            offset: 0\n-                                        },\n-                                        f = n.line < t.display.viewTo && Uo(t, n);\n-                                    if (!f) {\n-                                        var h = a[a.length - 1].measure,\n-                                            c = h.maps ? h.maps[h.maps.length - 1] : h.map;\n-                                        f = {\n-                                            node: c[c.length - 1],\n-                                            offset: c[c.length - 2] - c[c.length - 3]\n-                                        };\n-                                    }\n-                                    if (!s || !f) {\n-                                        e.removeAllRanges();\n-                                        return;\n-                                    }\n-                                    var p = e.rangeCount && e.getRangeAt(0),\n-                                        d;\n-                                    try {\n-                                        d = rt(s.node, s.offset, f.offset, f.node);\n-                                    } catch {}\n-                                    d && (!Fe && t.state.focused ? (e.collapse(s.node, s.offset), d.collapsed || (e.removeAllRanges(), e.addRange(d))) : (e.removeAllRanges(), e.addRange(d)), p && e.anchorNode == null ? e.addRange(p) : Fe && this.startGracePeriod()), this.rememberSelection();\n-                                }\n-                            }, P.prototype.startGracePeriod = function() {\n-                                var e = this;\n-                                clearTimeout(this.gracePeriod), this.gracePeriod = setTimeout(function() {\n-                                    e.gracePeriod = !1, e.selectionChanged() && e.cm.operation(function() {\n-                                        return e.cm.curOp.selectionChanged = !0;\n-                                    });\n-                                }, 20);\n-                            }, P.prototype.showMultipleSelections = function(e) {\n-                                ve(this.cm.display.cursorDiv, e.cursors), ve(this.cm.display.selectionDiv, e.selection);\n-                            }, P.prototype.rememberSelection = function() {\n-                                var e = this.getSelection();\n-                                this.lastAnchorNode = e.anchorNode, this.lastAnchorOffset = e.anchorOffset, this.lastFocusNode = e.focusNode, this.lastFocusOffset = e.focusOffset;\n-                            }, P.prototype.selectionInEditor = function() {\n-                                var e = this.getSelection();\n-                                if (!e.rangeCount) return !1;\n-                                var t = e.getRangeAt(0).commonAncestorContainer;\n-                                return Ke(this.div, t);\n-                            }, P.prototype.focus = function() {\n-                                this.cm.options.readOnly != \"nocursor\" && ((!this.selectionInEditor() || be() != this.div) && this.showSelection(this.prepareSelection(), !0), this.div.focus());\n-                            }, P.prototype.blur = function() {\n-                                this.div.blur();\n-                            }, P.prototype.getField = function() {\n-                                return this.div;\n-                            }, P.prototype.supportsTouch = function() {\n-                                return !0;\n-                            }, P.prototype.receivedFocus = function() {\n-                                var e = this,\n-                                    t = this;\n-                                this.selectionInEditor() ? setTimeout(function() {\n-                                    return e.pollSelection();\n-                                }, 20) : de(this.cm, function() {\n-                                    return t.cm.curOp.selectionChanged = !0;\n-                                });\n-\n-                                function i() {\n-                                    t.cm.state.focused && (t.pollSelection(), t.polling.set(t.cm.options.pollInterval, i));\n-                                }\n-                                u(i, \"poll\"), this.polling.set(this.cm.options.pollInterval, i);\n-                            }, P.prototype.selectionChanged = function() {\n-                                var e = this.getSelection();\n-                                return e.anchorNode != this.lastAnchorNode || e.anchorOffset != this.lastAnchorOffset || e.focusNode != this.lastFocusNode || e.focusOffset != this.lastFocusOffset;\n-                            }, P.prototype.pollSelection = function() {\n-                                if (!(this.readDOMTimeout != null || this.gracePeriod || !this.selectionChanged())) {\n-                                    var e = this.getSelection(),\n-                                        t = this.cm;\n-                                    if (Dr && Tr && this.cm.display.gutterSpecs.length && ru(e.anchorNode)) {\n-                                        this.cm.triggerOnKeyDown({\n-                                            type: \"keydown\",\n-                                            keyCode: 8,\n-                                            preventDefault: Math.abs\n-                                        }), this.blur(), this.focus();\n-                                        return;\n-                                    }\n-                                    if (!this.composing) {\n-                                        this.rememberSelection();\n-                                        var i = fi(t, e.anchorNode, e.anchorOffset),\n-                                            r = fi(t, e.focusNode, e.focusOffset);\n-                                        i && r && de(t, function() {\n-                                            te(t.doc, Ze(i, r), Me), (i.bad || r.bad) && (t.curOp.selectionChanged = !0);\n-                                        });\n-                                    }\n-                                }\n-                            }, P.prototype.pollContent = function() {\n-                                this.readDOMTimeout != null && (clearTimeout(this.readDOMTimeout), this.readDOMTimeout = null);\n-                                var e = this.cm,\n-                                    t = e.display,\n-                                    i = e.doc.sel.primary(),\n-                                    r = i.from(),\n-                                    n = i.to();\n-                                if (r.ch == 0 && r.line > e.firstLine() && (r = y(r.line - 1, S(e.doc, r.line - 1).length)), n.ch == S(e.doc, n.line).text.length && n.line < e.lastLine() && (n = y(n.line + 1, 0)), r.line < t.viewFrom || n.line > t.viewTo - 1) return !1;\n-                                var l, o, a;\n-                                r.line == t.viewFrom || (l = ht(e, r.line)) == 0 ? (o = F(t.view[0].line), a = t.view[0].node) : (o = F(t.view[l].line), a = t.view[l - 1].node.nextSibling);\n-                                var s = ht(e, n.line),\n-                                    f,\n-                                    h;\n-                                if (s == t.view.length - 1 ? (f = t.viewTo - 1, h = t.lineDiv.lastChild) : (f = F(t.view[s + 1].line) - 1, h = t.view[s + 1].node.previousSibling), !a) return !1;\n-                                for (var c = e.doc.splitLines(iu(e, a, h, o, f)), p = ot(e.doc, y(o, 0), y(f, S(e.doc, f).text.length)); c.length > 1 && p.length > 1;)\n-                                    if (H(c) == H(p)) c.pop(), p.pop(), f--;\n-                                    else if (c[0] == p[0]) c.shift(), p.shift(), o++;\n-                                else break;\n-                                for (var d = 0, v = 0, g = c[0], m = p[0], b = Math.min(g.length, m.length); d < b && g.charCodeAt(d) == m.charCodeAt(d);) ++d;\n-                                for (var C = H(c), x = H(p), w = Math.min(C.length - (c.length == 1 ? d : 0), x.length - (p.length == 1 ? d : 0)); v < w && C.charCodeAt(C.length - v - 1) == x.charCodeAt(x.length - v - 1);) ++v;\n-                                if (c.length == 1 && p.length == 1 && o == r.line)\n-                                    for (; d && d > r.ch && C.charCodeAt(C.length - v - 1) == x.charCodeAt(x.length - v - 1);) d--, v++;\n-                                c[c.length - 1] = C.slice(0, C.length - v).replace(/^\\u200b+/, \"\"), c[0] = c[0].slice(d).replace(/\\u200b+$/, \"\");\n-                                var k = y(o, d),\n-                                    L = y(f, p.length ? H(p).length - v : 0);\n-                                if (c.length > 1 || c[0] || D(k, L)) return Ft(e.doc, c, k, L, \"+input\"), !0;\n-                            }, P.prototype.ensurePolled = function() {\n-                                this.forceCompositionEnd();\n-                            }, P.prototype.reset = function() {\n-                                this.forceCompositionEnd();\n-                            }, P.prototype.forceCompositionEnd = function() {\n-                                this.composing && (clearTimeout(this.readDOMTimeout), this.composing = null, this.updateFromDOM(), this.div.blur(), this.div.focus());\n-                            }, P.prototype.readFromDOMSoon = function() {\n-                                var e = this;\n-                                this.readDOMTimeout == null && (this.readDOMTimeout = setTimeout(function() {\n-                                    if (e.readDOMTimeout = null, e.composing)\n-                                        if (e.composing.done) e.composing = null;\n-                                        else return;\n-                                    e.updateFromDOM();\n-                                }, 80));\n-                            }, P.prototype.updateFromDOM = function() {\n-                                var e = this;\n-                                (this.cm.isReadOnly() || !this.pollContent()) && de(this.cm, function() {\n-                                    return se(e.cm);\n-                                });\n-                            }, P.prototype.setUneditable = function(e) {\n-                                e.contentEditable = \"false\";\n-                            }, P.prototype.onKeyPress = function(e) {\n-                                e.charCode == 0 || this.composing || (e.preventDefault(), this.cm.isReadOnly() || Q(this.cm, Sn)(this.cm, String.fromCharCode(e.charCode == null ? e.keyCode : e.charCode), 0));\n-                            }, P.prototype.readOnlyChanged = function(e) {\n-                                this.div.contentEditable = String(e != \"nocursor\");\n-                            }, P.prototype.onContextMenu = function() {}, P.prototype.resetPosition = function() {}, P.prototype.needsContentAttribute = !0;\n-\n-                            function Uo(e, t) {\n-                                var i = _i(e, t.line);\n-                                if (!i || i.hidden) return null;\n-                                var r = S(e.doc, t.line),\n-                                    n = vl(i, r, t.line),\n-                                    l = Pe(r, e.doc.direction),\n-                                    o = \"left\";\n-                                if (l) {\n-                                    var a = Zt(l, t.ch);\n-                                    o = a % 2 ? \"right\" : \"left\";\n-                                }\n-                                var s = ml(n.map, t.ch, o);\n-                                return s.offset = s.collapse == \"right\" ? s.end : s.start, s;\n-                            }\n-                            u(Uo, \"posToDOM\");\n-\n-                            function ru(e) {\n-                                for (var t = e; t; t = t.parentNode)\n-                                    if (/CodeMirror-gutter-wrapper/.test(t.className)) return !0;\n-                                return !1;\n-                            }\n-                            u(ru, \"isInGutter\");\n-\n-                            function Bt(e, t) {\n-                                return t && (e.bad = !0), e;\n-                            }\n-                            u(Bt, \"badPos\");\n-\n-                            function iu(e, t, i, r, n) {\n-                                var l = \"\",\n-                                    o = !1,\n-                                    a = e.doc.lineSeparator(),\n-                                    s = !1;\n-\n-                                function f(d) {\n-                                    return function(v) {\n-                                        return v.id == d;\n-                                    };\n-                                }\n-                                u(f, \"recognizeMarker\");\n+                        }\n+                        ++delta;\n+                        ++n;\n+                    }\n+                    return output.join('');\n+                };\n \n-                                function h() {\n-                                    o && (l += a, s && (l += a), o = s = !1);\n-                                }\n-                                u(h, \"close\");\n+                /**\n+                 * Converts a Punycode string representing a domain name or an email address\n+                 * to Unicode. Only the Punycoded parts of the input will be converted, i.e.\n+                 * it doesn't matter if you call it on a string that has already been\n+                 * converted to Unicode.\n+                 * @memberOf punycode\n+                 * @param {String} input The Punycoded domain name or email address to\n+                 * convert to Unicode.\n+                 * @returns {String} The Unicode representation of the given Punycode\n+                 * string.\n+                 */\n+                exports.encode = encode;\n+                const toUnicode = function(input) {\n+                    return mapDomain(input, function(string) {\n+                        return regexPunycode.test(string) ? decode(string.slice(4).toLowerCase()) : string;\n+                    });\n+                };\n \n-                                function c(d) {\n-                                    d && (h(), l += d);\n-                                }\n-                                u(c, \"addText\");\n+                /**\n+                 * Converts a Unicode string representing a domain name or an email address to\n+                 * Punycode. Only the non-ASCII parts of the domain name will be converted,\n+                 * i.e. it doesn't matter if you call it with a domain that's already in\n+                 * ASCII.\n+                 * @memberOf punycode\n+                 * @param {String} input The domain name or email address to convert, as a\n+                 * Unicode string.\n+                 * @returns {String} The Punycode representation of the given domain name or\n+                 * email address.\n+                 */\n+                exports.toUnicode = toUnicode;\n+                const toASCII = function(input) {\n+                    return mapDomain(input, function(string) {\n+                        return regexNonASCII.test(string) ? 'xn--' + encode(string) : string;\n+                    });\n+                };\n \n-                                function p(d) {\n-                                    if (d.nodeType == 1) {\n-                                        var v = d.getAttribute(\"cm-text\");\n-                                        if (v) {\n-                                            c(v);\n-                                            return;\n-                                        }\n-                                        var g = d.getAttribute(\"cm-marker\"),\n-                                            m;\n-                                        if (g) {\n-                                            var b = e.findMarks(y(r, 0), y(n + 1, 0), f(+g));\n-                                            b.length && (m = b[0].find(0)) && c(ot(e.doc, m.from, m.to).join(a));\n-                                            return;\n-                                        }\n-                                        if (d.getAttribute(\"contenteditable\") == \"false\") return;\n-                                        var C = /^(pre|div|p|li|table|br)$/i.test(d.nodeName);\n-                                        if (!/^br$/i.test(d.nodeName) && d.textContent.length == 0) return;\n-                                        C && h();\n-                                        for (var x = 0; x < d.childNodes.length; x++) p(d.childNodes[x]);\n-                                        /^(pre|p)$/i.test(d.nodeName) && (s = !0), C && (o = !0);\n-                                    } else d.nodeType == 3 && c(d.nodeValue.replace(/\\u200b/g, \"\").replace(/\\u00a0/g, \" \"));\n-                                }\n-                                for (u(p, \"walk\"); p(t), t != i;) t = t.nextSibling, s = !1;\n-                                return l;\n-                            }\n-                            u(iu, \"domTextBetween\");\n-\n-                            function fi(e, t, i) {\n-                                var r;\n-                                if (t == e.display.lineDiv) {\n-                                    if (r = e.display.lineDiv.childNodes[i], !r) return Bt(e.clipPos(y(e.display.viewTo - 1)), !0);\n-                                    t = null, i = 0;\n-                                } else\n-                                    for (r = t;; r = r.parentNode) {\n-                                        if (!r || r == e.display.lineDiv) return null;\n-                                        if (r.parentNode && r.parentNode == e.display.lineDiv) break;\n-                                    }\n-                                for (var n = 0; n < e.display.view.length; n++) {\n-                                    var l = e.display.view[n];\n-                                    if (l.node == r) return nu(l, t, i);\n-                                }\n-                            }\n-                            u(fi, \"domToPos\");\n-\n-                            function nu(e, t, i) {\n-                                var r = e.text.firstChild,\n-                                    n = !1;\n-                                if (!t || !Ke(r, t)) return Bt(y(F(e.line), 0), !0);\n-                                if (t == r && (n = !0, t = r.childNodes[i], i = 0, !t)) {\n-                                    var l = e.rest ? H(e.rest) : e.line;\n-                                    return Bt(y(F(l), l.text.length), n);\n-                                }\n-                                var o = t.nodeType == 3 ? t : null,\n-                                    a = t;\n-                                for (!o && t.childNodes.length == 1 && t.firstChild.nodeType == 3 && (o = t.firstChild, i && (i = o.nodeValue.length)); a.parentNode != r;) a = a.parentNode;\n-                                var s = e.measure,\n-                                    f = s.maps;\n-\n-                                function h(m, b, C) {\n-                                    for (var x = -1; x < (f ? f.length : 0); x++)\n-                                        for (var w = x < 0 ? s.map : f[x], k = 0; k < w.length; k += 3) {\n-                                            var L = w[k + 2];\n-                                            if (L == m || L == b) {\n-                                                var A = F(x < 0 ? e.line : e.rest[x]),\n-                                                    E = w[k] + C;\n-                                                return (C < 0 || L != m) && (E = w[k + (C ? 1 : 0)]), y(A, E);\n-                                            }\n-                                        }\n-                                }\n-                                u(h, \"find\");\n-                                var c = h(o, a, i);\n-                                if (c) return Bt(c, n);\n-                                for (var p = a.nextSibling, d = o ? o.nodeValue.length - i : 0; p; p = p.nextSibling) {\n-                                    if (c = h(p, p.firstChild, 0), c) return Bt(y(c.line, c.ch - d), n);\n-                                    d += p.textContent.length;\n-                                }\n-                                for (var v = a.previousSibling, g = i; v; v = v.previousSibling) {\n-                                    if (c = h(v, v.firstChild, -1), c) return Bt(y(c.line, c.ch + g), n);\n-                                    g += v.textContent.length;\n-                                }\n-                            }\n-                            u(nu, \"locateNodeInLineView\");\n-                            var G = u(function(e) {\n-                                this.cm = e, this.prevInput = \"\", this.pollingFast = !1, this.polling = new _e(), this.hasSelection = !1, this.composing = null;\n-                            }, \"TextareaInput\");\n-                            G.prototype.init = function(e) {\n-                                var t = this,\n-                                    i = this,\n-                                    r = this.cm;\n-                                this.createField(e);\n-                                var n = this.textarea;\n-                                e.wrapper.insertBefore(this.wrapper, e.wrapper.firstChild), Ut && (n.style.width = \"0px\"), M(n, \"input\", function() {\n-                                    O && I >= 9 && t.hasSelection && (t.hasSelection = null), i.poll();\n-                                }), M(n, \"paste\", function(o) {\n-                                    q(r, o) || Eo(o, r) || (r.state.pasteIncoming = +new Date(), i.fastPoll());\n-                                });\n+                /*--------------------------------------------------------------------------*/\n \n-                                function l(o) {\n-                                    if (!q(r, o)) {\n-                                        if (r.somethingSelected()) ui({\n-                                            lineWise: !1,\n-                                            text: r.getSelections()\n-                                        });\n-                                        else if (r.options.lineWiseCopyCut) {\n-                                            var a = Ro(r);\n-                                            ui({\n-                                                lineWise: !0,\n-                                                text: a.text\n-                                            }), o.type == \"cut\" ? r.setSelections(a.ranges, null, Me) : (i.prevInput = \"\", n.value = a.text.join(`\n-`), _t(n));\n-                                        } else return;\n-                                        o.type == \"cut\" && (r.state.cutIncoming = +new Date());\n-                                    }\n-                                }\n-                                u(l, \"prepareCopyCut\"), M(n, \"cut\", l), M(n, \"copy\", l), M(e.scroller, \"paste\", function(o) {\n-                                    if (!(Re(e, o) || q(r, o))) {\n-                                        if (!n.dispatchEvent) {\n-                                            r.state.pasteIncoming = +new Date(), i.focus();\n-                                            return;\n-                                        }\n-                                        var a = new Event(\"paste\");\n-                                        a.clipboardData = o.clipboardData, n.dispatchEvent(a);\n-                                    }\n-                                }), M(e.lineSpace, \"selectstart\", function(o) {\n-                                    Re(e, o) || ae(o);\n-                                }), M(n, \"compositionstart\", function() {\n-                                    var o = r.getCursor(\"from\");\n-                                    i.composing && i.composing.range.clear(), i.composing = {\n-                                        start: o,\n-                                        range: r.markText(o, r.getCursor(\"to\"), {\n-                                            className: \"CodeMirror-composing\"\n-                                        })\n-                                    };\n-                                }), M(n, \"compositionend\", function() {\n-                                    i.composing && (i.poll(), i.composing.range.clear(), i.composing = null);\n-                                });\n-                            }, G.prototype.createField = function(e) {\n-                                this.wrapper = zo(), this.textarea = this.wrapper.firstChild;\n-                            }, G.prototype.screenReaderLabelChanged = function(e) {\n-                                e ? this.textarea.setAttribute(\"aria-label\", e) : this.textarea.removeAttribute(\"aria-label\");\n-                            }, G.prototype.prepareSelection = function() {\n-                                var e = this.cm,\n-                                    t = e.display,\n-                                    i = e.doc,\n-                                    r = Nl(e);\n-                                if (e.options.moveInputWithCursor) {\n-                                    var n = Le(e, i.sel.primary().head, \"div\"),\n-                                        l = t.wrapper.getBoundingClientRect(),\n-                                        o = t.lineDiv.getBoundingClientRect();\n-                                    r.teTop = Math.max(0, Math.min(t.wrapper.clientHeight - 10, n.top + o.top - l.top)), r.teLeft = Math.max(0, Math.min(t.wrapper.clientWidth - 10, n.left + o.left - l.left));\n-                                }\n-                                return r;\n-                            }, G.prototype.showSelection = function(e) {\n-                                var t = this.cm,\n-                                    i = t.display;\n-                                ve(i.cursorDiv, e.cursors), ve(i.selectionDiv, e.selection), e.teTop != null && (this.wrapper.style.top = e.teTop + \"px\", this.wrapper.style.left = e.teLeft + \"px\");\n-                            }, G.prototype.reset = function(e) {\n-                                if (!(this.contextMenuPending || this.composing)) {\n-                                    var t = this.cm;\n-                                    if (t.somethingSelected()) {\n-                                        this.prevInput = \"\";\n-                                        var i = t.getSelection();\n-                                        this.textarea.value = i, t.state.focused && _t(this.textarea), O && I >= 9 && (this.hasSelection = i);\n-                                    } else e || (this.prevInput = this.textarea.value = \"\", O && I >= 9 && (this.hasSelection = null));\n-                                }\n-                            }, G.prototype.getField = function() {\n-                                return this.textarea;\n-                            }, G.prototype.supportsTouch = function() {\n-                                return !1;\n-                            }, G.prototype.focus = function() {\n-                                if (this.cm.options.readOnly != \"nocursor\" && (!Kt || be() != this.textarea)) try {\n-                                    this.textarea.focus();\n-                                } catch {}\n-                            }, G.prototype.blur = function() {\n-                                this.textarea.blur();\n-                            }, G.prototype.resetPosition = function() {\n-                                this.wrapper.style.top = this.wrapper.style.left = 0;\n-                            }, G.prototype.receivedFocus = function() {\n-                                this.slowPoll();\n-                            }, G.prototype.slowPoll = function() {\n-                                var e = this;\n-                                this.pollingFast || this.polling.set(this.cm.options.pollInterval, function() {\n-                                    e.poll(), e.cm.state.focused && e.slowPoll();\n-                                });\n-                            }, G.prototype.fastPoll = function() {\n-                                var e = !1,\n-                                    t = this;\n-                                t.pollingFast = !0;\n-\n-                                function i() {\n-                                    var r = t.poll();\n-                                    !r && !e ? (e = !0, t.polling.set(60, i)) : (t.pollingFast = !1, t.slowPoll());\n-                                }\n-                                u(i, \"p\"), t.polling.set(20, i);\n-                            }, G.prototype.poll = function() {\n-                                var e = this,\n-                                    t = this.cm,\n-                                    i = this.textarea,\n-                                    r = this.prevInput;\n-                                if (this.contextMenuPending || !t.state.focused || ia(i) && !r && !this.composing || t.isReadOnly() || t.options.disableInput || t.state.keySeq) return !1;\n-                                var n = i.value;\n-                                if (n == r && !t.somethingSelected()) return !1;\n-                                if (O && I >= 9 && this.hasSelection === n || me && /[\\uf700-\\uf7ff]/.test(n)) return t.display.input.reset(), !1;\n-                                if (t.doc.sel == t.display.selForContextMenu) {\n-                                    var l = n.charCodeAt(0);\n-                                    if (l == 8203 && !r && (r = \"\u200b\"), l == 8666) return this.reset(), this.cm.execCommand(\"undo\");\n-                                }\n-                                for (var o = 0, a = Math.min(r.length, n.length); o < a && r.charCodeAt(o) == n.charCodeAt(o);) ++o;\n-                                return de(t, function() {\n-                                    Sn(t, n.slice(o), r.length - o, null, e.composing ? \"*compose\" : null), n.length > 1e3 || n.indexOf(`\n-`) > -1 ? i.value = e.prevInput = \"\" : e.prevInput = n, e.composing && (e.composing.range.clear(), e.composing.range = t.markText(e.composing.start, t.getCursor(\"to\"), {\n-                                        className: \"CodeMirror-composing\"\n-                                    }));\n-                                }), !0;\n-                            }, G.prototype.ensurePolled = function() {\n-                                this.pollingFast && this.poll() && (this.pollingFast = !1);\n-                            }, G.prototype.onKeyPress = function() {\n-                                O && I >= 9 && (this.hasSelection = null), this.fastPoll();\n-                            }, G.prototype.onContextMenu = function(e) {\n-                                var t = this,\n-                                    i = t.cm,\n-                                    r = i.display,\n-                                    n = t.textarea;\n-                                t.contextMenuPending && t.contextMenuPending();\n-                                var l = ft(i, e),\n-                                    o = r.scroller.scrollTop;\n-                                if (!l || we) return;\n-                                var a = i.options.resetSelectionOnContextMenu;\n-                                a && i.doc.sel.contains(l) == -1 && Q(i, te)(i.doc, Ze(l), Me);\n-                                var s = n.style.cssText,\n-                                    f = t.wrapper.style.cssText,\n-                                    h = t.wrapper.offsetParent.getBoundingClientRect();\n-                                t.wrapper.style.cssText = \"position: static\", n.style.cssText = `position: absolute; width: 30px; height: 30px;\n-      top: ` + (e.clientY - h.top - 5) + \"px; left: \" + (e.clientX - h.left - 5) + `px;\n-      z-index: 1000; background: ` + (O ? \"rgba(255, 255, 255, .05)\" : \"transparent\") + `;\n-      outline: none; border-width: 0; outline: none; overflow: hidden; opacity: .05; filter: alpha(opacity=5);`;\n-                                var c;\n-                                ne && (c = window.scrollY), r.input.focus(), ne && window.scrollTo(null, c), r.input.reset(), i.somethingSelected() || (n.value = t.prevInput = \" \"), t.contextMenuPending = d, r.selForContextMenu = i.doc.sel, clearTimeout(r.detectingSelectAll);\n-\n-                                function p() {\n-                                    if (n.selectionStart != null) {\n-                                        var g = i.somethingSelected(),\n-                                            m = \"\u200b\" + (g ? n.value : \"\");\n-                                        n.value = \"\u21da\", n.value = m, t.prevInput = g ? \"\" : \"\u200b\", n.selectionStart = 1, n.selectionEnd = m.length, r.selForContextMenu = i.doc.sel;\n-                                    }\n-                                }\n-                                u(p, \"prepareSelectAllHack\");\n-\n-                                function d() {\n-                                    if (t.contextMenuPending == d && (t.contextMenuPending = !1, t.wrapper.style.cssText = f, n.style.cssText = s, O && I < 9 && r.scrollbars.setScrollTop(r.scroller.scrollTop = o), n.selectionStart != null)) {\n-                                        (!O || O && I < 9) && p();\n-                                        var g = 0,\n-                                            m = u(function() {\n-                                                r.selForContextMenu == i.doc.sel && n.selectionStart == 0 && n.selectionEnd > 0 && t.prevInput == \"\u200b\" ? Q(i, lo)(i) : g++ < 10 ? r.detectingSelectAll = setTimeout(m, 500) : (r.selForContextMenu = null, r.input.reset());\n-                                            }, \"poll\");\n-                                        r.detectingSelectAll = setTimeout(m, 200);\n-                                    }\n-                                }\n-                                if (u(d, \"rehide\"), O && I >= 9 && p(), ci) {\n-                                    Qt(e);\n-                                    var v = u(function() {\n-                                        ge(window, \"mouseup\", v), setTimeout(d, 20);\n-                                    }, \"mouseup\");\n-                                    M(window, \"mouseup\", v);\n-                                } else setTimeout(d, 50);\n-                            }, G.prototype.readOnlyChanged = function(e) {\n-                                e || this.reset(), this.textarea.disabled = e == \"nocursor\", this.textarea.readOnly = !!e;\n-                            }, G.prototype.setUneditable = function() {}, G.prototype.needsContentAttribute = !1;\n-\n-                            function lu(e, t) {\n-                                if (t = t ? nt(t) : {}, t.value = e.value, !t.tabindex && e.tabIndex && (t.tabindex = e.tabIndex), !t.placeholder && e.placeholder && (t.placeholder = e.placeholder), t.autofocus == null) {\n-                                    var i = be();\n-                                    t.autofocus = i == e || e.getAttribute(\"autofocus\") != null && i == document.body;\n-                                }\n-\n-                                function r() {\n-                                    e.value = a.getValue();\n-                                }\n-                                u(r, \"save\");\n-                                var n;\n-                                if (e.form && (M(e.form, \"submit\", r), !t.leaveSubmitMethodAlone)) {\n-                                    var l = e.form;\n-                                    n = l.submit;\n-                                    try {\n-                                        var o = l.submit = function() {\n-                                            r(), l.submit = n, l.submit(), l.submit = o;\n-                                        };\n-                                    } catch {}\n-                                }\n-                                t.finishInit = function(s) {\n-                                    s.save = r, s.getTextArea = function() {\n-                                        return e;\n-                                    }, s.toTextArea = function() {\n-                                        s.toTextArea = isNaN, r(), e.parentNode.removeChild(s.getWrapperElement()), e.style.display = \"\", e.form && (ge(e.form, \"submit\", r), !t.leaveSubmitMethodAlone && typeof e.form.submit == \"function\" && (e.form.submit = n));\n-                                    };\n-                                }, e.style.display = \"none\";\n-                                var a = R(function(s) {\n-                                    return e.parentNode.insertBefore(s, e.nextSibling);\n-                                }, t);\n-                                return a;\n-                            }\n-                            u(lu, \"fromTextArea\");\n-\n-                            function ou(e) {\n-                                e.off = ge, e.on = M, e.wheelEventPixels = ds, e.Doc = ue, e.splitLines = ki, e.countColumn = xe, e.findColumn = gi, e.isWordChar = mi, e.Pass = Nr, e.signal = U, e.Line = St, e.changeEnd = Qe, e.scrollbarModel = Pl, e.Pos = y, e.cmpPos = D, e.modes = Mi, e.mimeModes = Ct, e.resolveMode = Hr, e.getMode = Di, e.modeExtensions = wt, e.extendMode = sa, e.copyState = lt, e.startState = Gn, e.innerMode = Ni, e.commands = br, e.keyMap = ze, e.keyName = wo, e.isModifierKey = xo, e.lookupKey = Et, e.normalizeKeyMap = Ps, e.StringStream = K, e.SharedTextMarker = gr, e.TextMarker = je, e.LineWidget = vr, e.e_preventDefault = ae, e.e_stopPropagation = Bn, e.e_stop = Qt, e.addClass = it, e.contains = Ke, e.rmClass = tt, e.keyNames = Ve;\n-                            }\n-                            u(ou, \"addLegacyProps\"), js(R), tu(R);\n-                            var au = \"iter insert remove copy getEditor constructor\".split(\" \");\n-                            for (var hi in ue.prototype) ue.prototype.hasOwnProperty(hi) && ee(au, hi) < 0 && (R.prototype[hi] = function(e) {\n-                                return function() {\n-                                    return e.apply(this.doc, arguments);\n-                                };\n-                            }(ue.prototype[hi]));\n-                            return xt(ue), R.inputStyles = {\n-                                textarea: G,\n-                                contenteditable: P\n-                            }, R.defineMode = function(e) {\n-                                !R.defaults.mode && e != \"null\" && (R.defaults.mode = e), oa.apply(this, arguments);\n-                            }, R.defineMIME = aa, R.defineMode(\"null\", function() {\n-                                return {\n-                                    token: function(e) {\n-                                        return e.skipToEnd();\n-                                    }\n-                                };\n-                            }), R.defineMIME(\"text/plain\", \"null\"), R.defineExtension = function(e, t) {\n-                                R.prototype[e] = t;\n-                            }, R.defineDocExtension = function(e, t) {\n-                                ue.prototype[e] = t;\n-                            }, R.fromTextArea = lu, ou(R), R.version = \"5.65.3\", R;\n-                        });\n-                    }(Mn)), Mn.exports;\n-                }\n-                u(hu, \"requireCodemirror\");\n-                exports.getDefaultExportFromCjs = fu;\n-                exports.requireCodemirror = hu;\n+                /** Define the public API */\n+                exports.toASCII = toASCII;\n+                const punycode = {\n+                    /**\n+                     * A string representing the current Punycode.js version number.\n+                     * @memberOf punycode\n+                     * @type String\n+                     */\n+                    'version': '2.3.1',\n+                    /**\n+                     * An object of methods to convert from JavaScript's internal character\n+                     * representation (UCS-2) to Unicode code points, and back.\n+                     * @see <https://mathiasbynens.be/notes/javascript-encoding>\n+                     * @memberOf punycode\n+                     * @type Object\n+                     */\n+                    'ucs2': {\n+                        'decode': ucs2decode,\n+                        'encode': ucs2encode\n+                    },\n+                    'decode': decode,\n+                    'encode': encode,\n+                    'toASCII': toASCII,\n+                    'toUnicode': toUnicode\n+                };\n+                var _default = exports[\"default\"] = punycode;\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-react/dist/comment.cjs.js\":\n-            /*!************************************************!*\\\n-              !*** ../../graphiql-react/dist/comment.cjs.js ***!\n-              \\************************************************/\n+        \"../../../node_modules/react-compiler-runtime/dist/index.js\":\n+            /*!******************************************************************!*\\\n+              !*** ../../../node_modules/react-compiler-runtime/dist/index.js ***!\n+              \\******************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                /**\n+                 * Copyright (c) Meta Platforms, Inc. and affiliates.\n+                 *\n+                 * This source code is licensed under the MIT license found in the\n+                 * LICENSE file in the root directory of this source tree.\n+                 *\n+                 * @lightSyntaxTransform\n+                 * @noflow\n+                 * @nolint\n+                 * @preventMunge\n+                 * @preserve-invariant-messages\n+                 */\n \n+                \"use no memo\";\n+                'use strict';\n \n-                var G = Object.defineProperty;\n-                var I = (p, E) => G(p, \"name\", {\n-                    value: E,\n-                    configurable: !0\n-                });\n-                const z = __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\");\n-\n-                function H(p, E) {\n-                    for (var u = 0; u < E.length; u++) {\n-                        const C = E[u];\n-                        if (typeof C != \"string\" && !Array.isArray(C)) {\n-                            for (const s in C)\n-                                if (s !== \"default\" && !(s in p)) {\n-                                    const r = Object.getOwnPropertyDescriptor(C, s);\n-                                    r && Object.defineProperty(p, s, r.get ? r : {\n-                                        enumerable: !0,\n-                                        get: () => C[s]\n-                                    });\n-                                }\n-                        }\n-                    }\n-                    return Object.freeze(Object.defineProperty(p, Symbol.toStringTag, {\n-                        value: \"Module\"\n-                    }));\n-                }\n-                I(H, \"_mergeNamespaces\");\n-                var J = {\n-                    exports: {}\n-                };\n-                (function(p, E) {\n-                    (function(u) {\n-                        u(z.requireCodemirror());\n-                    })(function(u) {\n-                        var C = {},\n-                            s = /[^\\s\\u00a0]/,\n-                            r = u.Pos,\n-                            F = u.cmpPos;\n-\n-                        function D(t) {\n-                            var l = t.search(s);\n-                            return l == -1 ? 0 : l;\n-                        }\n-                        I(D, \"firstNonWS\"), u.commands.toggleComment = function(t) {\n-                            t.toggleComment();\n-                        }, u.defineExtension(\"toggleComment\", function(t) {\n-                            t || (t = C);\n-                            for (var l = this, n = 1 / 0, e = this.listSelections(), f = null, m = e.length - 1; m >= 0; m--) {\n-                                var a = e[m].from(),\n-                                    i = e[m].to();\n-                                a.line >= n || (i.line >= n && (i = r(n, 0)), n = a.line, f == null ? l.uncomment(a, i, t) ? f = \"un\" : (l.lineComment(a, i, t), f = \"line\") : f == \"un\" ? l.uncomment(a, i, t) : l.lineComment(a, i, t));\n-                            }\n-                        });\n+                var React = __webpack_require__( /*! react */ \"react\");\n \n-                        function w(t, l, n) {\n-                            return /\\bstring\\b/.test(t.getTokenTypeAt(r(l.line, 0))) && !/^[\\'\\\"\\`]/.test(n);\n-                        }\n-                        I(w, \"probablyInsideString\");\n-\n-                        function P(t, l) {\n-                            var n = t.getMode();\n-                            return n.useInnerComments === !1 || !n.innerMode ? n : t.getModeAt(l);\n-                        }\n-                        I(P, \"getMode\"), u.defineExtension(\"lineComment\", function(t, l, n) {\n-                            n || (n = C);\n-                            var e = this,\n-                                f = P(e, t),\n-                                m = e.getLine(t.line);\n-                            if (!(m == null || w(e, t, m))) {\n-                                var a = n.lineComment || f.lineComment;\n-                                if (!a) {\n-                                    (n.blockCommentStart || f.blockCommentStart) && (n.fullLines = !0, e.blockComment(t, l, n));\n-                                    return;\n-                                }\n-                                var i = Math.min(l.ch != 0 || l.line == t.line ? l.line + 1 : l.line, e.lastLine() + 1),\n-                                    k = n.padding == null ? \" \" : n.padding,\n-                                    g = n.commentBlankLines || t.line == l.line;\n-                                e.operation(function() {\n-                                    if (n.indent) {\n-                                        for (var d = null, c = t.line; c < i; ++c) {\n-                                            var v = e.getLine(c),\n-                                                h = v.slice(0, D(v));\n-                                            (d == null || d.length > h.length) && (d = h);\n-                                        }\n-                                        for (var c = t.line; c < i; ++c) {\n-                                            var v = e.getLine(c),\n-                                                o = d.length;\n-                                            !g && !s.test(v) || (v.slice(0, o) != d && (o = D(v)), e.replaceRange(d + a + k, r(c, 0), r(c, o)));\n-                                        }\n-                                    } else\n-                                        for (var c = t.line; c < i; ++c)(g || s.test(e.getLine(c))) && e.replaceRange(a + k, r(c, 0));\n-                                });\n-                            }\n-                        }), u.defineExtension(\"blockComment\", function(t, l, n) {\n-                            n || (n = C);\n-                            var e = this,\n-                                f = P(e, t),\n-                                m = n.blockCommentStart || f.blockCommentStart,\n-                                a = n.blockCommentEnd || f.blockCommentEnd;\n-                            if (!m || !a) {\n-                                (n.lineComment || f.lineComment) && n.fullLines != !1 && e.lineComment(t, l, n);\n-                                return;\n-                            }\n-                            if (!/\\bcomment\\b/.test(e.getTokenTypeAt(r(t.line, 0)))) {\n-                                var i = Math.min(l.line, e.lastLine());\n-                                i != t.line && l.ch == 0 && s.test(e.getLine(i)) && --i;\n-                                var k = n.padding == null ? \" \" : n.padding;\n-                                t.line > i || e.operation(function() {\n-                                    if (n.fullLines != !1) {\n-                                        var g = s.test(e.getLine(i));\n-                                        e.replaceRange(k + a, r(i)), e.replaceRange(m + k, r(t.line, 0));\n-                                        var d = n.blockCommentLead || f.blockCommentLead;\n-                                        if (d != null)\n-                                            for (var c = t.line + 1; c <= i; ++c)(c != i || g) && e.replaceRange(d + k, r(c, 0));\n-                                    } else {\n-                                        var v = F(e.getCursor(\"to\"), l) == 0,\n-                                            h = !e.somethingSelected();\n-                                        e.replaceRange(a, l), v && e.setSelection(h ? l : e.getCursor(\"from\"), l), e.replaceRange(m, t);\n+                function _interopNamespaceDefault(e) {\n+                    var n = Object.create(null);\n+                    if (e) {\n+                        Object.keys(e).forEach(function(k) {\n+                            if (k !== 'default') {\n+                                var d = Object.getOwnPropertyDescriptor(e, k);\n+                                Object.defineProperty(n, k, d.get ? d : {\n+                                    enumerable: true,\n+                                    get: function() {\n+                                        return e[k];\n                                     }\n                                 });\n                             }\n-                        }), u.defineExtension(\"uncomment\", function(t, l, n) {\n-                            n || (n = C);\n-                            var e = this,\n-                                f = P(e, t),\n-                                m = Math.min(l.ch != 0 || l.line == t.line ? l.line : l.line - 1, e.lastLine()),\n-                                a = Math.min(t.line, m),\n-                                i = n.lineComment || f.lineComment,\n-                                k = [],\n-                                g = n.padding == null ? \" \" : n.padding,\n-                                d;\n-                            e: {\n-                                if (!i) break e;\n-                                for (var c = a; c <= m; ++c) {\n-                                    var v = e.getLine(c),\n-                                        h = v.indexOf(i);\n-                                    if (h > -1 && !/comment/.test(e.getTokenTypeAt(r(c, h + 1))) && (h = -1), h == -1 && s.test(v) || h > -1 && s.test(v.slice(0, h))) break e;\n-                                    k.push(v);\n-                                }\n-                                if (e.operation(function() {\n-                                        for (var b = a; b <= m; ++b) {\n-                                            var x = k[b - a],\n-                                                O = x.indexOf(i),\n-                                                L = O + i.length;\n-                                            O < 0 || (x.slice(L, L + g.length) == g && (L += g.length), d = !0, e.replaceRange(\"\", r(b, O), r(b, L)));\n-                                        }\n-                                    }), d) return !0;\n-                            }\n-                            var o = n.blockCommentStart || f.blockCommentStart,\n-                                S = n.blockCommentEnd || f.blockCommentEnd;\n-                            if (!o || !S) return !1;\n-                            var q = n.blockCommentLead || f.blockCommentLead,\n-                                A = e.getLine(a),\n-                                j = A.indexOf(o);\n-                            if (j == -1) return !1;\n-                            var _ = m == a ? A : e.getLine(m),\n-                                y = _.indexOf(S, m == a ? j + o.length : 0),\n-                                N = r(a, j + 1),\n-                                W = r(m, y + 1);\n-                            if (y == -1 || !/comment/.test(e.getTokenTypeAt(N)) || !/comment/.test(e.getTokenTypeAt(W)) || e.getRange(N, W, `\n-`).indexOf(S) > -1) return !1;\n-                            var R = A.lastIndexOf(o, t.ch),\n-                                T = R == -1 ? -1 : A.slice(0, t.ch).indexOf(S, R + o.length);\n-                            if (R != -1 && T != -1 && T + S.length != t.ch) return !1;\n-                            T = _.indexOf(S, l.ch);\n-                            var $ = _.slice(l.ch).lastIndexOf(o, T - l.ch);\n-                            return R = T == -1 || $ == -1 ? -1 : l.ch + $, T != -1 && R != -1 && R != l.ch ? !1 : (e.operation(function() {\n-                                e.replaceRange(\"\", r(m, y - (g && _.slice(y - g.length, y) == g ? g.length : 0)), r(m, y + S.length));\n-                                var b = j + o.length;\n-                                if (g && A.slice(b, b + g.length) == g && (b += g.length), e.replaceRange(\"\", r(a, j), r(a, b)), q)\n-                                    for (var x = a + 1; x <= m; ++x) {\n-                                        var O = e.getLine(x),\n-                                            L = O.indexOf(q);\n-                                        if (!(L == -1 || s.test(O.slice(0, L)))) {\n-                                            var M = L + q.length;\n-                                            g && O.slice(M, M + g.length) == g && (M += g.length), e.replaceRange(\"\", r(x, L), r(x, M));\n-                                        }\n-                                    }\n-                            }), !0);\n                         });\n-                    });\n-                })();\n-                var B = J.exports;\n-                const K = z.getDefaultExportFromCjs(B),\n-                    Q = H({\n-                        __proto__: null,\n-                        default: K\n-                    }, [B]);\n-                exports.comment = Q;\n-\n-                /***/\n-            }),\n+                    }\n+                    n.default = e;\n+                    return Object.freeze(n);\n+                }\n+                var React__namespace = /*#__PURE__*/ _interopNamespaceDefault(React);\n+                var _a, _b;\n+                const {\n+                    useRef,\n+                    useEffect,\n+                    isValidElement\n+                } = React__namespace;\n+                const ReactSecretInternals = (_a = React__namespace.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE) !== null && _a !== void 0 ? _a : React__namespace.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;\n+                const $empty = Symbol.for('react.memo_cache_sentinel');\n+                const c = typeof((_b = React__namespace.__COMPILER_RUNTIME) === null || _b === void 0 ? void 0 : _b.c) === 'function' ? React__namespace.__COMPILER_RUNTIME.c : function c(size) {\n+                    return React__namespace.useMemo(() => {\n+                        const $ = new Array(size);\n+                        for (let ii = 0; ii < size; ii++) {\n+                            $[ii] = $empty;\n+                        }\n+                        $[$empty] = true;\n+                        return $;\n+                    }, []);\n+                };\n+                const LazyGuardDispatcher = {};\n+                ['readContext', 'useCallback', 'useContext', 'useEffect', 'useImperativeHandle', 'useInsertionEffect', 'useLayoutEffect', 'useMemo', 'useReducer', 'useRef', 'useState', 'useDebugValue', 'useDeferredValue', 'useTransition', 'useMutableSource', 'useSyncExternalStore', 'useId', 'unstable_isNewReconciler', 'getCacheSignal', 'getCacheForType', 'useCacheRefresh'].forEach(name => {\n+                    LazyGuardDispatcher[name] = () => {\n+                        throw new Error(`[React] Unexpected React hook call (${name}) from a React compiled function. ` + \"Check that all hooks are called directly and named according to convention ('use[A-Z]') \");\n+                    };\n+                });\n+                let originalDispatcher = null;\n+                LazyGuardDispatcher['useMemoCache'] = count => {\n+                    if (originalDispatcher == null) {\n+                        throw new Error('React Compiler internal invariant violation: unexpected null dispatcher');\n+                    } else {\n+                        return originalDispatcher.useMemoCache(count);\n+                    }\n+                };\n+                var GuardKind;\n+                (function(GuardKind) {\n+                    GuardKind[GuardKind[\"PushGuardContext\"] = 0] = \"PushGuardContext\";\n+                    GuardKind[GuardKind[\"PopGuardContext\"] = 1] = \"PopGuardContext\";\n+                    GuardKind[GuardKind[\"PushExpectHook\"] = 2] = \"PushExpectHook\";\n+                    GuardKind[GuardKind[\"PopExpectHook\"] = 3] = \"PopExpectHook\";\n+                })(GuardKind || (GuardKind = {}));\n+\n+                function setCurrent(newDispatcher) {\n+                    ReactSecretInternals.ReactCurrentDispatcher.current = newDispatcher;\n+                    return ReactSecretInternals.ReactCurrentDispatcher.current;\n+                }\n+                const guardFrames = [];\n+\n+                function $dispatcherGuard(kind) {\n+                    const curr = ReactSecretInternals.ReactCurrentDispatcher.current;\n+                    if (kind === GuardKind.PushGuardContext) {\n+                        guardFrames.push(curr);\n+                        if (guardFrames.length === 1) {\n+                            originalDispatcher = curr;\n+                        }\n+                        if (curr === LazyGuardDispatcher) {\n+                            throw new Error(`[React] Unexpected call to custom hook or component from a React compiled function. ` + \"Check that (1) all hooks are called directly and named according to convention ('use[A-Z]') \" + 'and (2) components are returned as JSX instead of being directly invoked.');\n+                        }\n+                        setCurrent(LazyGuardDispatcher);\n+                    } else if (kind === GuardKind.PopGuardContext) {\n+                        const lastFrame = guardFrames.pop();\n+                        if (lastFrame == null) {\n+                            throw new Error('React Compiler internal error: unexpected null in guard stack');\n+                        }\n+                        if (guardFrames.length === 0) {\n+                            originalDispatcher = null;\n+                        }\n+                        setCurrent(lastFrame);\n+                    } else if (kind === GuardKind.PushExpectHook) {\n+                        guardFrames.push(curr);\n+                        setCurrent(originalDispatcher);\n+                    } else if (kind === GuardKind.PopExpectHook) {\n+                        const lastFrame = guardFrames.pop();\n+                        if (lastFrame == null) {\n+                            throw new Error('React Compiler internal error: unexpected null in guard stack');\n+                        }\n+                        setCurrent(lastFrame);\n+                    } else {\n+                        throw new Error('React Compiler internal error: unreachable block' + kind);\n+                    }\n+                }\n \n-        /***/\n-        \"../../graphiql-react/dist/dialog.cjs.js\":\n-            /*!***********************************************!*\\\n-              !*** ../../graphiql-react/dist/dialog.cjs.js ***!\n-              \\***********************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                function $reset($) {\n+                    for (let ii = 0; ii < $.length; ii++) {\n+                        $[ii] = $empty;\n+                    }\n+                }\n \n+                function $makeReadOnly() {\n+                    throw new Error('TODO: implement $makeReadOnly in react-compiler-runtime');\n+                }\n+                const renderCounterRegistry = new Map();\n \n+                function clearRenderCounterRegistry() {\n+                    for (const counters of renderCounterRegistry.values()) {\n+                        counters.forEach(counter => {\n+                            counter.count = 0;\n+                        });\n+                    }\n+                }\n \n-                var E = Object.defineProperty;\n-                var g = (v, m) => E(v, \"name\", {\n-                    value: m,\n-                    configurable: !0\n-                });\n-                const b = __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\");\n-\n-                function O(v, m) {\n-                    for (var n = 0; n < m.length; n++) {\n-                        const r = m[n];\n-                        if (typeof r != \"string\" && !Array.isArray(r)) {\n-                            for (const c in r)\n-                                if (c !== \"default\" && !(c in v)) {\n-                                    const u = Object.getOwnPropertyDescriptor(r, c);\n-                                    u && Object.defineProperty(v, c, u.get ? u : {\n-                                        enumerable: !0,\n-                                        get: () => r[c]\n-                                    });\n-                                }\n-                        }\n+                function registerRenderCounter(name, val) {\n+                    let counters = renderCounterRegistry.get(name);\n+                    if (counters == null) {\n+                        counters = new Set();\n+                        renderCounterRegistry.set(name, counters);\n                     }\n-                    return Object.freeze(Object.defineProperty(v, Symbol.toStringTag, {\n-                        value: \"Module\"\n-                    }));\n+                    counters.add(val);\n                 }\n-                g(O, \"_mergeNamespaces\");\n-                var T = {\n-                    exports: {}\n-                };\n-                (function(v, m) {\n-                    (function(n) {\n-                        n(b.requireCodemirror());\n-                    })(function(n) {\n-                        function r(u, f, e) {\n-                            var a = u.getWrapperElement(),\n-                                l;\n-                            return l = a.appendChild(document.createElement(\"div\")), e ? l.className = \"CodeMirror-dialog CodeMirror-dialog-bottom\" : l.className = \"CodeMirror-dialog CodeMirror-dialog-top\", typeof f == \"string\" ? l.innerHTML = f : l.appendChild(f), n.addClass(a, \"dialog-opened\"), l;\n-                        }\n-                        g(r, \"dialogDiv\");\n-\n-                        function c(u, f) {\n-                            u.state.currentNotificationClose && u.state.currentNotificationClose(), u.state.currentNotificationClose = f;\n-                        }\n-                        g(c, \"closeNotification\"), n.defineExtension(\"openDialog\", function(u, f, e) {\n-                            e || (e = {}), c(this, null);\n-                            var a = r(this, u, e.bottom),\n-                                l = !1,\n-                                s = this;\n \n-                            function i(t) {\n-                                if (typeof t == \"string\") o.value = t;\n-                                else {\n-                                    if (l) return;\n-                                    l = !0, n.rmClass(a.parentNode, \"dialog-opened\"), a.parentNode.removeChild(a), s.focus(), e.onClose && e.onClose(a);\n-                                }\n-                            }\n-                            g(i, \"close\");\n-                            var o = a.getElementsByTagName(\"input\")[0],\n-                                d;\n-                            return o ? (o.focus(), e.value && (o.value = e.value, e.selectValueOnOpen !== !1 && o.select()), e.onInput && n.on(o, \"input\", function(t) {\n-                                e.onInput(t, o.value, i);\n-                            }), e.onKeyUp && n.on(o, \"keyup\", function(t) {\n-                                e.onKeyUp(t, o.value, i);\n-                            }), n.on(o, \"keydown\", function(t) {\n-                                e && e.onKeyDown && e.onKeyDown(t, o.value, i) || ((t.keyCode == 27 || e.closeOnEnter !== !1 && t.keyCode == 13) && (o.blur(), n.e_stop(t), i()), t.keyCode == 13 && f(o.value, t));\n-                            }), e.closeOnBlur !== !1 && n.on(a, \"focusout\", function(t) {\n-                                t.relatedTarget !== null && i();\n-                            })) : (d = a.getElementsByTagName(\"button\")[0]) && (n.on(d, \"click\", function() {\n-                                i(), s.focus();\n-                            }), e.closeOnBlur !== !1 && n.on(d, \"blur\", i), d.focus()), i;\n-                        }), n.defineExtension(\"openConfirm\", function(u, f, e) {\n-                            c(this, null);\n-                            var a = r(this, u, e && e.bottom),\n-                                l = a.getElementsByTagName(\"button\"),\n-                                s = !1,\n-                                i = this,\n-                                o = 1;\n-\n-                            function d() {\n-                                s || (s = !0, n.rmClass(a.parentNode, \"dialog-opened\"), a.parentNode.removeChild(a), i.focus());\n-                            }\n-                            g(d, \"close\"), l[0].focus();\n-                            for (var t = 0; t < l.length; ++t) {\n-                                var p = l[t];\n-                                (function(N) {\n-                                    n.on(p, \"click\", function(h) {\n-                                        n.e_preventDefault(h), d(), N && N(i);\n-                                    });\n-                                })(f[t]), n.on(p, \"blur\", function() {\n-                                    --o, setTimeout(function() {\n-                                        o <= 0 && d();\n-                                    }, 200);\n-                                }), n.on(p, \"focus\", function() {\n-                                    ++o;\n-                                });\n-                            }\n-                        }), n.defineExtension(\"openNotification\", function(u, f) {\n-                            c(this, i);\n-                            var e = r(this, u, f && f.bottom),\n-                                a = !1,\n-                                l,\n-                                s = f && typeof f.duration < \"u\" ? f.duration : 5e3;\n+                function removeRenderCounter(name, val) {\n+                    const counters = renderCounterRegistry.get(name);\n+                    if (counters == null) {\n+                        return;\n+                    }\n+                    counters.delete(val);\n+                }\n \n-                            function i() {\n-                                a || (a = !0, clearTimeout(l), n.rmClass(e.parentNode, \"dialog-opened\"), e.parentNode.removeChild(e));\n+                function useRenderCounter(name) {\n+                    const val = useRef(null);\n+                    if (val.current != null) {\n+                        val.current.count += 1;\n+                    }\n+                    useEffect(() => {\n+                        if (val.current == null) {\n+                            const counter = {\n+                                count: 0\n+                            };\n+                            registerRenderCounter(name, counter);\n+                            val.current = counter;\n+                        }\n+                        return () => {\n+                            if (val.current !== null) {\n+                                removeRenderCounter(name, val.current);\n                             }\n-                            return g(i, \"close\"), n.on(e, \"click\", function(o) {\n-                                n.e_preventDefault(o), i();\n-                            }), s && (l = setTimeout(i, s)), i;\n-                        });\n+                        };\n                     });\n-                })();\n-                var y = T.exports;\n-                const x = b.getDefaultExportFromCjs(y),\n-                    k = O({\n-                        __proto__: null,\n-                        default: x\n-                    }, [y]);\n-                exports.dialog = k;\n-                exports.dialogExports = y;\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../graphiql-react/dist/foldgutter.cjs.js\":\n-            /*!***************************************************!*\\\n-              !*** ../../graphiql-react/dist/foldgutter.cjs.js ***!\n-              \\***************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n+                }\n+                const seenErrors = new Set();\n \n-                var z = Object.defineProperty;\n-                var u = (O, k) => z(O, \"name\", {\n-                    value: k,\n-                    configurable: !0\n-                });\n-                const G = __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\");\n-\n-                function L(O, k) {\n-                    for (var i = 0; i < k.length; i++) {\n-                        const s = k[i];\n-                        if (typeof s != \"string\" && !Array.isArray(s)) {\n-                            for (const p in s)\n-                                if (p !== \"default\" && !(p in O)) {\n-                                    const w = Object.getOwnPropertyDescriptor(s, p);\n-                                    w && Object.defineProperty(O, p, w.get ? w : {\n-                                        enumerable: !0,\n-                                        get: () => s[p]\n-                                    });\n-                                }\n+                function $structuralCheck(oldValue, newValue, variableName, fnName, kind, loc) {\n+                    function error(l, r, path, depth) {\n+                        const str = `${fnName}:${loc} [${kind}] ${variableName}${path} changed from ${l} to ${r} at depth ${depth}`;\n+                        if (seenErrors.has(str)) {\n+                            return;\n                         }\n+                        seenErrors.add(str);\n+                        console.error(str);\n                     }\n-                    return Object.freeze(Object.defineProperty(O, Symbol.toStringTag, {\n-                        value: \"Module\"\n-                    }));\n-                }\n-                u(L, \"_mergeNamespaces\");\n-                var j = {\n-                        exports: {}\n-                    },\n-                    U = {\n-                        exports: {}\n-                    },\n-                    N;\n+                    const depthLimit = 2;\n \n-                function q() {\n-                    return N || (N = 1, function(O, k) {\n-                        (function(i) {\n-                            i(G.requireCodemirror());\n-                        })(function(i) {\n-                            function s(t, o, f, a) {\n-                                if (f && f.call) {\n-                                    var g = f;\n-                                    f = null;\n-                                } else var g = v(t, f, \"rangeFinder\");\n-                                typeof o == \"number\" && (o = i.Pos(o, 0));\n-                                var y = v(t, f, \"minFoldSize\");\n-\n-                                function x(l) {\n-                                    var r = g(t, o);\n-                                    if (!r || r.to.line - r.from.line < y) return null;\n-                                    if (a === \"fold\") return r;\n-                                    for (var c = t.findMarksAt(r.from), h = 0; h < c.length; ++h)\n-                                        if (c[h].__isFold) {\n-                                            if (!l) return null;\n-                                            r.cleared = !0, c[h].clear();\n+                    function recur(oldValue, newValue, path, depth) {\n+                        if (depth > depthLimit) {\n+                            return;\n+                        } else if (oldValue === newValue) {\n+                            return;\n+                        } else if (typeof oldValue !== typeof newValue) {\n+                            error(`type ${typeof oldValue}`, `type ${typeof newValue}`, path, depth);\n+                        } else if (typeof oldValue === 'object') {\n+                            const oldArray = Array.isArray(oldValue);\n+                            const newArray = Array.isArray(newValue);\n+                            if (oldValue === null && newValue !== null) {\n+                                error('null', `type ${typeof newValue}`, path, depth);\n+                            } else if (newValue === null) {\n+                                error(`type ${typeof oldValue}`, 'null', path, depth);\n+                            } else if (oldValue instanceof Map) {\n+                                if (!(newValue instanceof Map)) {\n+                                    error(`Map instance`, `other value`, path, depth);\n+                                } else if (oldValue.size !== newValue.size) {\n+                                    error(`Map instance with size ${oldValue.size}`, `Map instance with size ${newValue.size}`, path, depth);\n+                                } else {\n+                                    for (const [k, v] of oldValue) {\n+                                        if (!newValue.has(k)) {\n+                                            error(`Map instance with key ${k}`, `Map instance without key ${k}`, path, depth);\n+                                        } else {\n+                                            recur(v, newValue.get(k), `${path}.get(${k})`, depth + 1);\n                                         }\n-                                    return r;\n+                                    }\n                                 }\n-                                u(x, \"getRange\");\n-                                var d = x(!0);\n-                                if (v(t, f, \"scanUp\"))\n-                                    for (; !d && o.line > t.firstLine();) o = i.Pos(o.line - 1, 0), d = x(!1);\n-                                if (!(!d || d.cleared || a === \"unfold\")) {\n-                                    var e = p(t, f, d);\n-                                    i.on(e, \"mousedown\", function(l) {\n-                                        n.clear(), i.e_preventDefault(l);\n-                                    });\n-                                    var n = t.markText(d.from, d.to, {\n-                                        replacedWith: e,\n-                                        clearOnEnter: v(t, f, \"clearOnEnter\"),\n-                                        __isFold: !0\n-                                    });\n-                                    n.on(\"clear\", function(l, r) {\n-                                        i.signal(t, \"unfold\", t, l, r);\n-                                    }), i.signal(t, \"fold\", t, d.from, d.to);\n-                                }\n-                            }\n-                            u(s, \"doFold\");\n-\n-                            function p(t, o, f) {\n-                                var a = v(t, o, \"widget\");\n-                                if (typeof a == \"function\" && (a = a(f.from, f.to)), typeof a == \"string\") {\n-                                    var g = document.createTextNode(a);\n-                                    a = document.createElement(\"span\"), a.appendChild(g), a.className = \"CodeMirror-foldmarker\";\n-                                } else a && (a = a.cloneNode(!0));\n-                                return a;\n-                            }\n-                            u(p, \"makeWidget\"), i.newFoldFunction = function(t, o) {\n-                                return function(f, a) {\n-                                    s(f, a, {\n-                                        rangeFinder: t,\n-                                        widget: o\n-                                    });\n-                                };\n-                            }, i.defineExtension(\"foldCode\", function(t, o, f) {\n-                                s(this, t, o, f);\n-                            }), i.defineExtension(\"isFolded\", function(t) {\n-                                for (var o = this.findMarksAt(t), f = 0; f < o.length; ++f)\n-                                    if (o[f].__isFold) return !0;\n-                            }), i.commands.toggleFold = function(t) {\n-                                t.foldCode(t.getCursor());\n-                            }, i.commands.fold = function(t) {\n-                                t.foldCode(t.getCursor(), null, \"fold\");\n-                            }, i.commands.unfold = function(t) {\n-                                t.foldCode(t.getCursor(), {\n-                                    scanUp: !1\n-                                }, \"unfold\");\n-                            }, i.commands.foldAll = function(t) {\n-                                t.operation(function() {\n-                                    for (var o = t.firstLine(), f = t.lastLine(); o <= f; o++) t.foldCode(i.Pos(o, 0), {\n-                                        scanUp: !1\n-                                    }, \"fold\");\n-                                });\n-                            }, i.commands.unfoldAll = function(t) {\n-                                t.operation(function() {\n-                                    for (var o = t.firstLine(), f = t.lastLine(); o <= f; o++) t.foldCode(i.Pos(o, 0), {\n-                                        scanUp: !1\n-                                    }, \"unfold\");\n-                                });\n-                            }, i.registerHelper(\"fold\", \"combine\", function() {\n-                                var t = Array.prototype.slice.call(arguments, 0);\n-                                return function(o, f) {\n-                                    for (var a = 0; a < t.length; ++a) {\n-                                        var g = t[a](o, f);\n-                                        if (g) return g;\n+                            } else if (newValue instanceof Map) {\n+                                error('other value', `Map instance`, path, depth);\n+                            } else if (oldValue instanceof Set) {\n+                                if (!(newValue instanceof Set)) {\n+                                    error(`Set instance`, `other value`, path, depth);\n+                                } else if (oldValue.size !== newValue.size) {\n+                                    error(`Set instance with size ${oldValue.size}`, `Set instance with size ${newValue.size}`, path, depth);\n+                                } else {\n+                                    for (const v of newValue) {\n+                                        if (!oldValue.has(v)) {\n+                                            error(`Set instance without element ${v}`, `Set instance with element ${v}`, path, depth);\n+                                        }\n                                     }\n-                                };\n-                            }), i.registerHelper(\"fold\", \"auto\", function(t, o) {\n-                                for (var f = t.getHelpers(o, \"fold\"), a = 0; a < f.length; a++) {\n-                                    var g = f[a](t, o);\n-                                    if (g) return g;\n-                                }\n-                            });\n-                            var w = {\n-                                rangeFinder: i.fold.auto,\n-                                widget: \"\u2194\",\n-                                minFoldSize: 0,\n-                                scanUp: !1,\n-                                clearOnEnter: !0\n-                            };\n-                            i.defineOption(\"foldOptions\", null);\n-\n-                            function v(t, o, f) {\n-                                if (o && o[f] !== void 0) return o[f];\n-                                var a = t.options.foldOptions;\n-                                return a && a[f] !== void 0 ? a[f] : w[f];\n-                            }\n-                            u(v, \"getOption\"), i.defineExtension(\"foldOption\", function(t, o) {\n-                                return v(this, t, o);\n-                            });\n-                        });\n-                    }()), U.exports;\n-                }\n-                u(q, \"requireFoldcode\");\n-                (function(O, k) {\n-                    (function(i) {\n-                        i(G.requireCodemirror(), q());\n-                    })(function(i) {\n-                        i.defineOption(\"foldGutter\", !1, function(e, n, l) {\n-                            l && l != i.Init && (e.clearGutter(e.state.foldGutter.options.gutter), e.state.foldGutter = null, e.off(\"gutterClick\", g), e.off(\"changes\", y), e.off(\"viewportChange\", x), e.off(\"fold\", d), e.off(\"unfold\", d), e.off(\"swapDoc\", y)), n && (e.state.foldGutter = new p(w(n)), a(e), e.on(\"gutterClick\", g), e.on(\"changes\", y), e.on(\"viewportChange\", x), e.on(\"fold\", d), e.on(\"unfold\", d), e.on(\"swapDoc\", y));\n-                        });\n-                        var s = i.Pos;\n-\n-                        function p(e) {\n-                            this.options = e, this.from = this.to = 0;\n-                        }\n-                        u(p, \"State\");\n-\n-                        function w(e) {\n-                            return e === !0 && (e = {}), e.gutter == null && (e.gutter = \"CodeMirror-foldgutter\"), e.indicatorOpen == null && (e.indicatorOpen = \"CodeMirror-foldgutter-open\"), e.indicatorFolded == null && (e.indicatorFolded = \"CodeMirror-foldgutter-folded\"), e;\n-                        }\n-                        u(w, \"parseOptions\");\n-\n-                        function v(e, n) {\n-                            for (var l = e.findMarks(s(n, 0), s(n + 1, 0)), r = 0; r < l.length; ++r)\n-                                if (l[r].__isFold) {\n-                                    var c = l[r].find(-1);\n-                                    if (c && c.line === n) return l[r];\n-                                }\n-                        }\n-                        u(v, \"isFolded\");\n-\n-                        function t(e) {\n-                            if (typeof e == \"string\") {\n-                                var n = document.createElement(\"div\");\n-                                return n.className = e + \" CodeMirror-guttermarker-subtle\", n;\n-                            } else return e.cloneNode(!0);\n-                        }\n-                        u(t, \"marker\");\n-\n-                        function o(e, n, l) {\n-                            var r = e.state.foldGutter.options,\n-                                c = n - 1,\n-                                h = e.foldOption(r, \"minFoldSize\"),\n-                                E = e.foldOption(r, \"rangeFinder\"),\n-                                S = typeof r.indicatorFolded == \"string\" && f(r.indicatorFolded),\n-                                T = typeof r.indicatorOpen == \"string\" && f(r.indicatorOpen);\n-                            e.eachLine(n, l, function(b) {\n-                                ++c;\n-                                var _ = null,\n-                                    F = b.gutterMarkers;\n-                                if (F && (F = F[r.gutter]), v(e, c)) {\n-                                    if (S && F && S.test(F.className)) return;\n-                                    _ = t(r.indicatorFolded);\n+                                }\n+                            } else if (newValue instanceof Set) {\n+                                error('other value', `Set instance`, path, depth);\n+                            } else if (oldArray || newArray) {\n+                                if (oldArray !== newArray) {\n+                                    error(`type ${oldArray ? 'array' : 'object'}`, `type ${newArray ? 'array' : 'object'}`, path, depth);\n+                                } else if (oldValue.length !== newValue.length) {\n+                                    error(`array with length ${oldValue.length}`, `array with length ${newValue.length}`, path, depth);\n                                 } else {\n-                                    var A = s(c, 0),\n-                                        m = E && E(e, A);\n-                                    if (m && m.to.line - m.from.line >= h) {\n-                                        if (T && F && T.test(F.className)) return;\n-                                        _ = t(r.indicatorOpen);\n+                                    for (let ii = 0; ii < oldValue.length; ii++) {\n+                                        recur(oldValue[ii], newValue[ii], `${path}[${ii}]`, depth + 1);\n+                                    }\n+                                }\n+                            } else if (isValidElement(oldValue) || isValidElement(newValue)) {\n+                                if (isValidElement(oldValue) !== isValidElement(newValue)) {\n+                                    error(`type ${isValidElement(oldValue) ? 'React element' : 'object'}`, `type ${isValidElement(newValue) ? 'React element' : 'object'}`, path, depth);\n+                                } else if (oldValue.type !== newValue.type) {\n+                                    error(`React element of type ${oldValue.type}`, `React element of type ${newValue.type}`, path, depth);\n+                                } else {\n+                                    recur(oldValue.props, newValue.props, `[props of ${path}]`, depth + 1);\n+                                }\n+                            } else {\n+                                for (const key in newValue) {\n+                                    if (!(key in oldValue)) {\n+                                        error(`object without key ${key}`, `object with key ${key}`, path, depth);\n+                                    }\n+                                }\n+                                for (const key in oldValue) {\n+                                    if (!(key in newValue)) {\n+                                        error(`object with key ${key}`, `object without key ${key}`, path, depth);\n+                                    } else {\n+                                        recur(oldValue[key], newValue[key], `${path}.${key}`, depth + 1);\n                                     }\n-                                }!_ && !F || e.setGutterMarker(b, r.gutter, _);\n-                            });\n-                        }\n-                        u(o, \"updateFoldInfo\");\n-\n-                        function f(e) {\n-                            return new RegExp(\"(^|\\\\s)\" + e + \"(?:$|\\\\s)\\\\s*\");\n-                        }\n-                        u(f, \"classTest\");\n-\n-                        function a(e) {\n-                            var n = e.getViewport(),\n-                                l = e.state.foldGutter;\n-                            l && (e.operation(function() {\n-                                o(e, n.from, n.to);\n-                            }), l.from = n.from, l.to = n.to);\n-                        }\n-                        u(a, \"updateInViewport\");\n-\n-                        function g(e, n, l) {\n-                            var r = e.state.foldGutter;\n-                            if (r) {\n-                                var c = r.options;\n-                                if (l == c.gutter) {\n-                                    var h = v(e, n);\n-                                    h ? h.clear() : e.foldCode(s(n, 0), c);\n                                 }\n                             }\n-                        }\n-                        u(g, \"onGutterClick\");\n-\n-                        function y(e) {\n-                            var n = e.state.foldGutter;\n-                            if (n) {\n-                                var l = n.options;\n-                                n.from = n.to = 0, clearTimeout(n.changeUpdate), n.changeUpdate = setTimeout(function() {\n-                                    a(e);\n-                                }, l.foldOnChangeTimeSpan || 600);\n-                            }\n-                        }\n-                        u(y, \"onChange\");\n-\n-                        function x(e) {\n-                            var n = e.state.foldGutter;\n-                            if (n) {\n-                                var l = n.options;\n-                                clearTimeout(n.changeUpdate), n.changeUpdate = setTimeout(function() {\n-                                    var r = e.getViewport();\n-                                    n.from == n.to || r.from - n.to > 20 || n.from - r.to > 20 ? a(e) : e.operation(function() {\n-                                        r.from < n.from && (o(e, r.from, n.from), n.from = r.from), r.to > n.to && (o(e, n.to, r.to), n.to = r.to);\n-                                    });\n-                                }, l.updateViewportTimeSpan || 400);\n-                            }\n-                        }\n-                        u(x, \"onViewportChange\");\n-\n-                        function d(e, n) {\n-                            var l = e.state.foldGutter;\n-                            if (l) {\n-                                var r = n.line;\n-                                r >= l.from && r < l.to && o(e, r, r + 1);\n-                            }\n-                        }\n-                        u(d, \"onFold\");\n-                    });\n-                })();\n-                var P = j.exports;\n-                const C = G.getDefaultExportFromCjs(P),\n-                    D = L({\n-                        __proto__: null,\n-                        default: C\n-                    }, [P]);\n-                exports.foldgutter = D;\n+                        } else if (typeof oldValue === 'function') {\n+                            return;\n+                        } else if (isNaN(oldValue) || isNaN(newValue)) {\n+                            if (isNaN(oldValue) !== isNaN(newValue)) {\n+                                error(`${isNaN(oldValue) ? 'NaN' : 'non-NaN value'}`, `${isNaN(newValue) ? 'NaN' : 'non-NaN value'}`, path, depth);\n+                            }\n+                        } else if (oldValue !== newValue) {\n+                            error(oldValue, newValue, path, depth);\n+                        }\n+                    }\n+                    recur(oldValue, newValue, '', 0);\n+                }\n+                exports.$dispatcherGuard = $dispatcherGuard;\n+                exports.$makeReadOnly = $makeReadOnly;\n+                exports.$reset = $reset;\n+                exports.$structuralCheck = $structuralCheck;\n+                exports.c = c;\n+                exports.clearRenderCounterRegistry = clearRenderCounterRegistry;\n+                exports.renderCounterRegistry = renderCounterRegistry;\n+                exports.useRenderCounter = useRenderCounter;\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-react/dist/forEachState.cjs.js\":\n-            /*!*****************************************************!*\\\n-              !*** ../../graphiql-react/dist/forEachState.cjs.js ***!\n-              \\*****************************************************/\n+        \"../../../node_modules/react-remove-scroll-bar/dist/es2015/component.js\":\n+            /*!******************************************************************************!*\\\n+              !*** ../../../node_modules/react-remove-scroll-bar/dist/es2015/component.js ***!\n+              \\******************************************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports) {\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                var c = Object.defineProperty;\n-                var r = (e, a) => c(e, \"name\", {\n-                    value: a,\n-                    configurable: !0\n-                });\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.RemoveScrollBar = void 0;\n+                var React = _interopRequireWildcard(__webpack_require__( /*! react */ \"react\"));\n+                var _reactStyleSingleton = __webpack_require__( /*! react-style-singleton */ \"../../../node_modules/react-style-singleton/dist/es2015/index.js\");\n+                var _constants = __webpack_require__( /*! ./constants */ \"../../../node_modules/react-remove-scroll-bar/dist/es2015/constants.js\");\n+                var _utils = __webpack_require__( /*! ./utils */ \"../../../node_modules/react-remove-scroll-bar/dist/es2015/utils.js\");\n \n-                function l(e, a) {\n-                    const i = [];\n-                    let t = e;\n-                    for (; t != null && t.kind;) i.push(t), t = t.prevState;\n-                    for (let o = i.length - 1; o >= 0; o--) a(i[o]);\n+                function _getRequireWildcardCache(e) {\n+                    if (\"function\" != typeof WeakMap) return null;\n+                    var r = new WeakMap(),\n+                        t = new WeakMap();\n+                    return (_getRequireWildcardCache = function(e) {\n+                        return e ? t : r;\n+                    })(e);\n+                }\n+\n+                function _interopRequireWildcard(e, r) {\n+                    if (!r && e && e.__esModule) return e;\n+                    if (null === e || \"object\" != typeof e && \"function\" != typeof e) return {\n+                        default: e\n+                    };\n+                    var t = _getRequireWildcardCache(r);\n+                    if (t && t.has(e)) return t.get(e);\n+                    var n = {\n+                            __proto__: null\n+                        },\n+                        a = Object.defineProperty && Object.getOwnPropertyDescriptor;\n+                    for (var u in e)\n+                        if (\"default\" !== u && Object.prototype.hasOwnProperty.call(e, u)) {\n+                            var i = a ? Object.getOwnPropertyDescriptor(e, u) : null;\n+                            i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u];\n+                        } return n.default = e, t && t.set(e, n), n;\n                 }\n-                r(l, \"forEachState\");\n-                exports.forEachState = l;\n+                var Style = (0, _reactStyleSingleton.styleSingleton)();\n+                // important tip - once we measure scrollBar width and remove them\n+                // we could not repeat this operation\n+                // thus we are using style-singleton - only the first \"yet correct\" style will be applied.\n+                var getStyles = function(_a, allowRelative, gapMode, important) {\n+                    var left = _a.left,\n+                        top = _a.top,\n+                        right = _a.right,\n+                        gap = _a.gap;\n+                    if (gapMode === void 0) {\n+                        gapMode = 'margin';\n+                    }\n+                    return \"\\n  .\".concat(_constants.noScrollbarsClassName, \" {\\n   overflow: hidden \").concat(important, \";\\n   padding-right: \").concat(gap, \"px \").concat(important, \";\\n  }\\n  body {\\n    overflow: hidden \").concat(important, \";\\n    overscroll-behavior: contain;\\n    \").concat([allowRelative && \"position: relative \".concat(important, \";\"), gapMode === 'margin' && \"\\n    padding-left: \".concat(left, \"px;\\n    padding-top: \").concat(top, \"px;\\n    padding-right: \").concat(right, \"px;\\n    margin-left:0;\\n    margin-top:0;\\n    margin-right: \").concat(gap, \"px \").concat(important, \";\\n    \"), gapMode === 'padding' && \"padding-right: \".concat(gap, \"px \").concat(important, \";\")].filter(Boolean).join(''), \"\\n  }\\n  \\n  .\").concat(_constants.zeroRightClassName, \" {\\n    right: \").concat(gap, \"px \").concat(important, \";\\n  }\\n  \\n  .\").concat(_constants.fullWidthClassName, \" {\\n    margin-right: \").concat(gap, \"px \").concat(important, \";\\n  }\\n  \\n  .\").concat(_constants.zeroRightClassName, \" .\").concat(_constants.zeroRightClassName, \" {\\n    right: 0 \").concat(important, \";\\n  }\\n  \\n  .\").concat(_constants.fullWidthClassName, \" .\").concat(_constants.fullWidthClassName, \" {\\n    margin-right: 0 \").concat(important, \";\\n  }\\n  \\n  body {\\n    \").concat(_constants.removedBarSizeVariable, \": \").concat(gap, \"px;\\n  }\\n\");\n+                };\n+                /**\n+                 * Removes page scrollbar and blocks page scroll when mounted\n+                 */\n+                var RemoveScrollBar = function(props) {\n+                    var noRelative = props.noRelative,\n+                        noImportant = props.noImportant,\n+                        _a = props.gapMode,\n+                        gapMode = _a === void 0 ? 'margin' : _a;\n+                    var gap = React.useMemo(function() {\n+                        return (0, _utils.getGapWidth)(gapMode);\n+                    }, [gapMode]);\n+                    return /*#__PURE__*/ React.createElement(Style, {\n+                        styles: getStyles(gap, !noRelative, gapMode, !noImportant ? '!important' : '')\n+                    });\n+                };\n+                exports.RemoveScrollBar = RemoveScrollBar;\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-react/dist/hint.cjs.js\":\n-            /*!*********************************************!*\\\n-              !*** ../../graphiql-react/dist/hint.cjs.js ***!\n-              \\*********************************************/\n+        \"../../../node_modules/react-remove-scroll-bar/dist/es2015/constants.js\":\n+            /*!******************************************************************************!*\\\n+              !*** ../../../node_modules/react-remove-scroll-bar/dist/es2015/constants.js ***!\n+              \\******************************************************************************/\n             /***/\n-            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n+            (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n-                const s = __webpack_require__( /*! ./codemirror.cjs.js */ \"../../graphiql-react/dist/codemirror.cjs.js\");\n-                __webpack_require__( /*! ./show-hint.cjs.js */ \"../../graphiql-react/dist/show-hint.cjs.js\");\n-                const c = __webpack_require__( /*! graphql-language-service */ \"../../graphql-language-service/esm/index.js\");\n-                __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\");\n-                s.CodeMirror.registerHelper(\"hint\", \"graphql\", (r, a) => {\n-                    const {\n-                        schema: i,\n-                        externalFragments: u\n-                    } = a;\n-                    if (!i) return;\n-                    const n = r.getCursor(),\n-                        t = r.getTokenAt(n),\n-                        l = t.type !== null && /\"|\\w/.test(t.string[0]) ? t.start : t.end,\n-                        g = new c.Position(n.line, l),\n-                        e = {\n-                            list: c.getAutocompleteSuggestions(i, r.getValue(), g, t, u).map(o => ({\n-                                text: o.label,\n-                                type: o.type,\n-                                description: o.documentation,\n-                                isDeprecated: o.isDeprecated,\n-                                deprecationReason: o.deprecationReason\n-                            })),\n-                            from: {\n-                                line: n.line,\n-                                ch: l\n-                            },\n-                            to: {\n-                                line: n.line,\n-                                ch: t.end\n-                            }\n-                        };\n-                    return e != null && e.list && e.list.length > 0 && (e.from = s.CodeMirror.Pos(e.from.line, e.from.ch), e.to = s.CodeMirror.Pos(e.to.line, e.to.ch), s.CodeMirror.signal(r, \"hasCompletion\", r, e, t)), e;\n-                });\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.zeroRightClassName = exports.removedBarSizeVariable = exports.noScrollbarsClassName = exports.fullWidthClassName = void 0;\n+                var zeroRightClassName = exports.zeroRightClassName = 'right-scroll-bar-position';\n+                var fullWidthClassName = exports.fullWidthClassName = 'width-before-scroll-bar';\n+                var noScrollbarsClassName = exports.noScrollbarsClassName = 'with-scroll-bars-hidden';\n+                /**\n+                 * Name of a CSS variable containing the amount of \"hidden\" scrollbar\n+                 * ! might be undefined ! use will fallback!\n+                 */\n+                var removedBarSizeVariable = exports.removedBarSizeVariable = '--removed-body-scroll-bar-size';\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-react/dist/hint.cjs2.js\":\n-            /*!**********************************************!*\\\n-              !*** ../../graphiql-react/dist/hint.cjs2.js ***!\n-              \\**********************************************/\n+        \"../../../node_modules/react-remove-scroll-bar/dist/es2015/index.js\":\n+            /*!**************************************************************************!*\\\n+              !*** ../../../node_modules/react-remove-scroll-bar/dist/es2015/index.js ***!\n+              \\**************************************************************************/\n             /***/\n-            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                var g = Object.defineProperty;\n-                var p = (i, n) => g(i, \"name\", {\n-                    value: n,\n-                    configurable: !0\n-                });\n-                const d = __webpack_require__( /*! ./codemirror.cjs.js */ \"../../graphiql-react/dist/codemirror.cjs.js\"),\n-                    a = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\"),\n-                    b = __webpack_require__( /*! ./forEachState.cjs.js */ \"../../graphiql-react/dist/forEachState.cjs.js\");\n-                __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\");\n-\n-                function f(i, n, t) {\n-                    const r = x(t, m(n.string));\n-                    if (!r) return;\n-                    const e = n.type !== null && /\"|\\w/.test(n.string[0]) ? n.start : n.end;\n-                    return {\n-                        list: r,\n-                        from: {\n-                            line: i.line,\n-                            ch: e\n-                        },\n-                        to: {\n-                            line: i.line,\n-                            ch: n.end\n-                        }\n-                    };\n-                }\n-                p(f, \"hintList\");\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                Object.defineProperty(exports, \"RemoveScrollBar\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _component.RemoveScrollBar;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"fullWidthClassName\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _constants.fullWidthClassName;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"getGapWidth\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _utils.getGapWidth;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"noScrollbarsClassName\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _constants.noScrollbarsClassName;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"removedBarSizeVariable\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _constants.removedBarSizeVariable;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"zeroRightClassName\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _constants.zeroRightClassName;\n+                    }\n+                }));\n+                var _component = __webpack_require__( /*! ./component */ \"../../../node_modules/react-remove-scroll-bar/dist/es2015/component.js\");\n+                var _constants = __webpack_require__( /*! ./constants */ \"../../../node_modules/react-remove-scroll-bar/dist/es2015/constants.js\");\n+                var _utils = __webpack_require__( /*! ./utils */ \"../../../node_modules/react-remove-scroll-bar/dist/es2015/utils.js\");\n \n-                function x(i, n) {\n-                    if (!n) return y(i, o => !o.isDeprecated);\n-                    const t = i.map(o => ({\n-                        proximity: L(m(o.text), n),\n-                        entry: o\n-                    }));\n-                    return y(y(t, o => o.proximity <= 2), o => !o.entry.isDeprecated).sort((o, l) => (o.entry.isDeprecated ? 1 : 0) - (l.entry.isDeprecated ? 1 : 0) || o.proximity - l.proximity || o.entry.text.length - l.entry.text.length).map(o => o.entry);\n-                }\n-                p(x, \"filterAndSortList\");\n+                /***/\n+            }),\n \n-                function y(i, n) {\n-                    const t = i.filter(n);\n-                    return t.length === 0 ? i : t;\n-                }\n-                p(y, \"filterNonEmpty\");\n+        /***/\n+        \"../../../node_modules/react-remove-scroll-bar/dist/es2015/utils.js\":\n+            /*!**************************************************************************!*\\\n+              !*** ../../../node_modules/react-remove-scroll-bar/dist/es2015/utils.js ***!\n+              \\**************************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports) {\n \n-                function m(i) {\n-                    return i.toLowerCase().replaceAll(/\\W/g, \"\");\n-                }\n-                p(m, \"normalizeText\");\n+                \"use strict\";\n \n-                function L(i, n) {\n-                    let t = T(n, i);\n-                    return i.length > n.length && (t -= i.length - n.length - 1, t += i.indexOf(n) === 0 ? 0 : .5), t;\n-                }\n-                p(L, \"getProximity\");\n \n-                function T(i, n) {\n-                    let t, r;\n-                    const e = [],\n-                        o = i.length,\n-                        l = n.length;\n-                    for (t = 0; t <= o; t++) e[t] = [t];\n-                    for (r = 1; r <= l; r++) e[0][r] = r;\n-                    for (t = 1; t <= o; t++)\n-                        for (r = 1; r <= l; r++) {\n-                            const u = i[t - 1] === n[r - 1] ? 0 : 1;\n-                            e[t][r] = Math.min(e[t - 1][r] + 1, e[t][r - 1] + 1, e[t - 1][r - 1] + u), t > 1 && r > 1 && i[t - 1] === n[r - 2] && i[t - 2] === n[r - 1] && (e[t][r] = Math.min(e[t][r], e[t - 2][r - 2] + u));\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.zeroGap = exports.getGapWidth = void 0;\n+                var zeroGap = exports.zeroGap = {\n+                    left: 0,\n+                    top: 0,\n+                    right: 0,\n+                    gap: 0\n+                };\n+                var parse = function(x) {\n+                    return parseInt(x || '', 10) || 0;\n+                };\n+                var getOffset = function(gapMode) {\n+                    var cs = window.getComputedStyle(document.body);\n+                    if (true) {\n+                        if (cs.overflowY === 'hidden') {\n+                            console.error('react-remove-scroll-bar: cannot calculate scrollbar size because it is removed (overflow:hidden on body');\n                         }\n-                    return e[o][l];\n-                }\n-                p(T, \"lexicalDistance\");\n-                d.CodeMirror.registerHelper(\"hint\", \"graphql-variables\", (i, n) => {\n-                    const t = i.getCursor(),\n-                        r = i.getTokenAt(t),\n-                        e = V(t, r, n);\n-                    return e != null && e.list && e.list.length > 0 && (e.from = d.CodeMirror.Pos(e.from.line, e.from.ch), e.to = d.CodeMirror.Pos(e.to.line, e.to.ch), d.CodeMirror.signal(i, \"hasCompletion\", i, e, r)), e;\n-                });\n-\n-                function V(i, n, t) {\n-                    const r = n.state.kind === \"Invalid\" ? n.state.prevState : n.state,\n-                        {\n-                            kind: e,\n-                            step: o\n-                        } = r;\n-                    if (e === \"Document\" && o === 0) return f(i, n, [{\n-                        text: \"{\"\n-                    }]);\n-                    const {\n-                        variableToType: l\n-                    } = t;\n-                    if (!l) return;\n-                    const u = j(l, n.state);\n-                    if (e === \"Document\" || e === \"Variable\" && o === 0) {\n-                        const c = Object.keys(l);\n-                        return f(i, n, c.map(s => ({\n-                            text: `\"${s}\": `,\n-                            type: l[s]\n-                        })));\n                     }\n-                    if ((e === \"ObjectValue\" || e === \"ObjectField\" && o === 0) && u.fields) {\n-                        const c = Object.keys(u.fields).map(s => u.fields[s]);\n-                        return f(i, n, c.map(s => ({\n-                            text: `\"${s.name}\": `,\n-                            type: s.type,\n-                            description: s.description\n-                        })));\n+                    var left = cs[gapMode === 'padding' ? 'paddingLeft' : 'marginLeft'];\n+                    var top = cs[gapMode === 'padding' ? 'paddingTop' : 'marginTop'];\n+                    var right = cs[gapMode === 'padding' ? 'paddingRight' : 'marginRight'];\n+                    return [parse(left), parse(top), parse(right)];\n+                };\n+                var getGapWidth = function(gapMode) {\n+                    if (gapMode === void 0) {\n+                        gapMode = 'margin';\n                     }\n-                    if (e === \"StringValue\" || e === \"NumberValue\" || e === \"BooleanValue\" || e === \"NullValue\" || e === \"ListValue\" && o === 1 || e === \"ObjectField\" && o === 2 || e === \"Variable\" && o === 2) {\n-                        const c = u.type ? a.getNamedType(u.type) : void 0;\n-                        if (c instanceof a.GraphQLInputObjectType) return f(i, n, [{\n-                            text: \"{\"\n-                        }]);\n-                        if (c instanceof a.GraphQLEnumType) {\n-                            const s = c.getValues();\n-                            return f(i, n, s.map(h => ({\n-                                text: `\"${h.name}\"`,\n-                                type: c,\n-                                description: h.description\n-                            })));\n-                        }\n-                        if (c === a.GraphQLBoolean) return f(i, n, [{\n-                            text: \"true\",\n-                            type: a.GraphQLBoolean,\n-                            description: \"Not false.\"\n-                        }, {\n-                            text: \"false\",\n-                            type: a.GraphQLBoolean,\n-                            description: \"Not true.\"\n-                        }]);\n+                    if (typeof window === 'undefined') {\n+                        return zeroGap;\n                     }\n-                }\n-                p(V, \"getVariablesHint\");\n-\n-                function j(i, n) {\n-                    const t = {\n-                        type: null,\n-                        fields: null\n+                    var offsets = getOffset(gapMode);\n+                    var documentWidth = document.documentElement.clientWidth;\n+                    var windowWidth = window.innerWidth;\n+                    return {\n+                        left: offsets[0],\n+                        top: offsets[1],\n+                        right: offsets[2],\n+                        gap: Math.max(0, windowWidth - documentWidth + offsets[2] - offsets[0])\n                     };\n-                    return b.forEachState(n, r => {\n-                        switch (r.kind) {\n-                            case \"Variable\": {\n-                                t.type = i[r.name];\n-                                break;\n-                            }\n-                            case \"ListValue\": {\n-                                const e = t.type ? a.getNullableType(t.type) : void 0;\n-                                t.type = e instanceof a.GraphQLList ? e.ofType : null;\n-                                break;\n-                            }\n-                            case \"ObjectValue\": {\n-                                const e = t.type ? a.getNamedType(t.type) : void 0;\n-                                t.fields = e instanceof a.GraphQLInputObjectType ? e.getFields() : null;\n-                                break;\n-                            }\n-                            case \"ObjectField\": {\n-                                const e = r.name && t.fields ? t.fields[r.name] : null;\n-                                t.type = e == null ? void 0 : e.type;\n-                                break;\n-                            }\n-                        }\n-                    }), t;\n-                }\n-                p(j, \"getTypeInfo\");\n+                };\n+                exports.getGapWidth = getGapWidth;\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-react/dist/index.js\":\n-            /*!******************************************!*\\\n-              !*** ../../graphiql-react/dist/index.js ***!\n-              \\******************************************/\n+        \"../../../node_modules/react-remove-scroll/dist/es2015/Combination.js\":\n+            /*!****************************************************************************!*\\\n+              !*** ../../../node_modules/react-remove-scroll/dist/es2015/Combination.js ***!\n+              \\****************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                var Nn = Object.defineProperty;\n-                var a = (e, t) => Nn(e, \"name\", {\n-                    value: t,\n-                    configurable: !0\n-                });\n-                Object.defineProperty(exports, Symbol.toStringTag, {\n-                    value: \"Module\"\n-                });\n-                const s = __webpack_require__( /*! react/jsx-runtime */ \"../../../node_modules/react/jsx-runtime.js\"),\n-                    l = __webpack_require__( /*! react */ \"react\"),\n-                    _ = __webpack_require__( /*! clsx */ \"../../../node_modules/clsx/dist/clsx.m.js\"),\n-                    M = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\"),\n-                    B = __webpack_require__( /*! @graphiql/toolkit */ \"../../graphiql-toolkit/esm/index.js\"),\n-                    jt = __webpack_require__( /*! graphql-language-service */ \"../../graphql-language-service/esm/index.js\"),\n-                    $e = __webpack_require__( /*! set-value */ \"../../../node_modules/set-value/index.js\"),\n-                    Tn = __webpack_require__( /*! copy-to-clipboard */ \"../../../node_modules/copy-to-clipboard/index.js\"),\n-                    Mn = __webpack_require__( /*! @radix-ui/react-dialog */ \"../../../node_modules/@radix-ui/react-dialog/dist/index.js\"),\n-                    Pn = __webpack_require__( /*! @radix-ui/react-visually-hidden */ \"../../../node_modules/@radix-ui/react-visually-hidden/dist/index.js\"),\n-                    xe = __webpack_require__( /*! @radix-ui/react-dropdown-menu */ \"../../../node_modules/@radix-ui/react-dropdown-menu/dist/index.js\"),\n-                    qn = __webpack_require__( /*! markdown-it */ \"../node_modules/markdown-it/dist/index.cjs.js\"),\n-                    kt = __webpack_require__( /*! framer-motion */ \"../../../node_modules/framer-motion/dist/cjs/index.js\"),\n-                    Rn = __webpack_require__( /*! @radix-ui/react-tooltip */ \"../../../node_modules/@radix-ui/react-tooltip/dist/index.js\"),\n-                    ae = __webpack_require__( /*! @headlessui/react */ \"../../../node_modules/@headlessui/react/dist/index.cjs\"),\n-                    vt = __webpack_require__( /*! react-dom */ \"react-dom\");\n-\n-                function nt(e) {\n-                    const t = Object.create(null, {\n-                        [Symbol.toStringTag]: {\n-                            value: \"Module\"\n-                        }\n-                    });\n-                    if (e) {\n-                        for (const n in e)\n-                            if (n !== \"default\") {\n-                                const r = Object.getOwnPropertyDescriptor(e, n);\n-                                Object.defineProperty(t, n, r.get ? r : {\n-                                    enumerable: !0,\n-                                    get: () => e[n]\n-                                });\n-                            }\n-                    }\n-                    return t.default = e, Object.freeze(t);\n-                }\n-                a(nt, \"_interopNamespaceDefault\");\n-                const u = nt(l),\n-                    ne = nt(Mn),\n-                    pe = nt(Rn);\n-\n-                function oe(e) {\n-                    const t = l.createContext(null);\n-                    return t.displayName = e, t;\n-                }\n-                a(oe, \"createNullableContext\");\n-\n-                function le(e) {\n-                    function t(n) {\n-                        var o;\n-                        const r = l.useContext(e);\n-                        if (r === null && n != null && n.nonNull) throw new Error(`Tried to use \\`${((o = n.caller) == null ? void 0 : o.name) || t.caller.name}\\` without the necessary context. Make sure to render the \\`${e.displayName}Provider\\` component higher up the tree.`);\n-                        return r;\n-                    }\n-                    return a(t, \"useGivenContext\"), Object.defineProperty(t, \"name\", {\n-                        value: `use${e.displayName}`\n-                    }), t;\n-                }\n-                a(le, \"createContextHook\");\n-                const rt = oe(\"StorageContext\");\n-\n-                function Nt(e) {\n-                    const t = l.useRef(!0),\n-                        [n, r] = l.useState(new B.StorageAPI(e.storage));\n-                    return l.useEffect(() => {\n-                        t.current ? t.current = !1 : r(new B.StorageAPI(e.storage));\n-                    }, [e.storage]), s.jsx(rt.Provider, {\n-                        value: n,\n-                        children: e.children\n-                    });\n-                }\n-                a(Nt, \"StorageContextProvider\");\n-                const re = le(rt),\n-                    Vn = a(_ref => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 14 14\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"path\", {\n-                            d: \"M5.0484 1.40838C6.12624 0.33054 7.87376 0.330541 8.9516 1.40838L12.5916 5.0484C13.6695 6.12624 13.6695 7.87376 12.5916 8.9516L8.9516 12.5916C7.87376 13.6695 6.12624 13.6695 5.0484 12.5916L1.40838 8.9516C0.33054 7.87376 0.330541 6.12624 1.40838 5.0484L5.0484 1.40838Z\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.2\n-                        }), u.createElement(\"rect\", {\n-                            x: 6,\n-                            y: 6,\n-                            width: 2,\n-                            height: 2,\n-                            rx: 1,\n-                            fill: \"currentColor\"\n-                        }));\n-                    }, \"SvgArgument\"),\n-                    In = a(_ref2 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref2;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 14 9\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"path\", {\n-                            d: \"M1 1L7 7L13 1\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.5\n-                        }));\n-                    }, \"SvgChevronDown\"),\n-                    Hn = a(_ref3 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref3;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 7 10\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"path\", {\n-                            d: \"M6 1.04819L2 5.04819L6 9.04819\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.75\n-                        }));\n-                    }, \"SvgChevronLeft\"),\n-                    Dn = a(_ref4 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref4;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 14 9\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"path\", {\n-                            d: \"M13 8L7 2L1 8\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.5\n-                        }));\n-                    }, \"SvgChevronUp\"),\n-                    An = a(_ref5 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref5;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 14 14\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"path\", {\n-                            d: \"M1 1L12.9998 12.9997\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.5\n-                        }), u.createElement(\"path\", {\n-                            d: \"M13 1L1.00079 13.0003\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.5\n-                        }));\n-                    }, \"SvgClose\"),\n-                    On = a(_ref6 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref6;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"-2 -2 22 22\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"path\", {\n-                            d: \"M11.25 14.2105V15.235C11.25 16.3479 10.3479 17.25 9.23501 17.25H2.76499C1.65214 17.25 0.75 16.3479 0.75 15.235L0.75 8.76499C0.75 7.65214 1.65214 6.75 2.76499 6.75L3.78947 6.75\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.5\n-                        }), u.createElement(\"rect\", {\n-                            x: 6.75,\n-                            y: .75,\n-                            width: 10.5,\n-                            height: 10.5,\n-                            rx: 2.2069,\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.5\n-                        }));\n-                    }, \"SvgCopy\"),\n-                    Fn = a(_ref7 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref7;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 14 14\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"path\", {\n-                            d: \"M5.0484 1.40838C6.12624 0.33054 7.87376 0.330541 8.9516 1.40838L12.5916 5.0484C13.6695 6.12624 13.6695 7.87376 12.5916 8.9516L8.9516 12.5916C7.87376 13.6695 6.12624 13.6695 5.0484 12.5916L1.40838 8.9516C0.33054 7.87376 0.330541 6.12624 1.40838 5.0484L5.0484 1.40838Z\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.2\n-                        }), u.createElement(\"path\", {\n-                            d: \"M5 9L9 5\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.2\n-                        }), u.createElement(\"path\", {\n-                            d: \"M5 5L9 9\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.2\n-                        }));\n-                    }, \"SvgDeprecatedArgument\"),\n-                    Bn = a(_ref8 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref8;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 12 12\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"path\", {\n-                            d: \"M4 8L8 4\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.2\n-                        }), u.createElement(\"path\", {\n-                            d: \"M4 4L8 8\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.2\n-                        }), u.createElement(\"path\", {\n-                            fillRule: \"evenodd\",\n-                            clipRule: \"evenodd\",\n-                            d: \"M8.5 1.2H9C9.99411 1.2 10.8 2.00589 10.8 3V9C10.8 9.99411 9.99411 10.8 9 10.8H8.5V12H9C10.6569 12 12 10.6569 12 9V3C12 1.34315 10.6569 0 9 0H8.5V1.2ZM3.5 1.2V0H3C1.34315 0 0 1.34315 0 3V9C0 10.6569 1.34315 12 3 12H3.5V10.8H3C2.00589 10.8 1.2 9.99411 1.2 9V3C1.2 2.00589 2.00589 1.2 3 1.2H3.5Z\",\n-                            fill: \"currentColor\"\n-                        }));\n-                    }, \"SvgDeprecatedEnumValue\"),\n-                    Wn = a(_ref9 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref9;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 12 12\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"rect\", {\n-                            x: .6,\n-                            y: .6,\n-                            width: 10.8,\n-                            height: 10.8,\n-                            rx: 3.4,\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.2\n-                        }), u.createElement(\"path\", {\n-                            d: \"M4 8L8 4\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.2\n-                        }), u.createElement(\"path\", {\n-                            d: \"M4 4L8 8\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.2\n-                        }));\n-                    }, \"SvgDeprecatedField\"),\n-                    _n = a(_ref10 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref10;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0.5 12 12\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"rect\", {\n-                            x: 7,\n-                            y: 5.5,\n-                            width: 2,\n-                            height: 2,\n-                            rx: 1,\n-                            transform: \"rotate(90 7 5.5)\",\n-                            fill: \"currentColor\"\n-                        }), u.createElement(\"path\", {\n-                            fillRule: \"evenodd\",\n-                            clipRule: \"evenodd\",\n-                            d: \"M10.8 9L10.8 9.5C10.8 10.4941 9.99411 11.3 9 11.3L3 11.3C2.00589 11.3 1.2 10.4941 1.2 9.5L1.2 9L-3.71547e-07 9L-3.93402e-07 9.5C-4.65826e-07 11.1569 1.34314 12.5 3 12.5L9 12.5C10.6569 12.5 12 11.1569 12 9.5L12 9L10.8 9ZM10.8 4L12 4L12 3.5C12 1.84315 10.6569 0.5 9 0.5L3 0.5C1.34315 0.5 -5.87117e-08 1.84315 -1.31135e-07 3.5L-1.5299e-07 4L1.2 4L1.2 3.5C1.2 2.50589 2.00589 1.7 3 1.7L9 1.7C9.99411 1.7 10.8 2.50589 10.8 3.5L10.8 4Z\",\n-                            fill: \"currentColor\"\n-                        }));\n-                    }, \"SvgDirective\"),\n-                    Zn = a(_ref11 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref11;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 20 24\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"path\", {\n-                            d: \"M0.75 3C0.75 1.75736 1.75736 0.75 3 0.75H17.25C17.8023 0.75 18.25 1.19772 18.25 1.75V5.25\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.5\n-                        }), u.createElement(\"path\", {\n-                            d: \"M0.75 3C0.75 4.24264 1.75736 5.25 3 5.25H18.25C18.8023 5.25 19.25 5.69771 19.25 6.25V22.25C19.25 22.8023 18.8023 23.25 18.25 23.25H3C1.75736 23.25 0.75 22.2426 0.75 21V3Z\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.5\n-                        }), u.createElement(\"path\", {\n-                            fillRule: \"evenodd\",\n-                            clipRule: \"evenodd\",\n-                            d: \"M3 5.25C1.75736 5.25 0.75 4.24264 0.75 3V21C0.75 22.2426 1.75736 23.25 3 23.25H18.25C18.8023 23.25 19.25 22.8023 19.25 22.25V6.25C19.25 5.69771 18.8023 5.25 18.25 5.25H3ZM13 11L6 11V12.5L13 12.5V11Z\",\n-                            fill: \"currentColor\"\n-                        }));\n-                    }, \"SvgDocsFilled\"),\n-                    Gn = a(_ref12 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref12;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 20 24\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"path\", {\n-                            d: \"M0.75 3C0.75 4.24264 1.75736 5.25 3 5.25H17.25M0.75 3C0.75 1.75736 1.75736 0.75 3 0.75H16.25C16.8023 0.75 17.25 1.19772 17.25 1.75V5.25M0.75 3V21C0.75 22.2426 1.75736 23.25 3 23.25H18.25C18.8023 23.25 19.25 22.8023 19.25 22.25V6.25C19.25 5.69771 18.8023 5.25 18.25 5.25H17.25\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.5\n-                        }), u.createElement(\"line\", {\n-                            x1: 13,\n-                            y1: 11.75,\n-                            x2: 6,\n-                            y2: 11.75,\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.5\n-                        }));\n-                    }, \"SvgDocs\"),\n-                    $n = a(_ref13 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref13;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 12 12\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"rect\", {\n-                            x: 5,\n-                            y: 5,\n-                            width: 2,\n-                            height: 2,\n-                            rx: 1,\n-                            fill: \"currentColor\"\n-                        }), u.createElement(\"path\", {\n-                            fillRule: \"evenodd\",\n-                            clipRule: \"evenodd\",\n-                            d: \"M8.5 1.2H9C9.99411 1.2 10.8 2.00589 10.8 3V9C10.8 9.99411 9.99411 10.8 9 10.8H8.5V12H9C10.6569 12 12 10.6569 12 9V3C12 1.34315 10.6569 0 9 0H8.5V1.2ZM3.5 1.2V0H3C1.34315 0 0 1.34315 0 3V9C0 10.6569 1.34315 12 3 12H3.5V10.8H3C2.00589 10.8 1.2 9.99411 1.2 9V3C1.2 2.00589 2.00589 1.2 3 1.2H3.5Z\",\n-                            fill: \"currentColor\"\n-                        }));\n-                    }, \"SvgEnumValue\"),\n-                    Qn = a(_ref14 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref14;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 12 13\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"rect\", {\n-                            x: .6,\n-                            y: 1.1,\n-                            width: 10.8,\n-                            height: 10.8,\n-                            rx: 2.4,\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.2\n-                        }), u.createElement(\"rect\", {\n-                            x: 5,\n-                            y: 5.5,\n-                            width: 2,\n-                            height: 2,\n-                            rx: 1,\n-                            fill: \"currentColor\"\n-                        }));\n-                    }, \"SvgField\"),\n-                    zn = a(_ref15 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref15;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 24 20\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"path\", {\n-                            d: \"M1.59375 9.52344L4.87259 12.9944L8.07872 9.41249\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.5,\n-                            strokeLinecap: \"square\"\n-                        }), u.createElement(\"path\", {\n-                            d: \"M13.75 5.25V10.75H18.75\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.5,\n-                            strokeLinecap: \"square\"\n-                        }), u.createElement(\"path\", {\n-                            d: \"M4.95427 11.9332C4.55457 10.0629 4.74441 8.11477 5.49765 6.35686C6.25089 4.59894 7.5305 3.11772 9.16034 2.11709C10.7902 1.11647 12.6901 0.645626 14.5986 0.769388C16.5071 0.893151 18.3303 1.60543 19.8172 2.80818C21.3042 4.01093 22.3818 5.64501 22.9017 7.48548C23.4216 9.32595 23.3582 11.2823 22.7203 13.0853C22.0824 14.8883 20.9013 16.4492 19.3396 17.5532C17.778 18.6572 15.9125 19.25 14 19.25\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.5\n-                        }));\n-                    }, \"SvgHistory\"),\n-                    Un = a(_ref16 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref16;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 12 12\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"circle\", {\n-                            cx: 6,\n-                            cy: 6,\n-                            r: 5.4,\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.2,\n-                            strokeDasharray: \"4.241025 4.241025\",\n-                            transform: \"rotate(22.5)\",\n-                            \"transform-origin\": \"center\"\n-                        }), u.createElement(\"circle\", {\n-                            cx: 6,\n-                            cy: 6,\n-                            r: 1,\n-                            fill: \"currentColor\"\n-                        }));\n-                    }, \"SvgImplements\"),\n-                    Kn = a(_ref17 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref17;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 19 18\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"path\", {\n-                            d: \"M1.5 14.5653C1.5 15.211 1.75652 15.8303 2.21314 16.2869C2.66975 16.7435 3.28905 17 3.9348 17C4.58054 17 5.19984 16.7435 5.65646 16.2869C6.11307 15.8303 6.36959 15.211 6.36959 14.5653V12.1305H3.9348C3.28905 12.1305 2.66975 12.387 2.21314 12.8437C1.75652 13.3003 1.5 13.9195 1.5 14.5653Z\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.125,\n-                            strokeLinecap: \"round\",\n-                            strokeLinejoin: \"round\"\n-                        }), u.createElement(\"path\", {\n-                            d: \"M3.9348 1.00063C3.28905 1.00063 2.66975 1.25715 2.21314 1.71375C1.75652 2.17035 1.5 2.78964 1.5 3.43537C1.5 4.0811 1.75652 4.70038 2.21314 5.15698C2.66975 5.61358 3.28905 5.8701 3.9348 5.8701H6.36959V3.43537C6.36959 2.78964 6.11307 2.17035 5.65646 1.71375C5.19984 1.25715 4.58054 1.00063 3.9348 1.00063Z\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.125,\n-                            strokeLinecap: \"round\",\n-                            strokeLinejoin: \"round\"\n-                        }), u.createElement(\"path\", {\n-                            d: \"M15.0652 12.1305H12.6304V14.5653C12.6304 15.0468 12.7732 15.5175 13.0407 15.9179C13.3083 16.3183 13.6885 16.6304 14.1334 16.8147C14.5783 16.9989 15.0679 17.0472 15.5402 16.9532C16.0125 16.8593 16.4464 16.6274 16.7869 16.2869C17.1274 15.9464 17.3593 15.5126 17.4532 15.0403C17.5472 14.568 17.4989 14.0784 17.3147 13.6335C17.1304 13.1886 16.8183 12.8084 16.4179 12.5409C16.0175 12.2733 15.5468 12.1305 15.0652 12.1305Z\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.125,\n-                            strokeLinecap: \"round\",\n-                            strokeLinejoin: \"round\"\n-                        }), u.createElement(\"path\", {\n-                            d: \"M12.6318 5.86775H6.36955V12.1285H12.6318V5.86775Z\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.125,\n-                            strokeLinecap: \"round\",\n-                            strokeLinejoin: \"round\"\n-                        }), u.createElement(\"path\", {\n-                            d: \"M17.5 3.43473C17.5 2.789 17.2435 2.16972 16.7869 1.71312C16.3303 1.25652 15.711 1 15.0652 1C14.4195 1 13.8002 1.25652 13.3435 1.71312C12.8869 2.16972 12.6304 2.789 12.6304 3.43473V5.86946H15.0652C15.711 5.86946 16.3303 5.61295 16.7869 5.15635C17.2435 4.69975 17.5 4.08046 17.5 3.43473Z\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.125,\n-                            strokeLinecap: \"round\",\n-                            strokeLinejoin: \"round\"\n-                        }));\n-                    }, \"SvgKeyboardShortcut\"),\n-                    Jn = a(_ref18 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref18;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 13 13\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"circle\", {\n-                            cx: 5,\n-                            cy: 5,\n-                            r: 4.35,\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.3\n-                        }), u.createElement(\"line\", {\n-                            x1: 8.45962,\n-                            y1: 8.54038,\n-                            x2: 11.7525,\n-                            y2: 11.8333,\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.3\n-                        }));\n-                    }, \"SvgMagnifyingGlass\"),\n-                    Yn = a(_ref19 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref19;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"-2 -2 22 22\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"path\", {\n-                            d: \"M17.2492 6V2.9569C17.2492 1.73806 16.2611 0.75 15.0423 0.75L2.9569 0.75C1.73806 0.75 0.75 1.73806 0.75 2.9569L0.75 6\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.5\n-                        }), u.createElement(\"path\", {\n-                            d: \"M0.749873 12V15.0431C0.749873 16.2619 1.73794 17.25 2.95677 17.25H15.0421C16.261 17.25 17.249 16.2619 17.249 15.0431V12\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.5\n-                        }), u.createElement(\"path\", {\n-                            d: \"M6 4.5L9 7.5L12 4.5\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.5\n-                        }), u.createElement(\"path\", {\n-                            d: \"M12 13.5L9 10.5L6 13.5\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.5\n-                        }));\n-                    }, \"SvgMerge\"),\n-                    Xn = a(_ref20 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref20;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 14 14\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"path\", {\n-                            d: \"M0.75 13.25L0.0554307 12.967C-0.0593528 13.2488 0.00743073 13.5719 0.224488 13.7851C0.441545 13.9983 0.765869 14.0592 1.04549 13.9393L0.75 13.25ZM12.8214 1.83253L12.2911 2.36286L12.2911 2.36286L12.8214 1.83253ZM12.8214 3.90194L13.3517 4.43227L12.8214 3.90194ZM10.0981 1.17859L9.56773 0.648259L10.0981 1.17859ZM12.1675 1.17859L12.6978 0.648258L12.6978 0.648257L12.1675 1.17859ZM2.58049 8.75697L3.27506 9.03994L2.58049 8.75697ZM2.70066 8.57599L3.23099 9.10632L2.70066 8.57599ZM5.2479 11.4195L4.95355 10.7297L5.2479 11.4195ZM5.42036 11.303L4.89003 10.7727L5.42036 11.303ZM4.95355 10.7297C4.08882 11.0987 3.41842 11.362 2.73535 11.6308C2.05146 11.9 1.35588 12.1743 0.454511 12.5607L1.04549 13.9393C1.92476 13.5624 2.60256 13.2951 3.28469 13.0266C3.96762 12.7578 4.65585 12.4876 5.54225 12.1093L4.95355 10.7297ZM1.44457 13.533L3.27506 9.03994L1.88592 8.474L0.0554307 12.967L1.44457 13.533ZM3.23099 9.10632L10.6284 1.70892L9.56773 0.648259L2.17033 8.04566L3.23099 9.10632ZM11.6371 1.70892L12.2911 2.36286L13.3517 1.3022L12.6978 0.648258L11.6371 1.70892ZM12.2911 3.37161L4.89003 10.7727L5.95069 11.8333L13.3517 4.43227L12.2911 3.37161ZM12.2911 2.36286C12.5696 2.64142 12.5696 3.09305 12.2911 3.37161L13.3517 4.43227C14.2161 3.56792 14.2161 2.16654 13.3517 1.3022L12.2911 2.36286ZM10.6284 1.70892C10.9069 1.43036 11.3586 1.43036 11.6371 1.70892L12.6978 0.648257C11.8335 -0.216088 10.4321 -0.216084 9.56773 0.648259L10.6284 1.70892ZM3.27506 9.03994C3.26494 9.06479 3.24996 9.08735 3.23099 9.10632L2.17033 8.04566C2.04793 8.16806 1.95123 8.31369 1.88592 8.474L3.27506 9.03994ZM5.54225 12.1093C5.69431 12.0444 5.83339 11.9506 5.95069 11.8333L4.89003 10.7727C4.90863 10.7541 4.92988 10.7398 4.95355 10.7297L5.54225 12.1093Z\",\n-                            fill: \"currentColor\"\n-                        }), u.createElement(\"path\", {\n-                            d: \"M11.5 4.5L9.5 2.5\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.4026,\n-                            strokeLinecap: \"round\",\n-                            strokeLinejoin: \"round\"\n-                        }), u.createElement(\"path\", {\n-                            d: \"M5.5 10.5L3.5 8.5\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.4026,\n-                            strokeLinecap: \"round\",\n-                            strokeLinejoin: \"round\"\n-                        }));\n-                    }, \"SvgPen\"),\n-                    er = a(_ref21 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref21;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 16 18\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"path\", {\n-                            d: \"M1.32226e-07 1.6609C7.22332e-08 0.907329 0.801887 0.424528 1.46789 0.777117L15.3306 8.11621C16.0401 8.49182 16.0401 9.50818 15.3306 9.88379L1.46789 17.2229C0.801886 17.5755 1.36076e-06 17.0927 1.30077e-06 16.3391L1.32226e-07 1.6609Z\",\n-                            fill: \"currentColor\"\n-                        }));\n-                    }, \"SvgPlay\"),\n-                    tr = a(_ref22 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref22;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 10 16\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"path\", {\n-                            fillRule: \"evenodd\",\n-                            clipRule: \"evenodd\",\n-                            d: \"M4.25 9.25V13.5H5.75V9.25L10 9.25V7.75L5.75 7.75V3.5H4.25V7.75L0 7.75V9.25L4.25 9.25Z\",\n-                            fill: \"currentColor\"\n-                        }));\n-                    }, \"SvgPlus\"),\n-                    nr = a(_ref23 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref23;\n-                        return u.createElement(\"svg\", {\n-                            width: 25,\n-                            height: 25,\n-                            viewBox: \"0 0 25 25\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"path\", {\n-                            d: \"M10.2852 24.0745L13.7139 18.0742\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.5625\n-                        }), u.createElement(\"path\", {\n-                            d: \"M14.5742 24.0749L17.1457 19.7891\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.5625\n-                        }), u.createElement(\"path\", {\n-                            d: \"M19.4868 24.0735L20.7229 21.7523C21.3259 20.6143 21.5457 19.3122 21.3496 18.0394C21.1535 16.7666 20.5519 15.591 19.6342 14.6874L23.7984 6.87853C24.0123 6.47728 24.0581 6.00748 23.9256 5.57249C23.7932 5.1375 23.4933 4.77294 23.0921 4.55901C22.6908 4.34509 22.221 4.29932 21.7861 4.43178C21.3511 4.56424 20.9865 4.86408 20.7726 5.26533L16.6084 13.0742C15.3474 12.8142 14.0362 12.9683 12.8699 13.5135C11.7035 14.0586 10.7443 14.9658 10.135 16.1L6 24.0735\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.5625\n-                        }), u.createElement(\"path\", {\n-                            d: \"M4 15L5 13L7 12L5 11L4 9L3 11L1 12L3 13L4 15Z\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.5625,\n-                            strokeLinejoin: \"round\"\n-                        }), u.createElement(\"path\", {\n-                            d: \"M11.5 8L12.6662 5.6662L15 4.5L12.6662 3.3338L11.5 1L10.3338 3.3338L8 4.5L10.3338 5.6662L11.5 8Z\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.5625,\n-                            strokeLinejoin: \"round\"\n-                        }));\n-                    }, \"SvgPrettify\"),\n-                    rr = a(_ref24 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref24;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 16 16\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"path\", {\n-                            d: \"M4.75 9.25H1.25V12.75\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1,\n-                            strokeLinecap: \"square\"\n-                        }), u.createElement(\"path\", {\n-                            d: \"M11.25 6.75H14.75V3.25\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1,\n-                            strokeLinecap: \"square\"\n-                        }), u.createElement(\"path\", {\n-                            d: \"M14.1036 6.65539C13.8 5.27698 13.0387 4.04193 11.9437 3.15131C10.8487 2.26069 9.48447 1.76694 8.0731 1.75043C6.66173 1.73392 5.28633 2.19563 4.17079 3.0604C3.05526 3.92516 2.26529 5.14206 1.92947 6.513\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1\n-                        }), u.createElement(\"path\", {\n-                            d: \"M1.89635 9.34461C2.20001 10.723 2.96131 11.9581 4.05631 12.8487C5.15131 13.7393 6.51553 14.2331 7.9269 14.2496C9.33827 14.2661 10.7137 13.8044 11.8292 12.9396C12.9447 12.0748 13.7347 10.8579 14.0705 9.487\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1\n-                        }));\n-                    }, \"SvgReload\"),\n-                    sr = a(_ref25 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref25;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 13 13\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"rect\", {\n-                            x: .6,\n-                            y: .6,\n-                            width: 11.8,\n-                            height: 11.8,\n-                            rx: 5.9,\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.2\n-                        }), u.createElement(\"path\", {\n-                            d: \"M4.25 7.5C4.25 6 5.75 5 6.5 6.5C7.25 8 8.75 7 8.75 5.5\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.2\n-                        }));\n-                    }, \"SvgRootType\"),\n-                    or = a(_ref26 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref26;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 21 20\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"path\", {\n-                            fillRule: \"evenodd\",\n-                            clipRule: \"evenodd\",\n-                            d: \"M9.29186 1.92702C9.06924 1.82745 8.87014 1.68202 8.70757 1.50024L7.86631 0.574931C7.62496 0.309957 7.30773 0.12592 6.95791 0.0479385C6.60809 -0.0300431 6.24274 0.00182978 5.91171 0.139208C5.58068 0.276585 5.3001 0.512774 5.10828 0.815537C4.91645 1.1183 4.82272 1.47288 4.83989 1.83089L4.90388 3.08019C4.91612 3.32348 4.87721 3.56662 4.78968 3.79394C4.70215 4.02126 4.56794 4.2277 4.39571 4.39994C4.22347 4.57219 4.01704 4.7064 3.78974 4.79394C3.56243 4.88147 3.3193 4.92038 3.07603 4.90814L1.8308 4.84414C1.47162 4.82563 1.11553 4.91881 0.811445 5.11086C0.507359 5.30292 0.270203 5.58443 0.132561 5.91671C-0.00508149 6.249 -0.0364554 6.61576 0.0427496 6.9666C0.121955 7.31744 0.307852 7.63514 0.5749 7.87606L1.50016 8.71204C1.68193 8.87461 1.82735 9.07373 1.92692 9.29636C2.02648 9.51898 2.07794 9.76012 2.07794 10.004C2.07794 10.2479 2.02648 10.489 1.92692 10.7116C1.82735 10.9343 1.68193 11.1334 1.50016 11.296L0.5749 12.1319C0.309856 12.3729 0.125575 12.6898 0.0471809 13.0393C-0.0312128 13.3888 9.64098e-05 13.754 0.13684 14.0851C0.273583 14.4162 0.509106 14.6971 0.811296 14.8894C1.11349 15.0817 1.46764 15.1762 1.82546 15.1599L3.0707 15.0959C3.31397 15.0836 3.5571 15.1225 3.7844 15.2101C4.01171 15.2976 4.21814 15.4318 4.39037 15.6041C4.56261 15.7763 4.69682 15.9827 4.78435 16.2101C4.87188 16.4374 4.91078 16.6805 4.89855 16.9238L4.83455 18.1691C4.81605 18.5283 4.90921 18.8844 5.10126 19.1885C5.2933 19.4926 5.5748 19.7298 5.90707 19.8674C6.23934 20.0051 6.60608 20.0365 6.9569 19.9572C7.30772 19.878 7.6254 19.6921 7.86631 19.4251L8.7129 18.4998C8.87547 18.318 9.07458 18.1725 9.29719 18.073C9.51981 17.9734 9.76093 17.9219 10.0048 17.9219C10.2487 17.9219 10.4898 17.9734 10.7124 18.073C10.935 18.1725 11.1341 18.318 11.2967 18.4998L12.1326 19.4251C12.3735 19.6921 12.6912 19.878 13.042 19.9572C13.3929 20.0365 13.7596 20.0051 14.0919 19.8674C14.4241 19.7298 14.7056 19.4926 14.8977 19.1885C15.0897 18.8844 15.1829 18.5283 15.1644 18.1691L15.1004 16.9238C15.0882 16.6805 15.1271 16.4374 15.2146 16.2101C15.3021 15.9827 15.4363 15.7763 15.6086 15.6041C15.7808 15.4318 15.9872 15.2976 16.2145 15.2101C16.4418 15.1225 16.685 15.0836 16.9282 15.0959L18.1735 15.1599C18.5326 15.1784 18.8887 15.0852 19.1928 14.8931C19.4969 14.7011 19.7341 14.4196 19.8717 14.0873C20.0093 13.755 20.0407 13.3882 19.9615 13.0374C19.8823 12.6866 19.6964 12.3689 19.4294 12.1279L18.5041 11.292C18.3223 11.1294 18.1769 10.9303 18.0774 10.7076C17.9778 10.485 17.9263 10.2439 17.9263 10C17.9263 9.75612 17.9778 9.51499 18.0774 9.29236C18.1769 9.06973 18.3223 8.87062 18.5041 8.70804L19.4294 7.87206C19.6964 7.63114 19.8823 7.31344 19.9615 6.9626C20.0407 6.61176 20.0093 6.245 19.8717 5.91271C19.7341 5.58043 19.4969 5.29892 19.1928 5.10686C18.8887 4.91481 18.5326 4.82163 18.1735 4.84014L16.9282 4.90414C16.685 4.91638 16.4418 4.87747 16.2145 4.78994C15.9872 4.7024 15.7808 4.56818 15.6086 4.39594C15.4363 4.2237 15.3021 4.01726 15.2146 3.78994C15.1271 3.56262 15.0882 3.31948 15.1004 3.07619L15.1644 1.83089C15.1829 1.4717 15.0897 1.11559 14.8977 0.811487C14.7056 0.507385 14.4241 0.270217 14.0919 0.132568C13.7596 -0.00508182 13.3929 -0.0364573 13.042 0.0427519C12.6912 0.121961 12.3735 0.307869 12.1326 0.574931L11.2914 1.50024C11.1288 1.68202 10.9297 1.82745 10.7071 1.92702C10.4845 2.02659 10.2433 2.07805 9.99947 2.07805C9.7556 2.07805 9.51448 2.02659 9.29186 1.92702ZM14.3745 10C14.3745 12.4162 12.4159 14.375 9.99977 14.375C7.58365 14.375 5.625 12.4162 5.625 10C5.625 7.58375 7.58365 5.625 9.99977 5.625C12.4159 5.625 14.3745 7.58375 14.3745 10Z\",\n-                            fill: \"currentColor\"\n-                        }));\n-                    }, \"SvgSettings\"),\n-                    lr = a(_ref27 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref27;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 14 14\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"path\", {\n-                            d: \"M6.5782 1.07092C6.71096 0.643026 7.28904 0.643027 7.4218 1.07092L8.59318 4.84622C8.65255 5.03758 8.82284 5.16714 9.01498 5.16714L12.8056 5.16714C13.2353 5.16714 13.4139 5.74287 13.0663 6.00732L9.99962 8.34058C9.84418 8.45885 9.77913 8.66848 9.83851 8.85984L11.0099 12.6351C11.1426 13.063 10.675 13.4189 10.3274 13.1544L7.26069 10.8211C7.10524 10.7029 6.89476 10.7029 6.73931 10.8211L3.6726 13.1544C3.32502 13.4189 2.85735 13.063 2.99012 12.6351L4.16149 8.85984C4.22087 8.66848 4.15582 8.45885 4.00038 8.34058L0.933671 6.00732C0.586087 5.74287 0.764722 5.16714 1.19436 5.16714L4.98502 5.16714C5.17716 5.16714 5.34745 5.03758 5.40682 4.84622L6.5782 1.07092Z\",\n-                            fill: \"currentColor\",\n-                            stroke: \"currentColor\"\n-                        }));\n-                    }, \"SvgStarFilled\"),\n-                    ir = a(_ref28 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref28;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 14 14\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"path\", {\n-                            d: \"M6.5782 1.07092C6.71096 0.643026 7.28904 0.643027 7.4218 1.07092L8.59318 4.84622C8.65255 5.03758 8.82284 5.16714 9.01498 5.16714L12.8056 5.16714C13.2353 5.16714 13.4139 5.74287 13.0663 6.00732L9.99962 8.34058C9.84418 8.45885 9.77913 8.66848 9.83851 8.85984L11.0099 12.6351C11.1426 13.063 10.675 13.4189 10.3274 13.1544L7.26069 10.8211C7.10524 10.7029 6.89476 10.7029 6.73931 10.8211L3.6726 13.1544C3.32502 13.4189 2.85735 13.063 2.99012 12.6351L4.16149 8.85984C4.22087 8.66848 4.15582 8.45885 4.00038 8.34058L0.933671 6.00732C0.586087 5.74287 0.764722 5.16714 1.19436 5.16714L4.98502 5.16714C5.17716 5.16714 5.34745 5.03758 5.40682 4.84622L6.5782 1.07092Z\",\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.5\n-                        }));\n-                    }, \"SvgStar\"),\n-                    ar = a(_ref29 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref29;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 16 16\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"rect\", {\n-                            width: 16,\n-                            height: 16,\n-                            rx: 2,\n-                            fill: \"currentColor\"\n-                        }));\n-                    }, \"SvgStop\"),\n-                    cr = a(_ref30 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref30;\n-                        return u.createElement(\"svg\", {\n-                            width: \"1em\",\n-                            height: \"5em\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            fillRule: \"evenodd\",\n-                            \"aria-hidden\": \"true\",\n-                            viewBox: \"0 0 23 23\",\n-                            style: {\n-                                height: \"1.5em\"\n-                            },\n-                            clipRule: \"evenodd\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e === void 0 ? u.createElement(\"title\", {\n-                            id: t\n-                        }, \"trash icon\") : e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"path\", {\n-                            d: \"M19 24h-14c-1.104 0-2-.896-2-2v-17h-1v-2h6v-1.5c0-.827.673-1.5 1.5-1.5h5c.825 0 1.5.671 1.5 1.5v1.5h6v2h-1v17c0 1.104-.896 2-2 2zm0-19h-14v16.5c0 .276.224.5.5.5h13c.276 0 .5-.224.5-.5v-16.5zm-7 7.586l3.293-3.293 1.414 1.414-3.293 3.293 3.293 3.293-1.414 1.414-3.293-3.293-3.293 3.293-1.414-1.414 3.293-3.293-3.293-3.293 1.414-1.414 3.293 3.293zm2-10.586h-4v1h4v-1z\",\n-                            fill: \"currentColor\",\n-                            strokeWidth: .25,\n-                            stroke: \"currentColor\"\n-                        }));\n-                    }, \"SvgTrash\"),\n-                    ur = a(_ref31 => {\n-                        let {\n-                            title: e,\n-                            titleId: t,\n-                            ...n\n-                        } = _ref31;\n-                        return u.createElement(\"svg\", {\n-                            height: \"1em\",\n-                            viewBox: \"0 0 13 13\",\n-                            fill: \"none\",\n-                            xmlns: \"http://www.w3.org/2000/svg\",\n-                            \"aria-labelledby\": t,\n-                            ...n\n-                        }, e ? u.createElement(\"title\", {\n-                            id: t\n-                        }, e) : null, u.createElement(\"rect\", {\n-                            x: .6,\n-                            y: .6,\n-                            width: 11.8,\n-                            height: 11.8,\n-                            rx: 5.9,\n-                            stroke: \"currentColor\",\n-                            strokeWidth: 1.2\n-                        }), u.createElement(\"rect\", {\n-                            x: 5.5,\n-                            y: 5.5,\n-                            width: 2,\n-                            height: 2,\n-                            rx: 1,\n-                            fill: \"currentColor\"\n-                        }));\n-                    }, \"SvgType\"),\n-                    Tt = V(Vn),\n-                    dr = V(In),\n-                    Mt = V(Hn),\n-                    hr = V(Dn),\n-                    Oe = V(An),\n-                    mr = V(On),\n-                    Pt = V(Fn),\n-                    qt = V(Bn),\n-                    Rt = V(Wn),\n-                    Vt = V(_n),\n-                    It = V(Zn, \"filled docs icon\"),\n-                    Ht = V(Gn),\n-                    Dt = V($n),\n-                    At = V(Qn),\n-                    Ot = V(zn),\n-                    Ft = V(Un),\n-                    fr = V(Kn),\n-                    Bt = V(Jn),\n-                    pr = V(Yn),\n-                    Wt = V(Xn),\n-                    _t = V(er),\n-                    gr = V(tr),\n-                    xr = V(nr),\n-                    Cr = V(rr),\n-                    Zt = V(sr),\n-                    vr = V(or),\n-                    Gt = V(lr, \"filled star icon\"),\n-                    $t = V(ir),\n-                    Qt = V(ar),\n-                    zt = V(cr, \"trash icon\"),\n-                    ge = V(ur);\n-\n-                function V(e) {\n-                    let t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : e.name.replace(\"Svg\", \"\").replaceAll(/([A-Z])/g, \" $1\").trimStart().toLowerCase() + \" icon\";\n-                    return e.defaultProps = {\n-                        title: t\n-                    }, e;\n-                }\n-                a(V, \"generateIcon\");\n-                const $ = l.forwardRef((e, t) => s.jsx(\"button\", {\n-                    ...e,\n-                    ref: t,\n-                    className: _.clsx(\"graphiql-un-styled\", e.className)\n-                }));\n-                $.displayName = \"UnStyledButton\";\n-                const me = l.forwardRef((e, t) => s.jsx(\"button\", {\n-                    ...e,\n-                    ref: t,\n-                    className: _.clsx(\"graphiql-button\", {\n-                        success: \"graphiql-button-success\",\n-                        error: \"graphiql-button-error\"\n-                    } [e.state], e.className)\n-                }));\n-                me.displayName = \"Button\";\n-                const Ut = l.forwardRef((e, t) => s.jsx(\"div\", {\n-                    ...e,\n-                    ref: t,\n-                    className: _.clsx(\"graphiql-button-group\", e.className)\n-                }));\n-                Ut.displayName = \"ButtonGroup\";\n-                const ye = a((e, t) => Object.entries(t).reduce((n, _ref32) => {\n-                    let [r, o] = _ref32;\n-                    return n[r] = o, n;\n-                }, e), \"createComponentGroup\");\n-                const Kt = l.forwardRef((e, t) => s.jsx(ne.Close, {\n-                    asChild: !0,\n-                    children: s.jsxs($, {\n-                        ...e,\n-                        ref: t,\n-                        type: \"button\",\n-                        className: _.clsx(\"graphiql-dialog-close\", e.className),\n-                        children: [s.jsx(Pn.Root, {\n-                            children: \"Close dialog\"\n-                        }), s.jsx(Oe, {})]\n-                    })\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n                 }));\n-                Kt.displayName = \"Dialog.Close\";\n+                exports[\"default\"] = void 0;\n+                var _tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.mjs\");\n+                var React = _interopRequireWildcard(__webpack_require__( /*! react */ \"react\"));\n+                var _UI = __webpack_require__( /*! ./UI */ \"../../../node_modules/react-remove-scroll/dist/es2015/UI.js\");\n+                var _sidecar = _interopRequireDefault(__webpack_require__( /*! ./sidecar */ \"../../../node_modules/react-remove-scroll/dist/es2015/sidecar.js\"));\n \n-                function Jt(_ref33) {\n-                    let {\n-                        children: e,\n-                        ...t\n-                    } = _ref33;\n-                    return s.jsx(ne.Root, {\n-                        ...t,\n-                        children: s.jsxs(ne.Portal, {\n-                            children: [s.jsx(ne.Overlay, {\n-                                className: \"graphiql-dialog-overlay\"\n-                            }), s.jsx(ne.Content, {\n-                                className: \"graphiql-dialog\",\n-                                children: e\n-                            })]\n-                        })\n-                    });\n+                function _interopRequireDefault(obj) {\n+                    return obj && obj.__esModule ? obj : {\n+                        default: obj\n+                    };\n                 }\n-                a(Jt, \"DialogRoot\");\n-                const yr = ye(Jt, {\n-                    Close: Kt,\n-                    Title: ne.Title,\n-                    Trigger: ne.Trigger,\n-                    Description: ne.Description\n-                });\n-                const Yt = l.forwardRef((e, t) => s.jsx(xe.Trigger, {\n-                    asChild: !0,\n-                    children: s.jsx(\"button\", {\n-                        ...e,\n-                        ref: t,\n-                        className: _.clsx(\"graphiql-un-styled\", e.className)\n-                    })\n-                }));\n-                Yt.displayName = \"DropdownMenuButton\";\n \n-                function br(_ref34) {\n-                    let {\n-                        children: e,\n-                        align: t = \"start\",\n-                        sideOffset: n = 5,\n-                        className: r,\n-                        ...o\n-                    } = _ref34;\n-                    return s.jsx(xe.Portal, {\n-                        children: s.jsx(xe.Content, {\n-                            align: t,\n-                            sideOffset: n,\n-                            className: _.clsx(\"graphiql-dropdown-content\", r),\n-                            ...o,\n-                            children: e\n-                        })\n-                    });\n+                function _getRequireWildcardCache(e) {\n+                    if (\"function\" != typeof WeakMap) return null;\n+                    var r = new WeakMap(),\n+                        t = new WeakMap();\n+                    return (_getRequireWildcardCache = function(e) {\n+                        return e ? t : r;\n+                    })(e);\n+                }\n+\n+                function _interopRequireWildcard(e, r) {\n+                    if (!r && e && e.__esModule) return e;\n+                    if (null === e || \"object\" != typeof e && \"function\" != typeof e) return {\n+                        default: e\n+                    };\n+                    var t = _getRequireWildcardCache(r);\n+                    if (t && t.has(e)) return t.get(e);\n+                    var n = {\n+                            __proto__: null\n+                        },\n+                        a = Object.defineProperty && Object.getOwnPropertyDescriptor;\n+                    for (var u in e)\n+                        if (\"default\" !== u && Object.prototype.hasOwnProperty.call(e, u)) {\n+                            var i = a ? Object.getOwnPropertyDescriptor(e, u) : null;\n+                            i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u];\n+                        } return n.default = e, t && t.set(e, n), n;\n                 }\n-                a(br, \"Content\");\n-                const wr = a(_ref35 => {\n-                        let {\n-                            className: e,\n-                            children: t,\n-                            ...n\n-                        } = _ref35;\n-                        return s.jsx(xe.Item, {\n-                            className: _.clsx(\"graphiql-dropdown-item\", e),\n-                            ...n,\n-                            children: t\n-                        });\n-                    }, \"Item\"),\n-                    X = ye(xe.Root, {\n-                        Button: Yt,\n-                        Item: wr,\n-                        Content: br\n-                    }),\n-                    Me = new qn({\n-                        breaks: !0,\n-                        linkify: !0\n-                    });\n-                const z = l.forwardRef((_ref36, o) => {\n-                    let {\n-                        children: e,\n-                        onlyShowFirstChild: t,\n-                        type: n,\n-                        ...r\n-                    } = _ref36;\n-                    return s.jsx(\"div\", {\n-                        ...r,\n-                        ref: o,\n-                        className: _.clsx(`graphiql-markdown-${n}`, t && \"graphiql-markdown-preview\", r.className),\n-                        dangerouslySetInnerHTML: {\n-                            __html: Me.render(e)\n-                        }\n-                    });\n+                var ReactRemoveScroll = /*#__PURE__*/ React.forwardRef(function(props, ref) {\n+                    return /*#__PURE__*/ React.createElement(_UI.RemoveScroll, (0, _tslib.__assign)({}, props, {\n+                        ref: ref,\n+                        sideCar: _sidecar.default\n+                    }));\n                 });\n-                z.displayName = \"MarkdownContent\";\n-                const st = l.forwardRef((e, t) => s.jsx(\"div\", {\n-                    ...e,\n-                    ref: t,\n-                    className: _.clsx(\"graphiql-spinner\", e.className)\n-                }));\n-                st.displayName = \"Spinner\";\n+                ReactRemoveScroll.classNames = _UI.RemoveScroll.classNames;\n+                var _default = exports[\"default\"] = ReactRemoveScroll;\n \n-                function Xt(_ref37) {\n-                    let {\n-                        children: e,\n-                        align: t = \"start\",\n-                        side: n = \"bottom\",\n-                        sideOffset: r = 5,\n-                        label: o\n-                    } = _ref37;\n-                    return s.jsxs(pe.Root, {\n-                        children: [s.jsx(pe.Trigger, {\n-                            asChild: !0,\n-                            children: e\n-                        }), s.jsx(pe.Portal, {\n-                            children: s.jsx(pe.Content, {\n-                                className: \"graphiql-tooltip\",\n-                                align: t,\n-                                side: n,\n-                                sideOffset: r,\n-                                children: o\n-                            })\n-                        })]\n-                    });\n-                }\n-                a(Xt, \"TooltipRoot\");\n-                const K = ye(Xt, {\n-                    Provider: pe.Provider\n-                });\n-                const en = l.forwardRef((_ref38, c) => {\n-                    let {\n-                        isActive: e,\n-                        value: t,\n-                        children: n,\n-                        className: r,\n-                        ...o\n-                    } = _ref38;\n-                    return s.jsx(kt.Reorder.Item, {\n-                        ...o,\n-                        ref: c,\n-                        value: t,\n-                        \"aria-selected\": e ? \"true\" : void 0,\n-                        role: \"tab\",\n-                        className: _.clsx(\"graphiql-tab\", e && \"graphiql-tab-active\", r),\n-                        children: n\n-                    });\n-                });\n-                en.displayName = \"Tab\";\n-                const tn = l.forwardRef((e, t) => s.jsx($, {\n-                    ...e,\n-                    ref: t,\n-                    type: \"button\",\n-                    className: _.clsx(\"graphiql-tab-button\", e.className),\n-                    children: e.children\n-                }));\n-                tn.displayName = \"Tab.Button\";\n-                const nn = l.forwardRef((e, t) => s.jsx(K, {\n-                    label: \"Close Tab\",\n-                    children: s.jsx($, {\n-                        \"aria-label\": \"Close Tab\",\n-                        ...e,\n-                        ref: t,\n-                        type: \"button\",\n-                        className: _.clsx(\"graphiql-tab-close\", e.className),\n-                        children: s.jsx(Oe, {})\n-                    })\n-                }));\n-                nn.displayName = \"Tab.Close\";\n-                const Er = ye(en, {\n-                        Button: tn,\n-                        Close: nn\n-                    }),\n-                    rn = l.forwardRef((_ref39, c) => {\n-                        let {\n-                            values: e,\n-                            onReorder: t,\n-                            children: n,\n-                            className: r,\n-                            ...o\n-                        } = _ref39;\n-                        return s.jsx(kt.Reorder.Group, {\n-                            ...o,\n-                            ref: c,\n-                            values: e,\n-                            onReorder: t,\n-                            axis: \"x\",\n-                            role: \"tablist\",\n-                            className: _.clsx(\"graphiql-tabs\", r),\n-                            children: n\n-                        });\n-                    });\n-                rn.displayName = \"Tabs\";\n-                const ot = oe(\"HistoryContext\");\n+                /***/\n+            }),\n \n-                function sn(e) {\n-                    var y;\n-                    const t = re(),\n-                        n = l.useRef(new B.HistoryStore(t || new B.StorageAPI(null), e.maxHistoryLength || Sr)),\n-                        [r, o] = l.useState(((y = n.current) == null ? void 0 : y.queries) || []),\n-                        c = l.useCallback(h => {\n-                            var x;\n-                            (x = n.current) == null || x.updateHistory(h), o(n.current.queries);\n-                        }, []),\n-                        i = l.useCallback((h, x) => {\n-                            n.current.editLabel(h, x), o(n.current.queries);\n-                        }, []),\n-                        d = l.useCallback(h => {\n-                            n.current.toggleFavorite(h), o(n.current.queries);\n-                        }, []),\n-                        g = l.useCallback(h => h, []),\n-                        m = l.useCallback(function(h) {\n-                            let x = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : !1;\n-                            n.current.deleteHistory(h, x), o(n.current.queries);\n-                        }, []),\n-                        p = l.useMemo(() => ({\n-                            addToHistory: c,\n-                            editLabel: i,\n-                            items: r,\n-                            toggleFavorite: d,\n-                            setActive: g,\n-                            deleteFromHistory: m\n-                        }), [c, i, r, d, g, m]);\n-                    return s.jsx(ot.Provider, {\n-                        value: p,\n-                        children: e.children\n-                    });\n-                }\n-                a(sn, \"HistoryContextProvider\");\n-                const be = le(ot),\n-                    Sr = 20;\n-\n-                function on() {\n-                    const {\n-                        items: e,\n-                        deleteFromHistory: t\n-                    } = be({\n-                        nonNull: !0\n-                    });\n-                    let n = e.slice().map((d, g) => ({\n-                        ...d,\n-                        index: g\n-                    })).reverse();\n-                    const r = n.filter(d => d.favorite);\n-                    r.length && (n = n.filter(d => !d.favorite));\n-                    const [o, c] = l.useState(null);\n-                    l.useEffect(() => {\n-                        o && setTimeout(() => {\n-                            c(null);\n-                        }, 2e3);\n-                    }, [o]);\n-                    const i = l.useCallback(() => {\n-                        try {\n-                            for (const d of n) t(d, !0);\n-                            c(\"success\");\n-                        } catch {\n-                            c(\"error\");\n-                        }\n-                    }, [t, n]);\n-                    return s.jsxs(\"section\", {\n-                        \"aria-label\": \"History\",\n-                        className: \"graphiql-history\",\n-                        children: [s.jsxs(\"div\", {\n-                            className: \"graphiql-history-header\",\n-                            children: [\"History\", (o || n.length > 0) && s.jsx(me, {\n-                                type: \"button\",\n-                                state: o || void 0,\n-                                disabled: !n.length,\n-                                onClick: i,\n-                                children: {\n-                                    success: \"Cleared\",\n-                                    error: \"Failed to Clear\"\n-                                } [o] || \"Clear\"\n-                            })]\n-                        }), !!r.length && s.jsx(\"ul\", {\n-                            className: \"graphiql-history-items\",\n-                            children: r.map(d => s.jsx(Pe, {\n-                                item: d\n-                            }, d.index))\n-                        }), !!r.length && !!n.length && s.jsx(\"div\", {\n-                            className: \"graphiql-history-item-spacer\"\n-                        }), !!n.length && s.jsx(\"ul\", {\n-                            className: \"graphiql-history-items\",\n-                            children: n.map(d => s.jsx(Pe, {\n-                                item: d\n-                            }, d.index))\n-                        })]\n-                    });\n-                }\n-                a(on, \"History\");\n+        /***/\n+        \"../../../node_modules/react-remove-scroll/dist/es2015/SideEffect.js\":\n+            /*!***************************************************************************!*\\\n+              !*** ../../../node_modules/react-remove-scroll/dist/es2015/SideEffect.js ***!\n+              \\***************************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                function Pe(e) {\n-                    const {\n-                        editLabel: t,\n-                        toggleFavorite: n,\n-                        deleteFromHistory: r,\n-                        setActive: o\n-                    } = be({\n-                            nonNull: !0,\n-                            caller: Pe\n-                        }), {\n-                            headerEditor: c,\n-                            queryEditor: i,\n-                            variableEditor: d\n-                        } = Z({\n-                            nonNull: !0,\n-                            caller: Pe\n-                        }),\n-                        g = l.useRef(null),\n-                        m = l.useRef(null),\n-                        [p, y] = l.useState(!1);\n-                    l.useEffect(() => {\n-                        var b;\n-                        p && ((b = g.current) == null || b.focus());\n-                    }, [p]);\n-                    const h = e.item.label || e.item.operationName || Lr(e.item.query),\n-                        x = l.useCallback(() => {\n-                            var T;\n-                            y(!1);\n-                            const {\n-                                index: b,\n-                                ...w\n-                            } = e.item;\n-                            t({\n-                                ...w,\n-                                label: (T = g.current) == null ? void 0 : T.value\n-                            }, b);\n-                        }, [t, e.item]),\n-                        f = l.useCallback(() => {\n-                            y(!1);\n-                        }, []),\n-                        C = l.useCallback(b => {\n-                            b.stopPropagation(), y(!0);\n-                        }, []),\n-                        E = l.useCallback(() => {\n-                            const {\n-                                query: b,\n-                                variables: w,\n-                                headers: T\n-                            } = e.item;\n-                            i == null || i.setValue(b !== null && b !== void 0 ? b : \"\"), d == null || d.setValue(w !== null && w !== void 0 ? w : \"\"), c == null || c.setValue(T !== null && T !== void 0 ? T : \"\"), o(e.item);\n-                        }, [c, e.item, i, o, d]),\n-                        k = l.useCallback(b => {\n-                            b.stopPropagation(), r(e.item);\n-                        }, [e.item, r]),\n-                        L = l.useCallback(b => {\n-                            b.stopPropagation(), n(e.item);\n-                        }, [e.item, n]);\n-                    return s.jsx(\"li\", {\n-                        className: _.clsx(\"graphiql-history-item\", p && \"editable\"),\n-                        children: p ? s.jsxs(s.Fragment, {\n-                            children: [s.jsx(\"input\", {\n-                                type: \"text\",\n-                                defaultValue: e.item.label,\n-                                ref: g,\n-                                onKeyDown: b => {\n-                                    b.key === \"Esc\" ? y(!1) : b.key === \"Enter\" && (y(!1), t({\n-                                        ...e.item,\n-                                        label: b.currentTarget.value\n-                                    }));\n-                                },\n-                                placeholder: \"Type a label\"\n-                            }), s.jsx($, {\n-                                type: \"button\",\n-                                ref: m,\n-                                onClick: x,\n-                                children: \"Save\"\n-                            }), s.jsx($, {\n-                                type: \"button\",\n-                                ref: m,\n-                                onClick: f,\n-                                children: s.jsx(Oe, {})\n-                            })]\n-                        }) : s.jsxs(s.Fragment, {\n-                            children: [s.jsx(K, {\n-                                label: \"Set active\",\n-                                children: s.jsx($, {\n-                                    type: \"button\",\n-                                    className: \"graphiql-history-item-label\",\n-                                    onClick: E,\n-                                    \"aria-label\": \"Set active\",\n-                                    children: h\n-                                })\n-                            }), s.jsx(K, {\n-                                label: \"Edit label\",\n-                                children: s.jsx($, {\n-                                    type: \"button\",\n-                                    className: \"graphiql-history-item-action\",\n-                                    onClick: C,\n-                                    \"aria-label\": \"Edit label\",\n-                                    children: s.jsx(Wt, {\n-                                        \"aria-hidden\": \"true\"\n-                                    })\n-                                })\n-                            }), s.jsx(K, {\n-                                label: e.item.favorite ? \"Remove favorite\" : \"Add favorite\",\n-                                children: s.jsx($, {\n-                                    type: \"button\",\n-                                    className: \"graphiql-history-item-action\",\n-                                    onClick: L,\n-                                    \"aria-label\": e.item.favorite ? \"Remove favorite\" : \"Add favorite\",\n-                                    children: e.item.favorite ? s.jsx(Gt, {\n-                                        \"aria-hidden\": \"true\"\n-                                    }) : s.jsx($t, {\n-                                        \"aria-hidden\": \"true\"\n-                                    })\n-                                })\n-                            }), s.jsx(K, {\n-                                label: \"Delete from history\",\n-                                children: s.jsx($, {\n-                                    type: \"button\",\n-                                    className: \"graphiql-history-item-action\",\n-                                    onClick: k,\n-                                    \"aria-label\": \"Delete from history\",\n-                                    children: s.jsx(zt, {\n-                                        \"aria-hidden\": \"true\"\n-                                    })\n-                                })\n-                            })]\n-                        })\n-                    });\n-                }\n-                a(Pe, \"HistoryItem\");\n+                \"use strict\";\n \n-                function Lr(e) {\n-                    return e == null ? void 0 : e.split(`\n-`).map(t => t.replace(/#(.*)/, \"\")).join(\" \").replaceAll(\"{\", \" { \").replaceAll(\"}\", \" } \").replaceAll(/[\\s]{2,}/g, \" \");\n-                }\n-                a(Lr, \"formatQuery\");\n-                const lt = oe(\"ExecutionContext\");\n \n-                function qe(_ref40) {\n-                    let {\n-                        fetcher: e,\n-                        getDefaultFieldNames: t,\n-                        children: n,\n-                        operationName: r\n-                    } = _ref40;\n-                    if (!e) throw new TypeError(\"The `ExecutionContextProvider` component requires a `fetcher` function to be passed as prop.\");\n-                    const {\n-                        externalFragments: o,\n-                        headerEditor: c,\n-                        queryEditor: i,\n-                        responseEditor: d,\n-                        variableEditor: g,\n-                        updateActiveTabValues: m\n-                    } = Z({\n-                            nonNull: !0,\n-                            caller: qe\n-                        }),\n-                        p = be(),\n-                        y = Ie({\n-                            getDefaultFieldNames: t,\n-                            caller: qe\n-                        }),\n-                        [h, x] = l.useState(!1),\n-                        [f, C] = l.useState(null),\n-                        E = l.useRef(0),\n-                        k = l.useCallback(() => {\n-                            f == null || f.unsubscribe(), x(!1), C(null);\n-                        }, [f]),\n-                        L = l.useCallback(async () => {\n-                            var _ref41;\n-                            if (!i || !d) return;\n-                            if (f) {\n-                                k();\n-                                return;\n-                            }\n-                            const T = a(N => {\n-                                d.setValue(N), m({\n-                                    response: N\n-                                });\n-                            }, \"setResponse\");\n-                            E.current += 1;\n-                            const A = E.current;\n-                            let F = y() || i.getValue();\n-                            const I = g == null ? void 0 : g.getValue();\n-                            let H;\n-                            try {\n-                                H = yt({\n-                                    json: I,\n-                                    errorMessageParse: \"Variables are invalid JSON\",\n-                                    errorMessageType: \"Variables are not a JSON object.\"\n-                                });\n-                            } catch (N) {\n-                                T(N instanceof Error ? N.message : `${N}`);\n-                                return;\n-                            }\n-                            const O = c == null ? void 0 : c.getValue();\n-                            let D;\n-                            try {\n-                                D = yt({\n-                                    json: O,\n-                                    errorMessageParse: \"Headers are invalid JSON\",\n-                                    errorMessageType: \"Headers are not a JSON object.\"\n-                                });\n-                            } catch (N) {\n-                                T(N instanceof Error ? N.message : `${N}`);\n-                                return;\n-                            }\n-                            if (o) {\n-                                const N = i.documentAST ? jt.getFragmentDependenciesForAST(i.documentAST, o) : [];\n-                                N.length > 0 && (F += `\n-` + N.map(P => M.print(P)).join(`\n-`));\n-                            }\n-                            T(\"\"), x(!0);\n-                            const q = (_ref41 = r !== null && r !== void 0 ? r : i.operationName) !== null && _ref41 !== void 0 ? _ref41 : void 0;\n-                            p == null || p.addToHistory({\n-                                query: F,\n-                                variables: I,\n-                                headers: O,\n-                                operationName: q\n-                            });\n-                            try {\n-                                var _D, _i$documentAST;\n-                                const N = {},\n-                                    P = a(v => {\n-                                        if (A !== E.current) return;\n-                                        let j = Array.isArray(v) ? v : !1;\n-                                        if (!j && typeof v == \"object\" && v !== null && \"hasNext\" in v && (j = [v]), j) {\n-                                            for (const R of j) ln(N, R);\n-                                            x(!1), T(B.formatResult(N));\n-                                        } else {\n-                                            const R = B.formatResult(v);\n-                                            x(!1), T(R);\n-                                        }\n-                                    }, \"handleResponse\"),\n-                                    S = e({\n-                                        query: F,\n-                                        variables: H,\n-                                        operationName: q\n-                                    }, {\n-                                        headers: (_D = D) !== null && _D !== void 0 ? _D : void 0,\n-                                        documentAST: (_i$documentAST = i.documentAST) !== null && _i$documentAST !== void 0 ? _i$documentAST : void 0\n-                                    }),\n-                                    W = await Promise.resolve(S);\n-                                if (B.isObservable(W)) C(W.subscribe({\n-                                    next(v) {\n-                                        P(v);\n-                                    },\n-                                    error(v) {\n-                                        x(!1), v && T(B.formatError(v)), C(null);\n-                                    },\n-                                    complete() {\n-                                        x(!1), C(null);\n-                                    }\n-                                }));\n-                                else if (B.isAsyncIterable(W)) {\n-                                    C({\n-                                        unsubscribe: () => {\n-                                            var v, j;\n-                                            return (j = (v = W[Symbol.asyncIterator]()).return) == null ? void 0 : j.call(v);\n-                                        }\n-                                    });\n-                                    for await (const v of W) P(v);\n-                                    x(!1), C(null);\n-                                } else P(W);\n-                            } catch (N) {\n-                                x(!1), T(B.formatError(N)), C(null);\n-                            }\n-                        }, [y, o, e, c, p, r, i, d, k, f, m, g]),\n-                        b = !!f,\n-                        w = l.useMemo(() => ({\n-                            isFetching: h,\n-                            isSubscribed: b,\n-                            operationName: r !== null && r !== void 0 ? r : null,\n-                            run: L,\n-                            stop: k\n-                        }), [h, b, r, L, k]);\n-                    return s.jsx(lt.Provider, {\n-                        value: w,\n-                        children: n\n-                    });\n-                }\n-                a(qe, \"ExecutionContextProvider\");\n-                const we = le(lt);\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.RemoveScrollSideCar = RemoveScrollSideCar;\n+                exports.getTouchXY = exports.getDeltaXY = void 0;\n+                var _tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.mjs\");\n+                var React = _interopRequireWildcard(__webpack_require__( /*! react */ \"react\"));\n+                var _reactRemoveScrollBar = __webpack_require__( /*! react-remove-scroll-bar */ \"../../../node_modules/react-remove-scroll-bar/dist/es2015/index.js\");\n+                var _reactStyleSingleton = __webpack_require__( /*! react-style-singleton */ \"../../../node_modules/react-style-singleton/dist/es2015/index.js\");\n+                var _aggresiveCapture = __webpack_require__( /*! ./aggresiveCapture */ \"../../../node_modules/react-remove-scroll/dist/es2015/aggresiveCapture.js\");\n+                var _handleScroll = __webpack_require__( /*! ./handleScroll */ \"../../../node_modules/react-remove-scroll/dist/es2015/handleScroll.js\");\n \n-                function yt(_ref42) {\n-                    let {\n-                        json: e,\n-                        errorMessageParse: t,\n-                        errorMessageType: n\n-                    } = _ref42;\n-                    let r;\n-                    try {\n-                        r = e && e.trim() !== \"\" ? JSON.parse(e) : void 0;\n-                    } catch (c) {\n-                        throw new Error(`${t}: ${c instanceof Error ? c.message : c}.`);\n-                    }\n-                    const o = typeof r == \"object\" && r !== null && !Array.isArray(r);\n-                    if (r !== void 0 && !o) throw new Error(n);\n-                    return r;\n+                function _getRequireWildcardCache(e) {\n+                    if (\"function\" != typeof WeakMap) return null;\n+                    var r = new WeakMap(),\n+                        t = new WeakMap();\n+                    return (_getRequireWildcardCache = function(e) {\n+                        return e ? t : r;\n+                    })(e);\n+                }\n+\n+                function _interopRequireWildcard(e, r) {\n+                    if (!r && e && e.__esModule) return e;\n+                    if (null === e || \"object\" != typeof e && \"function\" != typeof e) return {\n+                        default: e\n+                    };\n+                    var t = _getRequireWildcardCache(r);\n+                    if (t && t.has(e)) return t.get(e);\n+                    var n = {\n+                            __proto__: null\n+                        },\n+                        a = Object.defineProperty && Object.getOwnPropertyDescriptor;\n+                    for (var u in e)\n+                        if (\"default\" !== u && Object.prototype.hasOwnProperty.call(e, u)) {\n+                            var i = a ? Object.getOwnPropertyDescriptor(e, u) : null;\n+                            i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u];\n+                        } return n.default = e, t && t.set(e, n), n;\n                 }\n-                a(yt, \"tryParseJsonObject\");\n-\n-                function ln(e, t) {\n-                    var _t$path;\n-                    const n = [\"data\", ...((_t$path = t.path) !== null && _t$path !== void 0 ? _t$path : [])];\n-                    if (t.items)\n-                        for (const r of t.items) $e(e, n.join(\".\"), r), n[n.length - 1]++;\n-                    if (t.data && $e(e, n.join(\".\"), t.data, {\n-                            merge: !0\n-                        }), t.errors && (e.errors || (e.errors = []), e.errors.push(...t.errors)), t.extensions && $e(e, \"extensions\", t.extensions, {\n-                            merge: !0\n-                        }), t.incremental)\n-                        for (const r of t.incremental) ln(e, r);\n-                }\n-                a(ln, \"mergeIncrementalResult\");\n-                const Fe = \"graphiql\",\n-                    Be = \"sublime\";\n-                let an = !1;\n-                typeof window == \"object\" && (an = window.navigator.platform.toLowerCase().indexOf(\"mac\") === 0);\n-                const We = {\n-                    [an ? \"Cmd-F\" : \"Ctrl-F\"]: \"findPersistent\",\n-                    \"Cmd-G\": \"findPersistent\",\n-                    \"Ctrl-G\": \"findPersistent\",\n-                    \"Ctrl-Left\": \"goSubwordLeft\",\n-                    \"Ctrl-Right\": \"goSubwordRight\",\n-                    \"Alt-Left\": \"goGroupLeft\",\n-                    \"Alt-Right\": \"goGroupRight\"\n+                var getTouchXY = function(event) {\n+                    return 'changedTouches' in event ? [event.changedTouches[0].clientX, event.changedTouches[0].clientY] : [0, 0];\n                 };\n-                async function Ee(e, t) {\n-                    const n = await Promise.resolve().then(() => __webpack_require__( /*! ./codemirror.cjs.js */ \"../../graphiql-react/dist/codemirror.cjs.js\")).then(r => r.codemirror).then(r => typeof r == \"function\" ? r : r.default);\n-                    return await Promise.all((t == null ? void 0 : t.useCommonAddons) === !1 ? e : [Promise.resolve().then(() => __webpack_require__( /*! ./show-hint.cjs.js */ \"../../graphiql-react/dist/show-hint.cjs.js\")).then(r => r.showHint), Promise.resolve().then(() => __webpack_require__( /*! ./matchbrackets.cjs.js */ \"../../graphiql-react/dist/matchbrackets.cjs.js\")).then(r => r.matchbrackets), Promise.resolve().then(() => __webpack_require__( /*! ./closebrackets.cjs.js */ \"../../graphiql-react/dist/closebrackets.cjs.js\")).then(r => r.closebrackets), Promise.resolve().then(() => __webpack_require__( /*! ./brace-fold.cjs.js */ \"../../graphiql-react/dist/brace-fold.cjs.js\")).then(r => r.braceFold), Promise.resolve().then(() => __webpack_require__( /*! ./foldgutter.cjs.js */ \"../../graphiql-react/dist/foldgutter.cjs.js\")).then(r => r.foldgutter), Promise.resolve().then(() => __webpack_require__( /*! ./lint.cjs.js */ \"../../graphiql-react/dist/lint.cjs.js\")).then(r => r.lint), Promise.resolve().then(() => __webpack_require__( /*! ./searchcursor.cjs.js */ \"../../graphiql-react/dist/searchcursor.cjs.js\")).then(r => r.searchcursor), Promise.resolve().then(() => __webpack_require__( /*! ./jump-to-line.cjs.js */ \"../../graphiql-react/dist/jump-to-line.cjs.js\")).then(r => r.jumpToLine), Promise.resolve().then(() => __webpack_require__( /*! ./dialog.cjs.js */ \"../../graphiql-react/dist/dialog.cjs.js\")).then(r => r.dialog), Promise.resolve().then(() => __webpack_require__( /*! ./sublime.cjs.js */ \"../../graphiql-react/dist/sublime.cjs.js\")).then(r => r.sublime), ...e]), n;\n-                }\n-                a(Ee, \"importCodeMirror\");\n-                const jr = a(e => e ? M.print(e) : \"\", \"printDefault\");\n-\n-                function it(_ref43) {\n-                    let {\n-                        field: e\n-                    } = _ref43;\n-                    if (!(\"defaultValue\" in e) || e.defaultValue === void 0) return null;\n-                    const t = M.astFromValue(e.defaultValue, e.type);\n-                    return t ? s.jsxs(s.Fragment, {\n-                        children: [\" = \", s.jsx(\"span\", {\n-                            className: \"graphiql-doc-explorer-default-value\",\n-                            children: jr(t)\n-                        })]\n-                    }) : null;\n-                }\n-                a(it, \"DefaultValue\");\n-                const at = oe(\"SchemaContext\");\n-\n-                function ct(e) {\n-                    if (!e.fetcher) throw new TypeError(\"The `SchemaContextProvider` component requires a `fetcher` function to be passed as prop.\");\n-                    const {\n-                        initialHeaders: t,\n-                        headerEditor: n\n-                    } = Z({\n-                            nonNull: !0,\n-                            caller: ct\n-                        }),\n-                        [r, o] = l.useState(),\n-                        [c, i] = l.useState(!1),\n-                        [d, g] = l.useState(null),\n-                        m = l.useRef(0);\n-                    l.useEffect(() => {\n-                        o(M.isSchema(e.schema) || e.schema === null || e.schema === void 0 ? e.schema : void 0), m.current++;\n-                    }, [e.schema]);\n-                    const p = l.useRef(t);\n-                    l.useEffect(() => {\n-                        n && (p.current = n.getValue());\n-                    });\n-                    const {\n-                        introspectionQuery: y,\n-                        introspectionQueryName: h,\n-                        introspectionQuerySansSubscriptions: x\n-                    } = kr({\n-                            inputValueDeprecation: e.inputValueDeprecation,\n-                            introspectionQueryName: e.introspectionQueryName,\n-                            schemaDescription: e.schemaDescription\n-                        }), {\n-                            fetcher: f,\n-                            onSchemaChange: C,\n-                            dangerouslyAssumeSchemaIsValid: E,\n-                            children: k\n-                        } = e,\n-                        L = l.useCallback(() => {\n-                            if (M.isSchema(e.schema) || e.schema === null) return;\n-                            const T = ++m.current,\n-                                A = e.schema;\n-                            async function F() {\n-                                if (A) return A;\n-                                const I = Nr(p.current);\n-                                if (!I.isValidJSON) {\n-                                    g(\"Introspection failed as headers are invalid.\");\n-                                    return;\n-                                }\n-                                const H = I.headers ? {\n-                                        headers: I.headers\n-                                    } : {},\n-                                    O = B.fetcherReturnToPromise(f({\n-                                        query: y,\n-                                        operationName: h\n-                                    }, H));\n-                                if (!B.isPromise(O)) {\n-                                    g(\"Fetcher did not return a Promise for introspection.\");\n-                                    return;\n-                                }\n-                                i(!0), g(null);\n-                                let D = await O;\n-                                if (typeof D != \"object\" || D === null || !(\"data\" in D)) {\n-                                    const N = B.fetcherReturnToPromise(f({\n-                                        query: x,\n-                                        operationName: h\n-                                    }, H));\n-                                    if (!B.isPromise(N)) throw new Error(\"Fetcher did not return a Promise for introspection.\");\n-                                    D = await N;\n-                                }\n-                                if (i(!1), D != null && D.data && \"__schema\" in D.data) return D.data;\n-                                const q = typeof D == \"string\" ? D : B.formatResult(D);\n-                                g(q);\n-                            }\n-                            a(F, \"fetchIntrospectionData\"), F().then(I => {\n-                                if (!(T !== m.current || !I)) try {\n-                                    const H = M.buildClientSchema(I);\n-                                    o(H), C == null || C(H);\n-                                } catch (H) {\n-                                    g(B.formatError(H));\n-                                }\n-                            }).catch(I => {\n-                                T === m.current && (g(B.formatError(I)), i(!1));\n-                            });\n-                        }, [f, h, y, x, C, e.schema]);\n-                    l.useEffect(() => {\n-                        L();\n-                    }, [L]), l.useEffect(() => {\n-                        function T(A) {\n-                            A.ctrlKey && A.key === \"R\" && L();\n-                        }\n-                        return a(T, \"triggerIntrospection\"), window.addEventListener(\"keydown\", T), () => window.removeEventListener(\"keydown\", T);\n-                    });\n-                    const b = l.useMemo(() => !r || E ? [] : M.validateSchema(r), [r, E]),\n-                        w = l.useMemo(() => ({\n-                            fetchError: d,\n-                            introspect: L,\n-                            isFetching: c,\n-                            schema: r,\n-                            validationErrors: b\n-                        }), [d, L, c, r, b]);\n-                    return s.jsx(at.Provider, {\n-                        value: w,\n-                        children: k\n-                    });\n-                }\n-                a(ct, \"SchemaContextProvider\");\n-                const Y = le(at);\n-\n-                function kr(_ref44) {\n-                    let {\n-                        inputValueDeprecation: e,\n-                        introspectionQueryName: t,\n-                        schemaDescription: n\n-                    } = _ref44;\n-                    return l.useMemo(() => {\n-                        const r = t || \"IntrospectionQuery\";\n-                        let o = M.getIntrospectionQuery({\n-                            inputValueDeprecation: e,\n-                            schemaDescription: n\n-                        });\n-                        t && (o = o.replace(\"query IntrospectionQuery\", `query ${r}`));\n-                        const c = o.replace(\"subscriptionType { name }\", \"\");\n-                        return {\n-                            introspectionQueryName: r,\n-                            introspectionQuery: o,\n-                            introspectionQuerySansSubscriptions: c\n-                        };\n-                    }, [e, t, n]);\n-                }\n-                a(kr, \"useIntrospectionQuery\");\n-\n-                function Nr(e) {\n-                    let t = null,\n-                        n = !0;\n-                    try {\n-                        e && (t = JSON.parse(e));\n-                    } catch {\n-                        n = !1;\n-                    }\n-                    return {\n-                        headers: t,\n-                        isValidJSON: n\n-                    };\n-                }\n-                a(Nr, \"parseHeaderString\");\n-                const Le = {\n-                        name: \"Docs\"\n-                    },\n-                    ut = oe(\"ExplorerContext\");\n-\n-                function dt(e) {\n-                    const {\n-                        schema: t,\n-                        validationErrors: n\n-                    } = Y({\n-                            nonNull: !0,\n-                            caller: dt\n-                        }),\n-                        [r, o] = l.useState([Le]),\n-                        c = l.useCallback(m => {\n-                            o(p => p.at(-1).def === m.def ? p : [...p, m]);\n-                        }, []),\n-                        i = l.useCallback(() => {\n-                            o(m => m.length > 1 ? m.slice(0, -1) : m);\n-                        }, []),\n-                        d = l.useCallback(() => {\n-                            o(m => m.length === 1 ? m : [Le]);\n-                        }, []);\n-                    l.useEffect(() => {\n-                        t == null || n.length > 0 ? d() : o(m => {\n-                            if (m.length === 1) return m;\n-                            const p = [Le];\n-                            let y = null;\n-                            for (const h of m)\n-                                if (h !== Le)\n-                                    if (h.def) {\n-                                        if (M.isNamedType(h.def)) {\n-                                            const x = t.getType(h.def.name);\n-                                            if (x) p.push({\n-                                                name: h.name,\n-                                                def: x\n-                                            }), y = x;\n-                                            else break;\n-                                        } else {\n-                                            if (y === null) break;\n-                                            if (M.isObjectType(y) || M.isInputObjectType(y)) {\n-                                                const x = y.getFields()[h.name];\n-                                                if (x) p.push({\n-                                                    name: h.name,\n-                                                    def: x\n-                                                });\n-                                                else break;\n-                                            } else {\n-                                                if (M.isScalarType(y) || M.isEnumType(y) || M.isInterfaceType(y) || M.isUnionType(y)) break;\n-                                                {\n-                                                    const x = y;\n-                                                    if (x.args.find(C => C.name === h.name)) p.push({\n-                                                        name: h.name,\n-                                                        def: x\n-                                                    });\n-                                                    else break;\n-                                                }\n-                                            }\n-                                        }\n-                                    } else y = null, p.push(h);\n-                            return p;\n-                        });\n-                    }, [d, t, n]);\n-                    const g = l.useMemo(() => ({\n-                        explorerNavStack: r,\n-                        push: c,\n-                        pop: i,\n-                        reset: d\n-                    }), [r, c, i, d]);\n-                    return s.jsx(ut.Provider, {\n-                        value: g,\n-                        children: e.children\n-                    });\n-                }\n-                a(dt, \"ExplorerContextProvider\");\n-                const ee = le(ut);\n-\n-                function Re(e, t) {\n-                    return M.isNonNullType(e) ? s.jsxs(s.Fragment, {\n-                        children: [Re(e.ofType, t), \"!\"]\n-                    }) : M.isListType(e) ? s.jsxs(s.Fragment, {\n-                        children: [\"[\", Re(e.ofType, t), \"]\"]\n-                    }) : t(e);\n-                }\n-                a(Re, \"renderType\");\n-\n-                function Q(e) {\n-                    const {\n-                        push: t\n-                    } = ee({\n-                        nonNull: !0,\n-                        caller: Q\n-                    });\n-                    return e.type ? Re(e.type, n => s.jsx(\"a\", {\n-                        className: \"graphiql-doc-explorer-type-name\",\n-                        onClick: r => {\n-                            r.preventDefault(), t({\n-                                name: n.name,\n-                                def: n\n-                            });\n-                        },\n-                        href: \"#\",\n-                        children: n.name\n-                    })) : null;\n-                }\n-                a(Q, \"TypeLink\");\n-\n-                function Ce(_ref45) {\n-                    let {\n-                        arg: e,\n-                        showDefaultValue: t,\n-                        inline: n\n-                    } = _ref45;\n-                    const r = s.jsxs(\"span\", {\n-                        children: [s.jsx(\"span\", {\n-                            className: \"graphiql-doc-explorer-argument-name\",\n-                            children: e.name\n-                        }), \": \", s.jsx(Q, {\n-                            type: e.type\n-                        }), t !== !1 && s.jsx(it, {\n-                            field: e\n-                        })]\n-                    });\n-                    return n ? r : s.jsxs(\"div\", {\n-                        className: \"graphiql-doc-explorer-argument\",\n-                        children: [r, e.description ? s.jsx(z, {\n-                            type: \"description\",\n-                            children: e.description\n-                        }) : null, e.deprecationReason ? s.jsxs(\"div\", {\n-                            className: \"graphiql-doc-explorer-argument-deprecation\",\n-                            children: [s.jsx(\"div\", {\n-                                className: \"graphiql-doc-explorer-argument-deprecation-label\",\n-                                children: \"Deprecated\"\n-                            }), s.jsx(z, {\n-                                type: \"deprecation\",\n-                                children: e.deprecationReason\n-                            })]\n-                        }) : null]\n-                    });\n-                }\n-                a(Ce, \"Argument\");\n-\n-                function ht(e) {\n-                    var _e$preview;\n-                    return e.children ? s.jsxs(\"div\", {\n-                        className: \"graphiql-doc-explorer-deprecation\",\n-                        children: [s.jsx(\"div\", {\n-                            className: \"graphiql-doc-explorer-deprecation-label\",\n-                            children: \"Deprecated\"\n-                        }), s.jsx(z, {\n-                            type: \"deprecation\",\n-                            onlyShowFirstChild: (_e$preview = e.preview) !== null && _e$preview !== void 0 ? _e$preview : !0,\n-                            children: e.children\n-                        })]\n-                    }) : null;\n-                }\n-                a(ht, \"DeprecationReason\");\n-\n-                function cn(_ref46) {\n-                    let {\n-                        directive: e\n-                    } = _ref46;\n-                    return s.jsxs(\"span\", {\n-                        className: \"graphiql-doc-explorer-directive\",\n-                        children: [\"@\", e.name.value]\n-                    });\n-                }\n-                a(cn, \"Directive\");\n-\n-                function G(e) {\n-                    const t = Tr[e.title];\n-                    return s.jsxs(\"div\", {\n-                        children: [s.jsxs(\"div\", {\n-                            className: \"graphiql-doc-explorer-section-title\",\n-                            children: [s.jsx(t, {}), e.title]\n-                        }), s.jsx(\"div\", {\n-                            className: \"graphiql-doc-explorer-section-content\",\n-                            children: e.children\n-                        })]\n-                    });\n-                }\n-                a(G, \"ExplorerSection\");\n-                const Tr = {\n-                    Arguments: Tt,\n-                    \"Deprecated Arguments\": Pt,\n-                    \"Deprecated Enum Values\": qt,\n-                    \"Deprecated Fields\": Rt,\n-                    Directives: Vt,\n-                    \"Enum Values\": Dt,\n-                    Fields: At,\n-                    Implements: Ft,\n-                    Implementations: ge,\n-                    \"Possible Types\": ge,\n-                    \"Root Types\": Zt,\n-                    Type: ge,\n-                    \"All Schema Types\": ge\n-                };\n-\n-                function un(e) {\n-                    return s.jsxs(s.Fragment, {\n-                        children: [e.field.description ? s.jsx(z, {\n-                            type: \"description\",\n-                            children: e.field.description\n-                        }) : null, s.jsx(ht, {\n-                            preview: !1,\n-                            children: e.field.deprecationReason\n-                        }), s.jsx(G, {\n-                            title: \"Type\",\n-                            children: s.jsx(Q, {\n-                                type: e.field.type\n-                            })\n-                        }), s.jsx(Mr, {\n-                            field: e.field\n-                        }), s.jsx(Pr, {\n-                            field: e.field\n-                        })]\n-                    });\n-                }\n-                a(un, \"FieldDocumentation\");\n-\n-                function Mr(_ref47) {\n-                    let {\n-                        field: e\n-                    } = _ref47;\n-                    const [t, n] = l.useState(!1),\n-                        r = l.useCallback(() => {\n-                            n(!0);\n-                        }, []);\n-                    if (!(\"args\" in e)) return null;\n-                    const o = [],\n-                        c = [];\n-                    for (const i of e.args) i.deprecationReason ? c.push(i) : o.push(i);\n-                    return s.jsxs(s.Fragment, {\n-                        children: [o.length > 0 ? s.jsx(G, {\n-                            title: \"Arguments\",\n-                            children: o.map(i => s.jsx(Ce, {\n-                                arg: i\n-                            }, i.name))\n-                        }) : null, c.length > 0 ? t || o.length === 0 ? s.jsx(G, {\n-                            title: \"Deprecated Arguments\",\n-                            children: c.map(i => s.jsx(Ce, {\n-                                arg: i\n-                            }, i.name))\n-                        }) : s.jsx(me, {\n-                            type: \"button\",\n-                            onClick: r,\n-                            children: \"Show Deprecated Arguments\"\n-                        }) : null]\n-                    });\n-                }\n-                a(Mr, \"Arguments\");\n-\n-                function Pr(_ref48) {\n-                    let {\n-                        field: e\n-                    } = _ref48;\n-                    var n;\n-                    const t = ((n = e.astNode) == null ? void 0 : n.directives) || [];\n-                    return !t || t.length === 0 ? null : s.jsx(G, {\n-                        title: \"Directives\",\n-                        children: t.map(r => s.jsx(\"div\", {\n-                            children: s.jsx(cn, {\n-                                directive: r\n-                            })\n-                        }, r.name.value))\n-                    });\n-                }\n-                a(Pr, \"Directives\");\n-\n-                function dn(e) {\n-                    var i, d, g, m;\n-                    const t = e.schema.getQueryType(),\n-                        n = (d = (i = e.schema).getMutationType) == null ? void 0 : d.call(i),\n-                        r = (m = (g = e.schema).getSubscriptionType) == null ? void 0 : m.call(g),\n-                        o = e.schema.getTypeMap(),\n-                        c = [t == null ? void 0 : t.name, n == null ? void 0 : n.name, r == null ? void 0 : r.name];\n-                    return s.jsxs(s.Fragment, {\n-                        children: [s.jsx(z, {\n-                            type: \"description\",\n-                            children: e.schema.description || \"A GraphQL schema provides a root type for each kind of operation.\"\n-                        }), s.jsxs(G, {\n-                            title: \"Root Types\",\n-                            children: [t ? s.jsxs(\"div\", {\n-                                children: [s.jsx(\"span\", {\n-                                    className: \"graphiql-doc-explorer-root-type\",\n-                                    children: \"query\"\n-                                }), \": \", s.jsx(Q, {\n-                                    type: t\n-                                })]\n-                            }) : null, n && s.jsxs(\"div\", {\n-                                children: [s.jsx(\"span\", {\n-                                    className: \"graphiql-doc-explorer-root-type\",\n-                                    children: \"mutation\"\n-                                }), \": \", s.jsx(Q, {\n-                                    type: n\n-                                })]\n-                            }), r && s.jsxs(\"div\", {\n-                                children: [s.jsx(\"span\", {\n-                                    className: \"graphiql-doc-explorer-root-type\",\n-                                    children: \"subscription\"\n-                                }), \": \", s.jsx(Q, {\n-                                    type: r\n-                                })]\n-                            })]\n-                        }), s.jsx(G, {\n-                            title: \"All Schema Types\",\n-                            children: o && s.jsx(\"div\", {\n-                                children: Object.values(o).map(p => c.includes(p.name) || p.name.startsWith(\"__\") ? null : s.jsx(\"div\", {\n-                                    children: s.jsx(Q, {\n-                                        type: p\n-                                    })\n-                                }, p.name))\n-                            })\n-                        })]\n-                    });\n-                }\n-                a(dn, \"SchemaDocumentation\");\n+                exports.getTouchXY = getTouchXY;\n+                var getDeltaXY = function(event) {\n+                    return [event.deltaX, event.deltaY];\n+                };\n+                exports.getDeltaXY = getDeltaXY;\n+                var extractRef = function(ref) {\n+                    return ref && 'current' in ref ? ref.current : ref;\n+                };\n+                var deltaCompare = function(x, y) {\n+                    return x[0] === y[0] && x[1] === y[1];\n+                };\n+                var generateStyle = function(id) {\n+                    return \"\\n  .block-interactivity-\".concat(id, \" {pointer-events: none;}\\n  .allow-interactivity-\").concat(id, \" {pointer-events: all;}\\n\");\n+                };\n+                var idCounter = 0;\n+                var lockStack = [];\n \n-                function ue(e, t) {\n-                    let n;\n-                    return function() {\n-                        for (var _len = arguments.length, r = new Array(_len), _key = 0; _key < _len; _key++) {\n-                            r[_key] = arguments[_key];\n+                function RemoveScrollSideCar(props) {\n+                    var shouldPreventQueue = React.useRef([]);\n+                    var touchStartRef = React.useRef([0, 0]);\n+                    var activeAxis = React.useRef();\n+                    var id = React.useState(idCounter++)[0];\n+                    var Style = React.useState(function() {\n+                        return (0, _reactStyleSingleton.styleSingleton)();\n+                    })[0];\n+                    var lastProps = React.useRef(props);\n+                    React.useEffect(function() {\n+                        lastProps.current = props;\n+                    }, [props]);\n+                    React.useEffect(function() {\n+                        if (props.inert) {\n+                            document.body.classList.add(\"block-interactivity-\".concat(id));\n+                            var allow_1 = (0, _tslib.__spreadArray)([props.lockRef.current], (props.shards || []).map(extractRef), true).filter(Boolean);\n+                            allow_1.forEach(function(el) {\n+                                return el.classList.add(\"allow-interactivity-\".concat(id));\n+                            });\n+                            return function() {\n+                                document.body.classList.remove(\"block-interactivity-\".concat(id));\n+                                allow_1.forEach(function(el) {\n+                                    return el.classList.remove(\"allow-interactivity-\".concat(id));\n+                                });\n+                            };\n                         }\n-                        n && window.clearTimeout(n), n = window.setTimeout(() => {\n-                            n = null, t(...r);\n-                        }, e);\n-                    };\n-                }\n-                a(ue, \"debounce\");\n-\n-                function mt() {\n-                    const {\n-                        explorerNavStack: e,\n-                        push: t\n-                    } = ee({\n-                            nonNull: !0,\n-                            caller: mt\n-                        }),\n-                        n = l.useRef(null),\n-                        r = Ke(),\n-                        [o, c] = l.useState(\"\"),\n-                        [i, d] = l.useState(r(o)),\n-                        g = l.useMemo(() => ue(200, f => {\n-                            d(r(f));\n-                        }), [r]);\n-                    l.useEffect(() => {\n-                        g(o);\n-                    }, [g, o]), l.useEffect(() => {\n-                        function f(C) {\n-                            var E;\n-                            C.metaKey && C.key === \"k\" && ((E = n.current) == null || E.focus());\n+                        return;\n+                    }, [props.inert, props.lockRef.current, props.shards]);\n+                    var shouldCancelEvent = React.useCallback(function(event, parent) {\n+                        if ('touches' in event && event.touches.length === 2) {\n+                            return !lastProps.current.allowPinchZoom;\n+                        }\n+                        var touch = getTouchXY(event);\n+                        var touchStart = touchStartRef.current;\n+                        var deltaX = 'deltaX' in event ? event.deltaX : touchStart[0] - touch[0];\n+                        var deltaY = 'deltaY' in event ? event.deltaY : touchStart[1] - touch[1];\n+                        var currentAxis;\n+                        var target = event.target;\n+                        var moveDirection = Math.abs(deltaX) > Math.abs(deltaY) ? 'h' : 'v';\n+                        // allow horizontal touch move on Range inputs. They will not cause any scroll\n+                        if ('touches' in event && moveDirection === 'h' && target.type === 'range') {\n+                            return false;\n+                        }\n+                        var canBeScrolledInMainDirection = (0, _handleScroll.locationCouldBeScrolled)(moveDirection, target);\n+                        if (!canBeScrolledInMainDirection) {\n+                            return true;\n+                        }\n+                        if (canBeScrolledInMainDirection) {\n+                            currentAxis = moveDirection;\n+                        } else {\n+                            currentAxis = moveDirection === 'v' ? 'h' : 'v';\n+                            canBeScrolledInMainDirection = (0, _handleScroll.locationCouldBeScrolled)(moveDirection, target);\n+                            // other axis might be not scrollable\n+                        }\n+                        if (!canBeScrolledInMainDirection) {\n+                            return false;\n+                        }\n+                        if (!activeAxis.current && 'changedTouches' in event && (deltaX || deltaY)) {\n+                            activeAxis.current = currentAxis;\n+                        }\n+                        if (!currentAxis) {\n+                            return true;\n                         }\n-                        return a(f, \"handleKeyDown\"), window.addEventListener(\"keydown\", f), () => window.removeEventListener(\"keydown\", f);\n+                        var cancelingAxis = activeAxis.current || currentAxis;\n+                        return (0, _handleScroll.handleScroll)(cancelingAxis, parent, event, cancelingAxis === 'h' ? deltaX : deltaY, true);\n                     }, []);\n-                    const m = e.at(-1),\n-                        p = l.useCallback(f => {\n-                            t(\"field\" in f ? {\n-                                name: f.field.name,\n-                                def: f.field\n-                            } : {\n-                                name: f.type.name,\n-                                def: f.type\n+                    var shouldPrevent = React.useCallback(function(_event) {\n+                        var event = _event;\n+                        if (!lockStack.length || lockStack[lockStack.length - 1] !== Style) {\n+                            // not the last active\n+                            return;\n+                        }\n+                        var delta = 'deltaY' in event ? getDeltaXY(event) : getTouchXY(event);\n+                        var sourceEvent = shouldPreventQueue.current.filter(function(e) {\n+                            return e.name === event.type && e.target === event.target && deltaCompare(e.delta, delta);\n+                        })[0];\n+                        // self event, and should be canceled\n+                        if (sourceEvent && sourceEvent.should) {\n+                            if (event.cancelable) {\n+                                event.preventDefault();\n+                            }\n+                            return;\n+                        }\n+                        // outside or shard event\n+                        if (!sourceEvent) {\n+                            var shardNodes = (lastProps.current.shards || []).map(extractRef).filter(Boolean).filter(function(node) {\n+                                return node.contains(event.target);\n                             });\n-                        }, [t]),\n-                        y = l.useRef(!1),\n-                        h = l.useCallback(f => {\n-                            y.current = f.type === \"focus\";\n-                        }, []);\n-                    return e.length === 1 || M.isObjectType(m.def) || M.isInterfaceType(m.def) || M.isInputObjectType(m.def) ? s.jsxs(ae.Combobox, {\n-                        as: \"div\",\n-                        className: \"graphiql-doc-explorer-search\",\n-                        onChange: p,\n-                        \"data-state\": y ? void 0 : \"idle\",\n-                        \"aria-label\": `Search ${m.name}...`,\n-                        children: [s.jsxs(\"div\", {\n-                            className: \"graphiql-doc-explorer-search-input\",\n-                            onClick: () => {\n-                                var f;\n-                                (f = n.current) == null || f.focus();\n-                            },\n-                            children: [s.jsx(Bt, {}), s.jsx(ae.Combobox.Input, {\n-                                autoComplete: \"off\",\n-                                onFocus: h,\n-                                onBlur: h,\n-                                onChange: f => c(f.target.value),\n-                                placeholder: \"\u2318 K\",\n-                                ref: n,\n-                                value: o,\n-                                \"data-cy\": \"doc-explorer-input\"\n-                            })]\n-                        }), y.current && s.jsxs(ae.Combobox.Options, {\n-                            \"data-cy\": \"doc-explorer-list\",\n-                            children: [i.within.length + i.types.length + i.fields.length === 0 ? s.jsx(\"li\", {\n-                                className: \"graphiql-doc-explorer-search-empty\",\n-                                children: \"No results found\"\n-                            }) : i.within.map((f, C) => s.jsx(ae.Combobox.Option, {\n-                                value: f,\n-                                \"data-cy\": \"doc-explorer-option\",\n-                                children: s.jsx(bt, {\n-                                    field: f.field,\n-                                    argument: f.argument\n-                                })\n-                            }, `within-${C}`)), i.within.length > 0 && i.types.length + i.fields.length > 0 ? s.jsx(\"div\", {\n-                                className: \"graphiql-doc-explorer-search-divider\",\n-                                children: \"Other results\"\n-                            }) : null, i.types.map((f, C) => s.jsx(ae.Combobox.Option, {\n-                                value: f,\n-                                \"data-cy\": \"doc-explorer-option\",\n-                                children: s.jsx(Je, {\n-                                    type: f.type\n-                                })\n-                            }, `type-${C}`)), i.fields.map((f, C) => s.jsxs(ae.Combobox.Option, {\n-                                value: f,\n-                                \"data-cy\": \"doc-explorer-option\",\n-                                children: [s.jsx(Je, {\n-                                    type: f.type\n-                                }), \".\", s.jsx(bt, {\n-                                    field: f.field,\n-                                    argument: f.argument\n-                                })]\n-                            }, `field-${C}`))]\n-                        })]\n-                    }) : null;\n-                }\n-                a(mt, \"Search\");\n-\n-                function Ke(e) {\n-                    const {\n-                        explorerNavStack: t\n-                    } = ee({\n-                            nonNull: !0,\n-                            caller: e || Ke\n-                        }), {\n-                            schema: n\n-                        } = Y({\n-                            nonNull: !0,\n-                            caller: e || Ke\n-                        }),\n-                        r = t.at(-1);\n-                    return l.useCallback(o => {\n-                        const c = {\n-                            within: [],\n-                            types: [],\n-                            fields: []\n-                        };\n-                        if (!n) return c;\n-                        const i = r.def,\n-                            d = n.getTypeMap();\n-                        let g = Object.keys(d);\n-                        i && (g = g.filter(m => m !== i.name), g.unshift(i.name));\n-                        for (const m of g) {\n-                            if (c.within.length + c.types.length + c.fields.length >= 100) break;\n-                            const p = d[m];\n-                            if (i !== p && Qe(m, o) && c.types.push({\n-                                    type: p\n-                                }), !M.isObjectType(p) && !M.isInterfaceType(p) && !M.isInputObjectType(p)) continue;\n-                            const y = p.getFields();\n-                            for (const h in y) {\n-                                const x = y[h];\n-                                let f;\n-                                if (!Qe(h, o))\n-                                    if (\"args\" in x) {\n-                                        if (f = x.args.filter(C => Qe(C.name, o)), f.length === 0) continue;\n-                                    } else continue;\n-                                c[i === p ? \"within\" : \"fields\"].push(...(f ? f.map(C => ({\n-                                    type: p,\n-                                    field: x,\n-                                    argument: C\n-                                })) : [{\n-                                    type: p,\n-                                    field: x\n-                                }]));\n+                            var shouldStop = shardNodes.length > 0 ? shouldCancelEvent(event, shardNodes[0]) : !lastProps.current.noIsolation;\n+                            if (shouldStop) {\n+                                if (event.cancelable) {\n+                                    event.preventDefault();\n+                                }\n                             }\n                         }\n-                        return c;\n-                    }, [r.def, n]);\n-                }\n-                a(Ke, \"useSearchResults\");\n-\n-                function Qe(e, t) {\n-                    try {\n-                        const n = t.replaceAll(/[^_0-9A-Za-z]/g, r => \"\\\\\" + r);\n-                        return e.search(new RegExp(n, \"i\")) !== -1;\n-                    } catch {\n-                        return e.toLowerCase().includes(t.toLowerCase());\n-                    }\n-                }\n-                a(Qe, \"isMatch\");\n-\n-                function Je(e) {\n-                    return s.jsx(\"span\", {\n-                        className: \"graphiql-doc-explorer-search-type\",\n-                        children: e.type.name\n-                    });\n-                }\n-                a(Je, \"Type\");\n-\n-                function bt(_ref49) {\n-                    let {\n-                        field: e,\n-                        argument: t\n-                    } = _ref49;\n-                    return s.jsxs(s.Fragment, {\n-                        children: [s.jsx(\"span\", {\n-                            className: \"graphiql-doc-explorer-search-field\",\n-                            children: e.name\n-                        }), t ? s.jsxs(s.Fragment, {\n-                            children: [\"(\", s.jsx(\"span\", {\n-                                className: \"graphiql-doc-explorer-search-argument\",\n-                                children: t.name\n-                            }), \":\", \" \", Re(t.type, n => s.jsx(Je, {\n-                                type: n\n-                            })), \")\"]\n-                        }) : null]\n-                    });\n-                }\n-                a(bt, \"Field$1\");\n-\n-                function hn(e) {\n-                    const {\n-                        push: t\n-                    } = ee({\n-                        nonNull: !0\n-                    });\n-                    return s.jsx(\"a\", {\n-                        className: \"graphiql-doc-explorer-field-name\",\n-                        onClick: n => {\n-                            n.preventDefault(), t({\n-                                name: e.field.name,\n-                                def: e.field\n+                    }, []);\n+                    var shouldCancel = React.useCallback(function(name, delta, target, should) {\n+                        var event = {\n+                            name: name,\n+                            delta: delta,\n+                            target: target,\n+                            should: should\n+                        };\n+                        shouldPreventQueue.current.push(event);\n+                        setTimeout(function() {\n+                            shouldPreventQueue.current = shouldPreventQueue.current.filter(function(e) {\n+                                return e !== event;\n                             });\n-                        },\n-                        href: \"#\",\n-                        children: e.field.name\n-                    });\n-                }\n-                a(hn, \"FieldLink\");\n-\n-                function mn(e) {\n-                    return M.isNamedType(e.type) ? s.jsxs(s.Fragment, {\n-                        children: [e.type.description ? s.jsx(z, {\n-                            type: \"description\",\n-                            children: e.type.description\n-                        }) : null, s.jsx(qr, {\n-                            type: e.type\n-                        }), s.jsx(Rr, {\n-                            type: e.type\n-                        }), s.jsx(Vr, {\n-                            type: e.type\n-                        }), s.jsx(Ir, {\n-                            type: e.type\n-                        })]\n-                    }) : null;\n+                        }, 1);\n+                    }, []);\n+                    var scrollTouchStart = React.useCallback(function(event) {\n+                        touchStartRef.current = getTouchXY(event);\n+                        activeAxis.current = undefined;\n+                    }, []);\n+                    var scrollWheel = React.useCallback(function(event) {\n+                        shouldCancel(event.type, getDeltaXY(event), event.target, shouldCancelEvent(event, props.lockRef.current));\n+                    }, []);\n+                    var scrollTouchMove = React.useCallback(function(event) {\n+                        shouldCancel(event.type, getTouchXY(event), event.target, shouldCancelEvent(event, props.lockRef.current));\n+                    }, []);\n+                    React.useEffect(function() {\n+                        lockStack.push(Style);\n+                        props.setCallbacks({\n+                            onScrollCapture: scrollWheel,\n+                            onWheelCapture: scrollWheel,\n+                            onTouchMoveCapture: scrollTouchMove\n+                        });\n+                        document.addEventListener('wheel', shouldPrevent, _aggresiveCapture.nonPassive);\n+                        document.addEventListener('touchmove', shouldPrevent, _aggresiveCapture.nonPassive);\n+                        document.addEventListener('touchstart', scrollTouchStart, _aggresiveCapture.nonPassive);\n+                        return function() {\n+                            lockStack = lockStack.filter(function(inst) {\n+                                return inst !== Style;\n+                            });\n+                            document.removeEventListener('wheel', shouldPrevent, _aggresiveCapture.nonPassive);\n+                            document.removeEventListener('touchmove', shouldPrevent, _aggresiveCapture.nonPassive);\n+                            document.removeEventListener('touchstart', scrollTouchStart, _aggresiveCapture.nonPassive);\n+                        };\n+                    }, []);\n+                    var removeScrollBar = props.removeScrollBar,\n+                        inert = props.inert;\n+                    return /*#__PURE__*/ React.createElement(React.Fragment, null, inert ? /*#__PURE__*/ React.createElement(Style, {\n+                        styles: generateStyle(id)\n+                    }) : null, removeScrollBar ? /*#__PURE__*/ React.createElement(_reactRemoveScrollBar.RemoveScrollBar, {\n+                        gapMode: \"margin\"\n+                    }) : null);\n                 }\n-                a(mn, \"TypeDocumentation\");\n \n-                function qr(_ref50) {\n-                    let {\n-                        type: e\n-                    } = _ref50;\n-                    return M.isObjectType(e) && e.getInterfaces().length > 0 ? s.jsx(G, {\n-                        title: \"Implements\",\n-                        children: e.getInterfaces().map(n => s.jsx(\"div\", {\n-                            children: s.jsx(Q, {\n-                                type: n\n-                            })\n-                        }, n.name))\n-                    }) : null;\n-                }\n-                a(qr, \"ImplementsInterfaces\");\n+                /***/\n+            }),\n \n-                function Rr(_ref51) {\n-                    let {\n-                        type: e\n-                    } = _ref51;\n-                    const [t, n] = l.useState(!1),\n-                        r = l.useCallback(() => {\n-                            n(!0);\n-                        }, []);\n-                    if (!M.isObjectType(e) && !M.isInterfaceType(e) && !M.isInputObjectType(e)) return null;\n-                    const o = e.getFields(),\n-                        c = [],\n-                        i = [];\n-                    for (const d of Object.keys(o).map(g => o[g])) d.deprecationReason ? i.push(d) : c.push(d);\n-                    return s.jsxs(s.Fragment, {\n-                        children: [c.length > 0 ? s.jsx(G, {\n-                            title: \"Fields\",\n-                            children: c.map(d => s.jsx(wt, {\n-                                field: d\n-                            }, d.name))\n-                        }) : null, i.length > 0 ? t || c.length === 0 ? s.jsx(G, {\n-                            title: \"Deprecated Fields\",\n-                            children: i.map(d => s.jsx(wt, {\n-                                field: d\n-                            }, d.name))\n-                        }) : s.jsx(me, {\n-                            type: \"button\",\n-                            onClick: r,\n-                            children: \"Show Deprecated Fields\"\n-                        }) : null]\n-                    });\n-                }\n-                a(Rr, \"Fields\");\n+        /***/\n+        \"../../../node_modules/react-remove-scroll/dist/es2015/UI.js\":\n+            /*!*******************************************************************!*\\\n+              !*** ../../../node_modules/react-remove-scroll/dist/es2015/UI.js ***!\n+              \\*******************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                function wt(_ref52) {\n-                    let {\n-                        field: e\n-                    } = _ref52;\n-                    const t = \"args\" in e ? e.args.filter(n => !n.deprecationReason) : [];\n-                    return s.jsxs(\"div\", {\n-                        className: \"graphiql-doc-explorer-item\",\n-                        children: [s.jsxs(\"div\", {\n-                            children: [s.jsx(hn, {\n-                                field: e\n-                            }), t.length > 0 ? s.jsxs(s.Fragment, {\n-                                children: [\"(\", s.jsx(\"span\", {\n-                                    children: t.map(n => t.length === 1 ? s.jsx(Ce, {\n-                                        arg: n,\n-                                        inline: !0\n-                                    }, n.name) : s.jsx(\"div\", {\n-                                        className: \"graphiql-doc-explorer-argument-multiple\",\n-                                        children: s.jsx(Ce, {\n-                                            arg: n,\n-                                            inline: !0\n-                                        })\n-                                    }, n.name))\n-                                }), \")\"]\n-                            }) : null, \": \", s.jsx(Q, {\n-                                type: e.type\n-                            }), s.jsx(it, {\n-                                field: e\n-                            })]\n-                        }), e.description ? s.jsx(z, {\n-                            type: \"description\",\n-                            onlyShowFirstChild: !0,\n-                            children: e.description\n-                        }) : null, s.jsx(ht, {\n-                            children: e.deprecationReason\n-                        })]\n-                    });\n-                }\n-                a(wt, \"Field\");\n+                \"use strict\";\n \n-                function Vr(_ref53) {\n-                    let {\n-                        type: e\n-                    } = _ref53;\n-                    const [t, n] = l.useState(!1),\n-                        r = l.useCallback(() => {\n-                            n(!0);\n-                        }, []);\n-                    if (!M.isEnumType(e)) return null;\n-                    const o = [],\n-                        c = [];\n-                    for (const i of e.getValues()) i.deprecationReason ? c.push(i) : o.push(i);\n-                    return s.jsxs(s.Fragment, {\n-                        children: [o.length > 0 ? s.jsx(G, {\n-                            title: \"Enum Values\",\n-                            children: o.map(i => s.jsx(Et, {\n-                                value: i\n-                            }, i.name))\n-                        }) : null, c.length > 0 ? t || o.length === 0 ? s.jsx(G, {\n-                            title: \"Deprecated Enum Values\",\n-                            children: c.map(i => s.jsx(Et, {\n-                                value: i\n-                            }, i.name))\n-                        }) : s.jsx(me, {\n-                            type: \"button\",\n-                            onClick: r,\n-                            children: \"Show Deprecated Values\"\n-                        }) : null]\n-                    });\n-                }\n-                a(Vr, \"EnumValues\");\n \n-                function Et(_ref54) {\n-                    let {\n-                        value: e\n-                    } = _ref54;\n-                    return s.jsxs(\"div\", {\n-                        className: \"graphiql-doc-explorer-item\",\n-                        children: [s.jsx(\"div\", {\n-                            className: \"graphiql-doc-explorer-enum-value\",\n-                            children: e.name\n-                        }), e.description ? s.jsx(z, {\n-                            type: \"description\",\n-                            children: e.description\n-                        }) : null, e.deprecationReason ? s.jsx(z, {\n-                            type: \"deprecation\",\n-                            children: e.deprecationReason\n-                        }) : null]\n-                    });\n-                }\n-                a(Et, \"EnumValue\");\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.RemoveScroll = void 0;\n+                var _tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.mjs\");\n+                var React = _interopRequireWildcard(__webpack_require__( /*! react */ \"react\"));\n+                var _constants = __webpack_require__( /*! react-remove-scroll-bar/constants */ \"../../../node_modules/react-remove-scroll-bar/dist/es2015/constants.js\");\n+                var _useCallbackRef = __webpack_require__( /*! use-callback-ref */ \"../../../node_modules/use-callback-ref/dist/es2015/index.js\");\n+                var _medium = __webpack_require__( /*! ./medium */ \"../../../node_modules/react-remove-scroll/dist/es2015/medium.js\");\n \n-                function Ir(_ref55) {\n-                    let {\n-                        type: e\n-                    } = _ref55;\n-                    const {\n-                        schema: t\n-                    } = Y({\n-                        nonNull: !0\n-                    });\n-                    return !t || !M.isAbstractType(e) ? null : s.jsx(G, {\n-                        title: M.isInterfaceType(e) ? \"Implementations\" : \"Possible Types\",\n-                        children: t.getPossibleTypes(e).map(n => s.jsx(\"div\", {\n-                            children: s.jsx(Q, {\n-                                type: n\n-                            })\n-                        }, n.name))\n-                    });\n+                function _getRequireWildcardCache(e) {\n+                    if (\"function\" != typeof WeakMap) return null;\n+                    var r = new WeakMap(),\n+                        t = new WeakMap();\n+                    return (_getRequireWildcardCache = function(e) {\n+                        return e ? t : r;\n+                    })(e);\n+                }\n+\n+                function _interopRequireWildcard(e, r) {\n+                    if (!r && e && e.__esModule) return e;\n+                    if (null === e || \"object\" != typeof e && \"function\" != typeof e) return {\n+                        default: e\n+                    };\n+                    var t = _getRequireWildcardCache(r);\n+                    if (t && t.has(e)) return t.get(e);\n+                    var n = {\n+                            __proto__: null\n+                        },\n+                        a = Object.defineProperty && Object.getOwnPropertyDescriptor;\n+                    for (var u in e)\n+                        if (\"default\" !== u && Object.prototype.hasOwnProperty.call(e, u)) {\n+                            var i = a ? Object.getOwnPropertyDescriptor(e, u) : null;\n+                            i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u];\n+                        } return n.default = e, t && t.set(e, n), n;\n                 }\n-                a(Ir, \"PossibleTypes\");\n-\n-                function Ve() {\n-                    const {\n-                        fetchError: e,\n-                        isFetching: t,\n-                        schema: n,\n-                        validationErrors: r\n-                    } = Y({\n-                            nonNull: !0,\n-                            caller: Ve\n-                        }), {\n-                            explorerNavStack: o,\n-                            pop: c\n-                        } = ee({\n-                            nonNull: !0,\n-                            caller: Ve\n+                var nothing = function() {\n+                    return;\n+                };\n+                /**\n+                 * Removes scrollbar from the page and contain the scroll within the Lock\n+                 */\n+                var RemoveScroll = exports.RemoveScroll = /*#__PURE__*/ React.forwardRef(function(props, parentRef) {\n+                    var ref = React.useRef(null);\n+                    var _a = React.useState({\n+                            onScrollCapture: nothing,\n+                            onWheelCapture: nothing,\n+                            onTouchMoveCapture: nothing\n                         }),\n-                        i = o.at(-1);\n-                    let d = null;\n-                    e ? d = s.jsx(\"div\", {\n-                        className: \"graphiql-doc-explorer-error\",\n-                        children: \"Error fetching schema\"\n-                    }) : r.length > 0 ? d = s.jsxs(\"div\", {\n-                        className: \"graphiql-doc-explorer-error\",\n-                        children: [\"Schema is invalid: \", r[0].message]\n-                    }) : t ? d = s.jsx(st, {}) : n ? o.length === 1 ? d = s.jsx(dn, {\n-                        schema: n\n-                    }) : M.isType(i.def) ? d = s.jsx(mn, {\n-                        type: i.def\n-                    }) : i.def && (d = s.jsx(un, {\n-                        field: i.def\n-                    })) : d = s.jsx(\"div\", {\n-                        className: \"graphiql-doc-explorer-error\",\n-                        children: \"No GraphQL schema available\"\n-                    });\n-                    let g;\n-                    return o.length > 1 && (g = o.at(-2).name), s.jsxs(\"section\", {\n-                        className: \"graphiql-doc-explorer\",\n-                        \"aria-label\": \"Documentation Explorer\",\n-                        children: [s.jsxs(\"div\", {\n-                            className: \"graphiql-doc-explorer-header\",\n-                            children: [s.jsxs(\"div\", {\n-                                className: \"graphiql-doc-explorer-header-content\",\n-                                children: [g && s.jsxs(\"a\", {\n-                                    href: \"#\",\n-                                    className: \"graphiql-doc-explorer-back\",\n-                                    onClick: m => {\n-                                        m.preventDefault(), c();\n-                                    },\n-                                    \"aria-label\": `Go back to ${g}`,\n-                                    children: [s.jsx(Mt, {}), g]\n-                                }), s.jsx(\"div\", {\n-                                    className: \"graphiql-doc-explorer-title\",\n-                                    children: i.name\n-                                })]\n-                            }), s.jsx(mt, {}, i.name)]\n-                        }), s.jsx(\"div\", {\n-                            className: \"graphiql-doc-explorer-content\",\n-                            children: d\n-                        })]\n-                    });\n-                }\n-                a(Ve, \"DocExplorer\");\n-                const de = {\n-                        title: \"Documentation Explorer\",\n-                        icon: a(function() {\n-                            const t = _e();\n-                            return (t == null ? void 0 : t.visiblePlugin) === de ? s.jsx(It, {}) : s.jsx(Ht, {});\n-                        }, \"Icon\"),\n-                        content: Ve\n-                    },\n-                    Ye = {\n-                        title: \"History\",\n-                        icon: Ot,\n-                        content: on\n-                    },\n-                    ft = oe(\"PluginContext\");\n+                        callbacks = _a[0],\n+                        setCallbacks = _a[1];\n+                    var forwardProps = props.forwardProps,\n+                        children = props.children,\n+                        className = props.className,\n+                        removeScrollBar = props.removeScrollBar,\n+                        enabled = props.enabled,\n+                        shards = props.shards,\n+                        sideCar = props.sideCar,\n+                        noIsolation = props.noIsolation,\n+                        inert = props.inert,\n+                        allowPinchZoom = props.allowPinchZoom,\n+                        _b = props.as,\n+                        Container = _b === void 0 ? 'div' : _b,\n+                        rest = (0, _tslib.__rest)(props, [\"forwardProps\", \"children\", \"className\", \"removeScrollBar\", \"enabled\", \"shards\", \"sideCar\", \"noIsolation\", \"inert\", \"allowPinchZoom\", \"as\"]);\n+                    var SideCar = sideCar;\n+                    var containerRef = (0, _useCallbackRef.useMergeRefs)([ref, parentRef]);\n+                    var containerProps = (0, _tslib.__assign)((0, _tslib.__assign)({}, rest), callbacks);\n+                    return /*#__PURE__*/ React.createElement(React.Fragment, null, enabled && ( /*#__PURE__*/ React.createElement(SideCar, {\n+                        sideCar: _medium.effectCar,\n+                        removeScrollBar: removeScrollBar,\n+                        shards: shards,\n+                        noIsolation: noIsolation,\n+                        inert: inert,\n+                        setCallbacks: setCallbacks,\n+                        allowPinchZoom: !!allowPinchZoom,\n+                        lockRef: ref\n+                    })), forwardProps ? ( /*#__PURE__*/ React.cloneElement(React.Children.only(children), (0, _tslib.__assign)((0, _tslib.__assign)({}, containerProps), {\n+                        ref: containerRef\n+                    }))) : ( /*#__PURE__*/ React.createElement(Container, (0, _tslib.__assign)({}, containerProps, {\n+                        className: className,\n+                        ref: containerRef\n+                    }), children)));\n+                });\n+                RemoveScroll.defaultProps = {\n+                    enabled: true,\n+                    removeScrollBar: true,\n+                    inert: false\n+                };\n+                RemoveScroll.classNames = {\n+                    fullWidth: _constants.fullWidthClassName,\n+                    zeroRight: _constants.zeroRightClassName\n+                };\n \n-                function fn(e) {\n-                    const t = re(),\n-                        n = ee(),\n-                        r = be(),\n-                        o = !!n,\n-                        c = !!r,\n-                        i = l.useMemo(() => {\n-                            const x = [],\n-                                f = {};\n-                            o && (x.push(de), f[de.title] = !0), c && (x.push(Ye), f[Ye.title] = !0);\n-                            for (const C of e.plugins || []) {\n-                                if (typeof C.title != \"string\" || !C.title) throw new Error(\"All GraphiQL plugins must have a unique title\");\n-                                if (f[C.title]) throw new Error(`All GraphiQL plugins must have a unique title, found two plugins with the title '${C.title}'`);\n-                                x.push(C), f[C.title] = !0;\n-                            }\n-                            return x;\n-                        }, [o, c, e.plugins]),\n-                        [d, g] = l.useState(() => {\n-                            const x = t == null ? void 0 : t.get(St),\n-                                f = i.find(C => C.title === x);\n-                            return f || (x && (t == null || t.set(St, \"\")), e.visiblePlugin && i.find(C => (typeof e.visiblePlugin == \"string\" ? C.title : C) === e.visiblePlugin) || null);\n-                        }),\n-                        {\n-                            onTogglePluginVisibility: m,\n-                            children: p\n-                        } = e,\n-                        y = l.useCallback(x => {\n-                            const f = x && i.find(C => (typeof x == \"string\" ? C.title : C) === x) || null;\n-                            g(C => f === C ? C : (m == null || m(f), f));\n-                        }, [m, i]);\n-                    l.useEffect(() => {\n-                        e.visiblePlugin && y(e.visiblePlugin);\n-                    }, [i, e.visiblePlugin, y]);\n-                    const h = l.useMemo(() => ({\n-                        plugins: i,\n-                        setVisiblePlugin: y,\n-                        visiblePlugin: d\n-                    }), [i, y, d]);\n-                    return s.jsx(ft.Provider, {\n-                        value: h,\n-                        children: p\n-                    });\n-                }\n-                a(fn, \"PluginContextProvider\");\n-                const _e = le(ft),\n-                    St = \"visiblePlugin\";\n-\n-                function Hr(e, t, n, r, o, c) {\n-                    Ee([], {\n-                        useCommonAddons: !1\n-                    }).then(d => {\n-                        let g, m, p, y, h, x, f, C, E;\n-                        d.on(t, \"select\", (k, L) => {\n-                            if (!g) {\n-                                const b = L.parentNode;\n-                                g = document.createElement(\"div\"), g.className = \"CodeMirror-hint-information\", b.append(g);\n-                                const w = document.createElement(\"header\");\n-                                w.className = \"CodeMirror-hint-information-header\", g.append(w), m = document.createElement(\"span\"), m.className = \"CodeMirror-hint-information-field-name\", w.append(m), p = document.createElement(\"span\"), p.className = \"CodeMirror-hint-information-type-name-pill\", w.append(p), y = document.createElement(\"span\"), p.append(y), h = document.createElement(\"a\"), h.className = \"CodeMirror-hint-information-type-name\", h.href = \"javascript:void 0\", h.addEventListener(\"click\", i), p.append(h), x = document.createElement(\"span\"), p.append(x), f = document.createElement(\"div\"), f.className = \"CodeMirror-hint-information-description\", g.append(f), C = document.createElement(\"div\"), C.className = \"CodeMirror-hint-information-deprecation\", g.append(C);\n-                                const T = document.createElement(\"span\");\n-                                T.className = \"CodeMirror-hint-information-deprecation-label\", T.textContent = \"Deprecated\", C.append(T), E = document.createElement(\"div\"), E.className = \"CodeMirror-hint-information-deprecation-reason\", C.append(E);\n-                                const A = parseInt(window.getComputedStyle(g).paddingBottom.replace(/px$/, \"\"), 10) || 0,\n-                                    F = parseInt(window.getComputedStyle(g).maxHeight.replace(/px$/, \"\"), 10) || 0,\n-                                    I = a(() => {\n-                                        g && (g.style.paddingTop = b.scrollTop + A + \"px\", g.style.maxHeight = b.scrollTop + F + \"px\");\n-                                    }, \"handleScroll\");\n-                                b.addEventListener(\"scroll\", I);\n-                                let H;\n-                                b.addEventListener(\"DOMNodeRemoved\", H = a(O => {\n-                                    O.target === b && (b.removeEventListener(\"scroll\", I), b.removeEventListener(\"DOMNodeRemoved\", H), g && g.removeEventListener(\"click\", i), g = null, m = null, p = null, y = null, h = null, x = null, f = null, C = null, E = null, H = null);\n-                                }, \"onRemoveFn\"));\n-                            }\n-                            if (m && (m.textContent = k.text), p && y && h && x)\n-                                if (k.type) {\n-                                    p.style.display = \"inline\";\n-                                    const b = a(w => {\n-                                        M.isNonNullType(w) ? (x.textContent = \"!\" + x.textContent, b(w.ofType)) : M.isListType(w) ? (y.textContent += \"[\", x.textContent = \"]\" + x.textContent, b(w.ofType)) : h.textContent = w.name;\n-                                    }, \"renderType\");\n-                                    y.textContent = \"\", x.textContent = \"\", b(k.type);\n-                                } else y.textContent = \"\", h.textContent = \"\", x.textContent = \"\", p.style.display = \"none\";\n-                            f && (k.description ? (f.style.display = \"block\", f.innerHTML = Me.render(k.description)) : (f.style.display = \"none\", f.innerHTML = \"\")), C && E && (k.deprecationReason ? (C.style.display = \"block\", E.innerHTML = Me.render(k.deprecationReason)) : (C.style.display = \"none\", E.innerHTML = \"\"));\n-                        });\n-                    });\n-\n-                    function i(d) {\n-                        if (!n || !r || !o || !(d.currentTarget instanceof HTMLElement)) return;\n-                        const g = d.currentTarget.textContent || \"\",\n-                            m = n.getType(g);\n-                        m && (o.setVisiblePlugin(de), r.push({\n-                            name: m.name,\n-                            def: m\n-                        }), c == null || c(m));\n-                    }\n-                    a(i, \"onClickHintInformation\");\n-                }\n-                a(Hr, \"onHasCompletion\");\n-\n-                function je(e, t) {\n-                    l.useEffect(() => {\n-                        e && typeof t == \"string\" && t !== e.getValue() && e.setValue(t);\n-                    }, [e, t]);\n-                }\n-                a(je, \"useSynchronizeValue\");\n-\n-                function Ze(e, t, n) {\n-                    l.useEffect(() => {\n-                        e && e.setOption(t, n);\n-                    }, [e, t, n]);\n-                }\n-                a(Ze, \"useSynchronizeOption\");\n-\n-                function pn(e, t, n, r, o) {\n-                    const {\n-                        updateActiveTabValues: c\n-                    } = Z({\n-                            nonNull: !0,\n-                            caller: o\n-                        }),\n-                        i = re();\n-                    l.useEffect(() => {\n-                        if (!e) return;\n-                        const d = ue(500, p => {\n-                                !i || n === null || i.set(n, p);\n-                            }),\n-                            g = ue(100, p => {\n-                                c({\n-                                    [r]: p\n-                                });\n-                            }),\n-                            m = a((p, y) => {\n-                                if (!y) return;\n-                                const h = p.getValue();\n-                                d(h), g(h), t == null || t(h);\n-                            }, \"handleChange\");\n-                        return e.on(\"change\", m), () => e.off(\"change\", m);\n-                    }, [t, e, i, n, r, c]);\n-                }\n-                a(pn, \"useChangeHandler\");\n-\n-                function gn(e, t, n) {\n-                    const {\n-                        schema: r\n-                    } = Y({\n-                            nonNull: !0,\n-                            caller: n\n-                        }),\n-                        o = ee(),\n-                        c = _e();\n-                    l.useEffect(() => {\n-                        if (!e) return;\n-                        const i = a((d, g) => {\n-                            Hr(d, g, r, o, c, m => {\n-                                t == null || t({\n-                                    kind: \"Type\",\n-                                    type: m,\n-                                    schema: r || void 0\n-                                });\n-                            });\n-                        }, \"handleCompletion\");\n-                        return e.on(\"hasCompletion\", i), () => e.off(\"hasCompletion\", i);\n-                    }, [t, e, o, c, r]);\n-                }\n-                a(gn, \"useCompletion\");\n+                /***/\n+            }),\n \n-                function J(e, t, n) {\n-                    l.useEffect(() => {\n-                        if (e) {\n-                            for (const r of t) e.removeKeyMap(r);\n-                            if (n) {\n-                                const r = {};\n-                                for (const o of t) r[o] = () => n();\n-                                e.addKeyMap(r);\n-                            }\n-                        }\n-                    }, [e, t, n]);\n-                }\n-                a(J, \"useKeyMap\");\n+        /***/\n+        \"../../../node_modules/react-remove-scroll/dist/es2015/aggresiveCapture.js\":\n+            /*!*********************************************************************************!*\\\n+              !*** ../../../node_modules/react-remove-scroll/dist/es2015/aggresiveCapture.js ***!\n+              \\*********************************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports) {\n \n-                function pt() {\n-                    let {\n-                        caller: e,\n-                        onCopyQuery: t\n-                    } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n-                    const {\n-                        queryEditor: n\n-                    } = Z({\n-                        nonNull: !0,\n-                        caller: e || pt\n-                    });\n-                    return l.useCallback(() => {\n-                        if (!n) return;\n-                        const r = n.getValue();\n-                        Tn(r), t == null || t(r);\n-                    }, [n, t]);\n-                }\n-                a(pt, \"useCopyQuery\");\n+                \"use strict\";\n \n-                function he() {\n-                    let {\n-                        caller: e\n-                    } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n-                    const {\n-                        queryEditor: t\n-                    } = Z({\n-                        nonNull: !0,\n-                        caller: e || he\n-                    }), {\n-                        schema: n\n-                    } = Y({\n-                        nonNull: !0,\n-                        caller: he\n-                    });\n-                    return l.useCallback(() => {\n-                        const r = t == null ? void 0 : t.documentAST,\n-                            o = t == null ? void 0 : t.getValue();\n-                        !r || !o || t.setValue(M.print(B.mergeAst(r, n)));\n-                    }, [t, n]);\n-                }\n-                a(he, \"useMergeQuery\");\n \n-                function Se() {\n-                    let {\n-                        caller: e\n-                    } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n-                    const {\n-                        queryEditor: t,\n-                        headerEditor: n,\n-                        variableEditor: r\n-                    } = Z({\n-                        nonNull: !0,\n-                        caller: e || Se\n-                    });\n-                    return l.useCallback(() => {\n-                        if (r) {\n-                            const o = r.getValue();\n-                            try {\n-                                const c = JSON.stringify(JSON.parse(o), null, 2);\n-                                c !== o && r.setValue(c);\n-                            } catch {}\n-                        }\n-                        if (n) {\n-                            const o = n.getValue();\n-                            try {\n-                                const c = JSON.stringify(JSON.parse(o), null, 2);\n-                                c !== o && n.setValue(c);\n-                            } catch {}\n-                        }\n-                        if (t) {\n-                            const o = t.getValue(),\n-                                c = M.print(M.parse(o));\n-                            c !== o && t.setValue(c);\n-                        }\n-                    }, [t, r, n]);\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.nonPassive = void 0;\n+                var passiveSupported = false;\n+                if (typeof window !== 'undefined') {\n+                    try {\n+                        var options = Object.defineProperty({}, 'passive', {\n+                            get: function() {\n+                                passiveSupported = true;\n+                                return true;\n+                            }\n+                        });\n+                        // @ts-ignore\n+                        window.addEventListener('test', options, options);\n+                        // @ts-ignore\n+                        window.removeEventListener('test', options, options);\n+                    } catch (err) {\n+                        passiveSupported = false;\n+                    }\n                 }\n-                a(Se, \"usePrettifyEditors\");\n+                var nonPassive = exports.nonPassive = passiveSupported ? {\n+                    passive: false\n+                } : false;\n \n-                function Ie() {\n-                    let {\n-                        getDefaultFieldNames: e,\n-                        caller: t\n-                    } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n-                    const {\n-                        schema: n\n-                    } = Y({\n-                        nonNull: !0,\n-                        caller: t || Ie\n-                    }), {\n-                        queryEditor: r\n-                    } = Z({\n-                        nonNull: !0,\n-                        caller: t || Ie\n-                    });\n-                    return l.useCallback(() => {\n-                        if (!r) return;\n-                        const o = r.getValue(),\n-                            {\n-                                insertions: c,\n-                                result: i\n-                            } = B.fillLeafs(n, o, e);\n-                        return c && c.length > 0 && r.operation(() => {\n-                            const d = r.getCursor(),\n-                                g = r.indexFromPos(d);\n-                            r.setValue(i || \"\");\n-                            let m = 0;\n-                            const p = c.map(_ref56 => {\n-                                let {\n-                                    index: h,\n-                                    string: x\n-                                } = _ref56;\n-                                return r.markText(r.posFromIndex(h + m), r.posFromIndex(h + (m += x.length)), {\n-                                    className: \"auto-inserted-leaf\",\n-                                    clearOnEnter: !0,\n-                                    title: \"Automatically added leaf fields\"\n-                                });\n-                            });\n-                            setTimeout(() => {\n-                                for (const h of p) h.clear();\n-                            }, 7e3);\n-                            let y = g;\n-                            for (const {\n-                                    index: h,\n-                                    string: x\n-                                }\n-                                of c) h < g && (y += x.length);\n-                            r.setCursor(r.posFromIndex(y));\n-                        }), i;\n-                    }, [e, r, n]);\n-                }\n-                a(Ie, \"useAutoCompleteLeafs\");\n-                const Ge = a(e => {\n-                        var _ref57;\n-                        const n = Z({\n-                            nonNull: !0\n-                        })[`${e}Editor`];\n-                        let r = \"\";\n-                        const o = (_ref57 = n == null ? void 0 : n.getValue()) !== null && _ref57 !== void 0 ? _ref57 : !1;\n-                        o && o.length > 0 && (r = o);\n-                        const c = l.useCallback(i => n == null ? void 0 : n.setValue(i), [n]);\n-                        return l.useMemo(() => [r, c], [r, c]);\n-                    }, \"useEditorState\"),\n-                    Dr = a(() => Ge(\"query\"), \"useOperationsEditorState\"),\n-                    Ar = a(() => Ge(\"variable\"), \"useVariablesEditorState\"),\n-                    Or = a(() => Ge(\"header\"), \"useHeadersEditorState\");\n-\n-                function Fr(_ref58) {\n-                    let [e, t] = _ref58;\n-                    const n = l.useRef({\n-                            pending: null,\n-                            last: e\n-                        }),\n-                        [r, o] = l.useState(e);\n-                    l.useEffect(() => {\n-                        n.current.last === e || (n.current.last = e, n.current.pending === null ? o(e) : n.current.pending === e ? (n.current.pending = null, e !== r && (n.current.pending = r, t(r))) : (n.current.pending = null, o(e)));\n-                    }, [e, r, t]);\n-                    const c = l.useCallback(i => {\n-                        o(i), n.current.pending === null && n.current.last !== i && (n.current.pending = i, t(i));\n-                    }, [t]);\n-                    return l.useMemo(() => [r, c], [r, c]);\n-                }\n-                a(Fr, \"useOptimisticState\");\n+                /***/\n+            }),\n \n-                function ce() {\n-                    let {\n-                        editorTheme: e = Fe,\n-                        keyMap: t = Be,\n-                        onEdit: n,\n-                        readOnly: r = !1\n-                    } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n-                    let o = arguments.length > 1 ? arguments[1] : undefined;\n-                    const {\n-                        initialHeaders: c,\n-                        headerEditor: i,\n-                        setHeaderEditor: d,\n-                        shouldPersistHeaders: g\n-                    } = Z({\n-                            nonNull: !0,\n-                            caller: o || ce\n-                        }),\n-                        m = we(),\n-                        p = he({\n-                            caller: o || ce\n-                        }),\n-                        y = Se({\n-                            caller: o || ce\n-                        }),\n-                        h = l.useRef(null);\n-                    return l.useEffect(() => {\n-                        let x = !0;\n-                        return Ee([Promise.resolve().then(() => __webpack_require__( /*! ./javascript.cjs.js */ \"../../graphiql-react/dist/javascript.cjs.js\")).then(f => f.javascript)]).then(f => {\n-                            if (!x) return;\n-                            const C = h.current;\n-                            if (!C) return;\n-                            const E = f(C, {\n-                                value: c,\n-                                lineNumbers: !0,\n-                                tabSize: 2,\n-                                mode: {\n-                                    name: \"javascript\",\n-                                    json: !0\n-                                },\n-                                theme: e,\n-                                autoCloseBrackets: !0,\n-                                matchBrackets: !0,\n-                                showCursorWhenSelecting: !0,\n-                                readOnly: r ? \"nocursor\" : !1,\n-                                foldGutter: !0,\n-                                gutters: [\"CodeMirror-linenumbers\", \"CodeMirror-foldgutter\"],\n-                                extraKeys: We\n-                            });\n-                            E.addKeyMap({\n-                                \"Cmd-Space\"() {\n-                                    E.showHint({\n-                                        completeSingle: !1,\n-                                        container: C\n-                                    });\n-                                },\n-                                \"Ctrl-Space\"() {\n-                                    E.showHint({\n-                                        completeSingle: !1,\n-                                        container: C\n-                                    });\n-                                },\n-                                \"Alt-Space\"() {\n-                                    E.showHint({\n-                                        completeSingle: !1,\n-                                        container: C\n-                                    });\n-                                },\n-                                \"Shift-Space\"() {\n-                                    E.showHint({\n-                                        completeSingle: !1,\n-                                        container: C\n-                                    });\n-                                }\n-                            }), E.on(\"keyup\", (k, L) => {\n-                                const {\n-                                    code: b,\n-                                    key: w,\n-                                    shiftKey: T\n-                                } = L,\n-                                A = b.startsWith(\"Key\"),\n-                                    F = !T && b.startsWith(\"Digit\");\n-                                (A || F || w === \"_\" || w === '\"') && k.execCommand(\"autocomplete\");\n-                            }), d(E);\n-                        }), () => {\n-                            x = !1;\n-                        };\n-                    }, [e, c, r, d]), Ze(i, \"keyMap\", t), pn(i, n, g ? Te : null, \"headers\", ce), J(i, [\"Cmd-Enter\", \"Ctrl-Enter\"], m == null ? void 0 : m.run), J(i, [\"Shift-Ctrl-P\"], y), J(i, [\"Shift-Ctrl-M\"], p), h;\n-                }\n-                a(ce, \"useHeaderEditor\");\n-                const Te = \"headers\",\n-                    Br = Array.from({\n-                        length: 11\n-                    }, (e, t) => String.fromCharCode(8192 + t)).concat([\"\\u2028\", \"\\u2029\", \"\u202f\", \"\u00a0\"]),\n-                    Wr = new RegExp(\"[\" + Br.join(\"\") + \"]\", \"g\");\n+        /***/\n+        \"../../../node_modules/react-remove-scroll/dist/es2015/handleScroll.js\":\n+            /*!*****************************************************************************!*\\\n+              !*** ../../../node_modules/react-remove-scroll/dist/es2015/handleScroll.js ***!\n+              \\*****************************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports) {\n \n-                function _r(e) {\n-                    return e.replace(Wr, \" \");\n-                }\n-                a(_r, \"normalizeWhitespace\");\n+                \"use strict\";\n \n-                function te() {\n-                    let {\n-                        editorTheme: e = Fe,\n-                        keyMap: t = Be,\n-                        onClickReference: n,\n-                        onCopyQuery: r,\n-                        onEdit: o,\n-                        readOnly: c = !1\n-                    } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n-                    let i = arguments.length > 1 ? arguments[1] : undefined;\n-                    const {\n-                        schema: d\n-                    } = Y({\n-                            nonNull: !0,\n-                            caller: i || te\n-                        }), {\n-                            externalFragments: g,\n-                            initialQuery: m,\n-                            queryEditor: p,\n-                            setOperationName: y,\n-                            setQueryEditor: h,\n-                            validationRules: x,\n-                            variableEditor: f,\n-                            updateActiveTabValues: C\n-                        } = Z({\n-                            nonNull: !0,\n-                            caller: i || te\n-                        }),\n-                        E = we(),\n-                        k = re(),\n-                        L = ee(),\n-                        b = _e(),\n-                        w = pt({\n-                            caller: i || te,\n-                            onCopyQuery: r\n-                        }),\n-                        T = he({\n-                            caller: i || te\n-                        }),\n-                        A = Se({\n-                            caller: i || te\n-                        }),\n-                        F = l.useRef(null),\n-                        I = l.useRef(),\n-                        H = l.useRef(() => {});\n-                    l.useEffect(() => {\n-                        H.current = q => {\n-                            if (!(!L || !b)) {\n-                                switch (b.setVisiblePlugin(de), q.kind) {\n-                                    case \"Type\": {\n-                                        L.push({\n-                                            name: q.type.name,\n-                                            def: q.type\n-                                        });\n-                                        break;\n-                                    }\n-                                    case \"Field\": {\n-                                        L.push({\n-                                            name: q.field.name,\n-                                            def: q.field\n-                                        });\n-                                        break;\n-                                    }\n-                                    case \"Argument\": {\n-                                        q.field && L.push({\n-                                            name: q.field.name,\n-                                            def: q.field\n-                                        });\n-                                        break;\n-                                    }\n-                                    case \"EnumValue\": {\n-                                        q.type && L.push({\n-                                            name: q.type.name,\n-                                            def: q.type\n-                                        });\n-                                        break;\n-                                    }\n-                                }\n-                                n == null || n(q);\n-                            }\n-                        };\n-                    }, [L, n, b]), l.useEffect(() => {\n-                        let q = !0;\n-                        return Ee([Promise.resolve().then(() => __webpack_require__( /*! ./comment.cjs.js */ \"../../graphiql-react/dist/comment.cjs.js\")).then(N => N.comment), Promise.resolve().then(() => __webpack_require__( /*! ./search.cjs.js */ \"../../graphiql-react/dist/search.cjs.js\")).then(N => N.search), Promise.resolve().then(() => __webpack_require__( /*! ./hint.cjs.js */ \"../../graphiql-react/dist/hint.cjs.js\")), Promise.resolve().then(() => __webpack_require__( /*! ./lint.cjs2.js */ \"../../graphiql-react/dist/lint.cjs2.js\")), Promise.resolve().then(() => __webpack_require__( /*! ./info.cjs.js */ \"../../graphiql-react/dist/info.cjs.js\")), Promise.resolve().then(() => __webpack_require__( /*! ./jump.cjs.js */ \"../../graphiql-react/dist/jump.cjs.js\")), Promise.resolve().then(() => __webpack_require__( /*! ./mode.cjs.js */ \"../../graphiql-react/dist/mode.cjs.js\"))]).then(N => {\n-                            if (!q) return;\n-                            I.current = N;\n-                            const P = F.current;\n-                            if (!P) return;\n-                            const S = N(P, {\n-                                value: m,\n-                                lineNumbers: !0,\n-                                tabSize: 2,\n-                                foldGutter: !0,\n-                                mode: \"graphql\",\n-                                theme: e,\n-                                autoCloseBrackets: !0,\n-                                matchBrackets: !0,\n-                                showCursorWhenSelecting: !0,\n-                                readOnly: c ? \"nocursor\" : !1,\n-                                lint: {\n-                                    schema: void 0,\n-                                    validationRules: null,\n-                                    externalFragments: void 0\n-                                },\n-                                hintOptions: {\n-                                    schema: void 0,\n-                                    closeOnUnfocus: !1,\n-                                    completeSingle: !1,\n-                                    container: P,\n-                                    externalFragments: void 0\n-                                },\n-                                info: {\n-                                    schema: void 0,\n-                                    renderDescription: v => Me.render(v),\n-                                    onClick(v) {\n-                                        H.current(v);\n-                                    }\n-                                },\n-                                jump: {\n-                                    schema: void 0,\n-                                    onClick(v) {\n-                                        H.current(v);\n-                                    }\n-                                },\n-                                gutters: [\"CodeMirror-linenumbers\", \"CodeMirror-foldgutter\"],\n-                                extraKeys: {\n-                                    ...We,\n-                                    \"Cmd-S\"() {},\n-                                    \"Ctrl-S\"() {}\n-                                }\n-                            });\n-                            S.addKeyMap({\n-                                \"Cmd-Space\"() {\n-                                    S.showHint({\n-                                        completeSingle: !0,\n-                                        container: P\n-                                    });\n-                                },\n-                                \"Ctrl-Space\"() {\n-                                    S.showHint({\n-                                        completeSingle: !0,\n-                                        container: P\n-                                    });\n-                                },\n-                                \"Alt-Space\"() {\n-                                    S.showHint({\n-                                        completeSingle: !0,\n-                                        container: P\n-                                    });\n-                                },\n-                                \"Shift-Space\"() {\n-                                    S.showHint({\n-                                        completeSingle: !0,\n-                                        container: P\n-                                    });\n-                                },\n-                                \"Shift-Alt-Space\"() {\n-                                    S.showHint({\n-                                        completeSingle: !0,\n-                                        container: P\n-                                    });\n-                                }\n-                            }), S.on(\"keyup\", (v, j) => {\n-                                Qr.test(j.key) && v.execCommand(\"autocomplete\");\n-                            });\n-                            let W = !1;\n-                            S.on(\"startCompletion\", () => {\n-                                W = !0;\n-                            }), S.on(\"endCompletion\", () => {\n-                                W = !1;\n-                            }), S.on(\"keydown\", (v, j) => {\n-                                j.key === \"Escape\" && W && j.stopPropagation();\n-                            }), S.on(\"beforeChange\", (v, j) => {\n-                                var R;\n-                                if (j.origin === \"paste\") {\n-                                    const U = j.text.map(_r);\n-                                    (R = j.update) == null || R.call(j, j.from, j.to, U);\n-                                }\n-                            }), S.documentAST = null, S.operationName = null, S.operations = null, S.variableToType = null, h(S);\n-                        }), () => {\n-                            q = !1;\n-                        };\n-                    }, [e, m, c, h]), Ze(p, \"keyMap\", t), l.useEffect(() => {\n-                        if (!p) return;\n-\n-                        function q(P) {\n-                            var _P$operations, _P$operationName, _ref59, _ref60;\n-                            var v;\n-                            const S = jt.getOperationFacts(d, P.getValue()),\n-                                W = B.getSelectedOperationName((_P$operations = P.operations) !== null && _P$operations !== void 0 ? _P$operations : void 0, (_P$operationName = P.operationName) !== null && _P$operationName !== void 0 ? _P$operationName : void 0, S == null ? void 0 : S.operations);\n-                            return P.documentAST = (_ref59 = S == null ? void 0 : S.documentAST) !== null && _ref59 !== void 0 ? _ref59 : null, P.operationName = W !== null && W !== void 0 ? W : null, P.operations = (_ref60 = S == null ? void 0 : S.operations) !== null && _ref60 !== void 0 ? _ref60 : null, f && (f.state.lint.linterOptions.variableToType = S == null ? void 0 : S.variableToType, f.options.lint.variableToType = S == null ? void 0 : S.variableToType, f.options.hintOptions.variableToType = S == null ? void 0 : S.variableToType, (v = I.current) == null || v.signal(f, \"change\", f)), S ? {\n-                                ...S,\n-                                operationName: W\n-                            } : null;\n-                        }\n-                        a(q, \"getAndUpdateOperationFacts\");\n-                        const N = ue(100, P => {\n-                            var _ref61;\n-                            const S = P.getValue();\n-                            k == null || k.set(xn, S);\n-                            const W = P.operationName,\n-                                v = q(P);\n-                            (v == null ? void 0 : v.operationName) !== void 0 && (k == null || k.set(zr, v.operationName)), o == null || o(S, v == null ? void 0 : v.documentAST), v != null && v.operationName && W !== v.operationName && y(v.operationName), C({\n-                                query: S,\n-                                operationName: (_ref61 = v == null ? void 0 : v.operationName) !== null && _ref61 !== void 0 ? _ref61 : null\n-                            });\n-                        });\n-                        return q(p), p.on(\"change\", N), () => p.off(\"change\", N);\n-                    }, [o, p, d, y, k, f, C]), Zr(p, d !== null && d !== void 0 ? d : null, I), Gr(p, x !== null && x !== void 0 ? x : null, I), $r(p, g, I), gn(p, n || null, te);\n-                    const O = E == null ? void 0 : E.run,\n-                        D = l.useCallback(() => {\n-                            var P;\n-                            if (!O || !p || !p.operations || !p.hasFocus()) {\n-                                O == null || O();\n-                                return;\n-                            }\n-                            const q = p.indexFromPos(p.getCursor());\n-                            let N;\n-                            for (const S of p.operations) S.loc && S.loc.start <= q && S.loc.end >= q && (N = (P = S.name) == null ? void 0 : P.value);\n-                            N && N !== p.operationName && y(N), O();\n-                        }, [p, O, y]);\n-                    return J(p, [\"Cmd-Enter\", \"Ctrl-Enter\"], D), J(p, [\"Shift-Ctrl-C\"], w), J(p, [\"Shift-Ctrl-P\", \"Shift-Ctrl-F\"], A), J(p, [\"Shift-Ctrl-M\"], T), F;\n-                }\n-                a(te, \"useQueryEditor\");\n-\n-                function Zr(e, t, n) {\n-                    l.useEffect(() => {\n-                        if (!e) return;\n-                        const r = e.options.lint.schema !== t;\n-                        e.state.lint.linterOptions.schema = t, e.options.lint.schema = t, e.options.hintOptions.schema = t, e.options.info.schema = t, e.options.jump.schema = t, r && n.current && n.current.signal(e, \"change\", e);\n-                    }, [e, t, n]);\n-                }\n-                a(Zr, \"useSynchronizeSchema\");\n-\n-                function Gr(e, t, n) {\n-                    l.useEffect(() => {\n-                        if (!e) return;\n-                        const r = e.options.lint.validationRules !== t;\n-                        e.state.lint.linterOptions.validationRules = t, e.options.lint.validationRules = t, r && n.current && n.current.signal(e, \"change\", e);\n-                    }, [e, t, n]);\n-                }\n-                a(Gr, \"useSynchronizeValidationRules\");\n-\n-                function $r(e, t, n) {\n-                    const r = l.useMemo(() => [...t.values()], [t]);\n-                    l.useEffect(() => {\n-                        if (!e) return;\n-                        const o = e.options.lint.externalFragments !== r;\n-                        e.state.lint.linterOptions.externalFragments = r, e.options.lint.externalFragments = r, e.options.hintOptions.externalFragments = r, o && n.current && n.current.signal(e, \"change\", e);\n-                    }, [e, r, n]);\n-                }\n-                a($r, \"useSynchronizeExternalFragments\");\n-                const Qr = /^[a-zA-Z0-9_@(]$/,\n-                    xn = \"query\",\n-                    zr = \"operationName\";\n \n-                function Ur(_ref62) {\n-                    let {\n-                        defaultQuery: e,\n-                        defaultHeaders: t,\n-                        headers: n,\n-                        defaultTabs: r,\n-                        query: o,\n-                        variables: c,\n-                        storage: i,\n-                        shouldPersistHeaders: d\n-                    } = _ref62;\n-                    const g = i == null ? void 0 : i.get(ve);\n-                    try {\n-                        if (!g) throw new Error(\"Storage for tabs is empty\");\n-                        const m = JSON.parse(g),\n-                            p = d ? n : void 0;\n-                        if (Kr(m)) {\n-                            const y = He({\n-                                query: o,\n-                                variables: c,\n-                                headers: p\n-                            });\n-                            let h = -1;\n-                            for (let x = 0; x < m.tabs.length; x++) {\n-                                const f = m.tabs[x];\n-                                f.hash = He({\n-                                    query: f.query,\n-                                    variables: f.variables,\n-                                    headers: f.headers\n-                                }), f.hash === y && (h = x);\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.locationCouldBeScrolled = exports.handleScroll = void 0;\n+                var alwaysContainsScroll = function(node) {\n+                    // textarea will always _contain_ scroll inside self. It only can be hidden\n+                    return node.tagName === 'TEXTAREA';\n+                };\n+                var elementCanBeScrolled = function(node, overflow) {\n+                    var styles = window.getComputedStyle(node);\n+                    return (\n+                        // not-not-scrollable\n+                        styles[overflow] !== 'hidden' &&\n+                        // contains scroll inside self\n+                        !(styles.overflowY === styles.overflowX && !alwaysContainsScroll(node) && styles[overflow] === 'visible')\n+                    );\n+                };\n+                var elementCouldBeVScrolled = function(node) {\n+                    return elementCanBeScrolled(node, 'overflowY');\n+                };\n+                var elementCouldBeHScrolled = function(node) {\n+                    return elementCanBeScrolled(node, 'overflowX');\n+                };\n+                var locationCouldBeScrolled = function(axis, node) {\n+                    var current = node;\n+                    do {\n+                        // Skip over shadow root\n+                        if (typeof ShadowRoot !== 'undefined' && current instanceof ShadowRoot) {\n+                            current = current.host;\n+                        }\n+                        var isScrollable = elementCouldBeScrolled(axis, current);\n+                        if (isScrollable) {\n+                            var _a = getScrollVariables(axis, current),\n+                                s = _a[1],\n+                                d = _a[2];\n+                            if (s > d) {\n+                                return true;\n                             }\n-                            if (h >= 0) m.activeTabIndex = h;\n-                            else {\n-                                const x = o ? gt(o) : null;\n-                                m.tabs.push({\n-                                    id: bn(),\n-                                    hash: y,\n-                                    title: x || xt,\n-                                    query: o,\n-                                    variables: c,\n-                                    headers: n,\n-                                    operationName: x,\n-                                    response: null\n-                                }), m.activeTabIndex = m.tabs.length - 1;\n+                        }\n+                        current = current.parentNode;\n+                    } while (current && current !== document.body);\n+                    return false;\n+                };\n+                exports.locationCouldBeScrolled = locationCouldBeScrolled;\n+                var getVScrollVariables = function(_a) {\n+                    var scrollTop = _a.scrollTop,\n+                        scrollHeight = _a.scrollHeight,\n+                        clientHeight = _a.clientHeight;\n+                    return [scrollTop, scrollHeight, clientHeight];\n+                };\n+                var getHScrollVariables = function(_a) {\n+                    var scrollLeft = _a.scrollLeft,\n+                        scrollWidth = _a.scrollWidth,\n+                        clientWidth = _a.clientWidth;\n+                    return [scrollLeft, scrollWidth, clientWidth];\n+                };\n+                var elementCouldBeScrolled = function(axis, node) {\n+                    return axis === 'v' ? elementCouldBeVScrolled(node) : elementCouldBeHScrolled(node);\n+                };\n+                var getScrollVariables = function(axis, node) {\n+                    return axis === 'v' ? getVScrollVariables(node) : getHScrollVariables(node);\n+                };\n+                var getDirectionFactor = function(axis, direction) {\n+                    /**\n+                     * If the element's direction is rtl (right-to-left), then scrollLeft is 0 when the scrollbar is at its rightmost position,\n+                     * and then increasingly negative as you scroll towards the end of the content.\n+                     * @see https://developer.mozilla.org/en-US/docs/Web/API/Element/scrollLeft\n+                     */\n+                    return axis === 'h' && direction === 'rtl' ? -1 : 1;\n+                };\n+                var handleScroll = function(axis, endTarget, event, sourceDelta, noOverscroll) {\n+                    var directionFactor = getDirectionFactor(axis, window.getComputedStyle(endTarget).direction);\n+                    var delta = directionFactor * sourceDelta;\n+                    // find scrollable target\n+                    var target = event.target;\n+                    var targetInLock = endTarget.contains(target);\n+                    var shouldCancelScroll = false;\n+                    var isDeltaPositive = delta > 0;\n+                    var availableScroll = 0;\n+                    var availableScrollTop = 0;\n+                    do {\n+                        var _a = getScrollVariables(axis, target),\n+                            position = _a[0],\n+                            scroll_1 = _a[1],\n+                            capacity = _a[2];\n+                        var elementScroll = scroll_1 - capacity - directionFactor * position;\n+                        if (position || elementScroll) {\n+                            if (elementCouldBeScrolled(axis, target)) {\n+                                availableScroll += elementScroll;\n+                                availableScrollTop += position;\n                             }\n-                            return m;\n                         }\n-                        throw new Error(\"Storage for tabs is invalid\");\n-                    } catch {\n-                        return {\n-                            activeTabIndex: 0,\n-                            tabs: (r || [{\n-                                query: o !== null && o !== void 0 ? o : e,\n-                                variables: c,\n-                                headers: n !== null && n !== void 0 ? n : t\n-                            }]).map(vn)\n-                        };\n+                        target = target.parentNode;\n+                    } while (\n+                        // portaled content\n+                        !targetInLock && target !== document.body ||\n+                        // self content\n+                        targetInLock && (endTarget.contains(target) || endTarget === target));\n+                    if (isDeltaPositive && (noOverscroll && availableScroll === 0 || !noOverscroll && delta > availableScroll)) {\n+                        shouldCancelScroll = true;\n+                    } else if (!isDeltaPositive && (noOverscroll && availableScrollTop === 0 || !noOverscroll && -delta > availableScrollTop)) {\n+                        shouldCancelScroll = true;\n                     }\n-                }\n-                a(Ur, \"getDefaultTabState\");\n-\n-                function Kr(e) {\n-                    return e && typeof e == \"object\" && !Array.isArray(e) && Yr(e, \"activeTabIndex\") && \"tabs\" in e && Array.isArray(e.tabs) && e.tabs.every(Jr);\n-                }\n-                a(Kr, \"isTabsState\");\n-\n-                function Jr(e) {\n-                    return e && typeof e == \"object\" && !Array.isArray(e) && Lt(e, \"id\") && Lt(e, \"title\") && fe(e, \"query\") && fe(e, \"variables\") && fe(e, \"headers\") && fe(e, \"operationName\") && fe(e, \"response\");\n-                }\n-                a(Jr, \"isTabState\");\n-\n-                function Yr(e, t) {\n-                    return t in e && typeof e[t] == \"number\";\n-                }\n-                a(Yr, \"hasNumberKey\");\n-\n-                function Lt(e, t) {\n-                    return t in e && typeof e[t] == \"string\";\n-                }\n-                a(Lt, \"hasStringKey\");\n+                    return shouldCancelScroll;\n+                };\n+                exports.handleScroll = handleScroll;\n \n-                function fe(e, t) {\n-                    return t in e && (typeof e[t] == \"string\" || e[t] === null);\n-                }\n-                a(fe, \"hasStringOrNullKey\");\n+                /***/\n+            }),\n \n-                function Xr(_ref63) {\n-                    let {\n-                        queryEditor: e,\n-                        variableEditor: t,\n-                        headerEditor: n,\n-                        responseEditor: r\n-                    } = _ref63;\n-                    return l.useCallback(o => {\n-                        var _ref64, _ref65, _ref66, _ref67, _ref68;\n-                        const c = (_ref64 = e == null ? void 0 : e.getValue()) !== null && _ref64 !== void 0 ? _ref64 : null,\n-                            i = (_ref65 = t == null ? void 0 : t.getValue()) !== null && _ref65 !== void 0 ? _ref65 : null,\n-                            d = (_ref66 = n == null ? void 0 : n.getValue()) !== null && _ref66 !== void 0 ? _ref66 : null,\n-                            g = (_ref67 = e == null ? void 0 : e.operationName) !== null && _ref67 !== void 0 ? _ref67 : null,\n-                            m = (_ref68 = r == null ? void 0 : r.getValue()) !== null && _ref68 !== void 0 ? _ref68 : null;\n-                        return yn(o, {\n-                            query: c,\n-                            variables: i,\n-                            headers: d,\n-                            response: m,\n-                            operationName: g\n-                        });\n-                    }, [e, t, n, r]);\n-                }\n-                a(Xr, \"useSynchronizeActiveTabValues\");\n-\n-                function Cn(e) {\n-                    let t = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : !1;\n-                    return JSON.stringify(e, (n, r) => n === \"hash\" || n === \"response\" || !t && n === \"headers\" ? null : r);\n-                }\n-                a(Cn, \"serializeTabState\");\n+        /***/\n+        \"../../../node_modules/react-remove-scroll/dist/es2015/index.js\":\n+            /*!**********************************************************************!*\\\n+              !*** ../../../node_modules/react-remove-scroll/dist/es2015/index.js ***!\n+              \\**********************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                function es(_ref69) {\n-                    let {\n-                        storage: e,\n-                        shouldPersistHeaders: t\n-                    } = _ref69;\n-                    const n = l.useMemo(() => ue(500, r => {\n-                        e == null || e.set(ve, r);\n-                    }), [e]);\n-                    return l.useCallback(r => {\n-                        n(Cn(r, t));\n-                    }, [t, n]);\n-                }\n-                a(es, \"useStoreTabs\");\n+                \"use strict\";\n \n-                function ts(_ref70) {\n-                    let {\n-                        queryEditor: e,\n-                        variableEditor: t,\n-                        headerEditor: n,\n-                        responseEditor: r\n-                    } = _ref70;\n-                    return l.useCallback(_ref71 => {\n-                        let {\n-                            query: o,\n-                            variables: c,\n-                            headers: i,\n-                            response: d\n-                        } = _ref71;\n-                        e == null || e.setValue(o !== null && o !== void 0 ? o : \"\"), t == null || t.setValue(c !== null && c !== void 0 ? c : \"\"), n == null || n.setValue(i !== null && i !== void 0 ? i : \"\"), r == null || r.setValue(d !== null && d !== void 0 ? d : \"\");\n-                    }, [n, e, r, t]);\n-                }\n-                a(ts, \"useSetEditorValues\");\n \n-                function vn() {\n-                    let {\n-                        query: e = null,\n-                        variables: t = null,\n-                        headers: n = null\n-                    } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n-                    return {\n-                        id: bn(),\n-                        hash: He({\n-                            query: e,\n-                            variables: t,\n-                            headers: n\n-                        }),\n-                        title: e && gt(e) || xt,\n-                        query: e,\n-                        variables: t,\n-                        headers: n,\n-                        operationName: null,\n-                        response: null\n-                    };\n-                }\n-                a(vn, \"createTab\");\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                Object.defineProperty(exports, \"RemoveScroll\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _Combination.default;\n+                    }\n+                }));\n+                var _Combination = _interopRequireDefault(__webpack_require__( /*! ./Combination */ \"../../../node_modules/react-remove-scroll/dist/es2015/Combination.js\"));\n \n-                function yn(e, t) {\n-                    return {\n-                        ...e,\n-                        tabs: e.tabs.map((n, r) => {\n-                            if (r !== e.activeTabIndex) return n;\n-                            const o = {\n-                                ...n,\n-                                ...t\n-                            };\n-                            return {\n-                                ...o,\n-                                hash: He(o),\n-                                title: o.operationName || (o.query ? gt(o.query) : void 0) || xt\n-                            };\n-                        })\n+                function _interopRequireDefault(obj) {\n+                    return obj && obj.__esModule ? obj : {\n+                        default: obj\n                     };\n                 }\n-                a(yn, \"setPropertiesInActiveTab\");\n-\n-                function bn() {\n-                    const e = a(() => Math.floor((1 + Math.random()) * 65536).toString(16).slice(1), \"s4\");\n-                    return `${e()}${e()}-${e()}-${e()}-${e()}-${e()}${e()}${e()}`;\n-                }\n-                a(bn, \"guid\");\n-\n-                function He(e) {\n-                    var _e$query, _e$variables, _e$headers;\n-                    return [(_e$query = e.query) !== null && _e$query !== void 0 ? _e$query : \"\", (_e$variables = e.variables) !== null && _e$variables !== void 0 ? _e$variables : \"\", (_e$headers = e.headers) !== null && _e$headers !== void 0 ? _e$headers : \"\"].join(\"|\");\n-                }\n-                a(He, \"hashFromTabContents\");\n-\n-                function gt(e) {\n-                    var _ref72;\n-                    const n = /^(?!#).*(query|subscription|mutation)\\s+([a-zA-Z0-9_]+)/m.exec(e);\n-                    return (_ref72 = n == null ? void 0 : n[2]) !== null && _ref72 !== void 0 ? _ref72 : null;\n-                }\n-                a(gt, \"fuzzyExtractOperationName\");\n \n-                function ns(e) {\n-                    const t = e == null ? void 0 : e.get(ve);\n-                    if (t) {\n-                        const n = JSON.parse(t);\n-                        e == null || e.set(ve, JSON.stringify(n, (r, o) => r === \"headers\" ? null : o));\n-                    }\n-                }\n-                a(ns, \"clearHeadersFromTabs\");\n-                const xt = \"<untitled>\",\n-                    ve = \"tabState\";\n+                /***/\n+            }),\n \n-                function se() {\n-                    let {\n-                        editorTheme: e = Fe,\n-                        keyMap: t = Be,\n-                        onClickReference: n,\n-                        onEdit: r,\n-                        readOnly: o = !1\n-                    } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n-                    let c = arguments.length > 1 ? arguments[1] : undefined;\n-                    const {\n-                        initialVariables: i,\n-                        variableEditor: d,\n-                        setVariableEditor: g\n-                    } = Z({\n-                            nonNull: !0,\n-                            caller: c || se\n-                        }),\n-                        m = we(),\n-                        p = he({\n-                            caller: c || se\n-                        }),\n-                        y = Se({\n-                            caller: c || se\n-                        }),\n-                        h = l.useRef(null),\n-                        x = l.useRef();\n-                    return l.useEffect(() => {\n-                        let f = !0;\n-                        return Ee([Promise.resolve().then(() => __webpack_require__( /*! ./hint.cjs2.js */ \"../../graphiql-react/dist/hint.cjs2.js\")), Promise.resolve().then(() => __webpack_require__( /*! ./lint.cjs3.js */ \"../../graphiql-react/dist/lint.cjs3.js\")), Promise.resolve().then(() => __webpack_require__( /*! ./mode.cjs2.js */ \"../../graphiql-react/dist/mode.cjs2.js\"))]).then(C => {\n-                            if (!f) return;\n-                            x.current = C;\n-                            const E = h.current;\n-                            if (!E) return;\n-                            const k = C(E, {\n-                                value: i,\n-                                lineNumbers: !0,\n-                                tabSize: 2,\n-                                mode: \"graphql-variables\",\n-                                theme: e,\n-                                autoCloseBrackets: !0,\n-                                matchBrackets: !0,\n-                                showCursorWhenSelecting: !0,\n-                                readOnly: o ? \"nocursor\" : !1,\n-                                foldGutter: !0,\n-                                lint: {\n-                                    variableToType: void 0\n-                                },\n-                                hintOptions: {\n-                                    closeOnUnfocus: !1,\n-                                    completeSingle: !1,\n-                                    container: E,\n-                                    variableToType: void 0\n-                                },\n-                                gutters: [\"CodeMirror-linenumbers\", \"CodeMirror-foldgutter\"],\n-                                extraKeys: We\n-                            });\n-                            k.addKeyMap({\n-                                \"Cmd-Space\"() {\n-                                    k.showHint({\n-                                        completeSingle: !1,\n-                                        container: E\n-                                    });\n-                                },\n-                                \"Ctrl-Space\"() {\n-                                    k.showHint({\n-                                        completeSingle: !1,\n-                                        container: E\n-                                    });\n-                                },\n-                                \"Alt-Space\"() {\n-                                    k.showHint({\n-                                        completeSingle: !1,\n-                                        container: E\n-                                    });\n-                                },\n-                                \"Shift-Space\"() {\n-                                    k.showHint({\n-                                        completeSingle: !1,\n-                                        container: E\n-                                    });\n-                                }\n-                            }), k.on(\"keyup\", (L, b) => {\n-                                const {\n-                                    code: w,\n-                                    key: T,\n-                                    shiftKey: A\n-                                } = b,\n-                                F = w.startsWith(\"Key\"),\n-                                    I = !A && w.startsWith(\"Digit\");\n-                                (F || I || T === \"_\" || T === '\"') && L.execCommand(\"autocomplete\");\n-                            }), g(k);\n-                        }), () => {\n-                            f = !1;\n-                        };\n-                    }, [e, i, o, g]), Ze(d, \"keyMap\", t), pn(d, r, wn, \"variables\", se), gn(d, n || null, se), J(d, [\"Cmd-Enter\", \"Ctrl-Enter\"], m == null ? void 0 : m.run), J(d, [\"Shift-Ctrl-P\"], y), J(d, [\"Shift-Ctrl-M\"], p), h;\n-                }\n-                a(se, \"useVariableEditor\");\n-                const wn = \"variables\",\n-                    Ct = oe(\"EditorContext\");\n-\n-                function En(e) {\n-                    const t = re(),\n-                        [n, r] = l.useState(null),\n-                        [o, c] = l.useState(null),\n-                        [i, d] = l.useState(null),\n-                        [g, m] = l.useState(null),\n-                        [p, y] = l.useState(() => {\n-                            const v = (t == null ? void 0 : t.get(ze)) !== null;\n-                            return e.shouldPersistHeaders !== !1 && v ? (t == null ? void 0 : t.get(ze)) === \"true\" : !!e.shouldPersistHeaders;\n-                        });\n-                    je(n, e.headers), je(o, e.query), je(i, e.response), je(g, e.variables);\n-                    const h = es({\n-                            storage: t,\n-                            shouldPersistHeaders: p\n-                        }),\n-                        [x] = l.useState(() => {\n-                            var _ref73, _e$query2, _ref74, _e$variables2, _ref75, _e$headers2, _e$response, _ref76, _ref77;\n-                            const v = (_ref73 = (_e$query2 = e.query) !== null && _e$query2 !== void 0 ? _e$query2 : t == null ? void 0 : t.get(xn)) !== null && _ref73 !== void 0 ? _ref73 : null,\n-                                j = (_ref74 = (_e$variables2 = e.variables) !== null && _e$variables2 !== void 0 ? _e$variables2 : t == null ? void 0 : t.get(wn)) !== null && _ref74 !== void 0 ? _ref74 : null,\n-                                R = (_ref75 = (_e$headers2 = e.headers) !== null && _e$headers2 !== void 0 ? _e$headers2 : t == null ? void 0 : t.get(Te)) !== null && _ref75 !== void 0 ? _ref75 : null,\n-                                U = (_e$response = e.response) !== null && _e$response !== void 0 ? _e$response : \"\",\n-                                ie = Ur({\n-                                    query: v,\n-                                    variables: j,\n-                                    headers: R,\n-                                    defaultTabs: e.defaultTabs,\n-                                    defaultQuery: e.defaultQuery || rs,\n-                                    defaultHeaders: e.defaultHeaders,\n-                                    storage: t,\n-                                    shouldPersistHeaders: p\n-                                });\n-                            return h(ie), {\n-                                query: (_ref76 = v !== null && v !== void 0 ? v : ie.activeTabIndex === 0 ? ie.tabs[0].query : null) !== null && _ref76 !== void 0 ? _ref76 : \"\",\n-                                variables: j !== null && j !== void 0 ? j : \"\",\n-                                headers: (_ref77 = R !== null && R !== void 0 ? R : e.defaultHeaders) !== null && _ref77 !== void 0 ? _ref77 : \"\",\n-                                response: U,\n-                                tabState: ie\n-                            };\n-                        }),\n-                        [f, C] = l.useState(x.tabState),\n-                        E = l.useCallback(v => {\n-                            if (v) {\n-                                var _ref78;\n-                                t == null || t.set(Te, (_ref78 = n == null ? void 0 : n.getValue()) !== null && _ref78 !== void 0 ? _ref78 : \"\");\n-                                const j = Cn(f, !0);\n-                                t == null || t.set(ve, j);\n-                            } else t == null || t.set(Te, \"\"), ns(t);\n-                            y(v), t == null || t.set(ze, v.toString());\n-                        }, [t, f, n]),\n-                        k = l.useRef();\n-                    l.useEffect(() => {\n-                        const v = !!e.shouldPersistHeaders;\n-                        (k == null ? void 0 : k.current) !== v && (E(v), k.current = v);\n-                    }, [e.shouldPersistHeaders, E]);\n-                    const L = Xr({\n-                            queryEditor: o,\n-                            variableEditor: g,\n-                            headerEditor: n,\n-                            responseEditor: i\n-                        }),\n-                        b = ts({\n-                            queryEditor: o,\n-                            variableEditor: g,\n-                            headerEditor: n,\n-                            responseEditor: i\n-                        }),\n-                        {\n-                            onTabChange: w,\n-                            defaultHeaders: T,\n-                            children: A\n-                        } = e,\n-                        F = l.useCallback(() => {\n-                            C(v => {\n-                                const j = L(v),\n-                                    R = {\n-                                        tabs: [...j.tabs, vn({\n-                                            headers: T\n-                                        })],\n-                                        activeTabIndex: j.tabs.length\n-                                    };\n-                                return h(R), b(R.tabs[R.activeTabIndex]), w == null || w(R), R;\n-                            });\n-                        }, [T, w, b, h, L]),\n-                        I = l.useCallback(v => {\n-                            C(j => {\n-                                const R = {\n-                                    ...j,\n-                                    activeTabIndex: v\n-                                };\n-                                return h(R), b(R.tabs[R.activeTabIndex]), w == null || w(R), R;\n-                            });\n-                        }, [w, b, h]),\n-                        H = l.useCallback(v => {\n-                            C(j => {\n-                                const R = j.tabs[j.activeTabIndex],\n-                                    U = {\n-                                        tabs: v,\n-                                        activeTabIndex: v.indexOf(R)\n-                                    };\n-                                return h(U), b(U.tabs[U.activeTabIndex]), w == null || w(U), U;\n-                            });\n-                        }, [w, b, h]),\n-                        O = l.useCallback(v => {\n-                            C(j => {\n-                                const R = {\n-                                    tabs: j.tabs.filter((U, ie) => v !== ie),\n-                                    activeTabIndex: Math.max(j.activeTabIndex - 1, 0)\n-                                };\n-                                return h(R), b(R.tabs[R.activeTabIndex]), w == null || w(R), R;\n-                            });\n-                        }, [w, b, h]),\n-                        D = l.useCallback(v => {\n-                            C(j => {\n-                                const R = yn(j, v);\n-                                return h(R), w == null || w(R), R;\n-                            });\n-                        }, [w, h]),\n-                        {\n-                            onEditOperationName: q\n-                        } = e,\n-                        N = l.useCallback(v => {\n-                            o && (o.operationName = v, D({\n-                                operationName: v\n-                            }), q == null || q(v));\n-                        }, [q, o, D]),\n-                        P = l.useMemo(() => {\n-                            const v = new Map();\n-                            if (Array.isArray(e.externalFragments))\n-                                for (const j of e.externalFragments) v.set(j.name.value, j);\n-                            else if (typeof e.externalFragments == \"string\") M.visit(M.parse(e.externalFragments, {}), {\n-                                FragmentDefinition(j) {\n-                                    v.set(j.name.value, j);\n-                                }\n-                            });\n-                            else if (e.externalFragments) throw new Error(\"The `externalFragments` prop must either be a string that contains the fragment definitions in SDL or a list of FragmentDefinitionNode objects.\");\n-                            return v;\n-                        }, [e.externalFragments]),\n-                        S = l.useMemo(() => e.validationRules || [], [e.validationRules]),\n-                        W = l.useMemo(() => ({\n-                            ...f,\n-                            addTab: F,\n-                            changeTab: I,\n-                            moveTab: H,\n-                            closeTab: O,\n-                            updateActiveTabValues: D,\n-                            headerEditor: n,\n-                            queryEditor: o,\n-                            responseEditor: i,\n-                            variableEditor: g,\n-                            setHeaderEditor: r,\n-                            setQueryEditor: c,\n-                            setResponseEditor: d,\n-                            setVariableEditor: m,\n-                            setOperationName: N,\n-                            initialQuery: x.query,\n-                            initialVariables: x.variables,\n-                            initialHeaders: x.headers,\n-                            initialResponse: x.response,\n-                            externalFragments: P,\n-                            validationRules: S,\n-                            shouldPersistHeaders: p,\n-                            setShouldPersistHeaders: E\n-                        }), [f, F, I, H, O, D, n, o, i, g, N, x, P, S, p, E]);\n-                    return s.jsx(Ct.Provider, {\n-                        value: W,\n-                        children: A\n-                    });\n-                }\n-                a(En, \"EditorContextProvider\");\n-                const Z = le(Ct),\n-                    ze = \"shouldPersistHeaders\",\n-                    rs = `# Welcome to GraphiQL\n-#\n-# GraphiQL is an in-browser tool for writing, validating, and\n-# testing GraphQL queries.\n-#\n-# Type queries into this side of the screen, and you will see intelligent\n-# typeaheads aware of the current GraphQL type schema and live syntax and\n-# validation errors highlighted within the text.\n-#\n-# GraphQL queries typically start with a \"{\" character. Lines that start\n-# with a # are ignored.\n-#\n-# An example GraphQL query might look like:\n-#\n-#     {\n-#       field(arg: \"value\") {\n-#         subField\n-#       }\n-#     }\n-#\n-# Keyboard shortcuts:\n-#\n-#   Prettify query:  Shift-Ctrl-P (or press the prettify button)\n-#\n-#  Merge fragments:  Shift-Ctrl-M (or press the merge button)\n-#\n-#        Run Query:  Ctrl-Enter (or press the play button)\n-#\n-#    Auto Complete:  Ctrl-Space (or just start typing)\n-#\n+        /***/\n+        \"../../../node_modules/react-remove-scroll/dist/es2015/medium.js\":\n+            /*!***********************************************************************!*\\\n+              !*** ../../../node_modules/react-remove-scroll/dist/es2015/medium.js ***!\n+              \\***********************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-`;\n+                \"use strict\";\n \n-                function Xe(_ref79) {\n-                    let {\n-                        isHidden: e,\n-                        ...t\n-                    } = _ref79;\n-                    const {\n-                        headerEditor: n\n-                    } = Z({\n-                            nonNull: !0,\n-                            caller: Xe\n-                        }),\n-                        r = ce(t, Xe);\n-                    return l.useEffect(() => {\n-                        e || n == null || n.refresh();\n-                    }, [n, e]), s.jsx(\"div\", {\n-                        className: _.clsx(\"graphiql-editor\", e && \"hidden\"),\n-                        ref: r\n-                    });\n-                }\n-                a(Xe, \"HeaderEditor\");\n-\n-                function De(e) {\n-                    var g;\n-                    const [t, n] = l.useState({\n-                            width: null,\n-                            height: null\n-                        }),\n-                        [r, o] = l.useState(null),\n-                        c = l.useRef(null),\n-                        i = (g = Sn(e.token)) == null ? void 0 : g.href;\n-                    l.useEffect(() => {\n-                        if (c.current) {\n-                            if (!i) {\n-                                n({\n-                                    width: null,\n-                                    height: null\n-                                }), o(null);\n-                                return;\n-                            }\n-                            fetch(i, {\n-                                method: \"HEAD\"\n-                            }).then(m => {\n-                                o(m.headers.get(\"Content-Type\"));\n-                            }).catch(() => {\n-                                o(null);\n-                            });\n-                        }\n-                    }, [i]);\n-                    const d = t.width !== null && t.height !== null ? s.jsxs(\"div\", {\n-                        children: [t.width, \"x\", t.height, r === null ? null : \" \" + r]\n-                    }) : null;\n-                    return s.jsxs(\"div\", {\n-                        children: [s.jsx(\"img\", {\n-                            onLoad: () => {\n-                                var _ref80, _ref81;\n-                                var m, p;\n-                                n({\n-                                    width: (_ref80 = (m = c.current) == null ? void 0 : m.naturalWidth) !== null && _ref80 !== void 0 ? _ref80 : null,\n-                                    height: (_ref81 = (p = c.current) == null ? void 0 : p.naturalHeight) !== null && _ref81 !== void 0 ? _ref81 : null\n-                                });\n-                            },\n-                            ref: c,\n-                            src: i\n-                        }), d]\n-                    });\n-                }\n-                a(De, \"ImagePreview\");\n-                De.shouldRender = a(function(t) {\n-                    const n = Sn(t);\n-                    return n ? ss(n) : !1;\n-                }, \"shouldRender\");\n-\n-                function Sn(e) {\n-                    if (e.type !== \"string\") return;\n-                    const t = e.string.slice(1).slice(0, -1).trim();\n-                    try {\n-                        const {\n-                            location: n\n-                        } = window;\n-                        return new URL(t, n.protocol + \"//\" + n.host);\n-                    } catch {\n-                        return;\n-                    }\n-                }\n-                a(Sn, \"tokenToURL\");\n \n-                function ss(e) {\n-                    return /(bmp|gif|jpeg|jpg|png|svg)$/.test(e.pathname);\n-                }\n-                a(ss, \"isImageURL\");\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.effectCar = void 0;\n+                var _useSidecar = __webpack_require__( /*! use-sidecar */ \"../../../node_modules/use-sidecar/dist/es2015/index.js\");\n+                var effectCar = exports.effectCar = (0, _useSidecar.createSidecarMedium)();\n \n-                function Ln(e) {\n-                    const t = te(e, Ln);\n-                    return s.jsx(\"div\", {\n-                        className: \"graphiql-editor\",\n-                        ref: t\n-                    });\n-                }\n-                a(Ln, \"QueryEditor\");\n+                /***/\n+            }),\n \n-                function Ae() {\n-                    let {\n-                        responseTooltip: e,\n-                        editorTheme: t = Fe,\n-                        keyMap: n = Be\n-                    } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n-                    let r = arguments.length > 1 ? arguments[1] : undefined;\n-                    const {\n-                        fetchError: o,\n-                        validationErrors: c\n-                    } = Y({\n-                            nonNull: !0,\n-                            caller: r || Ae\n-                        }), {\n-                            initialResponse: i,\n-                            responseEditor: d,\n-                            setResponseEditor: g\n-                        } = Z({\n-                            nonNull: !0,\n-                            caller: r || Ae\n-                        }),\n-                        m = l.useRef(null),\n-                        p = l.useRef(e);\n-                    return l.useEffect(() => {\n-                        p.current = e;\n-                    }, [e]), l.useEffect(() => {\n-                        let y = !0;\n-                        return Ee([Promise.resolve().then(() => __webpack_require__( /*! ./foldgutter.cjs.js */ \"../../graphiql-react/dist/foldgutter.cjs.js\")).then(h => h.foldgutter), Promise.resolve().then(() => __webpack_require__( /*! ./brace-fold.cjs.js */ \"../../graphiql-react/dist/brace-fold.cjs.js\")).then(h => h.braceFold), Promise.resolve().then(() => __webpack_require__( /*! ./dialog.cjs.js */ \"../../graphiql-react/dist/dialog.cjs.js\")).then(h => h.dialog), Promise.resolve().then(() => __webpack_require__( /*! ./search.cjs.js */ \"../../graphiql-react/dist/search.cjs.js\")).then(h => h.search), Promise.resolve().then(() => __webpack_require__( /*! ./searchcursor.cjs.js */ \"../../graphiql-react/dist/searchcursor.cjs.js\")).then(h => h.searchcursor), Promise.resolve().then(() => __webpack_require__( /*! ./jump-to-line.cjs.js */ \"../../graphiql-react/dist/jump-to-line.cjs.js\")).then(h => h.jumpToLine), Promise.resolve().then(() => __webpack_require__( /*! ./sublime.cjs.js */ \"../../graphiql-react/dist/sublime.cjs.js\")).then(h => h.sublime), Promise.resolve().then(() => __webpack_require__( /*! ./mode.cjs3.js */ \"../../graphiql-react/dist/mode.cjs3.js\")), Promise.resolve().then(() => __webpack_require__( /*! ./info-addon.cjs.js */ \"../../graphiql-react/dist/info-addon.cjs.js\"))], {\n-                            useCommonAddons: !1\n-                        }).then(h => {\n-                            if (!y) return;\n-                            const x = document.createElement(\"div\");\n-                            h.registerHelper(\"info\", \"graphql-results\", (E, k, L, b) => {\n-                                const w = [],\n-                                    T = p.current;\n-                                return T && w.push(s.jsx(T, {\n-                                    pos: b,\n-                                    token: E\n-                                })), De.shouldRender(E) && w.push(s.jsx(De, {\n-                                    token: E\n-                                }, \"image-preview\")), w.length ? (vt.render(w, x), x) : (vt.unmountComponentAtNode(x), null);\n-                            });\n-                            const f = m.current;\n-                            if (!f) return;\n-                            const C = h(f, {\n-                                value: i,\n-                                lineWrapping: !0,\n-                                readOnly: !0,\n-                                theme: t,\n-                                mode: \"graphql-results\",\n-                                foldGutter: !0,\n-                                gutters: [\"CodeMirror-foldgutter\"],\n-                                info: !0,\n-                                extraKeys: We\n-                            });\n-                            g(C);\n-                        }), () => {\n-                            y = !1;\n-                        };\n-                    }, [t, i, g]), Ze(d, \"keyMap\", n), l.useEffect(() => {\n-                        o && (d == null || d.setValue(o)), c.length > 0 && (d == null || d.setValue(B.formatError(c)));\n-                    }, [d, o, c]), m;\n-                }\n-                a(Ae, \"useResponseEditor\");\n-\n-                function jn(e) {\n-                    const t = Ae(e, jn);\n-                    return s.jsx(\"section\", {\n-                        className: \"result-window\",\n-                        \"aria-label\": \"Result Window\",\n-                        \"aria-live\": \"polite\",\n-                        \"aria-atomic\": \"true\",\n-                        ref: t\n-                    });\n-                }\n-                a(jn, \"ResponseEditor\");\n+        /***/\n+        \"../../../node_modules/react-remove-scroll/dist/es2015/sidecar.js\":\n+            /*!************************************************************************!*\\\n+              !*** ../../../node_modules/react-remove-scroll/dist/es2015/sidecar.js ***!\n+              \\************************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                function et(_ref82) {\n-                    let {\n-                        isHidden: e,\n-                        ...t\n-                    } = _ref82;\n-                    const {\n-                        variableEditor: n\n-                    } = Z({\n-                            nonNull: !0,\n-                            caller: et\n-                        }),\n-                        r = se(t, et);\n-                    return l.useEffect(() => {\n-                        n && !e && n.refresh();\n-                    }, [n, e]), s.jsx(\"div\", {\n-                        className: _.clsx(\"graphiql-editor\", e && \"hidden\"),\n-                        ref: r\n-                    });\n-                }\n-                a(et, \"VariableEditor\");\n+                \"use strict\";\n \n-                function os(_ref83) {\n-                    let {\n-                        children: e,\n-                        dangerouslyAssumeSchemaIsValid: t,\n-                        defaultQuery: n,\n-                        defaultHeaders: r,\n-                        defaultTabs: o,\n-                        externalFragments: c,\n-                        fetcher: i,\n-                        getDefaultFieldNames: d,\n-                        headers: g,\n-                        inputValueDeprecation: m,\n-                        introspectionQueryName: p,\n-                        maxHistoryLength: y,\n-                        onEditOperationName: h,\n-                        onSchemaChange: x,\n-                        onTabChange: f,\n-                        onTogglePluginVisibility: C,\n-                        operationName: E,\n-                        plugins: k,\n-                        query: L,\n-                        response: b,\n-                        schema: w,\n-                        schemaDescription: T,\n-                        shouldPersistHeaders: A,\n-                        storage: F,\n-                        validationRules: I,\n-                        variables: H,\n-                        visiblePlugin: O\n-                    } = _ref83;\n-                    return s.jsx(Nt, {\n-                        storage: F,\n-                        children: s.jsx(sn, {\n-                            maxHistoryLength: y,\n-                            children: s.jsx(En, {\n-                                defaultQuery: n,\n-                                defaultHeaders: r,\n-                                defaultTabs: o,\n-                                externalFragments: c,\n-                                headers: g,\n-                                onEditOperationName: h,\n-                                onTabChange: f,\n-                                query: L,\n-                                response: b,\n-                                shouldPersistHeaders: A,\n-                                validationRules: I,\n-                                variables: H,\n-                                children: s.jsx(ct, {\n-                                    dangerouslyAssumeSchemaIsValid: t,\n-                                    fetcher: i,\n-                                    inputValueDeprecation: m,\n-                                    introspectionQueryName: p,\n-                                    onSchemaChange: x,\n-                                    schema: w,\n-                                    schemaDescription: T,\n-                                    children: s.jsx(qe, {\n-                                        getDefaultFieldNames: d,\n-                                        fetcher: i,\n-                                        operationName: E,\n-                                        children: s.jsx(dt, {\n-                                            children: s.jsx(fn, {\n-                                                onTogglePluginVisibility: C,\n-                                                plugins: k,\n-                                                visiblePlugin: O,\n-                                                children: e\n-                                            })\n-                                        })\n-                                    })\n-                                })\n-                            })\n-                        })\n-                    });\n-                }\n-                a(os, \"GraphiQLProvider\");\n \n-                function ls() {\n-                    const e = re(),\n-                        [t, n] = l.useState(() => {\n-                            if (!e) return null;\n-                            const o = e.get(Ue);\n-                            switch (o) {\n-                                case \"light\":\n-                                    return \"light\";\n-                                case \"dark\":\n-                                    return \"dark\";\n-                                default:\n-                                    return typeof o == \"string\" && e.set(Ue, \"\"), null;\n-                            }\n-                        });\n-                    l.useLayoutEffect(() => {\n-                        typeof window > \"u\" || (document.body.classList.remove(\"graphiql-light\", \"graphiql-dark\"), t && document.body.classList.add(`graphiql-${t}`));\n-                    }, [t]);\n-                    const r = l.useCallback(o => {\n-                        e == null || e.set(Ue, o || \"\"), n(o);\n-                    }, [e]);\n-                    return l.useMemo(() => ({\n-                        theme: t,\n-                        setTheme: r\n-                    }), [t, r]);\n-                }\n-                a(ls, \"useTheme\");\n-                const Ue = \"theme\";\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports[\"default\"] = void 0;\n+                var _useSidecar = __webpack_require__( /*! use-sidecar */ \"../../../node_modules/use-sidecar/dist/es2015/index.js\");\n+                var _SideEffect = __webpack_require__( /*! ./SideEffect */ \"../../../node_modules/react-remove-scroll/dist/es2015/SideEffect.js\");\n+                var _medium = __webpack_require__( /*! ./medium */ \"../../../node_modules/react-remove-scroll/dist/es2015/medium.js\");\n+                var _default = exports[\"default\"] = (0, _useSidecar.exportSidecar)(_medium.effectCar, _SideEffect.RemoveScrollSideCar);\n \n-                function is(_ref84) {\n-                    let {\n-                        defaultSizeRelation: e = as,\n-                        direction: t,\n-                        initiallyHidden: n,\n-                        onHiddenElementChange: r,\n-                        sizeThresholdFirst: o = 100,\n-                        sizeThresholdSecond: c = 100,\n-                        storageKey: i\n-                    } = _ref84;\n-                    const d = re(),\n-                        g = l.useMemo(() => ue(500, L => {\n-                            i && (d == null || d.set(i, L));\n-                        }), [d, i]),\n-                        [m, p] = l.useState(() => {\n-                            const L = i && (d == null ? void 0 : d.get(i));\n-                            return L === ke || n === \"first\" ? \"first\" : L === Ne || n === \"second\" ? \"second\" : null;\n-                        }),\n-                        y = l.useCallback(L => {\n-                            L !== m && (p(L), r == null || r(L));\n-                        }, [m, r]),\n-                        h = l.useRef(null),\n-                        x = l.useRef(null),\n-                        f = l.useRef(null),\n-                        C = l.useRef(`${e}`);\n-                    l.useLayoutEffect(() => {\n-                        const L = i && (d == null ? void 0 : d.get(i)) || C.current;\n-                        h.current && (h.current.style.display = \"flex\", h.current.style.flex = L === ke || L === Ne ? C.current : L), f.current && (f.current.style.display = \"flex\", f.current.style.flex = \"1\"), x.current && (x.current.style.display = \"flex\");\n-                    }, [t, d, i]);\n-                    const E = l.useCallback(L => {\n-                            const b = L === \"first\" ? h.current : f.current;\n-                            if (b && (b.style.left = \"-1000px\", b.style.position = \"absolute\", b.style.opacity = \"0\", b.style.height = \"500px\", b.style.width = \"500px\", h.current)) {\n-                                const w = parseFloat(h.current.style.flex);\n-                                (!Number.isFinite(w) || w < 1) && (h.current.style.flex = \"1\");\n-                            }\n-                        }, []),\n-                        k = l.useCallback(L => {\n-                            const b = L === \"first\" ? h.current : f.current;\n-                            if (b && (b.style.width = \"\", b.style.height = \"\", b.style.opacity = \"\", b.style.position = \"\", b.style.left = \"\", d && i)) {\n-                                const w = d.get(i);\n-                                h.current && w !== ke && w !== Ne && (h.current.style.flex = w || C.current);\n-                            }\n-                        }, [d, i]);\n-                    return l.useLayoutEffect(() => {\n-                        m === \"first\" ? E(\"first\") : k(\"first\"), m === \"second\" ? E(\"second\") : k(\"second\");\n-                    }, [m, E, k]), l.useEffect(() => {\n-                        if (!x.current || !h.current || !f.current) return;\n-                        const L = x.current,\n-                            b = h.current,\n-                            w = b.parentElement,\n-                            T = t === \"horizontal\" ? \"clientX\" : \"clientY\",\n-                            A = t === \"horizontal\" ? \"left\" : \"top\",\n-                            F = t === \"horizontal\" ? \"right\" : \"bottom\",\n-                            I = t === \"horizontal\" ? \"clientWidth\" : \"clientHeight\";\n-\n-                        function H(D) {\n-                            D.preventDefault();\n-                            const q = D[T] - L.getBoundingClientRect()[A];\n-\n-                            function N(S) {\n-                                if (S.buttons === 0) return P();\n-                                const W = S[T] - w.getBoundingClientRect()[A] - q,\n-                                    v = w.getBoundingClientRect()[F] - S[T] + q - L[I];\n-                                if (W < o) y(\"first\"), g(ke);\n-                                else if (v < c) y(\"second\"), g(Ne);\n-                                else {\n-                                    y(null);\n-                                    const j = `${W / v}`;\n-                                    b.style.flex = j, g(j);\n-                                }\n-                            }\n-                            a(N, \"handleMouseMove\");\n+                /***/\n+            }),\n \n-                            function P() {\n-                                document.removeEventListener(\"mousemove\", N), document.removeEventListener(\"mouseup\", P);\n-                            }\n-                            a(P, \"handleMouseUp\"), document.addEventListener(\"mousemove\", N), document.addEventListener(\"mouseup\", P);\n-                        }\n-                        a(H, \"handleMouseDown\"), L.addEventListener(\"mousedown\", H);\n+        /***/\n+        \"../../../node_modules/react-style-singleton/dist/es2015/component.js\":\n+            /*!****************************************************************************!*\\\n+              !*** ../../../node_modules/react-style-singleton/dist/es2015/component.js ***!\n+              \\****************************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                        function O() {\n-                            h.current && (h.current.style.flex = C.current), g(C.current), y(null);\n-                        }\n-                        return a(O, \"reset\"), L.addEventListener(\"dblclick\", O), () => {\n-                            L.removeEventListener(\"mousedown\", H), L.removeEventListener(\"dblclick\", O);\n-                        };\n-                    }, [t, y, o, c, g]), l.useMemo(() => ({\n-                        dragBarRef: x,\n-                        hiddenElement: m,\n-                        firstRef: h,\n-                        setHiddenElement: p,\n-                        secondRef: f\n-                    }), [m, p]);\n-                }\n-                a(is, \"useDragResize\");\n-                const as = 1,\n-                    ke = \"hide-first\",\n-                    Ne = \"hide-second\";\n-                const kn = l.forwardRef((_ref85, r) => {\n-                    let {\n-                        label: e,\n-                        onClick: t,\n-                        ...n\n-                    } = _ref85;\n-                    const [o, c] = l.useState(null),\n-                        i = l.useCallback(d => {\n-                            try {\n-                                t == null || t(d), c(null);\n-                            } catch (g) {\n-                                c(g instanceof Error ? g : new Error(`Toolbar button click failed: ${g}`));\n-                            }\n-                        }, [t]);\n-                    return s.jsx(K, {\n-                        label: e,\n-                        children: s.jsx($, {\n-                            ...n,\n-                            ref: r,\n-                            type: \"button\",\n-                            className: _.clsx(\"graphiql-toolbar-button\", o && \"error\", n.className),\n-                            onClick: i,\n-                            \"aria-label\": o ? o.message : e,\n-                            \"aria-invalid\": o ? \"true\" : n[\"aria-invalid\"]\n-                        })\n-                    });\n-                });\n-                kn.displayName = \"ToolbarButton\";\n+                \"use strict\";\n \n-                function tt() {\n-                    const {\n-                        queryEditor: e,\n-                        setOperationName: t\n-                    } = Z({\n-                            nonNull: !0,\n-                            caller: tt\n-                        }), {\n-                            isFetching: n,\n-                            isSubscribed: r,\n-                            operationName: o,\n-                            run: c,\n-                            stop: i\n-                        } = we({\n-                            nonNull: !0,\n-                            caller: tt\n-                        }),\n-                        d = (e == null ? void 0 : e.operations) || [],\n-                        g = d.length > 1 && typeof o != \"string\",\n-                        m = n || r,\n-                        p = `${m ? \"Stop\" : \"Execute\"} query (Ctrl-Enter)`,\n-                        y = {\n-                            type: \"button\",\n-                            className: \"graphiql-execute-button\",\n-                            children: m ? s.jsx(Qt, {}) : s.jsx(_t, {}),\n-                            \"aria-label\": p\n-                        };\n-                    return g && !m ? s.jsxs(X, {\n-                        children: [s.jsx(K, {\n-                            label: p,\n-                            children: s.jsx(X.Button, {\n-                                ...y\n-                            })\n-                        }), s.jsx(X.Content, {\n-                            children: d.map((h, x) => {\n-                                const f = h.name ? h.name.value : `<Unnamed ${h.operation}>`;\n-                                return s.jsx(X.Item, {\n-                                    onSelect: () => {\n-                                        var E;\n-                                        const C = (E = h.name) == null ? void 0 : E.value;\n-                                        e && C && C !== e.operationName && t(C), c();\n-                                    },\n-                                    children: f\n-                                }, `${f}-${x}`);\n-                            })\n-                        })]\n-                    }) : s.jsx(K, {\n-                        label: p,\n-                        children: s.jsx(\"button\", {\n-                            ...y,\n-                            onClick: () => {\n-                                m ? i() : c();\n-                            }\n-                        })\n-                    });\n-                }\n-                a(tt, \"ExecuteButton\");\n-                const cs = a(_ref86 => {\n-                        let {\n-                            button: e,\n-                            children: t,\n-                            label: n,\n-                            ...r\n-                        } = _ref86;\n-                        return s.jsxs(X, {\n-                            ...r,\n-                            children: [s.jsx(K, {\n-                                label: n,\n-                                children: s.jsx(X.Button, {\n-                                    className: _.clsx(\"graphiql-un-styled graphiql-toolbar-menu\", r.className),\n-                                    \"aria-label\": n,\n-                                    children: e\n-                                })\n-                            }), s.jsx(X.Content, {\n-                                children: t\n-                            })]\n-                        });\n-                    }, \"ToolbarMenuRoot\"),\n-                    us = ye(cs, {\n-                        Item: X.Item\n-                    });\n-                exports.Argument = Ce;\n-                exports.ArgumentIcon = Tt;\n-                exports.Button = me;\n-                exports.ButtonGroup = Ut;\n-                exports.ChevronDownIcon = dr;\n-                exports.ChevronLeftIcon = Mt;\n-                exports.ChevronUpIcon = hr;\n-                exports.CloseIcon = Oe;\n-                exports.CopyIcon = mr;\n-                exports.DOC_EXPLORER_PLUGIN = de;\n-                exports.DefaultValue = it;\n-                exports.DeprecatedArgumentIcon = Pt;\n-                exports.DeprecatedEnumValueIcon = qt;\n-                exports.DeprecatedFieldIcon = Rt;\n-                exports.DeprecationReason = ht;\n-                exports.Dialog = yr;\n-                exports.DialogRoot = Jt;\n-                exports.Directive = cn;\n-                exports.DirectiveIcon = Vt;\n-                exports.DocExplorer = Ve;\n-                exports.DocsFilledIcon = It;\n-                exports.DocsIcon = Ht;\n-                exports.DropdownMenu = X;\n-                exports.EditorContext = Ct;\n-                exports.EditorContextProvider = En;\n-                exports.EnumValueIcon = Dt;\n-                exports.ExecuteButton = tt;\n-                exports.ExecutionContext = lt;\n-                exports.ExecutionContextProvider = qe;\n-                exports.ExplorerContext = ut;\n-                exports.ExplorerContextProvider = dt;\n-                exports.ExplorerSection = G;\n-                exports.FieldDocumentation = un;\n-                exports.FieldIcon = At;\n-                exports.FieldLink = hn;\n-                exports.GraphiQLProvider = os;\n-                exports.HISTORY_PLUGIN = Ye;\n-                exports.HeaderEditor = Xe;\n-                exports.History = on;\n-                exports.HistoryContext = ot;\n-                exports.HistoryContextProvider = sn;\n-                exports.HistoryIcon = Ot;\n-                exports.ImagePreview = De;\n-                exports.ImplementsIcon = Ft;\n-                exports.KeyboardShortcutIcon = fr;\n-                exports.MagnifyingGlassIcon = Bt;\n-                exports.MarkdownContent = z;\n-                exports.MergeIcon = pr;\n-                exports.PenIcon = Wt;\n-                exports.PlayIcon = _t;\n-                exports.PluginContext = ft;\n-                exports.PluginContextProvider = fn;\n-                exports.PlusIcon = gr;\n-                exports.PrettifyIcon = xr;\n-                exports.QueryEditor = Ln;\n-                exports.ReloadIcon = Cr;\n-                exports.ResponseEditor = jn;\n-                exports.RootTypeIcon = Zt;\n-                exports.SchemaContext = at;\n-                exports.SchemaContextProvider = ct;\n-                exports.SchemaDocumentation = dn;\n-                exports.Search = mt;\n-                exports.SettingsIcon = vr;\n-                exports.Spinner = st;\n-                exports.StarFilledIcon = Gt;\n-                exports.StarIcon = $t;\n-                exports.StopIcon = Qt;\n-                exports.StorageContext = rt;\n-                exports.StorageContextProvider = Nt;\n-                exports.Tab = Er;\n-                exports.Tabs = rn;\n-                exports.ToolbarButton = kn;\n-                exports.ToolbarMenu = us;\n-                exports.Tooltip = K;\n-                exports.TooltipRoot = Xt;\n-                exports.TrashIcon = zt;\n-                exports.TypeDocumentation = mn;\n-                exports.TypeIcon = ge;\n-                exports.TypeLink = Q;\n-                exports.UnStyledButton = $;\n-                exports.VariableEditor = et;\n-                exports.useAutoCompleteLeafs = Ie;\n-                exports.useCopyQuery = pt;\n-                exports.useDragResize = is;\n-                exports.useEditorContext = Z;\n-                exports.useEditorState = Ge;\n-                exports.useExecutionContext = we;\n-                exports.useExplorerContext = ee;\n-                exports.useHeaderEditor = ce;\n-                exports.useHeadersEditorState = Or;\n-                exports.useHistoryContext = be;\n-                exports.useMergeQuery = he;\n-                exports.useOperationsEditorState = Dr;\n-                exports.useOptimisticState = Fr;\n-                exports.usePluginContext = _e;\n-                exports.usePrettifyEditors = Se;\n-                exports.useQueryEditor = te;\n-                exports.useResponseEditor = Ae;\n-                exports.useSchemaContext = Y;\n-                exports.useStorageContext = re;\n-                exports.useTheme = ls;\n-                exports.useVariableEditor = se;\n-                exports.useVariablesEditorState = Ar;\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.styleSingleton = void 0;\n+                var _hook = __webpack_require__( /*! ./hook */ \"../../../node_modules/react-style-singleton/dist/es2015/hook.js\");\n+                /**\n+                 * create a Component to add styles on demand\n+                 * - styles are added when first instance is mounted\n+                 * - styles are removed when the last instance is unmounted\n+                 * - changing styles in runtime does nothing unless dynamic is set. But with multiple components that can lead to the undefined behavior\n+                 */\n+                var styleSingleton = function() {\n+                    var useStyle = (0, _hook.styleHookSingleton)();\n+                    var Sheet = function(_a) {\n+                        var styles = _a.styles,\n+                            dynamic = _a.dynamic;\n+                        useStyle(styles, dynamic);\n+                        return null;\n+                    };\n+                    return Sheet;\n+                };\n+                exports.styleSingleton = styleSingleton;\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-react/dist/info-addon.cjs.js\":\n-            /*!***************************************************!*\\\n-              !*** ../../graphiql-react/dist/info-addon.cjs.js ***!\n-              \\***************************************************/\n+        \"../../../node_modules/react-style-singleton/dist/es2015/hook.js\":\n+            /*!***********************************************************************!*\\\n+              !*** ../../../node_modules/react-style-singleton/dist/es2015/hook.js ***!\n+              \\***********************************************************************/\n             /***/\n-            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                var M = Object.defineProperty;\n-                var i = (e, t) => M(e, \"name\", {\n-                    value: t,\n-                    configurable: !0\n-                });\n-                const r = __webpack_require__( /*! ./codemirror.cjs.js */ \"../../graphiql-react/dist/codemirror.cjs.js\");\n-                __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\");\n-                r.CodeMirror.defineOption(\"info\", !1, (e, t, n) => {\n-                    if (n && n !== r.CodeMirror.Init) {\n-                        const o = e.state.info.onMouseOver;\n-                        r.CodeMirror.off(e.getWrapperElement(), \"mouseover\", o), clearTimeout(e.state.info.hoverTimeout), delete e.state.info;\n-                    }\n-                    if (t) {\n-                        const o = e.state.info = g(t);\n-                        o.onMouseOver = h.bind(null, e), r.CodeMirror.on(e.getWrapperElement(), \"mouseover\", o.onMouseOver);\n-                    }\n-                });\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.styleHookSingleton = void 0;\n+                var React = _interopRequireWildcard(__webpack_require__( /*! react */ \"react\"));\n+                var _singleton = __webpack_require__( /*! ./singleton */ \"../../../node_modules/react-style-singleton/dist/es2015/singleton.js\");\n \n-                function g(e) {\n-                    return {\n-                        options: e instanceof Function ? {\n-                            render: e\n-                        } : e === !0 ? {} : e\n-                    };\n-                }\n-                i(g, \"createState\");\n-\n-                function T(e) {\n-                    const {\n-                        options: t\n-                    } = e.state.info;\n-                    return (t == null ? void 0 : t.hoverTime) || 500;\n-                }\n-                i(T, \"getHoverTime\");\n-\n-                function h(e, t) {\n-                    const n = e.state.info,\n-                        o = t.target || t.srcElement;\n-                    if (!(o instanceof HTMLElement) || o.nodeName !== \"SPAN\" || n.hoverTimeout !== void 0) return;\n-                    const s = o.getBoundingClientRect(),\n-                        u = i(function() {\n-                            clearTimeout(n.hoverTimeout), n.hoverTimeout = setTimeout(p, d);\n-                        }, \"onMouseMove\"),\n-                        f = i(function() {\n-                            r.CodeMirror.off(document, \"mousemove\", u), r.CodeMirror.off(e.getWrapperElement(), \"mouseout\", f), clearTimeout(n.hoverTimeout), n.hoverTimeout = void 0;\n-                        }, \"onMouseOut\"),\n-                        p = i(function() {\n-                            r.CodeMirror.off(document, \"mousemove\", u), r.CodeMirror.off(e.getWrapperElement(), \"mouseout\", f), n.hoverTimeout = void 0, C(e, s);\n-                        }, \"onHover\"),\n-                        d = T(e);\n-                    n.hoverTimeout = setTimeout(p, d), r.CodeMirror.on(document, \"mousemove\", u), r.CodeMirror.on(e.getWrapperElement(), \"mouseout\", f);\n-                }\n-                i(h, \"onMouseOver\");\n-\n-                function C(e, t) {\n-                    const n = e.coordsChar({\n-                            left: (t.left + t.right) / 2,\n-                            top: (t.top + t.bottom) / 2\n-                        }, \"window\"),\n-                        o = e.state.info,\n-                        {\n-                            options: s\n-                        } = o,\n-                        u = s.render || e.getHelper(n, \"info\");\n-                    if (u) {\n-                        const f = e.getTokenAt(n, !0);\n-                        if (f) {\n-                            const p = u(f, s, e, n);\n-                            p && w(e, t, p);\n-                        }\n-                    }\n+                function _getRequireWildcardCache(e) {\n+                    if (\"function\" != typeof WeakMap) return null;\n+                    var r = new WeakMap(),\n+                        t = new WeakMap();\n+                    return (_getRequireWildcardCache = function(e) {\n+                        return e ? t : r;\n+                    })(e);\n+                }\n+\n+                function _interopRequireWildcard(e, r) {\n+                    if (!r && e && e.__esModule) return e;\n+                    if (null === e || \"object\" != typeof e && \"function\" != typeof e) return {\n+                        default: e\n+                    };\n+                    var t = _getRequireWildcardCache(r);\n+                    if (t && t.has(e)) return t.get(e);\n+                    var n = {\n+                            __proto__: null\n+                        },\n+                        a = Object.defineProperty && Object.getOwnPropertyDescriptor;\n+                    for (var u in e)\n+                        if (\"default\" !== u && Object.prototype.hasOwnProperty.call(e, u)) {\n+                            var i = a ? Object.getOwnPropertyDescriptor(e, u) : null;\n+                            i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u];\n+                        } return n.default = e, t && t.set(e, n), n;\n                 }\n-                i(C, \"onMouseHover\");\n-\n-                function w(e, t, n) {\n-                    const o = document.createElement(\"div\");\n-                    o.className = \"CodeMirror-info\", o.append(n), document.body.append(o);\n-                    const s = o.getBoundingClientRect(),\n-                        u = window.getComputedStyle(o),\n-                        f = s.right - s.left + parseFloat(u.marginLeft) + parseFloat(u.marginRight),\n-                        p = s.bottom - s.top + parseFloat(u.marginTop) + parseFloat(u.marginBottom);\n-                    let d = t.bottom;\n-                    p > window.innerHeight - t.bottom - 15 && t.top > window.innerHeight - t.bottom && (d = t.top - p), d < 0 && (d = t.bottom);\n-                    let m = Math.max(0, window.innerWidth - f - 15);\n-                    m > t.left && (m = t.left), o.style.opacity = \"1\", o.style.top = d + \"px\", o.style.left = m + \"px\";\n-                    let l;\n-                    const c = i(function() {\n-                            clearTimeout(l);\n-                        }, \"onMouseOverPopup\"),\n-                        a = i(function() {\n-                            clearTimeout(l), l = setTimeout(v, 200);\n-                        }, \"onMouseOut\"),\n-                        v = i(function() {\n-                            r.CodeMirror.off(o, \"mouseover\", c), r.CodeMirror.off(o, \"mouseout\", a), r.CodeMirror.off(e.getWrapperElement(), \"mouseout\", a), o.style.opacity ? (o.style.opacity = \"0\", setTimeout(() => {\n-                                o.parentNode && o.remove();\n-                            }, 600)) : o.parentNode && o.remove();\n-                        }, \"hidePopup\");\n-                    r.CodeMirror.on(o, \"mouseover\", c), r.CodeMirror.on(o, \"mouseout\", a), r.CodeMirror.on(e.getWrapperElement(), \"mouseout\", a);\n-                }\n-                i(w, \"showPopup\");\n+                /**\n+                 * creates a hook to control style singleton\n+                 * @see {@link styleSingleton} for a safer component version\n+                 * @example\n+                 * ```tsx\n+                 * const useStyle = styleHookSingleton();\n+                 * ///\n+                 * useStyle('body { overflow: hidden}');\n+                 */\n+                var styleHookSingleton = function() {\n+                    var sheet = (0, _singleton.stylesheetSingleton)();\n+                    return function(styles, isDynamic) {\n+                        React.useEffect(function() {\n+                            sheet.add(styles);\n+                            return function() {\n+                                sheet.remove();\n+                            };\n+                        }, [styles && isDynamic]);\n+                    };\n+                };\n+                exports.styleHookSingleton = styleHookSingleton;\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-react/dist/info.cjs.js\":\n-            /*!*********************************************!*\\\n-              !*** ../../graphiql-react/dist/info.cjs.js ***!\n-              \\*********************************************/\n+        \"../../../node_modules/react-style-singleton/dist/es2015/index.js\":\n+            /*!************************************************************************!*\\\n+              !*** ../../../node_modules/react-style-singleton/dist/es2015/index.js ***!\n+              \\************************************************************************/\n             /***/\n-            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                var v = Object.defineProperty;\n-                var l = (a, e) => v(a, \"name\", {\n-                    value: e,\n-                    configurable: !0\n-                });\n-                const s = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\"),\n-                    D = __webpack_require__( /*! ./codemirror.cjs.js */ \"../../graphiql-react/dist/codemirror.cjs.js\"),\n-                    m = __webpack_require__( /*! ./SchemaReference.cjs.js */ \"../../graphiql-react/dist/SchemaReference.cjs.js\");\n-                __webpack_require__( /*! ./info-addon.cjs.js */ \"../../graphiql-react/dist/info-addon.cjs.js\");\n-                __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\");\n-                __webpack_require__( /*! ./forEachState.cjs.js */ \"../../graphiql-react/dist/forEachState.cjs.js\");\n-                D.CodeMirror.registerHelper(\"info\", \"graphql\", (a, e) => {\n-                    if (!e.schema || !a.state) return;\n-                    const {\n-                        kind: c,\n-                        step: n\n-                    } = a.state,\n-                        r = m.getTypeInfo(e.schema, a.state);\n-                    if (c === \"Field\" && n === 0 && r.fieldDef || c === \"AliasedField\" && n === 2 && r.fieldDef) {\n-                        const i = document.createElement(\"div\");\n-                        i.className = \"CodeMirror-info-header\", E(i, r, e);\n-                        const d = document.createElement(\"div\");\n-                        return d.append(i), o(d, e, r.fieldDef), d;\n-                    }\n-                    if (c === \"Directive\" && n === 1 && r.directiveDef) {\n-                        const i = document.createElement(\"div\");\n-                        i.className = \"CodeMirror-info-header\", h(i, r, e);\n-                        const d = document.createElement(\"div\");\n-                        return d.append(i), o(d, e, r.directiveDef), d;\n-                    }\n-                    if (c === \"Argument\" && n === 0 && r.argDef) {\n-                        const i = document.createElement(\"div\");\n-                        i.className = \"CodeMirror-info-header\", T(i, r, e);\n-                        const d = document.createElement(\"div\");\n-                        return d.append(i), o(d, e, r.argDef), d;\n-                    }\n-                    if (c === \"EnumValue\" && r.enumValue && r.enumValue.description) {\n-                        const i = document.createElement(\"div\");\n-                        i.className = \"CodeMirror-info-header\", g(i, r, e);\n-                        const d = document.createElement(\"div\");\n-                        return d.append(i), o(d, e, r.enumValue), d;\n-                    }\n-                    if (c === \"NamedType\" && r.type && r.type.description) {\n-                        const i = document.createElement(\"div\");\n-                        i.className = \"CodeMirror-info-header\", u(i, r, e, r.type);\n-                        const d = document.createElement(\"div\");\n-                        return d.append(i), o(d, e, r.type), d;\n-                    }\n-                });\n-\n-                function E(a, e, c) {\n-                    N(a, e, c), p(a, e, c, e.type);\n-                }\n-                l(E, \"renderField\");\n-\n-                function N(a, e, c) {\n-                    var n;\n-                    const r = ((n = e.fieldDef) === null || n === void 0 ? void 0 : n.name) || \"\";\n-                    t(a, r, \"field-name\", c, m.getFieldReference(e));\n-                }\n-                l(N, \"renderQualifiedField\");\n-\n-                function h(a, e, c) {\n-                    var n;\n-                    const r = \"@\" + (((n = e.directiveDef) === null || n === void 0 ? void 0 : n.name) || \"\");\n-                    t(a, r, \"directive-name\", c, m.getDirectiveReference(e));\n-                }\n-                l(h, \"renderDirective\");\n-\n-                function T(a, e, c) {\n-                    var n;\n-                    const r = ((n = e.argDef) === null || n === void 0 ? void 0 : n.name) || \"\";\n-                    t(a, r, \"arg-name\", c, m.getArgumentReference(e)), p(a, e, c, e.inputType);\n-                }\n-                l(T, \"renderArg\");\n-\n-                function g(a, e, c) {\n-                    var n;\n-                    const r = ((n = e.enumValue) === null || n === void 0 ? void 0 : n.name) || \"\";\n-                    u(a, e, c, e.inputType), t(a, \".\"), t(a, r, \"enum-value\", c, m.getEnumValueReference(e));\n-                }\n-                l(g, \"renderEnumValue\");\n-\n-                function p(a, e, c, n) {\n-                    const r = document.createElement(\"span\");\n-                    r.className = \"type-name-pill\", n instanceof s.GraphQLNonNull ? (u(r, e, c, n.ofType), t(r, \"!\")) : n instanceof s.GraphQLList ? (t(r, \"[\"), u(r, e, c, n.ofType), t(r, \"]\")) : t(r, (n == null ? void 0 : n.name) || \"\", \"type-name\", c, m.getTypeReference(e, n)), a.append(r);\n-                }\n-                l(p, \"renderTypeAnnotation\");\n-\n-                function u(a, e, c, n) {\n-                    n instanceof s.GraphQLNonNull ? (u(a, e, c, n.ofType), t(a, \"!\")) : n instanceof s.GraphQLList ? (t(a, \"[\"), u(a, e, c, n.ofType), t(a, \"]\")) : t(a, (n == null ? void 0 : n.name) || \"\", \"type-name\", c, m.getTypeReference(e, n));\n-                }\n-                l(u, \"renderType\");\n-\n-                function o(a, e, c) {\n-                    const {\n-                        description: n\n-                    } = c;\n-                    if (n) {\n-                        const r = document.createElement(\"div\");\n-                        r.className = \"info-description\", e.renderDescription ? r.innerHTML = e.renderDescription(n) : r.append(document.createTextNode(n)), a.append(r);\n-                    }\n-                    L(a, e, c);\n-                }\n-                l(o, \"renderDescription\");\n-\n-                function L(a, e, c) {\n-                    const n = c.deprecationReason;\n-                    if (n) {\n-                        const r = document.createElement(\"div\");\n-                        r.className = \"info-deprecation\", a.append(r);\n-                        const i = document.createElement(\"span\");\n-                        i.className = \"info-deprecation-label\", i.append(document.createTextNode(\"Deprecated\")), r.append(i);\n-                        const d = document.createElement(\"div\");\n-                        d.className = \"info-deprecation-reason\", e.renderDescription ? d.innerHTML = e.renderDescription(n) : d.append(document.createTextNode(n)), r.append(d);\n-                    }\n-                }\n-                l(L, \"renderDeprecation\");\n-\n-                function t(a, e) {\n-                    let c = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : \"\";\n-                    let n = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {\n-                        onClick: null\n-                    };\n-                    let r = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : null;\n-                    if (c) {\n-                        const {\n-                            onClick: i\n-                        } = n;\n-                        let d;\n-                        i ? (d = document.createElement(\"a\"), d.href = \"javascript:void 0\", d.addEventListener(\"click\", f => {\n-                            f.preventDefault(), i(r, f);\n-                        })) : d = document.createElement(\"span\"), d.className = c, d.append(document.createTextNode(e)), a.append(d);\n-                    } else a.append(document.createTextNode(e));\n-                }\n-                l(t, \"text\");\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                Object.defineProperty(exports, \"styleHookSingleton\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _hook.styleHookSingleton;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"styleSingleton\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _component.styleSingleton;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"stylesheetSingleton\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _singleton.stylesheetSingleton;\n+                    }\n+                }));\n+                var _component = __webpack_require__( /*! ./component */ \"../../../node_modules/react-style-singleton/dist/es2015/component.js\");\n+                var _singleton = __webpack_require__( /*! ./singleton */ \"../../../node_modules/react-style-singleton/dist/es2015/singleton.js\");\n+                var _hook = __webpack_require__( /*! ./hook */ \"../../../node_modules/react-style-singleton/dist/es2015/hook.js\");\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-react/dist/javascript.cjs.js\":\n-            /*!***************************************************!*\\\n-              !*** ../../graphiql-react/dist/javascript.cjs.js ***!\n-              \\***************************************************/\n+        \"../../../node_modules/react-style-singleton/dist/es2015/singleton.js\":\n+            /*!****************************************************************************!*\\\n+              !*** ../../../node_modules/react-style-singleton/dist/es2015/singleton.js ***!\n+              \\****************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                var ve = Object.defineProperty;\n-                var f = (F, W) => ve(F, \"name\", {\n-                    value: W,\n-                    configurable: !0\n-                });\n-                const Dr = __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\");\n-\n-                function ge(F, W) {\n-                    for (var w = 0; w < W.length; w++) {\n-                        const M = W[w];\n-                        if (typeof M != \"string\" && !Array.isArray(M)) {\n-                            for (const h in M)\n-                                if (h !== \"default\" && !(h in F)) {\n-                                    const A = Object.getOwnPropertyDescriptor(M, h);\n-                                    A && Object.defineProperty(F, h, A.get ? A : {\n-                                        enumerable: !0,\n-                                        get: () => M[h]\n-                                    });\n-                                }\n-                        }\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.stylesheetSingleton = void 0;\n+                var _getNonce = __webpack_require__( /*! get-nonce */ \"../../../node_modules/get-nonce/dist/es2015/index.js\");\n+\n+                function makeStyleTag() {\n+                    if (!document) return null;\n+                    var tag = document.createElement('style');\n+                    tag.type = 'text/css';\n+                    var nonce = (0, _getNonce.getNonce)();\n+                    if (nonce) {\n+                        tag.setAttribute('nonce', nonce);\n                     }\n-                    return Object.freeze(Object.defineProperty(F, Symbol.toStringTag, {\n-                        value: \"Module\"\n-                    }));\n+                    return tag;\n                 }\n-                f(ge, \"_mergeNamespaces\");\n-                var ye = {\n-                    exports: {}\n-                };\n-                (function(F, W) {\n-                    (function(w) {\n-                        w(Dr.requireCodemirror());\n-                    })(function(w) {\n-                        w.defineMode(\"javascript\", function(M, h) {\n-                            var A = M.indentUnit,\n-                                vr = h.statementIndent,\n-                                rr = h.jsonld,\n-                                O = h.json || rr,\n-                                gr = h.trackScope !== !1,\n-                                k = h.typescript,\n-                                er = h.wordCharacters || /[\\w$\\xa1-\\uffff]/,\n-                                yr = function() {\n-                                    function r(y) {\n-                                        return {\n-                                            type: y,\n-                                            style: \"keyword\"\n-                                        };\n-                                    }\n-                                    f(r, \"kw\");\n-                                    var e = r(\"keyword a\"),\n-                                        t = r(\"keyword b\"),\n-                                        a = r(\"keyword c\"),\n-                                        o = r(\"keyword d\"),\n-                                        d = r(\"operator\"),\n-                                        p = {\n-                                            type: \"atom\",\n-                                            style: \"atom\"\n-                                        };\n-                                    return {\n-                                        if: r(\"if\"),\n-                                        while: e,\n-                                        with: e,\n-                                        else: t,\n-                                        do: t,\n-                                        try: t,\n-                                        finally: t,\n-                                        return: o,\n-                                        break: o,\n-                                        continue: o,\n-                                        new: r(\"new\"),\n-                                        delete: a,\n-                                        void: a,\n-                                        throw: a,\n-                                        debugger: r(\"debugger\"),\n-                                        var: r(\"var\"),\n-                                        const: r(\"var\"),\n-                                        let: r(\"var\"),\n-                                        function: r(\"function\"),\n-                                        catch: r(\"catch\"),\n-                                        for: r(\"for\"),\n-                                        switch: r(\"switch\"),\n-                                        case: r(\"case\"),\n-                                        default: r(\"default\"),\n-                                        in: d,\n-                                        typeof: d,\n-                                        instanceof: d,\n-                                        true: p,\n-                                        false: p,\n-                                        null: p,\n-                                        undefined: p,\n-                                        NaN: p,\n-                                        Infinity: p,\n-                                        this: r(\"this\"),\n-                                        class: r(\"class\"),\n-                                        super: r(\"atom\"),\n-                                        yield: a,\n-                                        export: r(\"export\"),\n-                                        import: r(\"import\"),\n-                                        extends: a,\n-                                        await: a\n-                                    };\n-                                }(),\n-                                jr = /[+\\-*&%=<>!?|~^@]/,\n-                                Lr = /^@(context|id|value|language|type|container|list|set|reverse|index|base|vocab|graph)\"/;\n-\n-                            function Qr(r) {\n-                                for (var e = !1, t, a = !1;\n-                                    (t = r.next()) != null;) {\n-                                    if (!e) {\n-                                        if (t == \"/\" && !a) return;\n-                                        t == \"[\" ? a = !0 : a && t == \"]\" && (a = !1);\n-                                    }\n-                                    e = !e && t == \"\\\\\";\n-                                }\n-                            }\n-                            f(Qr, \"readRegexp\");\n-                            var K, nr;\n-\n-                            function x(r, e, t) {\n-                                return K = r, nr = t, e;\n-                            }\n-                            f(x, \"ret\");\n-\n-                            function $(r, e) {\n-                                var t = r.next();\n-                                if (t == '\"' || t == \"'\") return e.tokenize = Rr(t), e.tokenize(r, e);\n-                                if (t == \".\" && r.match(/^\\d[\\d_]*(?:[eE][+\\-]?[\\d_]+)?/)) return x(\"number\", \"number\");\n-                                if (t == \".\" && r.match(\"..\")) return x(\"spread\", \"meta\");\n-                                if (/[\\[\\]{}\\(\\),;\\:\\.]/.test(t)) return x(t);\n-                                if (t == \"=\" && r.eat(\">\")) return x(\"=>\", \"operator\");\n-                                if (t == \"0\" && r.match(/^(?:x[\\dA-Fa-f_]+|o[0-7_]+|b[01_]+)n?/)) return x(\"number\", \"number\");\n-                                if (/\\d/.test(t)) return r.match(/^[\\d_]*(?:n|(?:\\.[\\d_]*)?(?:[eE][+\\-]?[\\d_]+)?)?/), x(\"number\", \"number\");\n-                                if (t == \"/\") return r.eat(\"*\") ? (e.tokenize = tr, tr(r, e)) : r.eat(\"/\") ? (r.skipToEnd(), x(\"comment\", \"comment\")) : Fr(r, e, 1) ? (Qr(r), r.match(/^\\b(([gimyus])(?![gimyus]*\\2))+\\b/), x(\"regexp\", \"string-2\")) : (r.eat(\"=\"), x(\"operator\", \"operator\", r.current()));\n-                                if (t == \"`\") return e.tokenize = H, H(r, e);\n-                                if (t == \"#\" && r.peek() == \"!\") return r.skipToEnd(), x(\"meta\", \"meta\");\n-                                if (t == \"#\" && r.eatWhile(er)) return x(\"variable\", \"property\");\n-                                if (t == \"<\" && r.match(\"!--\") || t == \"-\" && r.match(\"->\") && !/\\S/.test(r.string.slice(0, r.start))) return r.skipToEnd(), x(\"comment\", \"comment\");\n-                                if (jr.test(t)) return (t != \">\" || !e.lexical || e.lexical.type != \">\") && (r.eat(\"=\") ? (t == \"!\" || t == \"=\") && r.eat(\"=\") : /[<>*+\\-|&?]/.test(t) && (r.eat(t), t == \">\" && r.eat(t))), t == \"?\" && r.eat(\".\") ? x(\".\") : x(\"operator\", \"operator\", r.current());\n-                                if (er.test(t)) {\n-                                    r.eatWhile(er);\n-                                    var a = r.current();\n-                                    if (e.lastType != \".\") {\n-                                        if (yr.propertyIsEnumerable(a)) {\n-                                            var o = yr[a];\n-                                            return x(o.type, o.style, a);\n-                                        }\n-                                        if (a == \"async\" && r.match(/^(\\s|\\/\\*([^*]|\\*(?!\\/))*?\\*\\/)*[\\[\\(\\w]/, !1)) return x(\"async\", \"keyword\", a);\n-                                    }\n-                                    return x(\"variable\", \"variable\", a);\n-                                }\n-                            }\n-                            f($, \"tokenBase\");\n \n-                            function Rr(r) {\n-                                return function(e, t) {\n-                                    var a = !1,\n-                                        o;\n-                                    if (rr && e.peek() == \"@\" && e.match(Lr)) return t.tokenize = $, x(\"jsonld-keyword\", \"meta\");\n-                                    for (;\n-                                        (o = e.next()) != null && !(o == r && !a);) a = !a && o == \"\\\\\";\n-                                    return a || (t.tokenize = $), x(\"string\", \"string\");\n-                                };\n-                            }\n-                            f(Rr, \"tokenString\");\n+                function injectStyles(tag, css) {\n+                    // @ts-ignore\n+                    if (tag.styleSheet) {\n+                        // @ts-ignore\n+                        tag.styleSheet.cssText = css;\n+                    } else {\n+                        tag.appendChild(document.createTextNode(css));\n+                    }\n+                }\n \n-                            function tr(r, e) {\n-                                for (var t = !1, a; a = r.next();) {\n-                                    if (a == \"/\" && t) {\n-                                        e.tokenize = $;\n-                                        break;\n-                                    }\n-                                    t = a == \"*\";\n+                function insertStyleTag(tag) {\n+                    var head = document.head || document.getElementsByTagName('head')[0];\n+                    head.appendChild(tag);\n+                }\n+                var stylesheetSingleton = function() {\n+                    var counter = 0;\n+                    var stylesheet = null;\n+                    return {\n+                        add: function(style) {\n+                            if (counter == 0) {\n+                                if (stylesheet = makeStyleTag()) {\n+                                    injectStyles(stylesheet, style);\n+                                    insertStyleTag(stylesheet);\n                                 }\n-                                return x(\"comment\", \"comment\");\n                             }\n-                            f(tr, \"tokenComment\");\n-\n-                            function H(r, e) {\n-                                for (var t = !1, a;\n-                                    (a = r.next()) != null;) {\n-                                    if (!t && (a == \"`\" || a == \"$\" && r.eat(\"{\"))) {\n-                                        e.tokenize = $;\n-                                        break;\n-                                    }\n-                                    t = !t && a == \"\\\\\";\n-                                }\n-                                return x(\"quasi\", \"string-2\", r.current());\n+                            counter++;\n+                        },\n+                        remove: function() {\n+                            counter--;\n+                            if (!counter && stylesheet) {\n+                                stylesheet.parentNode && stylesheet.parentNode.removeChild(stylesheet);\n+                                stylesheet = null;\n                             }\n-                            f(H, \"tokenQuasi\");\n-                            var Ur = \"([{}])\";\n+                        }\n+                    };\n+                };\n+                exports.stylesheetSingleton = stylesheetSingleton;\n \n-                            function dr(r, e) {\n-                                e.fatArrowAt && (e.fatArrowAt = null);\n-                                var t = r.string.indexOf(\"=>\", r.start);\n-                                if (!(t < 0)) {\n-                                    if (k) {\n-                                        var a = /:\\s*(?:\\w+(?:<[^>]*>|\\[\\])?|\\{[^}]*\\})\\s*$/.exec(r.string.slice(r.start, t));\n-                                        a && (t = a.index);\n-                                    }\n-                                    for (var o = 0, d = !1, p = t - 1; p >= 0; --p) {\n-                                        var y = r.string.charAt(p),\n-                                            V = Ur.indexOf(y);\n-                                        if (V >= 0 && V < 3) {\n-                                            if (!o) {\n-                                                ++p;\n-                                                break;\n-                                            }\n-                                            if (--o == 0) {\n-                                                y == \"(\" && (d = !0);\n-                                                break;\n-                                            }\n-                                        } else if (V >= 3 && V < 6) ++o;\n-                                        else if (er.test(y)) d = !0;\n-                                        else if (/[\"'\\/`]/.test(y))\n-                                            for (;; --p) {\n-                                                if (p == 0) return;\n-                                                var he = r.string.charAt(p - 1);\n-                                                if (he == y && r.string.charAt(p - 2) != \"\\\\\") {\n-                                                    p--;\n-                                                    break;\n-                                                }\n-                                            } else if (d && !o) {\n-                                                ++p;\n-                                                break;\n-                                            }\n-                                    }\n-                                    d && !o && (e.fatArrowAt = p);\n-                                }\n-                            }\n-                            f(dr, \"findFatArrow\");\n-                            var Wr = {\n-                                atom: !0,\n-                                number: !0,\n-                                variable: !0,\n-                                string: !0,\n-                                regexp: !0,\n-                                this: !0,\n-                                import: !0,\n-                                \"jsonld-keyword\": !0\n-                            };\n+                /***/\n+            }),\n \n-                            function Er(r, e, t, a, o, d) {\n-                                this.indented = r, this.column = e, this.type = t, this.prev = o, this.info = d, a != null && (this.align = a);\n-                            }\n-                            f(Er, \"JSLexical\");\n+        /***/\n+        \"../../../node_modules/react/cjs/react-jsx-runtime.development.js\":\n+            /*!************************************************************************!*\\\n+              !*** ../../../node_modules/react/cjs/react-jsx-runtime.development.js ***!\n+              \\************************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                            function Kr(r, e) {\n-                                if (!gr) return !1;\n-                                for (var t = r.localVars; t; t = t.next)\n-                                    if (t.name == e) return !0;\n-                                for (var a = r.context; a; a = a.prev)\n-                                    for (var t = a.vars; t; t = t.next)\n-                                        if (t.name == e) return !0;\n-                            }\n-                            f(Kr, \"inScope\");\n+                \"use strict\";\n+                /**\n+                 * @license React\n+                 * react-jsx-runtime.development.js\n+                 *\n+                 * Copyright (c) Facebook, Inc. and its affiliates.\n+                 *\n+                 * This source code is licensed under the MIT license found in the\n+                 * LICENSE file in the root directory of this source tree.\n+                 */\n \n-                            function Tr(r, e, t, a, o) {\n-                                var d = r.cc;\n-                                for (i.state = r, i.stream = o, i.marked = null, i.cc = d, i.style = e, r.lexical.hasOwnProperty(\"align\") || (r.lexical.align = !0);;) {\n-                                    var p = d.length ? d.pop() : O ? b : v;\n-                                    if (p(t, a)) {\n-                                        for (; d.length && d[d.length - 1].lex;) d.pop()();\n-                                        return i.marked ? i.marked : t == \"variable\" && Kr(r, a) ? \"variable-2\" : e;\n-                                    }\n-                                }\n-                            }\n-                            f(Tr, \"parseJS\");\n-                            var i = {\n-                                state: null,\n-                                column: null,\n-                                marked: null,\n-                                cc: null\n-                            };\n \n-                            function s() {\n-                                for (var r = arguments.length - 1; r >= 0; r--) i.cc.push(arguments[r]);\n-                            }\n-                            f(s, \"pass\");\n \n-                            function n() {\n-                                return s.apply(null, arguments), !0;\n-                            }\n-                            f(n, \"cont\");\n+                if (true) {\n+                    (function() {\n+                        'use strict';\n+\n+                        var React = __webpack_require__( /*! react */ \"react\");\n+\n+                        // ATTENTION\n+                        // When adding new symbols to this file,\n+                        // Please consider also adding to 'react-devtools-shared/src/backend/ReactSymbols'\n+                        // The Symbol used to tag the ReactElement-like types.\n+                        var REACT_ELEMENT_TYPE = Symbol.for('react.element');\n+                        var REACT_PORTAL_TYPE = Symbol.for('react.portal');\n+                        var REACT_FRAGMENT_TYPE = Symbol.for('react.fragment');\n+                        var REACT_STRICT_MODE_TYPE = Symbol.for('react.strict_mode');\n+                        var REACT_PROFILER_TYPE = Symbol.for('react.profiler');\n+                        var REACT_PROVIDER_TYPE = Symbol.for('react.provider');\n+                        var REACT_CONTEXT_TYPE = Symbol.for('react.context');\n+                        var REACT_FORWARD_REF_TYPE = Symbol.for('react.forward_ref');\n+                        var REACT_SUSPENSE_TYPE = Symbol.for('react.suspense');\n+                        var REACT_SUSPENSE_LIST_TYPE = Symbol.for('react.suspense_list');\n+                        var REACT_MEMO_TYPE = Symbol.for('react.memo');\n+                        var REACT_LAZY_TYPE = Symbol.for('react.lazy');\n+                        var REACT_OFFSCREEN_TYPE = Symbol.for('react.offscreen');\n+                        var MAYBE_ITERATOR_SYMBOL = Symbol.iterator;\n+                        var FAUX_ITERATOR_SYMBOL = '@@iterator';\n \n-                            function mr(r, e) {\n-                                for (var t = e; t; t = t.next)\n-                                    if (t.name == r) return !0;\n-                                return !1;\n+                        function getIteratorFn(maybeIterable) {\n+                            if (maybeIterable === null || typeof maybeIterable !== 'object') {\n+                                return null;\n                             }\n-                            f(mr, \"inList\");\n+                            var maybeIterator = MAYBE_ITERATOR_SYMBOL && maybeIterable[MAYBE_ITERATOR_SYMBOL] || maybeIterable[FAUX_ITERATOR_SYMBOL];\n+                            if (typeof maybeIterator === 'function') {\n+                                return maybeIterator;\n+                            }\n+                            return null;\n+                        }\n+                        var ReactSharedInternals = React.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;\n \n-                            function D(r) {\n-                                var e = i.state;\n-                                if (i.marked = \"def\", !!gr) {\n-                                    if (e.context) {\n-                                        if (e.lexical.info == \"var\" && e.context && e.context.block) {\n-                                            var t = Ar(r, e.context);\n-                                            if (t != null) {\n-                                                e.context = t;\n-                                                return;\n-                                            }\n-                                        } else if (!mr(r, e.localVars)) {\n-                                            e.localVars = new X(r, e.localVars);\n-                                            return;\n-                                        }\n+                        function error(format) {\n+                            {\n+                                {\n+                                    for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {\n+                                        args[_key2 - 1] = arguments[_key2];\n                                     }\n-                                    h.globalVars && !mr(r, e.globalVars) && (e.globalVars = new X(r, e.globalVars));\n+                                    printWarning('error', format, args);\n                                 }\n                             }\n-                            f(D, \"register\");\n+                        }\n \n-                            function Ar(r, e) {\n-                                if (e) {\n-                                    if (e.block) {\n-                                        var t = Ar(r, e.prev);\n-                                        return t ? t == e.prev ? e : new G(t, e.vars, !0) : null;\n-                                    } else return mr(r, e.vars) ? e : new G(e.prev, new X(r, e.vars), !1);\n-                                } else return null;\n-                            }\n-                            f(Ar, \"registerVarScoped\");\n+                        function printWarning(level, format, args) {\n+                            // When changing this logic, you might want to also\n+                            // update consoleWithStackDev.www.js as well.\n+                            {\n+                                var ReactDebugCurrentFrame = ReactSharedInternals.ReactDebugCurrentFrame;\n+                                var stack = ReactDebugCurrentFrame.getStackAddendum();\n+                                if (stack !== '') {\n+                                    format += '%s';\n+                                    args = args.concat([stack]);\n+                                } // eslint-disable-next-line react-internal/safe-string-coercion\n \n-                            function ir(r) {\n-                                return r == \"public\" || r == \"private\" || r == \"protected\" || r == \"abstract\" || r == \"readonly\";\n-                            }\n-                            f(ir, \"isModifier\");\n+                                var argsWithFormat = args.map(function(item) {\n+                                    return String(item);\n+                                }); // Careful: RN currently depends on this prefix\n \n-                            function G(r, e, t) {\n-                                this.prev = r, this.vars = e, this.block = t;\n-                            }\n-                            f(G, \"Context\");\n+                                argsWithFormat.unshift('Warning: ' + format); // We intentionally don't use spread (or .apply) directly because it\n+                                // breaks IE9: https://github.com/facebook/react/issues/13610\n+                                // eslint-disable-next-line react-internal/no-production-logging\n \n-                            function X(r, e) {\n-                                this.name = r, this.next = e;\n+                                Function.prototype.apply.call(console[level], console, argsWithFormat);\n                             }\n-                            f(X, \"Var\");\n-                            var Hr = new X(\"this\", new X(\"arguments\", null));\n+                        }\n \n-                            function q() {\n-                                i.state.context = new G(i.state.context, i.state.localVars, !1), i.state.localVars = Hr;\n-                            }\n-                            f(q, \"pushcontext\");\n+                        // -----------------------------------------------------------------------------\n \n-                            function fr() {\n-                                i.state.context = new G(i.state.context, i.state.localVars, !0), i.state.localVars = null;\n-                            }\n-                            f(fr, \"pushblockcontext\"), q.lex = fr.lex = !0;\n+                        var enableScopeAPI = false; // Experimental Create Event Handle API.\n+                        var enableCacheElement = false;\n+                        var enableTransitionTracing = false; // No known bugs, but needs performance testing\n \n-                            function E() {\n-                                i.state.localVars = i.state.context.vars, i.state.context = i.state.context.prev;\n-                            }\n-                            f(E, \"popcontext\"), E.lex = !0;\n+                        var enableLegacyHidden = false; // Enables unstable_avoidThisFallback feature in Fiber\n+                        // stuff. Intended to enable React core members to more easily debug scheduling\n+                        // issues in DEV builds.\n \n-                            function c(r, e) {\n-                                var t = f(function() {\n-                                    var a = i.state,\n-                                        o = a.indented;\n-                                    if (a.lexical.type == \"stat\") o = a.lexical.indented;\n-                                    else\n-                                        for (var d = a.lexical; d && d.type == \")\" && d.align; d = d.prev) o = d.indented;\n-                                    a.lexical = new Er(o, i.stream.column(), r, null, a.lexical, e);\n-                                }, \"result\");\n-                                return t.lex = !0, t;\n-                            }\n-                            f(c, \"pushlex\");\n+                        var enableDebugTracing = false; // Track which Fiber(s) schedule render work.\n \n-                            function u() {\n-                                var r = i.state;\n-                                r.lexical.prev && (r.lexical.type == \")\" && (r.indented = r.lexical.indented), r.lexical = r.lexical.prev);\n-                            }\n-                            f(u, \"poplex\"), u.lex = !0;\n+                        var REACT_MODULE_REFERENCE;\n+                        {\n+                            REACT_MODULE_REFERENCE = Symbol.for('react.module.reference');\n+                        }\n+\n+                        function isValidElementType(type) {\n+                            if (typeof type === 'string' || typeof type === 'function') {\n+                                return true;\n+                            } // Note: typeof might be other than 'symbol' or 'number' (e.g. if it's a polyfill).\n \n-                            function l(r) {\n-                                function e(t) {\n-                                    return t == r ? n() : r == \";\" || t == \"}\" || t == \")\" || t == \"]\" ? s() : n(e);\n+                            if (type === REACT_FRAGMENT_TYPE || type === REACT_PROFILER_TYPE || enableDebugTracing || type === REACT_STRICT_MODE_TYPE || type === REACT_SUSPENSE_TYPE || type === REACT_SUSPENSE_LIST_TYPE || enableLegacyHidden || type === REACT_OFFSCREEN_TYPE || enableScopeAPI || enableCacheElement || enableTransitionTracing) {\n+                                return true;\n+                            }\n+                            if (typeof type === 'object' && type !== null) {\n+                                if (type.$$typeof === REACT_LAZY_TYPE || type.$$typeof === REACT_MEMO_TYPE || type.$$typeof === REACT_PROVIDER_TYPE || type.$$typeof === REACT_CONTEXT_TYPE || type.$$typeof === REACT_FORWARD_REF_TYPE ||\n+                                    // This needs to include all possible module reference object\n+                                    // types supported by any Flight configuration anywhere since\n+                                    // we don't know which Flight build this will end up being used\n+                                    // with.\n+                                    type.$$typeof === REACT_MODULE_REFERENCE || type.getModuleId !== undefined) {\n+                                    return true;\n                                 }\n-                                return f(e, \"exp\"), e;\n                             }\n-                            f(l, \"expect\");\n+                            return false;\n+                        }\n \n-                            function v(r, e) {\n-                                return r == \"var\" ? n(c(\"vardef\", e), xr, l(\";\"), u) : r == \"keyword a\" ? n(c(\"form\"), pr, v, u) : r == \"keyword b\" ? n(c(\"form\"), v, u) : r == \"keyword d\" ? i.stream.match(/^\\s*$/, !1) ? n() : n(c(\"stat\"), J, l(\";\"), u) : r == \"debugger\" ? n(l(\";\")) : r == \"{\" ? n(c(\"}\"), fr, or, u, E) : r == \";\" ? n() : r == \"if\" ? (i.state.lexical.info == \"else\" && i.state.cc[i.state.cc.length - 1] == u && i.state.cc.pop()(), n(c(\"form\"), pr, v, u, Mr)) : r == \"function\" ? n(z) : r == \"for\" ? n(c(\"form\"), fr, Or, v, E, u) : r == \"class\" || k && e == \"interface\" ? (i.marked = \"keyword\", n(c(\"form\", r == \"class\" ? r : e), qr, u)) : r == \"variable\" ? k && e == \"declare\" ? (i.marked = \"keyword\", n(v)) : k && (e == \"module\" || e == \"enum\" || e == \"type\") && i.stream.match(/^\\s*\\w/, !1) ? (i.marked = \"keyword\", e == \"enum\" ? n(Pr) : e == \"type\" ? n($r, l(\"operator\"), m, l(\";\")) : n(c(\"form\"), T, l(\"{\"), c(\"}\"), or, u, u)) : k && e == \"namespace\" ? (i.marked = \"keyword\", n(c(\"form\"), b, v, u)) : k && e == \"abstract\" ? (i.marked = \"keyword\", n(v)) : n(c(\"stat\"), re) : r == \"switch\" ? n(c(\"form\"), pr, l(\"{\"), c(\"}\", \"switch\"), fr, or, u, u, E) : r == \"case\" ? n(b, l(\":\")) : r == \"default\" ? n(l(\":\")) : r == \"catch\" ? n(c(\"form\"), q, Gr, v, u, E) : r == \"export\" ? n(c(\"stat\"), me, u) : r == \"import\" ? n(c(\"stat\"), pe, u) : r == \"async\" ? n(v) : e == \"@\" ? n(b, v) : s(c(\"stat\"), b, l(\";\"), u);\n+                        function getWrappedName(outerType, innerType, wrapperName) {\n+                            var displayName = outerType.displayName;\n+                            if (displayName) {\n+                                return displayName;\n                             }\n-                            f(v, \"statement\");\n+                            var functionName = innerType.displayName || innerType.name || '';\n+                            return functionName !== '' ? wrapperName + \"(\" + functionName + \")\" : wrapperName;\n+                        } // Keep in sync with react-reconciler/getComponentNameFromFiber\n \n-                            function Gr(r) {\n-                                if (r == \"(\") return n(P, l(\")\"));\n-                            }\n-                            f(Gr, \"maybeCatchBinding\");\n+                        function getContextName(type) {\n+                            return type.displayName || 'Context';\n+                        } // Note that the reconciler package should generally prefer to use getComponentNameFromFiber() instead.\n \n-                            function b(r, e) {\n-                                return Vr(r, e, !1);\n+                        function getComponentNameFromType(type) {\n+                            if (type == null) {\n+                                // Host root, text node or just invalid type.\n+                                return null;\n+                            } {\n+                                if (typeof type.tag === 'number') {\n+                                    error('Received an unexpected object in getComponentNameFromType(). ' + 'This is likely a bug in React. Please file an issue.');\n+                                }\n                             }\n-                            f(b, \"expression\");\n-\n-                            function j(r, e) {\n-                                return Vr(r, e, !0);\n+                            if (typeof type === 'function') {\n+                                return type.displayName || type.name || null;\n                             }\n-                            f(j, \"expressionNoComma\");\n-\n-                            function pr(r) {\n-                                return r != \"(\" ? s() : n(c(\")\"), J, l(\")\"), u);\n+                            if (typeof type === 'string') {\n+                                return type;\n+                            }\n+                            switch (type) {\n+                                case REACT_FRAGMENT_TYPE:\n+                                    return 'Fragment';\n+                                case REACT_PORTAL_TYPE:\n+                                    return 'Portal';\n+                                case REACT_PROFILER_TYPE:\n+                                    return 'Profiler';\n+                                case REACT_STRICT_MODE_TYPE:\n+                                    return 'StrictMode';\n+                                case REACT_SUSPENSE_TYPE:\n+                                    return 'Suspense';\n+                                case REACT_SUSPENSE_LIST_TYPE:\n+                                    return 'SuspenseList';\n                             }\n-                            f(pr, \"parenExpr\");\n+                            if (typeof type === 'object') {\n+                                switch (type.$$typeof) {\n+                                    case REACT_CONTEXT_TYPE:\n+                                        var context = type;\n+                                        return getContextName(context) + '.Consumer';\n+                                    case REACT_PROVIDER_TYPE:\n+                                        var provider = type;\n+                                        return getContextName(provider._context) + '.Provider';\n+                                    case REACT_FORWARD_REF_TYPE:\n+                                        return getWrappedName(type, type.render, 'ForwardRef');\n+                                    case REACT_MEMO_TYPE:\n+                                        var outerName = type.displayName || null;\n+                                        if (outerName !== null) {\n+                                            return outerName;\n+                                        }\n+                                        return getComponentNameFromType(type.type) || 'Memo';\n+                                    case REACT_LAZY_TYPE: {\n+                                        var lazyComponent = type;\n+                                        var payload = lazyComponent._payload;\n+                                        var init = lazyComponent._init;\n+                                        try {\n+                                            return getComponentNameFromType(init(payload));\n+                                        } catch (x) {\n+                                            return null;\n+                                        }\n+                                    }\n \n-                            function Vr(r, e, t) {\n-                                if (i.state.fatArrowAt == i.stream.start) {\n-                                    var a = t ? Sr : Ir;\n-                                    if (r == \"(\") return n(q, c(\")\"), g(P, \")\"), u, l(\"=>\"), a, E);\n-                                    if (r == \"variable\") return s(q, T, l(\"=>\"), a, E);\n+                                    // eslint-disable-next-line no-fallthrough\n                                 }\n-                                var o = t ? L : N;\n-                                return Wr.hasOwnProperty(r) ? n(o) : r == \"function\" ? n(z, o) : r == \"class\" || k && e == \"interface\" ? (i.marked = \"keyword\", n(c(\"form\"), de, u)) : r == \"keyword c\" || r == \"async\" ? n(t ? j : b) : r == \"(\" ? n(c(\")\"), J, l(\")\"), u, o) : r == \"operator\" || r == \"spread\" ? n(t ? j : b) : r == \"[\" ? n(c(\"]\"), be, u, o) : r == \"{\" ? Y(ur, \"}\", null, o) : r == \"quasi\" ? s(ar, o) : r == \"new\" ? n(Yr(t)) : n();\n                             }\n-                            f(Vr, \"expressionInner\");\n+                            return null;\n+                        }\n+                        var assign = Object.assign;\n \n-                            function J(r) {\n-                                return r.match(/[;\\}\\)\\],]/) ? s() : s(b);\n-                            }\n-                            f(J, \"maybeexpression\");\n+                        // Helpers to patch console.logs to avoid logging during side-effect free\n+                        // replaying on render function. This currently only patches the object\n+                        // lazily which won't cover if the log function was extracted eagerly.\n+                        // We could also eagerly patch the method.\n+                        var disabledDepth = 0;\n+                        var prevLog;\n+                        var prevInfo;\n+                        var prevWarn;\n+                        var prevError;\n+                        var prevGroup;\n+                        var prevGroupCollapsed;\n+                        var prevGroupEnd;\n \n-                            function N(r, e) {\n-                                return r == \",\" ? n(J) : L(r, e, !1);\n-                            }\n-                            f(N, \"maybeoperatorComma\");\n+                        function disabledLog() {}\n+                        disabledLog.__reactDisabledLog = true;\n \n-                            function L(r, e, t) {\n-                                var a = t == !1 ? N : L,\n-                                    o = t == !1 ? b : j;\n-                                if (r == \"=>\") return n(q, t ? Sr : Ir, E);\n-                                if (r == \"operator\") return /\\+\\+|--/.test(e) || k && e == \"!\" ? n(a) : k && e == \"<\" && i.stream.match(/^([^<>]|<[^<>]*>)*>\\s*\\(/, !1) ? n(c(\">\"), g(m, \">\"), u, a) : e == \"?\" ? n(b, l(\":\"), o) : n(o);\n-                                if (r == \"quasi\") return s(ar, a);\n-                                if (r != \";\") {\n-                                    if (r == \"(\") return Y(j, \")\", \"call\", a);\n-                                    if (r == \".\") return n(ee, a);\n-                                    if (r == \"[\") return n(c(\"]\"), J, l(\"]\"), u, a);\n-                                    if (k && e == \"as\") return i.marked = \"keyword\", n(m, a);\n-                                    if (r == \"regexp\") return i.state.lastType = i.marked = \"operator\", i.stream.backUp(i.stream.pos - i.stream.start - 1), n(o);\n-                                }\n-                            }\n-                            f(L, \"maybeoperatorNoComma\");\n+                        function disableLogs() {\n+                            {\n+                                if (disabledDepth === 0) {\n+                                    /* eslint-disable react-internal/no-production-logging */\n+                                    prevLog = console.log;\n+                                    prevInfo = console.info;\n+                                    prevWarn = console.warn;\n+                                    prevError = console.error;\n+                                    prevGroup = console.group;\n+                                    prevGroupCollapsed = console.groupCollapsed;\n+                                    prevGroupEnd = console.groupEnd; // https://github.com/facebook/react/issues/19099\n \n-                            function ar(r, e) {\n-                                return r != \"quasi\" ? s() : e.slice(e.length - 2) != \"${\" ? n(ar) : n(J, Xr);\n-                            }\n-                            f(ar, \"quasi\");\n+                                    var props = {\n+                                        configurable: true,\n+                                        enumerable: true,\n+                                        value: disabledLog,\n+                                        writable: true\n+                                    }; // $FlowFixMe Flow thinks console is immutable.\n \n-                            function Xr(r) {\n-                                if (r == \"}\") return i.marked = \"string-2\", i.state.tokenize = H, n(ar);\n+                                    Object.defineProperties(console, {\n+                                        info: props,\n+                                        log: props,\n+                                        warn: props,\n+                                        error: props,\n+                                        group: props,\n+                                        groupCollapsed: props,\n+                                        groupEnd: props\n+                                    });\n+                                    /* eslint-enable react-internal/no-production-logging */\n+                                }\n+                                disabledDepth++;\n                             }\n-                            f(Xr, \"continueQuasi\");\n+                        }\n \n-                            function Ir(r) {\n-                                return dr(i.stream, i.state), s(r == \"{\" ? v : b);\n-                            }\n-                            f(Ir, \"arrowBody\");\n+                        function reenableLogs() {\n+                            {\n+                                disabledDepth--;\n+                                if (disabledDepth === 0) {\n+                                    /* eslint-disable react-internal/no-production-logging */\n+                                    var props = {\n+                                        configurable: true,\n+                                        enumerable: true,\n+                                        writable: true\n+                                    }; // $FlowFixMe Flow thinks console is immutable.\n \n-                            function Sr(r) {\n-                                return dr(i.stream, i.state), s(r == \"{\" ? v : j);\n+                                    Object.defineProperties(console, {\n+                                        log: assign({}, props, {\n+                                            value: prevLog\n+                                        }),\n+                                        info: assign({}, props, {\n+                                            value: prevInfo\n+                                        }),\n+                                        warn: assign({}, props, {\n+                                            value: prevWarn\n+                                        }),\n+                                        error: assign({}, props, {\n+                                            value: prevError\n+                                        }),\n+                                        group: assign({}, props, {\n+                                            value: prevGroup\n+                                        }),\n+                                        groupCollapsed: assign({}, props, {\n+                                            value: prevGroupCollapsed\n+                                        }),\n+                                        groupEnd: assign({}, props, {\n+                                            value: prevGroupEnd\n+                                        })\n+                                    });\n+                                    /* eslint-enable react-internal/no-production-logging */\n+                                }\n+                                if (disabledDepth < 0) {\n+                                    error('disabledDepth fell below zero. ' + 'This is a bug in React. Please file an issue.');\n+                                }\n                             }\n-                            f(Sr, \"arrowBodyNoComma\");\n+                        }\n+                        var ReactCurrentDispatcher = ReactSharedInternals.ReactCurrentDispatcher;\n+                        var prefix;\n \n-                            function Yr(r) {\n-                                return function(e) {\n-                                    return e == \".\" ? n(r ? Cr : Zr) : e == \"variable\" && k ? n(ue, r ? L : N) : s(r ? j : b);\n-                                };\n-                            }\n-                            f(Yr, \"maybeTarget\");\n+                        function describeBuiltInComponentFrame(name, source, ownerFn) {\n+                            {\n+                                if (prefix === undefined) {\n+                                    // Extract the VM specific prefix used by each line.\n+                                    try {\n+                                        throw Error();\n+                                    } catch (x) {\n+                                        var match = x.stack.trim().match(/\\n( *(at )?)/);\n+                                        prefix = match && match[1] || '';\n+                                    }\n+                                } // We use the prefix to ensure our stacks line up with native stack frames.\n \n-                            function Zr(r, e) {\n-                                if (e == \"target\") return i.marked = \"keyword\", n(N);\n+                                return '\\n' + prefix + name;\n                             }\n-                            f(Zr, \"target\");\n+                        }\n+                        var reentry = false;\n+                        var componentFrameCache;\n+                        {\n+                            var PossiblyWeakMap = typeof WeakMap === 'function' ? WeakMap : Map;\n+                            componentFrameCache = new PossiblyWeakMap();\n+                        }\n \n-                            function Cr(r, e) {\n-                                if (e == \"target\") return i.marked = \"keyword\", n(L);\n+                        function describeNativeComponentFrame(fn, construct) {\n+                            // If something asked for a stack inside a fake render, it should get ignored.\n+                            if (!fn || reentry) {\n+                                return '';\n+                            } {\n+                                var frame = componentFrameCache.get(fn);\n+                                if (frame !== undefined) {\n+                                    return frame;\n+                                }\n                             }\n-                            f(Cr, \"targetNoComma\");\n+                            var control;\n+                            reentry = true;\n+                            var previousPrepareStackTrace = Error.prepareStackTrace; // $FlowFixMe It does accept undefined.\n \n-                            function re(r) {\n-                                return r == \":\" ? n(u, v) : s(N, l(\";\"), u);\n-                            }\n-                            f(re, \"maybelabel\");\n+                            Error.prepareStackTrace = undefined;\n+                            var previousDispatcher;\n+                            {\n+                                previousDispatcher = ReactCurrentDispatcher.current; // Set the dispatcher in DEV because this might be call in the render function\n+                                // for warnings.\n \n-                            function ee(r) {\n-                                if (r == \"variable\") return i.marked = \"property\", n();\n+                                ReactCurrentDispatcher.current = null;\n+                                disableLogs();\n                             }\n-                            f(ee, \"property\");\n+                            try {\n+                                // This should throw.\n+                                if (construct) {\n+                                    // Something should be setting the props in the constructor.\n+                                    var Fake = function() {\n+                                        throw Error();\n+                                    }; // $FlowFixMe\n \n-                            function ur(r, e) {\n-                                if (r == \"async\") return i.marked = \"property\", n(ur);\n-                                if (r == \"variable\" || i.style == \"keyword\") {\n-                                    if (i.marked = \"property\", e == \"get\" || e == \"set\") return n(ne);\n-                                    var t;\n-                                    return k && i.state.fatArrowAt == i.stream.start && (t = i.stream.match(/^\\s*:\\s*/, !1)) && (i.state.fatArrowAt = i.stream.pos + t[0].length), n(B);\n+                                    Object.defineProperty(Fake.prototype, 'props', {\n+                                        set: function() {\n+                                            // We use a throwing setter instead of frozen or non-writable props\n+                                            // because that won't throw in a non-strict mode function.\n+                                            throw Error();\n+                                        }\n+                                    });\n+                                    if (typeof Reflect === 'object' && Reflect.construct) {\n+                                        // We construct a different control for this case to include any extra\n+                                        // frames added by the construct call.\n+                                        try {\n+                                            Reflect.construct(Fake, []);\n+                                        } catch (x) {\n+                                            control = x;\n+                                        }\n+                                        Reflect.construct(fn, [], Fake);\n+                                    } else {\n+                                        try {\n+                                            Fake.call();\n+                                        } catch (x) {\n+                                            control = x;\n+                                        }\n+                                        fn.call(Fake.prototype);\n+                                    }\n                                 } else {\n-                                    if (r == \"number\" || r == \"string\") return i.marked = rr ? \"property\" : i.style + \" property\", n(B);\n-                                    if (r == \"jsonld-keyword\") return n(B);\n-                                    if (k && ir(e)) return i.marked = \"keyword\", n(ur);\n-                                    if (r == \"[\") return n(b, Q, l(\"]\"), B);\n-                                    if (r == \"spread\") return n(j, B);\n-                                    if (e == \"*\") return i.marked = \"keyword\", n(ur);\n-                                    if (r == \":\") return s(B);\n+                                    try {\n+                                        throw Error();\n+                                    } catch (x) {\n+                                        control = x;\n+                                    }\n+                                    fn();\n                                 }\n-                            }\n-                            f(ur, \"objprop\");\n+                            } catch (sample) {\n+                                // This is inlined manually because closure doesn't do it for us.\n+                                if (sample && control && typeof sample.stack === 'string') {\n+                                    // This extracts the first frame from the sample that isn't also in the control.\n+                                    // Skipping one frame that we assume is the frame that calls the two.\n+                                    var sampleLines = sample.stack.split('\\n');\n+                                    var controlLines = control.stack.split('\\n');\n+                                    var s = sampleLines.length - 1;\n+                                    var c = controlLines.length - 1;\n+                                    while (s >= 1 && c >= 0 && sampleLines[s] !== controlLines[c]) {\n+                                        // We expect at least one stack frame to be shared.\n+                                        // Typically this will be the root most one. However, stack frames may be\n+                                        // cut off due to maximum stack limits. In this case, one maybe cut off\n+                                        // earlier than the other. We assume that the sample is longer or the same\n+                                        // and there for cut off earlier. So we should find the root most frame in\n+                                        // the sample somewhere in the control.\n+                                        c--;\n+                                    }\n+                                    for (; s >= 1 && c >= 0; s--, c--) {\n+                                        // Next we find the first one that isn't the same which should be the\n+                                        // frame that called our sample function and the control.\n+                                        if (sampleLines[s] !== controlLines[c]) {\n+                                            // In V8, the first line is describing the message but other VMs don't.\n+                                            // If we're about to return the first line, and the control is also on the same\n+                                            // line, that's a pretty good indicator that our sample threw at same line as\n+                                            // the control. I.e. before we entered the sample frame. So we ignore this result.\n+                                            // This can happen if you passed a class to function component, or non-function.\n+                                            if (s !== 1 || c !== 1) {\n+                                                do {\n+                                                    s--;\n+                                                    c--; // We may still have similar intermediate frames from the construct call.\n+                                                    // The next one that isn't the same should be our match though.\n \n-                            function ne(r) {\n-                                return r != \"variable\" ? s(B) : (i.marked = \"property\", n(z));\n-                            }\n-                            f(ne, \"getterSetter\");\n+                                                    if (c < 0 || sampleLines[s] !== controlLines[c]) {\n+                                                        // V8 adds a \"new\" prefix for native classes. Let's remove it to make it prettier.\n+                                                        var _frame = '\\n' + sampleLines[s].replace(' at new ', ' at '); // If our component frame is labeled \"<anonymous>\"\n+                                                        // but we have a user-provided \"displayName\"\n+                                                        // splice it in to make the stack more readable.\n \n-                            function B(r) {\n-                                if (r == \":\") return n(j);\n-                                if (r == \"(\") return s(z);\n-                            }\n-                            f(B, \"afterprop\");\n+                                                        if (fn.displayName && _frame.includes('<anonymous>')) {\n+                                                            _frame = _frame.replace('<anonymous>', fn.displayName);\n+                                                        } {\n+                                                            if (typeof fn === 'function') {\n+                                                                componentFrameCache.set(fn, _frame);\n+                                                            }\n+                                                        } // Return the line we found.\n \n-                            function g(r, e, t) {\n-                                function a(o, d) {\n-                                    if (t ? t.indexOf(o) > -1 : o == \",\") {\n-                                        var p = i.state.lexical;\n-                                        return p.info == \"call\" && (p.pos = (p.pos || 0) + 1), n(function(y, V) {\n-                                            return y == e || V == e ? s() : s(r);\n-                                        }, a);\n+                                                        return _frame;\n+                                                    }\n+                                                } while (s >= 1 && c >= 0);\n+                                            }\n+                                            break;\n+                                        }\n                                     }\n-                                    return o == e || d == e ? n() : t && t.indexOf(\";\") > -1 ? s(r) : n(l(e));\n                                 }\n-                                return f(a, \"proceed\"),\n-                                    function(o, d) {\n-                                        return o == e || d == e ? n() : s(r, a);\n-                                    };\n-                            }\n-                            f(g, \"commasep\");\n+                            } finally {\n+                                reentry = false;\n+                                {\n+                                    ReactCurrentDispatcher.current = previousDispatcher;\n+                                    reenableLogs();\n+                                }\n+                                Error.prepareStackTrace = previousPrepareStackTrace;\n+                            } // Fallback to just using the name if we couldn't make it throw.\n \n-                            function Y(r, e, t) {\n-                                for (var a = 3; a < arguments.length; a++) i.cc.push(arguments[a]);\n-                                return n(c(e, t), g(r, e), u);\n+                            var name = fn ? fn.displayName || fn.name : '';\n+                            var syntheticFrame = name ? describeBuiltInComponentFrame(name) : '';\n+                            {\n+                                if (typeof fn === 'function') {\n+                                    componentFrameCache.set(fn, syntheticFrame);\n+                                }\n                             }\n-                            f(Y, \"contCommasep\");\n+                            return syntheticFrame;\n+                        }\n \n-                            function or(r) {\n-                                return r == \"}\" ? n() : s(v, or);\n+                        function describeFunctionComponentFrame(fn, source, ownerFn) {\n+                            {\n+                                return describeNativeComponentFrame(fn, false);\n                             }\n-                            f(or, \"block\");\n+                        }\n \n-                            function Q(r, e) {\n-                                if (k) {\n-                                    if (r == \":\") return n(m);\n-                                    if (e == \"?\") return n(Q);\n-                                }\n-                            }\n-                            f(Q, \"maybetype\");\n+                        function shouldConstruct(Component) {\n+                            var prototype = Component.prototype;\n+                            return !!(prototype && prototype.isReactComponent);\n+                        }\n \n-                            function te(r, e) {\n-                                if (k && (r == \":\" || e == \"in\")) return n(m);\n+                        function describeUnknownElementTypeFrameInDEV(type, source, ownerFn) {\n+                            if (type == null) {\n+                                return '';\n                             }\n-                            f(te, \"maybetypeOrIn\");\n-\n-                            function _r(r) {\n-                                if (k && r == \":\") return i.stream.match(/^\\s*\\w+\\s+is\\b/, !1) ? n(b, ie, m) : n(m);\n+                            if (typeof type === 'function') {\n+                                {\n+                                    return describeNativeComponentFrame(type, shouldConstruct(type));\n+                                }\n                             }\n-                            f(_r, \"mayberettype\");\n-\n-                            function ie(r, e) {\n-                                if (e == \"is\") return i.marked = \"keyword\", n();\n+                            if (typeof type === 'string') {\n+                                return describeBuiltInComponentFrame(type);\n                             }\n-                            f(ie, \"isKW\");\n-\n-                            function m(r, e) {\n-                                if (e == \"keyof\" || e == \"typeof\" || e == \"infer\" || e == \"readonly\") return i.marked = \"keyword\", n(e == \"typeof\" ? j : m);\n-                                if (r == \"variable\" || e == \"void\") return i.marked = \"type\", n(I);\n-                                if (e == \"|\" || e == \"&\") return n(m);\n-                                if (r == \"string\" || r == \"number\" || r == \"atom\") return n(I);\n-                                if (r == \"[\") return n(c(\"]\"), g(m, \"]\", \",\"), u, I);\n-                                if (r == \"{\") return n(c(\"}\"), kr, u, I);\n-                                if (r == \"(\") return n(g(wr, \")\"), fe, I);\n-                                if (r == \"<\") return n(g(m, \">\"), m);\n-                                if (r == \"quasi\") return s(br, I);\n+                            switch (type) {\n+                                case REACT_SUSPENSE_TYPE:\n+                                    return describeBuiltInComponentFrame('Suspense');\n+                                case REACT_SUSPENSE_LIST_TYPE:\n+                                    return describeBuiltInComponentFrame('SuspenseList');\n                             }\n-                            f(m, \"typeexpr\");\n-\n-                            function fe(r) {\n-                                if (r == \"=>\") return n(m);\n+                            if (typeof type === 'object') {\n+                                switch (type.$$typeof) {\n+                                    case REACT_FORWARD_REF_TYPE:\n+                                        return describeFunctionComponentFrame(type.render);\n+                                    case REACT_MEMO_TYPE:\n+                                        // Memo may contain any component type so we recursively resolve it.\n+                                        return describeUnknownElementTypeFrameInDEV(type.type, source, ownerFn);\n+                                    case REACT_LAZY_TYPE: {\n+                                        var lazyComponent = type;\n+                                        var payload = lazyComponent._payload;\n+                                        var init = lazyComponent._init;\n+                                        try {\n+                                            // Lazy may contain any component type so we recursively resolve it.\n+                                            return describeUnknownElementTypeFrameInDEV(init(payload), source, ownerFn);\n+                                        } catch (x) {}\n+                                    }\n+                                }\n                             }\n-                            f(fe, \"maybeReturnType\");\n+                            return '';\n+                        }\n+                        var hasOwnProperty = Object.prototype.hasOwnProperty;\n+                        var loggedTypeFailures = {};\n+                        var ReactDebugCurrentFrame = ReactSharedInternals.ReactDebugCurrentFrame;\n \n-                            function kr(r) {\n-                                return r.match(/[\\}\\)\\]]/) ? n() : r == \",\" || r == \";\" ? n(kr) : s(Z, kr);\n+                        function setCurrentlyValidatingElement(element) {\n+                            {\n+                                if (element) {\n+                                    var owner = element._owner;\n+                                    var stack = describeUnknownElementTypeFrameInDEV(element.type, element._source, owner ? owner.type : null);\n+                                    ReactDebugCurrentFrame.setExtraStackFrame(stack);\n+                                } else {\n+                                    ReactDebugCurrentFrame.setExtraStackFrame(null);\n+                                }\n                             }\n-                            f(kr, \"typeprops\");\n+                        }\n \n-                            function Z(r, e) {\n-                                if (r == \"variable\" || i.style == \"keyword\") return i.marked = \"property\", n(Z);\n-                                if (e == \"?\" || r == \"number\" || r == \"string\") return n(Z);\n-                                if (r == \":\") return n(m);\n-                                if (r == \"[\") return n(l(\"variable\"), te, l(\"]\"), Z);\n-                                if (r == \"(\") return s(U, Z);\n-                                if (!r.match(/[;\\}\\)\\],]/)) return n();\n-                            }\n-                            f(Z, \"typeprop\");\n+                        function checkPropTypes(typeSpecs, values, location, componentName, element) {\n+                            {\n+                                // $FlowFixMe This is okay but Flow doesn't know it.\n+                                var has = Function.call.bind(hasOwnProperty);\n+                                for (var typeSpecName in typeSpecs) {\n+                                    if (has(typeSpecs, typeSpecName)) {\n+                                        var error$1 = void 0; // Prop type validation may throw. In case they do, we don't want to\n+                                        // fail the render phase where it didn't fail before. So we log it.\n+                                        // After these have been cleaned up, we'll let them throw.\n \n-                            function br(r, e) {\n-                                return r != \"quasi\" ? s() : e.slice(e.length - 2) != \"${\" ? n(br) : n(m, ae);\n+                                        try {\n+                                            // This is intentionally an invariant that gets caught. It's the same\n+                                            // behavior as without this statement except with a better message.\n+                                            if (typeof typeSpecs[typeSpecName] !== 'function') {\n+                                                // eslint-disable-next-line react-internal/prod-error-codes\n+                                                var err = Error((componentName || 'React class') + ': ' + location + ' type `' + typeSpecName + '` is invalid; ' + 'it must be a function, usually from the `prop-types` package, but received `' + typeof typeSpecs[typeSpecName] + '`.' + 'This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.');\n+                                                err.name = 'Invariant Violation';\n+                                                throw err;\n+                                            }\n+                                            error$1 = typeSpecs[typeSpecName](values, typeSpecName, componentName, location, null, 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED');\n+                                        } catch (ex) {\n+                                            error$1 = ex;\n+                                        }\n+                                        if (error$1 && !(error$1 instanceof Error)) {\n+                                            setCurrentlyValidatingElement(element);\n+                                            error('%s: type specification of %s' + ' `%s` is invalid; the type checker ' + 'function must return `null` or an `Error` but returned a %s. ' + 'You may have forgotten to pass an argument to the type checker ' + 'creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and ' + 'shape all require an argument).', componentName || 'React class', location, typeSpecName, typeof error$1);\n+                                            setCurrentlyValidatingElement(null);\n+                                        }\n+                                        if (error$1 instanceof Error && !(error$1.message in loggedTypeFailures)) {\n+                                            // Only monitor this failure once because there tends to be a lot of the\n+                                            // same error.\n+                                            loggedTypeFailures[error$1.message] = true;\n+                                            setCurrentlyValidatingElement(element);\n+                                            error('Failed %s type: %s', location, error$1.message);\n+                                            setCurrentlyValidatingElement(null);\n+                                        }\n+                                    }\n+                                }\n                             }\n-                            f(br, \"quasiType\");\n+                        }\n+                        var isArrayImpl = Array.isArray; // eslint-disable-next-line no-redeclare\n \n-                            function ae(r) {\n-                                if (r == \"}\") return i.marked = \"string-2\", i.state.tokenize = H, n(br);\n-                            }\n-                            f(ae, \"continueQuasiType\");\n+                        function isArray(a) {\n+                            return isArrayImpl(a);\n+                        }\n \n-                            function wr(r, e) {\n-                                return r == \"variable\" && i.stream.match(/^\\s*[?:]/, !1) || e == \"?\" ? n(wr) : r == \":\" ? n(m) : r == \"spread\" ? n(wr) : s(m);\n+                        /*\n+                         * The `'' + value` pattern (used in in perf-sensitive code) throws for Symbol\n+                         * and Temporal.* types. See https://github.com/facebook/react/pull/22064.\n+                         *\n+                         * The functions in this module will throw an easier-to-understand,\n+                         * easier-to-debug exception with a clear errors message message explaining the\n+                         * problem. (Instead of a confusing exception thrown inside the implementation\n+                         * of the `value` object).\n+                         */\n+                        // $FlowFixMe only called in DEV, so void return is not possible.\n+                        function typeName(value) {\n+                            {\n+                                // toStringTag is needed for namespaced types like Temporal.Instant\n+                                var hasToStringTag = typeof Symbol === 'function' && Symbol.toStringTag;\n+                                var type = hasToStringTag && value[Symbol.toStringTag] || value.constructor.name || 'Object';\n+                                return type;\n                             }\n-                            f(wr, \"typearg\");\n+                        } // $FlowFixMe only called in DEV, so void return is not possible.\n \n-                            function I(r, e) {\n-                                if (e == \"<\") return n(c(\">\"), g(m, \">\"), u, I);\n-                                if (e == \"|\" || r == \".\" || e == \"&\") return n(m);\n-                                if (r == \"[\") return n(m, l(\"]\"), I);\n-                                if (e == \"extends\" || e == \"implements\") return i.marked = \"keyword\", n(m);\n-                                if (e == \"?\") return n(m, l(\":\"), m);\n+                        function willCoercionThrow(value) {\n+                            {\n+                                try {\n+                                    testStringCoercion(value);\n+                                    return false;\n+                                } catch (e) {\n+                                    return true;\n+                                }\n                             }\n-                            f(I, \"afterType\");\n+                        }\n \n-                            function ue(r, e) {\n-                                if (e == \"<\") return n(c(\">\"), g(m, \">\"), u, I);\n-                            }\n-                            f(ue, \"maybeTypeArgs\");\n+                        function testStringCoercion(value) {\n+                            // If you ended up here by following an exception call stack, here's what's\n+                            // happened: you supplied an object or symbol value to React (as a prop, key,\n+                            // DOM attribute, CSS property, string ref, etc.) and when React tried to\n+                            // coerce it to a string using `'' + value`, an exception was thrown.\n+                            //\n+                            // The most common types that will cause this exception are `Symbol` instances\n+                            // and Temporal objects like `Temporal.Instant`. But any object that has a\n+                            // `valueOf` or `[Symbol.toPrimitive]` method that throws will also cause this\n+                            // exception. (Library authors do this to prevent users from using built-in\n+                            // numeric operators like `+` or comparison operators like `>=` because custom\n+                            // methods are needed to perform accurate arithmetic or comparison.)\n+                            //\n+                            // To fix the problem, coerce this object or symbol value to a string before\n+                            // passing it to React. The most reliable way is usually `String(value)`.\n+                            //\n+                            // To find which value is throwing, check the browser or debugger console.\n+                            // Before this exception was thrown, there should be `console.error` output\n+                            // that shows the type (Symbol, Temporal.PlainDate, etc.) that caused the\n+                            // problem and how that type was used: key, atrribute, input value prop, etc.\n+                            // In most cases, this console output also shows the component and its\n+                            // ancestor components where the exception happened.\n+                            //\n+                            // eslint-disable-next-line react-internal/safe-string-coercion\n+                            return '' + value;\n+                        }\n \n-                            function sr() {\n-                                return s(m, oe);\n+                        function checkKeyStringCoercion(value) {\n+                            {\n+                                if (willCoercionThrow(value)) {\n+                                    error('The provided key is an unsupported type %s.' + ' This value must be coerced to a string before before using it here.', typeName(value));\n+                                    return testStringCoercion(value); // throw (to help callers find troubleshooting comments)\n+                                }\n                             }\n-                            f(sr, \"typeparam\");\n+                        }\n+                        var ReactCurrentOwner = ReactSharedInternals.ReactCurrentOwner;\n+                        var RESERVED_PROPS = {\n+                            key: true,\n+                            ref: true,\n+                            __self: true,\n+                            __source: true\n+                        };\n+                        var specialPropKeyWarningShown;\n+                        var specialPropRefWarningShown;\n+                        var didWarnAboutStringRefs;\n+                        {\n+                            didWarnAboutStringRefs = {};\n+                        }\n \n-                            function oe(r, e) {\n-                                if (e == \"=\") return n(m);\n+                        function hasValidRef(config) {\n+                            {\n+                                if (hasOwnProperty.call(config, 'ref')) {\n+                                    var getter = Object.getOwnPropertyDescriptor(config, 'ref').get;\n+                                    if (getter && getter.isReactWarning) {\n+                                        return false;\n+                                    }\n+                                }\n                             }\n-                            f(oe, \"maybeTypeDefault\");\n+                            return config.ref !== undefined;\n+                        }\n \n-                            function xr(r, e) {\n-                                return e == \"enum\" ? (i.marked = \"keyword\", n(Pr)) : s(T, Q, _, ce);\n+                        function hasValidKey(config) {\n+                            {\n+                                if (hasOwnProperty.call(config, 'key')) {\n+                                    var getter = Object.getOwnPropertyDescriptor(config, 'key').get;\n+                                    if (getter && getter.isReactWarning) {\n+                                        return false;\n+                                    }\n+                                }\n                             }\n-                            f(xr, \"vardef\");\n+                            return config.key !== undefined;\n+                        }\n \n-                            function T(r, e) {\n-                                if (k && ir(e)) return i.marked = \"keyword\", n(T);\n-                                if (r == \"variable\") return D(e), n();\n-                                if (r == \"spread\") return n(T);\n-                                if (r == \"[\") return Y(se, \"]\");\n-                                if (r == \"{\") return Y(zr, \"}\");\n+                        function warnIfStringRefCannotBeAutoConverted(config, self) {\n+                            {\n+                                if (typeof config.ref === 'string' && ReactCurrentOwner.current && self && ReactCurrentOwner.current.stateNode !== self) {\n+                                    var componentName = getComponentNameFromType(ReactCurrentOwner.current.type);\n+                                    if (!didWarnAboutStringRefs[componentName]) {\n+                                        error('Component \"%s\" contains the string ref \"%s\". ' + 'Support for string refs will be removed in a future major release. ' + 'This case cannot be automatically converted to an arrow function. ' + 'We ask you to manually fix this case by using useRef() or createRef() instead. ' + 'Learn more about using refs safely here: ' + 'https://reactjs.org/link/strict-mode-string-ref', getComponentNameFromType(ReactCurrentOwner.current.type), config.ref);\n+                                        didWarnAboutStringRefs[componentName] = true;\n+                                    }\n+                                }\n                             }\n-                            f(T, \"pattern\");\n+                        }\n \n-                            function zr(r, e) {\n-                                return r == \"variable\" && !i.stream.match(/^\\s*:/, !1) ? (D(e), n(_)) : (r == \"variable\" && (i.marked = \"property\"), r == \"spread\" ? n(T) : r == \"}\" ? s() : r == \"[\" ? n(b, l(\"]\"), l(\":\"), zr) : n(l(\":\"), T, _));\n+                        function defineKeyPropWarningGetter(props, displayName) {\n+                            {\n+                                var warnAboutAccessingKey = function() {\n+                                    if (!specialPropKeyWarningShown) {\n+                                        specialPropKeyWarningShown = true;\n+                                        error('%s: `key` is not a prop. Trying to access it will result ' + 'in `undefined` being returned. If you need to access the same ' + 'value within the child component, you should pass it as a different ' + 'prop. (https://reactjs.org/link/special-props)', displayName);\n+                                    }\n+                                };\n+                                warnAboutAccessingKey.isReactWarning = true;\n+                                Object.defineProperty(props, 'key', {\n+                                    get: warnAboutAccessingKey,\n+                                    configurable: true\n+                                });\n                             }\n-                            f(zr, \"proppattern\");\n+                        }\n \n-                            function se() {\n-                                return s(T, _);\n+                        function defineRefPropWarningGetter(props, displayName) {\n+                            {\n+                                var warnAboutAccessingRef = function() {\n+                                    if (!specialPropRefWarningShown) {\n+                                        specialPropRefWarningShown = true;\n+                                        error('%s: `ref` is not a prop. Trying to access it will result ' + 'in `undefined` being returned. If you need to access the same ' + 'value within the child component, you should pass it as a different ' + 'prop. (https://reactjs.org/link/special-props)', displayName);\n+                                    }\n+                                };\n+                                warnAboutAccessingRef.isReactWarning = true;\n+                                Object.defineProperty(props, 'ref', {\n+                                    get: warnAboutAccessingRef,\n+                                    configurable: true\n+                                });\n                             }\n-                            f(se, \"eltpattern\");\n+                        }\n+                        /**\n+                         * Factory method to create a new React element. This no longer adheres to\n+                         * the class pattern, so do not use new to call it. Also, instanceof check\n+                         * will not work. Instead test $$typeof field against Symbol.for('react.element') to check\n+                         * if something is a React Element.\n+                         *\n+                         * @param {*} type\n+                         * @param {*} props\n+                         * @param {*} key\n+                         * @param {string|object} ref\n+                         * @param {*} owner\n+                         * @param {*} self A *temporary* helper to detect places where `this` is\n+                         * different from the `owner` when React.createElement is called, so that we\n+                         * can warn. We want to get rid of owner and replace string `ref`s with arrow\n+                         * functions, and as long as `this` and owner are the same, there will be no\n+                         * change in behavior.\n+                         * @param {*} source An annotation object (added by a transpiler or otherwise)\n+                         * indicating filename, line number, and/or other information.\n+                         * @internal\n+                         */\n \n-                            function _(r, e) {\n-                                if (e == \"=\") return n(j);\n-                            }\n-                            f(_, \"maybeAssign\");\n+                        var ReactElement = function(type, key, ref, self, source, owner, props) {\n+                            var element = {\n+                                // This tag allows us to uniquely identify this as a React Element\n+                                $$typeof: REACT_ELEMENT_TYPE,\n+                                // Built-in properties that belong on the element\n+                                type: type,\n+                                key: key,\n+                                ref: ref,\n+                                props: props,\n+                                // Record the component responsible for creating this element.\n+                                _owner: owner\n+                            };\n+                            {\n+                                // The validation flag is currently mutative. We put it on\n+                                // an external backing store so that we can freeze the whole object.\n+                                // This can be replaced with a WeakMap once they are implemented in\n+                                // commonly used development environments.\n+                                element._store = {}; // To make comparing ReactElements easier for testing purposes, we make\n+                                // the validation flag non-enumerable (where possible, which should\n+                                // include every environment we run tests in), so the test framework\n+                                // ignores it.\n \n-                            function ce(r) {\n-                                if (r == \",\") return n(xr);\n-                            }\n-                            f(ce, \"vardefCont\");\n+                                Object.defineProperty(element._store, 'validated', {\n+                                    configurable: false,\n+                                    enumerable: false,\n+                                    writable: true,\n+                                    value: false\n+                                }); // self and source are DEV only properties.\n \n-                            function Mr(r, e) {\n-                                if (r == \"keyword b\" && e == \"else\") return n(c(\"form\", \"else\"), v, u);\n-                            }\n-                            f(Mr, \"maybeelse\");\n+                                Object.defineProperty(element, '_self', {\n+                                    configurable: false,\n+                                    enumerable: false,\n+                                    writable: false,\n+                                    value: self\n+                                }); // Two elements created in two different places should be considered\n+                                // equal for testing purposes and therefore we hide it from enumeration.\n \n-                            function Or(r, e) {\n-                                if (e == \"await\") return n(Or);\n-                                if (r == \"(\") return n(c(\")\"), le, u);\n+                                Object.defineProperty(element, '_source', {\n+                                    configurable: false,\n+                                    enumerable: false,\n+                                    writable: false,\n+                                    value: source\n+                                });\n+                                if (Object.freeze) {\n+                                    Object.freeze(element.props);\n+                                    Object.freeze(element);\n+                                }\n                             }\n-                            f(Or, \"forspec\");\n+                            return element;\n+                        };\n+                        /**\n+                         * https://github.com/reactjs/rfcs/pull/107\n+                         * @param {*} type\n+                         * @param {object} props\n+                         * @param {string} key\n+                         */\n \n-                            function le(r) {\n-                                return r == \"var\" ? n(xr, R) : r == \"variable\" ? n(R) : s(R);\n-                            }\n-                            f(le, \"forspec1\");\n+                        function jsxDEV(type, config, maybeKey, source, self) {\n+                            {\n+                                var propName; // Reserved names are extracted\n \n-                            function R(r, e) {\n-                                return r == \")\" ? n() : r == \";\" ? n(R) : e == \"in\" || e == \"of\" ? (i.marked = \"keyword\", n(b, R)) : s(b, R);\n-                            }\n-                            f(R, \"forspec2\");\n+                                var props = {};\n+                                var key = null;\n+                                var ref = null; // Currently, key can be spread in as a prop. This causes a potential\n+                                // issue if key is also explicitly declared (ie. <div {...props} key=\"Hi\" />\n+                                // or <div key=\"Hi\" {...props} /> ). We want to deprecate key spread,\n+                                // but as an intermediary step, we will use jsxDEV for everything except\n+                                // <div {...props} key=\"Hi\" />, because we aren't currently able to tell if\n+                                // key is explicitly declared to be undefined or not.\n \n-                            function z(r, e) {\n-                                if (e == \"*\") return i.marked = \"keyword\", n(z);\n-                                if (r == \"variable\") return D(e), n(z);\n-                                if (r == \"(\") return n(q, c(\")\"), g(P, \")\"), u, _r, v, E);\n-                                if (k && e == \"<\") return n(c(\">\"), g(sr, \">\"), u, z);\n-                            }\n-                            f(z, \"functiondef\");\n+                                if (maybeKey !== undefined) {\n+                                    {\n+                                        checkKeyStringCoercion(maybeKey);\n+                                    }\n+                                    key = '' + maybeKey;\n+                                }\n+                                if (hasValidKey(config)) {\n+                                    {\n+                                        checkKeyStringCoercion(config.key);\n+                                    }\n+                                    key = '' + config.key;\n+                                }\n+                                if (hasValidRef(config)) {\n+                                    ref = config.ref;\n+                                    warnIfStringRefCannotBeAutoConverted(config, self);\n+                                } // Remaining properties are added to a new props object\n \n-                            function U(r, e) {\n-                                if (e == \"*\") return i.marked = \"keyword\", n(U);\n-                                if (r == \"variable\") return D(e), n(U);\n-                                if (r == \"(\") return n(q, c(\")\"), g(P, \")\"), u, _r, E);\n-                                if (k && e == \"<\") return n(c(\">\"), g(sr, \">\"), u, U);\n-                            }\n-                            f(U, \"functiondecl\");\n+                                for (propName in config) {\n+                                    if (hasOwnProperty.call(config, propName) && !RESERVED_PROPS.hasOwnProperty(propName)) {\n+                                        props[propName] = config[propName];\n+                                    }\n+                                } // Resolve default props\n \n-                            function $r(r, e) {\n-                                if (r == \"keyword\" || r == \"variable\") return i.marked = \"type\", n($r);\n-                                if (e == \"<\") return n(c(\">\"), g(sr, \">\"), u);\n+                                if (type && type.defaultProps) {\n+                                    var defaultProps = type.defaultProps;\n+                                    for (propName in defaultProps) {\n+                                        if (props[propName] === undefined) {\n+                                            props[propName] = defaultProps[propName];\n+                                        }\n+                                    }\n+                                }\n+                                if (key || ref) {\n+                                    var displayName = typeof type === 'function' ? type.displayName || type.name || 'Unknown' : type;\n+                                    if (key) {\n+                                        defineKeyPropWarningGetter(props, displayName);\n+                                    }\n+                                    if (ref) {\n+                                        defineRefPropWarningGetter(props, displayName);\n+                                    }\n+                                }\n+                                return ReactElement(type, key, ref, self, source, ReactCurrentOwner.current, props);\n                             }\n-                            f($r, \"typename\");\n+                        }\n+                        var ReactCurrentOwner$1 = ReactSharedInternals.ReactCurrentOwner;\n+                        var ReactDebugCurrentFrame$1 = ReactSharedInternals.ReactDebugCurrentFrame;\n \n-                            function P(r, e) {\n-                                return e == \"@\" && n(b, P), r == \"spread\" ? n(P) : k && ir(e) ? (i.marked = \"keyword\", n(P)) : k && r == \"this\" ? n(Q, _) : s(T, Q, _);\n+                        function setCurrentlyValidatingElement$1(element) {\n+                            {\n+                                if (element) {\n+                                    var owner = element._owner;\n+                                    var stack = describeUnknownElementTypeFrameInDEV(element.type, element._source, owner ? owner.type : null);\n+                                    ReactDebugCurrentFrame$1.setExtraStackFrame(stack);\n+                                } else {\n+                                    ReactDebugCurrentFrame$1.setExtraStackFrame(null);\n+                                }\n                             }\n-                            f(P, \"funarg\");\n+                        }\n+                        var propTypesMisspellWarningShown;\n+                        {\n+                            propTypesMisspellWarningShown = false;\n+                        }\n+                        /**\n+                         * Verifies the object is a ReactElement.\n+                         * See https://reactjs.org/docs/react-api.html#isvalidelement\n+                         * @param {?object} object\n+                         * @return {boolean} True if `object` is a ReactElement.\n+                         * @final\n+                         */\n \n-                            function de(r, e) {\n-                                return r == \"variable\" ? qr(r, e) : cr(r, e);\n+                        function isValidElement(object) {\n+                            {\n+                                return typeof object === 'object' && object !== null && object.$$typeof === REACT_ELEMENT_TYPE;\n                             }\n-                            f(de, \"classExpression\");\n+                        }\n \n-                            function qr(r, e) {\n-                                if (r == \"variable\") return D(e), n(cr);\n+                        function getDeclarationErrorAddendum() {\n+                            {\n+                                if (ReactCurrentOwner$1.current) {\n+                                    var name = getComponentNameFromType(ReactCurrentOwner$1.current.type);\n+                                    if (name) {\n+                                        return '\\n\\nCheck the render method of `' + name + '`.';\n+                                    }\n+                                }\n+                                return '';\n                             }\n-                            f(qr, \"className\");\n+                        }\n \n-                            function cr(r, e) {\n-                                if (e == \"<\") return n(c(\">\"), g(sr, \">\"), u, cr);\n-                                if (e == \"extends\" || e == \"implements\" || k && r == \",\") return e == \"implements\" && (i.marked = \"keyword\"), n(k ? m : b, cr);\n-                                if (r == \"{\") return n(c(\"}\"), S, u);\n+                        function getSourceInfoErrorAddendum(source) {\n+                            {\n+                                if (source !== undefined) {\n+                                    var fileName = source.fileName.replace(/^.*[\\\\\\/]/, '');\n+                                    var lineNumber = source.lineNumber;\n+                                    return '\\n\\nCheck your code at ' + fileName + ':' + lineNumber + '.';\n+                                }\n+                                return '';\n                             }\n-                            f(cr, \"classNameAfter\");\n+                        }\n+                        /**\n+                         * Warn if there's no key explicitly set on dynamic arrays of children or\n+                         * object keys are not valid. This allows us to keep track of children between\n+                         * updates.\n+                         */\n \n-                            function S(r, e) {\n-                                if (r == \"async\" || r == \"variable\" && (e == \"static\" || e == \"get\" || e == \"set\" || k && ir(e)) && i.stream.match(/^\\s+[\\w$\\xa1-\\uffff]/, !1)) return i.marked = \"keyword\", n(S);\n-                                if (r == \"variable\" || i.style == \"keyword\") return i.marked = \"property\", n(C, S);\n-                                if (r == \"number\" || r == \"string\") return n(C, S);\n-                                if (r == \"[\") return n(b, Q, l(\"]\"), C, S);\n-                                if (e == \"*\") return i.marked = \"keyword\", n(S);\n-                                if (k && r == \"(\") return s(U, S);\n-                                if (r == \";\" || r == \",\") return n(S);\n-                                if (r == \"}\") return n();\n-                                if (e == \"@\") return n(b, S);\n-                            }\n-                            f(S, \"classBody\");\n+                        var ownerHasKeyUseWarning = {};\n \n-                            function C(r, e) {\n-                                if (e == \"!\" || e == \"?\") return n(C);\n-                                if (r == \":\") return n(m, _);\n-                                if (e == \"=\") return n(j);\n-                                var t = i.state.lexical.prev,\n-                                    a = t && t.info == \"interface\";\n-                                return s(a ? U : z);\n+                        function getCurrentComponentErrorInfo(parentType) {\n+                            {\n+                                var info = getDeclarationErrorAddendum();\n+                                if (!info) {\n+                                    var parentName = typeof parentType === 'string' ? parentType : parentType.displayName || parentType.name;\n+                                    if (parentName) {\n+                                        info = \"\\n\\nCheck the top-level render call using <\" + parentName + \">.\";\n+                                    }\n+                                }\n+                                return info;\n                             }\n-                            f(C, \"classfield\");\n+                        }\n+                        /**\n+                         * Warn if the element doesn't have an explicit key assigned to it.\n+                         * This element is in an array. The array could grow and shrink or be\n+                         * reordered. All children that haven't already been validated are required to\n+                         * have a \"key\" property assigned to it. Error statuses are cached so a warning\n+                         * will only be shown once.\n+                         *\n+                         * @internal\n+                         * @param {ReactElement} element Element that requires a key.\n+                         * @param {*} parentType element's parent's type.\n+                         */\n \n-                            function me(r, e) {\n-                                return e == \"*\" ? (i.marked = \"keyword\", n(hr, l(\";\"))) : e == \"default\" ? (i.marked = \"keyword\", n(b, l(\";\"))) : r == \"{\" ? n(g(Nr, \"}\"), hr, l(\";\")) : s(v);\n-                            }\n-                            f(me, \"afterExport\");\n+                        function validateExplicitKey(element, parentType) {\n+                            {\n+                                if (!element._store || element._store.validated || element.key != null) {\n+                                    return;\n+                                }\n+                                element._store.validated = true;\n+                                var currentComponentErrorInfo = getCurrentComponentErrorInfo(parentType);\n+                                if (ownerHasKeyUseWarning[currentComponentErrorInfo]) {\n+                                    return;\n+                                }\n+                                ownerHasKeyUseWarning[currentComponentErrorInfo] = true; // Usually the current owner is the offender, but if it accepts children as a\n+                                // property, it may be the creator of the child that's responsible for\n+                                // assigning it a key.\n \n-                            function Nr(r, e) {\n-                                if (e == \"as\") return i.marked = \"keyword\", n(l(\"variable\"));\n-                                if (r == \"variable\") return s(j, Nr);\n+                                var childOwner = '';\n+                                if (element && element._owner && element._owner !== ReactCurrentOwner$1.current) {\n+                                    // Give the component that originally created this child.\n+                                    childOwner = \" It was passed a child from \" + getComponentNameFromType(element._owner.type) + \".\";\n+                                }\n+                                setCurrentlyValidatingElement$1(element);\n+                                error('Each child in a list should have a unique \"key\" prop.' + '%s%s See https://reactjs.org/link/warning-keys for more information.', currentComponentErrorInfo, childOwner);\n+                                setCurrentlyValidatingElement$1(null);\n                             }\n-                            f(Nr, \"exportField\");\n+                        }\n+                        /**\n+                         * Ensure that every element either is passed in a static location, in an\n+                         * array with an explicit keys property defined, or in an object literal\n+                         * with valid key property.\n+                         *\n+                         * @internal\n+                         * @param {ReactNode} node Statically passed child of any type.\n+                         * @param {*} parentType node's parent's type.\n+                         */\n \n-                            function pe(r) {\n-                                return r == \"string\" ? n() : r == \"(\" ? s(b) : r == \".\" ? s(N) : s(lr, Br, hr);\n+                        function validateChildKeys(node, parentType) {\n+                            {\n+                                if (typeof node !== 'object') {\n+                                    return;\n+                                }\n+                                if (isArray(node)) {\n+                                    for (var i = 0; i < node.length; i++) {\n+                                        var child = node[i];\n+                                        if (isValidElement(child)) {\n+                                            validateExplicitKey(child, parentType);\n+                                        }\n+                                    }\n+                                } else if (isValidElement(node)) {\n+                                    // This element was passed in a valid location.\n+                                    if (node._store) {\n+                                        node._store.validated = true;\n+                                    }\n+                                } else if (node) {\n+                                    var iteratorFn = getIteratorFn(node);\n+                                    if (typeof iteratorFn === 'function') {\n+                                        // Entry iterators used to provide implicit keys,\n+                                        // but now we print a separate warning for them later.\n+                                        if (iteratorFn !== node.entries) {\n+                                            var iterator = iteratorFn.call(node);\n+                                            var step;\n+                                            while (!(step = iterator.next()).done) {\n+                                                if (isValidElement(step.value)) {\n+                                                    validateExplicitKey(step.value, parentType);\n+                                                }\n+                                            }\n+                                        }\n+                                    }\n+                                }\n                             }\n-                            f(pe, \"afterImport\");\n+                        }\n+                        /**\n+                         * Given an element, validate that its props follow the propTypes definition,\n+                         * provided by the type.\n+                         *\n+                         * @param {ReactElement} element\n+                         */\n \n-                            function lr(r, e) {\n-                                return r == \"{\" ? Y(lr, \"}\") : (r == \"variable\" && D(e), e == \"*\" && (i.marked = \"keyword\"), n(ke));\n-                            }\n-                            f(lr, \"importSpec\");\n+                        function validatePropTypes(element) {\n+                            {\n+                                var type = element.type;\n+                                if (type === null || type === undefined || typeof type === 'string') {\n+                                    return;\n+                                }\n+                                var propTypes;\n+                                if (typeof type === 'function') {\n+                                    propTypes = type.propTypes;\n+                                } else if (typeof type === 'object' && (type.$$typeof === REACT_FORWARD_REF_TYPE ||\n+                                        // Note: Memo only checks outer props here.\n+                                        // Inner props are checked in the reconciler.\n+                                        type.$$typeof === REACT_MEMO_TYPE)) {\n+                                    propTypes = type.propTypes;\n+                                } else {\n+                                    return;\n+                                }\n+                                if (propTypes) {\n+                                    // Intentionally inside to avoid triggering lazy initializers:\n+                                    var name = getComponentNameFromType(type);\n+                                    checkPropTypes(propTypes, element.props, 'prop', name, element);\n+                                } else if (type.PropTypes !== undefined && !propTypesMisspellWarningShown) {\n+                                    propTypesMisspellWarningShown = true; // Intentionally inside to avoid triggering lazy initializers:\n \n-                            function Br(r) {\n-                                if (r == \",\") return n(lr, Br);\n+                                    var _name = getComponentNameFromType(type);\n+                                    error('Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?', _name || 'Unknown');\n+                                }\n+                                if (typeof type.getDefaultProps === 'function' && !type.getDefaultProps.isReactClassApproved) {\n+                                    error('getDefaultProps is only used on classic React.createClass ' + 'definitions. Use a static property named `defaultProps` instead.');\n+                                }\n                             }\n-                            f(Br, \"maybeMoreImports\");\n+                        }\n+                        /**\n+                         * Given a fragment, validate that it can only be provided with fragment props\n+                         * @param {ReactElement} fragment\n+                         */\n \n-                            function ke(r, e) {\n-                                if (e == \"as\") return i.marked = \"keyword\", n(lr);\n+                        function validateFragmentProps(fragment) {\n+                            {\n+                                var keys = Object.keys(fragment.props);\n+                                for (var i = 0; i < keys.length; i++) {\n+                                    var key = keys[i];\n+                                    if (key !== 'children' && key !== 'key') {\n+                                        setCurrentlyValidatingElement$1(fragment);\n+                                        error('Invalid prop `%s` supplied to `React.Fragment`. ' + 'React.Fragment can only have `key` and `children` props.', key);\n+                                        setCurrentlyValidatingElement$1(null);\n+                                        break;\n+                                    }\n+                                }\n+                                if (fragment.ref !== null) {\n+                                    setCurrentlyValidatingElement$1(fragment);\n+                                    error('Invalid attribute `ref` supplied to `React.Fragment`.');\n+                                    setCurrentlyValidatingElement$1(null);\n+                                }\n                             }\n-                            f(ke, \"maybeAs\");\n+                        }\n \n-                            function hr(r, e) {\n-                                if (e == \"from\") return i.marked = \"keyword\", n(b);\n-                            }\n-                            f(hr, \"maybeFrom\");\n+                        function jsxWithValidation(type, props, key, isStaticChildren, source, self) {\n+                            {\n+                                var validType = isValidElementType(type); // We warn in this case but don't throw. We expect the element creation to\n+                                // succeed and there will likely be errors in render.\n \n-                            function be(r) {\n-                                return r == \"]\" ? n() : s(g(j, \"]\"));\n-                            }\n-                            f(be, \"arrayLiteral\");\n+                                if (!validType) {\n+                                    var info = '';\n+                                    if (type === undefined || typeof type === 'object' && type !== null && Object.keys(type).length === 0) {\n+                                        info += ' You likely forgot to export your component from the file ' + \"it's defined in, or you might have mixed up default and named imports.\";\n+                                    }\n+                                    var sourceInfo = getSourceInfoErrorAddendum(source);\n+                                    if (sourceInfo) {\n+                                        info += sourceInfo;\n+                                    } else {\n+                                        info += getDeclarationErrorAddendum();\n+                                    }\n+                                    var typeString;\n+                                    if (type === null) {\n+                                        typeString = 'null';\n+                                    } else if (isArray(type)) {\n+                                        typeString = 'array';\n+                                    } else if (type !== undefined && type.$$typeof === REACT_ELEMENT_TYPE) {\n+                                        typeString = \"<\" + (getComponentNameFromType(type.type) || 'Unknown') + \" />\";\n+                                        info = ' Did you accidentally export a JSX literal instead of a component?';\n+                                    } else {\n+                                        typeString = typeof type;\n+                                    }\n+                                    error('React.jsx: type is invalid -- expected a string (for ' + 'built-in components) or a class/function (for composite ' + 'components) but got: %s.%s', typeString, info);\n+                                }\n+                                var element = jsxDEV(type, props, key, source, self); // The result can be nullish if a mock or a custom function is used.\n+                                // TODO: Drop this when these are no longer allowed as the type argument.\n \n-                            function Pr() {\n-                                return s(c(\"form\"), T, l(\"{\"), c(\"}\"), g(we, \"}\"), u, u);\n-                            }\n-                            f(Pr, \"enumdef\");\n+                                if (element == null) {\n+                                    return element;\n+                                } // Skip key warning if the type isn't valid since our key validation logic\n+                                // doesn't expect a non-string/function type and can throw confusing errors.\n+                                // We don't want exception behavior to differ between dev and prod.\n+                                // (Rendering will throw with a helpful message and as soon as the type is\n+                                // fixed, the key warnings will appear.)\n \n-                            function we() {\n-                                return s(T, _);\n+                                if (validType) {\n+                                    var children = props.children;\n+                                    if (children !== undefined) {\n+                                        if (isStaticChildren) {\n+                                            if (isArray(children)) {\n+                                                for (var i = 0; i < children.length; i++) {\n+                                                    validateChildKeys(children[i], type);\n+                                                }\n+                                                if (Object.freeze) {\n+                                                    Object.freeze(children);\n+                                                }\n+                                            } else {\n+                                                error('React.jsx: Static children should always be an array. ' + 'You are likely explicitly calling React.jsxs or React.jsxDEV. ' + 'Use the Babel transform instead.');\n+                                            }\n+                                        } else {\n+                                            validateChildKeys(children, type);\n+                                        }\n+                                    }\n+                                }\n+                                if (type === REACT_FRAGMENT_TYPE) {\n+                                    validateFragmentProps(element);\n+                                } else {\n+                                    validatePropTypes(element);\n+                                }\n+                                return element;\n                             }\n-                            f(we, \"enummember\");\n+                        } // These two functions exist to still get child warnings in dev\n+                        // even with the prod transform. This means that jsxDEV is purely\n+                        // opt-in behavior for better messages but that we won't stop\n+                        // giving you warnings if you use production apis.\n \n-                            function xe(r, e) {\n-                                return r.lastType == \"operator\" || r.lastType == \",\" || jr.test(e.charAt(0)) || /[,.]/.test(e.charAt(0));\n+                        function jsxWithValidationStatic(type, props, key) {\n+                            {\n+                                return jsxWithValidation(type, props, key, true);\n                             }\n-                            f(xe, \"isContinuedStatement\");\n+                        }\n \n-                            function Fr(r, e, t) {\n-                                return e.tokenize == $ && /^(?:operator|sof|keyword [bcd]|case|new|export|default|spread|[\\[{}\\(,;:]|=>)$/.test(e.lastType) || e.lastType == \"quasi\" && /\\{\\s*$/.test(r.string.slice(0, r.pos - (t || 0)));\n+                        function jsxWithValidationDynamic(type, props, key) {\n+                            {\n+                                return jsxWithValidation(type, props, key, false);\n                             }\n-                            return f(Fr, \"expressionAllowed\"), {\n-                                startState: function(r) {\n-                                    var e = {\n-                                        tokenize: $,\n-                                        lastType: \"sof\",\n-                                        cc: [],\n-                                        lexical: new Er((r || 0) - A, 0, \"block\", !1),\n-                                        localVars: h.localVars,\n-                                        context: h.localVars && new G(null, null, !1),\n-                                        indented: r || 0\n-                                    };\n-                                    return h.globalVars && typeof h.globalVars == \"object\" && (e.globalVars = h.globalVars), e;\n-                                },\n-                                token: function(r, e) {\n-                                    if (r.sol() && (e.lexical.hasOwnProperty(\"align\") || (e.lexical.align = !1), e.indented = r.indentation(), dr(r, e)), e.tokenize != tr && r.eatSpace()) return null;\n-                                    var t = e.tokenize(r, e);\n-                                    return K == \"comment\" ? t : (e.lastType = K == \"operator\" && (nr == \"++\" || nr == \"--\") ? \"incdec\" : K, Tr(e, t, K, nr, r));\n-                                },\n-                                indent: function(r, e) {\n-                                    if (r.tokenize == tr || r.tokenize == H) return w.Pass;\n-                                    if (r.tokenize != $) return 0;\n-                                    var t = e && e.charAt(0),\n-                                        a = r.lexical,\n-                                        o;\n-                                    if (!/^\\s*else\\b/.test(e))\n-                                        for (var d = r.cc.length - 1; d >= 0; --d) {\n-                                            var p = r.cc[d];\n-                                            if (p == u) a = a.prev;\n-                                            else if (p != Mr && p != E) break;\n-                                        }\n-                                    for (;\n-                                        (a.type == \"stat\" || a.type == \"form\") && (t == \"}\" || (o = r.cc[r.cc.length - 1]) && (o == N || o == L) && !/^[,\\.=+\\-*:?[\\(]/.test(e));) a = a.prev;\n-                                    vr && a.type == \")\" && a.prev.type == \"stat\" && (a = a.prev);\n-                                    var y = a.type,\n-                                        V = t == y;\n-                                    return y == \"vardef\" ? a.indented + (r.lastType == \"operator\" || r.lastType == \",\" ? a.info.length + 1 : 0) : y == \"form\" && t == \"{\" ? a.indented : y == \"form\" ? a.indented + A : y == \"stat\" ? a.indented + (xe(r, e) ? vr || A : 0) : a.info == \"switch\" && !V && h.doubleIndentSwitch != !1 ? a.indented + (/^(?:case|default)\\b/.test(e) ? A : 2 * A) : a.align ? a.column + (V ? 0 : 1) : a.indented + (V ? 0 : A);\n-                                },\n-                                electricInput: /^\\s*(?:case .*?:|default:|\\{|\\})$/,\n-                                blockCommentStart: O ? null : \"/*\",\n-                                blockCommentEnd: O ? null : \"*/\",\n-                                blockCommentContinue: O ? null : \" * \",\n-                                lineComment: O ? null : \"//\",\n-                                fold: \"brace\",\n-                                closeBrackets: \"()[]{}''\\\"\\\"``\",\n-                                helperType: O ? \"json\" : \"javascript\",\n-                                jsonldMode: rr,\n-                                jsonMode: O,\n-                                expressionAllowed: Fr,\n-                                skipExpression: function(r) {\n-                                    Tr(r, \"atom\", \"atom\", \"true\", new w.StringStream(\"\", 2, null));\n-                                }\n-                            };\n-                        }), w.registerHelper(\"wordChars\", \"javascript\", /[\\w$]/), w.defineMIME(\"text/javascript\", \"javascript\"), w.defineMIME(\"text/ecmascript\", \"javascript\"), w.defineMIME(\"application/javascript\", \"javascript\"), w.defineMIME(\"application/x-javascript\", \"javascript\"), w.defineMIME(\"application/ecmascript\", \"javascript\"), w.defineMIME(\"application/json\", {\n-                            name: \"javascript\",\n-                            json: !0\n-                        }), w.defineMIME(\"application/x-json\", {\n-                            name: \"javascript\",\n-                            json: !0\n-                        }), w.defineMIME(\"application/manifest+json\", {\n-                            name: \"javascript\",\n-                            json: !0\n-                        }), w.defineMIME(\"application/ld+json\", {\n-                            name: \"javascript\",\n-                            jsonld: !0\n-                        }), w.defineMIME(\"text/typescript\", {\n-                            name: \"javascript\",\n-                            typescript: !0\n-                        }), w.defineMIME(\"application/typescript\", {\n-                            name: \"javascript\",\n-                            typescript: !0\n-                        });\n-                    });\n-                })();\n-                var Jr = ye.exports;\n-                const je = Dr.getDefaultExportFromCjs(Jr),\n-                    Ee = ge({\n-                        __proto__: null,\n-                        default: je\n-                    }, [Jr]);\n-                exports.javascript = Ee;\n+                        }\n+                        var jsx = jsxWithValidationDynamic; // we may want to special case jsxs internally to take advantage of static children.\n+                        // for now we can ship identical prod functions\n+\n+                        var jsxs = jsxWithValidationStatic;\n+                        exports.Fragment = REACT_FRAGMENT_TYPE;\n+                        exports.jsx = jsx;\n+                        exports.jsxs = jsxs;\n+                    })();\n+                }\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-react/dist/jump-to-line.cjs.js\":\n-            /*!*****************************************************!*\\\n-              !*** ../../graphiql-react/dist/jump-to-line.cjs.js ***!\n-              \\*****************************************************/\n+        \"../../../node_modules/react/jsx-runtime.js\":\n+            /*!**************************************************!*\\\n+              !*** ../../../node_modules/react/jsx-runtime.js ***!\n+              \\**************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+            (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                var m = Object.defineProperty;\n-                var c = (u, p) => m(u, \"name\", {\n-                    value: p,\n-                    configurable: !0\n-                });\n-                const f = __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\"),\n-                    g = __webpack_require__( /*! ./dialog.cjs.js */ \"../../graphiql-react/dist/dialog.cjs.js\");\n-\n-                function h(u, p) {\n-                    for (var o = 0; o < p.length; o++) {\n-                        const s = p[o];\n-                        if (typeof s != \"string\" && !Array.isArray(s)) {\n-                            for (const i in s)\n-                                if (i !== \"default\" && !(i in u)) {\n-                                    const a = Object.getOwnPropertyDescriptor(s, i);\n-                                    a && Object.defineProperty(u, i, a.get ? a : {\n-                                        enumerable: !0,\n-                                        get: () => s[i]\n-                                    });\n-                                }\n-                        }\n-                    }\n-                    return Object.freeze(Object.defineProperty(u, Symbol.toStringTag, {\n-                        value: \"Module\"\n-                    }));\n+                if (false) {} else {\n+                    module.exports = __webpack_require__( /*! ./cjs/react-jsx-runtime.development.js */ \"../../../node_modules/react/cjs/react-jsx-runtime.development.js\");\n                 }\n-                c(h, \"_mergeNamespaces\");\n-                var b = {\n-                    exports: {}\n-                };\n-                (function(u, p) {\n-                    (function(o) {\n-                        o(f.requireCodemirror(), g.dialogExports);\n-                    })(function(o) {\n-                        o.defineOption(\"search\", {\n-                            bottom: !1\n-                        });\n-\n-                        function s(e, r, n, t, l) {\n-                            e.openDialog ? e.openDialog(r, l, {\n-                                value: t,\n-                                selectValueOnOpen: !0,\n-                                bottom: e.options.search.bottom\n-                            }) : l(prompt(n, t));\n-                        }\n-                        c(s, \"dialog\");\n-\n-                        function i(e) {\n-                            return e.phrase(\"Jump to line:\") + ' <input type=\"text\" style=\"width: 10em\" class=\"CodeMirror-search-field\"/> <span style=\"color: #888\" class=\"CodeMirror-search-hint\">' + e.phrase(\"(Use line:column or scroll% syntax)\") + \"</span>\";\n-                        }\n-                        c(i, \"getJumpDialog\");\n-\n-                        function a(e, r) {\n-                            var n = Number(r);\n-                            return /^[-+]/.test(r) ? e.getCursor().line + n : n - 1;\n-                        }\n-                        c(a, \"interpretLine\"), o.commands.jumpToLine = function(e) {\n-                            var r = e.getCursor();\n-                            s(e, i(e), e.phrase(\"Jump to line:\"), r.line + 1 + \":\" + r.ch, function(n) {\n-                                if (n) {\n-                                    var t;\n-                                    if (t = /^\\s*([\\+\\-]?\\d+)\\s*\\:\\s*(\\d+)\\s*$/.exec(n)) e.setCursor(a(e, t[1]), Number(t[2]));\n-                                    else if (t = /^\\s*([\\+\\-]?\\d+(\\.\\d+)?)\\%\\s*/.exec(n)) {\n-                                        var l = Math.round(e.lineCount() * Number(t[1]) / 100);\n-                                        /^[-+]/.test(t[1]) && (l = r.line + l + 1), e.setCursor(l - 1, r.ch);\n-                                    } else(t = /^\\s*\\:?\\s*([\\+\\-]?\\d+)\\s*/.exec(n)) && e.setCursor(a(e, t[1]), r.ch);\n-                                }\n-                            });\n-                        }, o.keyMap.default[\"Alt-G\"] = \"jumpToLine\";\n-                    });\n-                })();\n-                var d = b.exports;\n-                const j = f.getDefaultExportFromCjs(d),\n-                    y = h({\n-                        __proto__: null,\n-                        default: j\n-                    }, [d]);\n-                exports.jumpToLine = y;\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-react/dist/jump.cjs.js\":\n-            /*!*********************************************!*\\\n-              !*** ../../graphiql-react/dist/jump.cjs.js ***!\n-              \\*********************************************/\n+        \"../../../node_modules/set-value/index.js\":\n+            /*!************************************************!*\\\n+              !*** ../../../node_modules/set-value/index.js ***!\n+              \\************************************************/\n             /***/\n-            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n+            (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n+                /*!\n+                 * set-value <https://github.com/jonschlinkert/set-value>\n+                 *\n+                 * Copyright (c) Jon Schlinkert (https://github.com/jonschlinkert).\n+                 * Released under the MIT License.\n+                 */\n \n \n-                var c = Object.defineProperty;\n-                var s = (e, r) => c(e, \"name\", {\n-                    value: r,\n-                    configurable: !0\n-                });\n-                const u = __webpack_require__( /*! ./codemirror.cjs.js */ \"../../graphiql-react/dist/codemirror.cjs.js\"),\n-                    d = __webpack_require__( /*! ./SchemaReference.cjs.js */ \"../../graphiql-react/dist/SchemaReference.cjs.js\");\n-                __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\");\n-                __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n-                __webpack_require__( /*! ./forEachState.cjs.js */ \"../../graphiql-react/dist/forEachState.cjs.js\");\n-                u.CodeMirror.defineOption(\"jump\", !1, (e, r, n) => {\n-                    if (n && n !== u.CodeMirror.Init) {\n-                        const t = e.state.jump.onMouseOver;\n-                        u.CodeMirror.off(e.getWrapperElement(), \"mouseover\", t);\n-                        const i = e.state.jump.onMouseOut;\n-                        u.CodeMirror.off(e.getWrapperElement(), \"mouseout\", i), u.CodeMirror.off(document, \"keydown\", e.state.jump.onKeyDown), delete e.state.jump;\n-                    }\n-                    if (r) {\n-                        const t = e.state.jump = {\n-                            options: r,\n-                            onMouseOver: M.bind(null, e),\n-                            onMouseOut: m.bind(null, e),\n-                            onKeyDown: g.bind(null, e)\n-                        };\n-                        u.CodeMirror.on(e.getWrapperElement(), \"mouseover\", t.onMouseOver), u.CodeMirror.on(e.getWrapperElement(), \"mouseout\", t.onMouseOut), u.CodeMirror.on(document, \"keydown\", t.onKeyDown);\n-                    }\n-                });\n \n-                function M(e, r) {\n-                    const n = r.target || r.srcElement;\n-                    if (!(n instanceof HTMLElement) || (n == null ? void 0 : n.nodeName) !== \"SPAN\") return;\n-                    const t = n.getBoundingClientRect(),\n-                        i = {\n-                            left: (t.left + t.right) / 2,\n-                            top: (t.top + t.bottom) / 2\n-                        };\n-                    e.state.jump.cursor = i, e.state.jump.isHoldingModifier && l(e);\n-                }\n-                s(M, \"onMouseOver\");\n-\n-                function m(e) {\n-                    if (!e.state.jump.isHoldingModifier && e.state.jump.cursor) {\n-                        e.state.jump.cursor = null;\n-                        return;\n+                const {\n+                    deleteProperty\n+                } = Reflect;\n+                const isPrimitive = __webpack_require__( /*! is-primitive */ \"../../../node_modules/is-primitive/index.js\");\n+                const isPlainObject = __webpack_require__( /*! is-plain-object */ \"../../../node_modules/is-plain-object/index.js\");\n+                const isObject = value => {\n+                    return typeof value === 'object' && value !== null || typeof value === 'function';\n+                };\n+                const isUnsafeKey = key => {\n+                    return key === '__proto__' || key === 'constructor' || key === 'prototype';\n+                };\n+                const validateKey = key => {\n+                    if (!isPrimitive(key)) {\n+                        throw new TypeError('Object keys must be strings or symbols');\n                     }\n-                    e.state.jump.isHoldingModifier && e.state.jump.marker && p(e);\n-                }\n-                s(m, \"onMouseOut\");\n-\n-                function g(e, r) {\n-                    if (e.state.jump.isHoldingModifier || !k(r.key)) return;\n-                    e.state.jump.isHoldingModifier = !0, e.state.jump.cursor && l(e);\n-                    const n = s(o => {\n-                            o.code === r.code && (e.state.jump.isHoldingModifier = !1, e.state.jump.marker && p(e), u.CodeMirror.off(document, \"keyup\", n), u.CodeMirror.off(document, \"click\", t), e.off(\"mousedown\", i));\n-                        }, \"onKeyUp\"),\n-                        t = s(o => {\n-                            const {\n-                                destination: a,\n-                                options: f\n-                            } = e.state.jump;\n-                            a && f.onClick(a, o);\n-                        }, \"onClick\"),\n-                        i = s((o, a) => {\n-                            e.state.jump.destination && (a.codemirrorIgnore = !0);\n-                        }, \"onMouseDown\");\n-                    u.CodeMirror.on(document, \"keyup\", n), u.CodeMirror.on(document, \"click\", t), e.on(\"mousedown\", i);\n-                }\n-                s(g, \"onKeyDown\");\n-                const j = typeof navigator < \"u\" && navigator && navigator.appVersion.includes(\"Mac\");\n-\n-                function k(e) {\n-                    return e === (j ? \"Meta\" : \"Control\");\n-                }\n-                s(k, \"isJumpModifier\");\n-\n-                function l(e) {\n-                    if (e.state.jump.marker) return;\n-                    const {\n-                        cursor: r,\n-                        options: n\n-                    } = e.state.jump,\n-                        t = e.coordsChar(r),\n-                        i = e.getTokenAt(t, !0),\n-                        o = n.getDestination || e.getHelper(t, \"jump\");\n-                    if (o) {\n-                        const a = o(i, n, e);\n-                        if (a) {\n-                            const f = e.markText({\n-                                line: t.line,\n-                                ch: i.start\n-                            }, {\n-                                line: t.line,\n-                                ch: i.end\n-                            }, {\n-                                className: \"CodeMirror-jump-token\"\n-                            });\n-                            e.state.jump.marker = f, e.state.jump.destination = a;\n+                    if (isUnsafeKey(key)) {\n+                        throw new Error(`Cannot set unsafe key: \"${key}\"`);\n+                    }\n+                };\n+                const toStringKey = input => {\n+                    return Array.isArray(input) ? input.flat().map(String).join(',') : input;\n+                };\n+                const createMemoKey = (input, options) => {\n+                    if (typeof input !== 'string' || !options) return input;\n+                    let key = input + ';';\n+                    if (options.arrays !== undefined) key += `arrays=${options.arrays};`;\n+                    if (options.separator !== undefined) key += `separator=${options.separator};`;\n+                    if (options.split !== undefined) key += `split=${options.split};`;\n+                    if (options.merge !== undefined) key += `merge=${options.merge};`;\n+                    if (options.preservePaths !== undefined) key += `preservePaths=${options.preservePaths};`;\n+                    return key;\n+                };\n+                const memoize = (input, options, fn) => {\n+                    const key = toStringKey(options ? createMemoKey(input, options) : input);\n+                    validateKey(key);\n+                    const value = setValue.cache.get(key) || fn();\n+                    setValue.cache.set(key, value);\n+                    return value;\n+                };\n+                const splitString = (input, options = {}) => {\n+                    const sep = options.separator || '.';\n+                    const preserve = sep === '/' ? false : options.preservePaths;\n+                    if (typeof input === 'string' && preserve !== false && /\\//.test(input)) {\n+                        return [input];\n+                    }\n+                    const parts = [];\n+                    let part = '';\n+                    const push = part => {\n+                        let number;\n+                        if (part.trim() !== '' && Number.isInteger(number = Number(part))) {\n+                            parts.push(number);\n+                        } else {\n+                            parts.push(part);\n+                        }\n+                    };\n+                    for (let i = 0; i < input.length; i++) {\n+                        const value = input[i];\n+                        if (value === '\\\\') {\n+                            part += input[++i];\n+                            continue;\n+                        }\n+                        if (value === sep) {\n+                            push(part);\n+                            part = '';\n+                            continue;\n                         }\n+                        part += value;\n                     }\n-                }\n-                s(l, \"enableJumpMode\");\n+                    if (part) {\n+                        push(part);\n+                    }\n+                    return parts;\n+                };\n+                const split = (input, options) => {\n+                    if (options && typeof options.split === 'function') return options.split(input);\n+                    if (typeof input === 'symbol') return [input];\n+                    if (Array.isArray(input)) return input;\n+                    return memoize(input, options, () => splitString(input, options));\n+                };\n+                const assignProp = (obj, prop, value, options) => {\n+                    validateKey(prop);\n \n-                function p(e) {\n-                    const {\n-                        marker: r\n-                    } = e.state.jump;\n-                    e.state.jump.marker = null, e.state.jump.destination = null, r.clear();\n-                }\n-                s(p, \"disableJumpMode\");\n-                u.CodeMirror.registerHelper(\"jump\", \"graphql\", (e, r) => {\n-                    if (!r.schema || !r.onClick || !e.state) return;\n-                    const {\n-                        state: n\n-                    } = e, {\n-                        kind: t,\n-                        step: i\n-                    } = n,\n-                    o = d.getTypeInfo(r.schema, n);\n-                    if (t === \"Field\" && i === 0 && o.fieldDef || t === \"AliasedField\" && i === 2 && o.fieldDef) return d.getFieldReference(o);\n-                    if (t === \"Directive\" && i === 1 && o.directiveDef) return d.getDirectiveReference(o);\n-                    if (t === \"Argument\" && i === 0 && o.argDef) return d.getArgumentReference(o);\n-                    if (t === \"EnumValue\" && o.enumValue) return d.getEnumValueReference(o);\n-                    if (t === \"NamedType\" && o.type) return d.getTypeReference(o);\n-                });\n+                    // Delete property when \"value\" is undefined\n+                    if (value === undefined) {\n+                        deleteProperty(obj, prop);\n+                    } else if (options && options.merge) {\n+                        const merge = options.merge === 'function' ? options.merge : Object.assign;\n+\n+                        // Only merge plain objects\n+                        if (merge && isPlainObject(obj[prop]) && isPlainObject(value)) {\n+                            obj[prop] = merge(obj[prop], value);\n+                        } else {\n+                            obj[prop] = value;\n+                        }\n+                    } else {\n+                        obj[prop] = value;\n+                    }\n+                    return obj;\n+                };\n+                const setValue = (target, path, value, options) => {\n+                    if (!path || !isObject(target)) return target;\n+                    const keys = split(path, options);\n+                    let obj = target;\n+                    for (let i = 0; i < keys.length; i++) {\n+                        const key = keys[i];\n+                        const next = keys[i + 1];\n+                        validateKey(key);\n+                        if (next === undefined) {\n+                            assignProp(obj, key, value, options);\n+                            break;\n+                        }\n+                        if (typeof next === 'number' && !Array.isArray(obj[key])) {\n+                            obj = obj[key] = [];\n+                            continue;\n+                        }\n+                        if (!isObject(obj[key])) {\n+                            obj[key] = {};\n+                        }\n+                        obj = obj[key];\n+                    }\n+                    return target;\n+                };\n+                setValue.split = split;\n+                setValue.cache = new Map();\n+                setValue.clear = () => {\n+                    setValue.cache = new Map();\n+                };\n+                module.exports = setValue;\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-react/dist/lint.cjs.js\":\n-            /*!*********************************************!*\\\n-              !*** ../../graphiql-react/dist/lint.cjs.js ***!\n-              \\*********************************************/\n+        \"../../../node_modules/style-value-types/dist/valueTypes.cjs.js\":\n+            /*!**********************************************************************!*\\\n+              !*** ../../../node_modules/style-value-types/dist/valueTypes.cjs.js ***!\n+              \\**********************************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+            (function(__unused_webpack_module, exports) {\n+\n+                \"use strict\";\n \n \n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                const clamp = (min, max) => v => Math.max(Math.min(v, max), min);\n+                const sanitize = v => v % 1 ? Number(v.toFixed(5)) : v;\n+                const floatRegex = /(-)?([\\d]*\\.?[\\d])+/g;\n+                const colorRegex = /(#[0-9a-f]{6}|#[0-9a-f]{3}|#(?:[0-9a-f]{2}){2,4}|(rgb|hsl)a?\\((-?[\\d\\.]+%?[,\\s]+){2,3}\\s*\\/*\\s*[\\d\\.]+%?\\))/gi;\n+                const singleColorRegex = /^(#[0-9a-f]{3}|#(?:[0-9a-f]{2}){2,4}|(rgb|hsl)a?\\((-?[\\d\\.]+%?[,\\s]+){2,3}\\s*\\/*\\s*[\\d\\.]+%?\\))$/i;\n \n-                var W = Object.defineProperty;\n-                var s = (h, v) => W(h, \"name\", {\n-                    value: v,\n-                    configurable: !0\n+                function isString(v) {\n+                    return typeof v === 'string';\n+                }\n+                const number = {\n+                    test: v => typeof v === 'number',\n+                    parse: parseFloat,\n+                    transform: v => v\n+                };\n+                const alpha = Object.assign(Object.assign({}, number), {\n+                    transform: clamp(0, 1)\n+                });\n+                const scale = Object.assign(Object.assign({}, number), {\n+                    default: 1\n+                });\n+                const createUnitType = unit => ({\n+                    test: v => isString(v) && v.endsWith(unit) && v.split(' ').length === 1,\n+                    parse: parseFloat,\n+                    transform: v => `${v}${unit}`\n+                });\n+                const degrees = createUnitType('deg');\n+                const percent = createUnitType('%');\n+                const px = createUnitType('px');\n+                const vh = createUnitType('vh');\n+                const vw = createUnitType('vw');\n+                const progressPercentage = Object.assign(Object.assign({}, percent), {\n+                    parse: v => percent.parse(v) / 100,\n+                    transform: v => percent.transform(v * 100)\n+                });\n+                const isColorString = (type, testProp) => v => {\n+                    return Boolean(isString(v) && singleColorRegex.test(v) && v.startsWith(type) || testProp && Object.prototype.hasOwnProperty.call(v, testProp));\n+                };\n+                const splitColor = (aName, bName, cName) => v => {\n+                    if (!isString(v)) return v;\n+                    const [a, b, c, alpha] = v.match(floatRegex);\n+                    return {\n+                        [aName]: parseFloat(a),\n+                        [bName]: parseFloat(b),\n+                        [cName]: parseFloat(c),\n+                        alpha: alpha !== undefined ? parseFloat(alpha) : 1\n+                    };\n+                };\n+                const hsla = {\n+                    test: isColorString('hsl', 'hue'),\n+                    parse: splitColor('hue', 'saturation', 'lightness'),\n+                    transform: ({\n+                        hue,\n+                        saturation,\n+                        lightness,\n+                        alpha: alpha$1 = 1\n+                    }) => {\n+                        return 'hsla(' + Math.round(hue) + ', ' + percent.transform(sanitize(saturation)) + ', ' + percent.transform(sanitize(lightness)) + ', ' + sanitize(alpha.transform(alpha$1)) + ')';\n+                    }\n+                };\n+                const clampRgbUnit = clamp(0, 255);\n+                const rgbUnit = Object.assign(Object.assign({}, number), {\n+                    transform: v => Math.round(clampRgbUnit(v))\n                 });\n-                const x = __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\");\n+                const rgba = {\n+                    test: isColorString('rgb', 'red'),\n+                    parse: splitColor('red', 'green', 'blue'),\n+                    transform: ({\n+                        red,\n+                        green,\n+                        blue,\n+                        alpha: alpha$1 = 1\n+                    }) => 'rgba(' + rgbUnit.transform(red) + ', ' + rgbUnit.transform(green) + ', ' + rgbUnit.transform(blue) + ', ' + sanitize(alpha.transform(alpha$1)) + ')'\n+                };\n \n-                function q(h, v) {\n-                    for (var l = 0; l < v.length; l++) {\n-                        const u = v[l];\n-                        if (typeof u != \"string\" && !Array.isArray(u)) {\n-                            for (const g in u)\n-                                if (g !== \"default\" && !(g in h)) {\n-                                    const c = Object.getOwnPropertyDescriptor(u, g);\n-                                    c && Object.defineProperty(h, g, c.get ? c : {\n-                                        enumerable: !0,\n-                                        get: () => u[g]\n-                                    });\n-                                }\n-                        }\n+                function parseHex(v) {\n+                    let r = '';\n+                    let g = '';\n+                    let b = '';\n+                    let a = '';\n+                    if (v.length > 5) {\n+                        r = v.substr(1, 2);\n+                        g = v.substr(3, 2);\n+                        b = v.substr(5, 2);\n+                        a = v.substr(7, 2);\n+                    } else {\n+                        r = v.substr(1, 1);\n+                        g = v.substr(2, 1);\n+                        b = v.substr(3, 1);\n+                        a = v.substr(4, 1);\n+                        r += r;\n+                        g += g;\n+                        b += b;\n+                        a += a;\n                     }\n-                    return Object.freeze(Object.defineProperty(h, Symbol.toStringTag, {\n-                        value: \"Module\"\n-                    }));\n+                    return {\n+                        red: parseInt(r, 16),\n+                        green: parseInt(g, 16),\n+                        blue: parseInt(b, 16),\n+                        alpha: a ? parseInt(a, 16) / 255 : 1\n+                    };\n                 }\n-                s(q, \"_mergeNamespaces\");\n-                var B = {\n-                    exports: {}\n-                };\n-                (function(h, v) {\n-                    (function(l) {\n-                        l(x.requireCodemirror());\n-                    })(function(l) {\n-                        var u = \"CodeMirror-lint-markers\",\n-                            g = \"CodeMirror-lint-line-\";\n-\n-                        function c(t, e, r) {\n-                            var n = document.createElement(\"div\");\n-                            n.className = \"CodeMirror-lint-tooltip cm-s-\" + t.options.theme, n.appendChild(r.cloneNode(!0)), t.state.lint.options.selfContain ? t.getWrapperElement().appendChild(n) : document.body.appendChild(n);\n-\n-                            function i(o) {\n-                                if (!n.parentNode) return l.off(document, \"mousemove\", i);\n-                                n.style.top = Math.max(0, o.clientY - n.offsetHeight - 5) + \"px\", n.style.left = o.clientX + 5 + \"px\";\n-                            }\n-                            return s(i, \"position\"), l.on(document, \"mousemove\", i), i(e), n.style.opacity != null && (n.style.opacity = 1), n;\n-                        }\n-                        s(c, \"showTooltip\");\n-\n-                        function L(t) {\n-                            t.parentNode && t.parentNode.removeChild(t);\n-                        }\n-                        s(L, \"rm\");\n-\n-                        function A(t) {\n-                            t.parentNode && (t.style.opacity == null && L(t), t.style.opacity = 0, setTimeout(function() {\n-                                L(t);\n-                            }, 600));\n-                        }\n-                        s(A, \"hideTooltip\");\n-\n-                        function M(t, e, r, n) {\n-                            var i = c(t, e, r);\n-\n-                            function o() {\n-                                l.off(n, \"mouseout\", o), i && (A(i), i = null);\n-                            }\n-                            s(o, \"hide\");\n-                            var a = setInterval(function() {\n-                                if (i)\n-                                    for (var f = n;; f = f.parentNode) {\n-                                        if (f && f.nodeType == 11 && (f = f.host), f == document.body) return;\n-                                        if (!f) {\n-                                            o();\n-                                            break;\n-                                        }\n-                                    }\n-                                if (!i) return clearInterval(a);\n-                            }, 400);\n-                            l.on(n, \"mouseout\", o);\n-                        }\n-                        s(M, \"showTooltipFor\");\n-\n-                        function F(t, e, r) {\n-                            this.marked = [], e instanceof Function && (e = {\n-                                getAnnotations: e\n-                            }), (!e || e === !0) && (e = {}), this.options = {}, this.linterOptions = e.options || {};\n-                            for (var n in C) this.options[n] = C[n];\n-                            for (var n in e) C.hasOwnProperty(n) ? e[n] != null && (this.options[n] = e[n]) : e.options || (this.linterOptions[n] = e[n]);\n-                            this.timeout = null, this.hasGutter = r, this.onMouseOver = function(i) {\n-                                U(t, i);\n-                            }, this.waitingFor = 0;\n-                        }\n-                        s(F, \"LintState\");\n-                        var C = {\n-                            highlightLines: !1,\n-                            tooltips: !0,\n-                            delay: 500,\n-                            lintOnChange: !0,\n-                            getAnnotations: null,\n-                            async: !1,\n-                            selfContain: null,\n-                            formatAnnotation: null,\n-                            onUpdateLinting: null\n-                        };\n-\n-                        function E(t) {\n-                            var e = t.state.lint;\n-                            e.hasGutter && t.clearGutter(u), e.options.highlightLines && G(t);\n-                            for (var r = 0; r < e.marked.length; ++r) e.marked[r].clear();\n-                            e.marked.length = 0;\n-                        }\n-                        s(E, \"clearMarks\");\n-\n-                        function G(t) {\n-                            t.eachLine(function(e) {\n-                                var r = e.wrapClass && /\\bCodeMirror-lint-line-\\w+\\b/.exec(e.wrapClass);\n-                                r && t.removeLineClass(e, \"wrap\", r[0]);\n-                            });\n-                        }\n-                        s(G, \"clearErrorLines\");\n-\n-                        function I(t, e, r, n, i) {\n-                            var o = document.createElement(\"div\"),\n-                                a = o;\n-                            return o.className = \"CodeMirror-lint-marker CodeMirror-lint-marker-\" + r, n && (a = o.appendChild(document.createElement(\"div\")), a.className = \"CodeMirror-lint-marker CodeMirror-lint-marker-multiple\"), i != !1 && l.on(a, \"mouseover\", function(f) {\n-                                M(t, f, e, a);\n-                            }), o;\n-                        }\n-                        s(I, \"makeMarker\");\n-\n-                        function D(t, e) {\n-                            return t == \"error\" ? t : e;\n-                        }\n-                        s(D, \"getMaxSeverity\");\n-\n-                        function j(t) {\n-                            for (var e = [], r = 0; r < t.length; ++r) {\n-                                var n = t[r],\n-                                    i = n.from.line;\n-                                (e[i] || (e[i] = [])).push(n);\n-                            }\n-                            return e;\n-                        }\n-                        s(j, \"groupByLine\");\n-\n-                        function N(t) {\n-                            var e = t.severity;\n-                            e || (e = \"error\");\n-                            var r = document.createElement(\"div\");\n-                            return r.className = \"CodeMirror-lint-message CodeMirror-lint-message-\" + e, typeof t.messageHTML < \"u\" ? r.innerHTML = t.messageHTML : r.appendChild(document.createTextNode(t.message)), r;\n-                        }\n-                        s(N, \"annotationTooltip\");\n-\n-                        function H(t, e) {\n-                            var r = t.state.lint,\n-                                n = ++r.waitingFor;\n-\n-                            function i() {\n-                                n = -1, t.off(\"change\", i);\n-                            }\n-                            s(i, \"abort\"), t.on(\"change\", i), e(t.getValue(), function(o, a) {\n-                                t.off(\"change\", i), r.waitingFor == n && (a && o instanceof l && (o = a), t.operation(function() {\n-                                    O(t, o);\n-                                }));\n-                            }, r.linterOptions, t);\n+                const hex = {\n+                    test: isColorString('#'),\n+                    parse: parseHex,\n+                    transform: rgba.transform\n+                };\n+                const color = {\n+                    test: v => rgba.test(v) || hex.test(v) || hsla.test(v),\n+                    parse: v => {\n+                        if (rgba.test(v)) {\n+                            return rgba.parse(v);\n+                        } else if (hsla.test(v)) {\n+                            return hsla.parse(v);\n+                        } else {\n+                            return hex.parse(v);\n                         }\n-                        s(H, \"lintAsync\");\n+                    },\n+                    transform: v => {\n+                        return isString(v) ? v : v.hasOwnProperty('red') ? rgba.transform(v) : hsla.transform(v);\n+                    }\n+                };\n+                const colorToken = '${c}';\n+                const numberToken = '${n}';\n \n-                        function k(t) {\n-                            var e = t.state.lint;\n-                            if (e) {\n-                                var r = e.options,\n-                                    n = r.getAnnotations || t.getHelper(l.Pos(0, 0), \"lint\");\n-                                if (n)\n-                                    if (r.async || n.async) H(t, n);\n-                                    else {\n-                                        var i = n(t.getValue(), e.linterOptions, t);\n-                                        if (!i) return;\n-                                        i.then ? i.then(function(o) {\n-                                            t.operation(function() {\n-                                                O(t, o);\n-                                            });\n-                                        }) : t.operation(function() {\n-                                            O(t, i);\n-                                        });\n-                                    }\n-                            }\n-                        }\n-                        s(k, \"startLinting\");\n+                function test(v) {\n+                    var _a, _b, _c, _d;\n+                    return isNaN(v) && isString(v) && ((_b = (_a = v.match(floatRegex)) === null || _a === void 0 ? void 0 : _a.length) !== null && _b !== void 0 ? _b : 0) + ((_d = (_c = v.match(colorRegex)) === null || _c === void 0 ? void 0 : _c.length) !== null && _d !== void 0 ? _d : 0) > 0;\n+                }\n \n-                        function O(t, e) {\n-                            var r = t.state.lint;\n-                            if (r) {\n-                                var n = r.options;\n-                                E(t);\n-                                for (var i = j(e), o = 0; o < i.length; ++o) {\n-                                    var a = i[o];\n-                                    if (a) {\n-                                        var f = [];\n-                                        a = a.filter(function(w) {\n-                                            return f.indexOf(w.message) > -1 ? !1 : f.push(w.message);\n-                                        });\n-                                        for (var p = null, m = r.hasGutter && document.createDocumentFragment(), T = 0; T < a.length; ++T) {\n-                                            var d = a[T],\n-                                                y = d.severity;\n-                                            y || (y = \"error\"), p = D(p, y), n.formatAnnotation && (d = n.formatAnnotation(d)), r.hasGutter && m.appendChild(N(d)), d.to && r.marked.push(t.markText(d.from, d.to, {\n-                                                className: \"CodeMirror-lint-mark CodeMirror-lint-mark-\" + y,\n-                                                __annotation: d\n-                                            }));\n-                                        }\n-                                        r.hasGutter && t.setGutterMarker(o, u, I(t, m, p, i[o].length > 1, n.tooltips)), n.highlightLines && t.addLineClass(o, \"wrap\", g + p);\n-                                    }\n-                                }\n-                                n.onUpdateLinting && n.onUpdateLinting(e, i, t);\n-                            }\n-                        }\n-                        s(O, \"updateLinting\");\n+                function analyse(v) {\n+                    if (typeof v === 'number') v = `${v}`;\n+                    const values = [];\n+                    let numColors = 0;\n+                    const colors = v.match(colorRegex);\n+                    if (colors) {\n+                        numColors = colors.length;\n+                        v = v.replace(colorRegex, colorToken);\n+                        values.push(...colors.map(color.parse));\n+                    }\n+                    const numbers = v.match(floatRegex);\n+                    if (numbers) {\n+                        v = v.replace(floatRegex, numberToken);\n+                        values.push(...numbers.map(number.parse));\n+                    }\n+                    return {\n+                        values,\n+                        numColors,\n+                        tokenised: v\n+                    };\n+                }\n \n-                        function b(t) {\n-                            var e = t.state.lint;\n-                            e && (clearTimeout(e.timeout), e.timeout = setTimeout(function() {\n-                                k(t);\n-                            }, e.options.delay));\n-                        }\n-                        s(b, \"onChange\");\n+                function parse(v) {\n+                    return analyse(v).values;\n+                }\n \n-                        function P(t, e, r) {\n-                            for (var n = r.target || r.srcElement, i = document.createDocumentFragment(), o = 0; o < e.length; o++) {\n-                                var a = e[o];\n-                                i.appendChild(N(a));\n-                            }\n-                            M(t, r, i, n);\n+                function createTransformer(v) {\n+                    const {\n+                        values,\n+                        numColors,\n+                        tokenised\n+                    } = analyse(v);\n+                    const numValues = values.length;\n+                    return v => {\n+                        let output = tokenised;\n+                        for (let i = 0; i < numValues; i++) {\n+                            output = output.replace(i < numColors ? colorToken : numberToken, i < numColors ? color.transform(v[i]) : sanitize(v[i]));\n                         }\n-                        s(P, \"popupTooltips\");\n+                        return output;\n+                    };\n+                }\n+                const convertNumbersToZero = v => typeof v === 'number' ? 0 : v;\n \n-                        function U(t, e) {\n-                            var r = e.target || e.srcElement;\n-                            if (/\\bCodeMirror-lint-mark-/.test(r.className)) {\n-                                for (var n = r.getBoundingClientRect(), i = (n.left + n.right) / 2, o = (n.top + n.bottom) / 2, a = t.findMarksAt(t.coordsChar({\n-                                        left: i,\n-                                        top: o\n-                                    }, \"client\")), f = [], p = 0; p < a.length; ++p) {\n-                                    var m = a[p].__annotation;\n-                                    m && f.push(m);\n-                                }\n-                                f.length && P(t, f, e);\n-                            }\n-                        }\n-                        s(U, \"onMouseOver\"), l.defineOption(\"lint\", !1, function(t, e, r) {\n-                            if (r && r != l.Init && (E(t), t.state.lint.options.lintOnChange !== !1 && t.off(\"change\", b), l.off(t.getWrapperElement(), \"mouseover\", t.state.lint.onMouseOver), clearTimeout(t.state.lint.timeout), delete t.state.lint), e) {\n-                                for (var n = t.getOption(\"gutters\"), i = !1, o = 0; o < n.length; ++o) n[o] == u && (i = !0);\n-                                var a = t.state.lint = new F(t, e, i);\n-                                a.options.lintOnChange && t.on(\"change\", b), a.options.tooltips != !1 && a.options.tooltips != \"gutter\" && l.on(t.getWrapperElement(), \"mouseover\", a.onMouseOver), k(t);\n-                            }\n-                        }), l.defineExtension(\"performLint\", function() {\n-                            k(this);\n-                        });\n-                    });\n-                })();\n-                var _ = B.exports;\n-                const R = x.getDefaultExportFromCjs(_),\n-                    V = q({\n-                        __proto__: null,\n-                        default: R\n-                    }, [_]);\n-                exports.lint = V;\n+                function getAnimatableNone(v) {\n+                    const parsed = parse(v);\n+                    const transformer = createTransformer(v);\n+                    return transformer(parsed.map(convertNumbersToZero));\n+                }\n+                const complex = {\n+                    test,\n+                    parse,\n+                    createTransformer,\n+                    getAnimatableNone\n+                };\n+                const maxDefaults = new Set(['brightness', 'contrast', 'saturate', 'opacity']);\n+\n+                function applyDefaultFilter(v) {\n+                    let [name, value] = v.slice(0, -1).split('(');\n+                    if (name === 'drop-shadow') return v;\n+                    const [number] = value.match(floatRegex) || [];\n+                    if (!number) return v;\n+                    const unit = value.replace(number, '');\n+                    let defaultValue = maxDefaults.has(name) ? 1 : 0;\n+                    if (number !== value) defaultValue *= 100;\n+                    return name + '(' + defaultValue + unit + ')';\n+                }\n+                const functionRegex = /([a-z-]*)\\(.*?\\)/g;\n+                const filter = Object.assign(Object.assign({}, complex), {\n+                    getAnimatableNone: v => {\n+                        const functions = v.match(functionRegex);\n+                        return functions ? functions.map(applyDefaultFilter).join(' ') : v;\n+                    }\n+                });\n+                exports.alpha = alpha;\n+                exports.color = color;\n+                exports.complex = complex;\n+                exports.degrees = degrees;\n+                exports.filter = filter;\n+                exports.hex = hex;\n+                exports.hsla = hsla;\n+                exports.number = number;\n+                exports.percent = percent;\n+                exports.progressPercentage = progressPercentage;\n+                exports.px = px;\n+                exports.rgbUnit = rgbUnit;\n+                exports.rgba = rgba;\n+                exports.scale = scale;\n+                exports.vh = vh;\n+                exports.vw = vw;\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-react/dist/lint.cjs2.js\":\n-            /*!**********************************************!*\\\n-              !*** ../../graphiql-react/dist/lint.cjs2.js ***!\n-              \\**********************************************/\n+        \"../../../node_modules/toggle-selection/index.js\":\n+            /*!*******************************************************!*\\\n+              !*** ../../../node_modules/toggle-selection/index.js ***!\n+              \\*******************************************************/\n             /***/\n-            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n+            (function(module) {\n \n+                \"use strict\";\n \n \n-                const t = __webpack_require__( /*! ./codemirror.cjs.js */ \"../../graphiql-react/dist/codemirror.cjs.js\"),\n-                    c = __webpack_require__( /*! graphql-language-service */ \"../../graphql-language-service/esm/index.js\");\n-                __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\");\n-                const a = [\"error\", \"warning\", \"information\", \"hint\"],\n-                    g = {\n-                        \"GraphQL: Validation\": \"validation\",\n-                        \"GraphQL: Deprecation\": \"deprecation\",\n-                        \"GraphQL: Syntax\": \"syntax\"\n-                    };\n-                t.CodeMirror.registerHelper(\"lint\", \"graphql\", (n, s) => {\n-                    const {\n-                        schema: r,\n-                        validationRules: i,\n-                        externalFragments: o\n-                    } = s;\n-                    return c.getDiagnostics(n, r, i, void 0, o).map(e => ({\n-                        message: e.message,\n-                        severity: e.severity ? a[e.severity - 1] : a[0],\n-                        type: e.source ? g[e.source] : void 0,\n-                        from: t.CodeMirror.Pos(e.range.start.line, e.range.start.character),\n-                        to: t.CodeMirror.Pos(e.range.end.line, e.range.end.character)\n-                    }));\n-                });\n+                module.exports = function() {\n+                    var selection = document.getSelection();\n+                    if (!selection.rangeCount) {\n+                        return function() {};\n+                    }\n+                    var active = document.activeElement;\n+                    var ranges = [];\n+                    for (var i = 0; i < selection.rangeCount; i++) {\n+                        ranges.push(selection.getRangeAt(i));\n+                    }\n+                    switch (active.tagName.toUpperCase()) {\n+                        // .toUpperCase handles XHTML\n+                        case 'INPUT':\n+                        case 'TEXTAREA':\n+                            active.blur();\n+                            break;\n+                        default:\n+                            active = null;\n+                            break;\n+                    }\n+                    selection.removeAllRanges();\n+                    return function() {\n+                        selection.type === 'Caret' && selection.removeAllRanges();\n+                        if (!selection.rangeCount) {\n+                            ranges.forEach(function(range) {\n+                                selection.addRange(range);\n+                            });\n+                        }\n+                        active && active.focus();\n+                    };\n+                };\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-react/dist/lint.cjs3.js\":\n-            /*!**********************************************!*\\\n-              !*** ../../graphiql-react/dist/lint.cjs3.js ***!\n-              \\**********************************************/\n+        \"../../../node_modules/tslib/tslib.es6.mjs\":\n+            /*!*************************************************!*\\\n+              !*** ../../../node_modules/tslib/tslib.es6.mjs ***!\n+              \\*************************************************/\n             /***/\n-            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n+            (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n-                var V = Object.defineProperty;\n-                var t = (e, n) => V(e, \"name\", {\n-                    value: n,\n-                    configurable: !0\n-                });\n-                const I = __webpack_require__( /*! ./codemirror.cjs.js */ \"../../graphiql-react/dist/codemirror.cjs.js\"),\n-                    b = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n-                __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\");\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.__addDisposableResource = __addDisposableResource;\n+                exports.__assign = void 0;\n+                exports.__asyncDelegator = __asyncDelegator;\n+                exports.__asyncGenerator = __asyncGenerator;\n+                exports.__asyncValues = __asyncValues;\n+                exports.__await = __await;\n+                exports.__awaiter = __awaiter;\n+                exports.__classPrivateFieldGet = __classPrivateFieldGet;\n+                exports.__classPrivateFieldIn = __classPrivateFieldIn;\n+                exports.__classPrivateFieldSet = __classPrivateFieldSet;\n+                exports.__createBinding = void 0;\n+                exports.__decorate = __decorate;\n+                exports.__disposeResources = __disposeResources;\n+                exports.__esDecorate = __esDecorate;\n+                exports.__exportStar = __exportStar;\n+                exports.__extends = __extends;\n+                exports.__generator = __generator;\n+                exports.__importDefault = __importDefault;\n+                exports.__importStar = __importStar;\n+                exports.__makeTemplateObject = __makeTemplateObject;\n+                exports.__metadata = __metadata;\n+                exports.__param = __param;\n+                exports.__propKey = __propKey;\n+                exports.__read = __read;\n+                exports.__rest = __rest;\n+                exports.__runInitializers = __runInitializers;\n+                exports.__setFunctionName = __setFunctionName;\n+                exports.__spread = __spread;\n+                exports.__spreadArray = __spreadArray;\n+                exports.__spreadArrays = __spreadArrays;\n+                exports.__values = __values;\n+                exports[\"default\"] = void 0;\n+                /******************************************************************************\n+                Copyright (c) Microsoft Corporation.\n \n-                function C(e) {\n-                    d = e, E = e.length, s = u = N = -1, o(), y();\n-                    const n = q();\n-                    return p(\"EOF\"), n;\n-                }\n-                t(C, \"jsonParse\");\n-                let d, E, s, u, N, r, l;\n+                Permission to use, copy, modify, and/or distribute this software for any\n+                purpose with or without fee is hereby granted.\n+\n+                THE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\n+                REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\n+                AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\n+                INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\n+                LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\n+                OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\n+                PERFORMANCE OF THIS SOFTWARE.\n+                ***************************************************************************** */\n+                /* global Reflect, Promise, SuppressedError, Symbol */\n \n-                function q() {\n-                    const e = s,\n-                        n = [];\n-                    if (p(\"{\"), !x(\"}\")) {\n-                        do n.push(M()); while (x(\",\"));\n-                        p(\"}\");\n+                var extendStatics = function(d, b) {\n+                    extendStatics = Object.setPrototypeOf || {\n+                        __proto__: []\n                     }\n-                    return {\n-                        kind: \"Object\",\n-                        start: e,\n-                        end: N,\n-                        members: n\n+                    instanceof Array && function(d, b) {\n+                        d.__proto__ = b;\n+                    } || function(d, b) {\n+                        for (var p in b)\n+                            if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];\n                     };\n-                }\n-                t(q, \"parseObj\");\n+                    return extendStatics(d, b);\n+                };\n \n-                function M() {\n-                    const e = s,\n-                        n = l === \"String\" ? G() : null;\n-                    p(\"String\"), p(\":\");\n-                    const i = B();\n-                    return {\n-                        kind: \"Member\",\n-                        start: e,\n-                        end: N,\n-                        key: n,\n-                        value: i\n-                    };\n-                }\n-                t(M, \"parseMember\");\n+                function __extends(d, b) {\n+                    if (typeof b !== \"function\" && b !== null) throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n+                    extendStatics(d, b);\n \n-                function v() {\n-                    const e = s,\n-                        n = [];\n-                    if (p(\"[\"), !x(\"]\")) {\n-                        do n.push(B()); while (x(\",\"));\n-                        p(\"]\");\n+                    function __() {\n+                        this.constructor = d;\n                     }\n-                    return {\n-                        kind: \"Array\",\n-                        start: e,\n-                        end: N,\n-                        values: n\n+                    d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n+                }\n+                var __assign = function() {\n+                    exports.__assign = __assign = Object.assign || function __assign(t) {\n+                        for (var s, i = 1, n = arguments.length; i < n; i++) {\n+                            s = arguments[i];\n+                            for (var p in s)\n+                                if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n+                        }\n+                        return t;\n                     };\n+                    return __assign.apply(this, arguments);\n+                };\n+                exports.__assign = __assign;\n+\n+                function __rest(s, e) {\n+                    var t = {};\n+                    for (var p in s)\n+                        if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];\n+                    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n+                        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n+                            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];\n+                        }\n+                    return t;\n                 }\n-                t(v, \"parseArr\");\n \n-                function B() {\n-                    switch (l) {\n-                        case \"[\":\n-                            return v();\n-                        case \"{\":\n-                            return q();\n-                        case \"String\":\n-                        case \"Number\":\n-                        case \"Boolean\":\n-                        case \"Null\":\n-                            const e = G();\n-                            return y(), e;\n-                    }\n-                    p(\"Value\");\n+                function __decorate(decorators, target, key, desc) {\n+                    var c = arguments.length,\n+                        r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc,\n+                        d;\n+                    if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n+                    else\n+                        for (var i = decorators.length - 1; i >= 0; i--)\n+                            if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n+                    return c > 3 && r && Object.defineProperty(target, key, r), r;\n                 }\n-                t(B, \"parseVal\");\n \n-                function G() {\n-                    return {\n-                        kind: l,\n-                        start: s,\n-                        end: u,\n-                        value: JSON.parse(d.slice(s, u))\n+                function __param(paramIndex, decorator) {\n+                    return function(target, key) {\n+                        decorator(target, key, paramIndex);\n                     };\n                 }\n-                t(G, \"curToken\");\n \n-                function p(e) {\n-                    if (l === e) {\n-                        y();\n-                        return;\n-                    }\n-                    let n;\n-                    if (l === \"EOF\") n = \"[end of file]\";\n-                    else if (u - s > 1) n = \"`\" + d.slice(s, u) + \"`\";\n-                    else {\n-                        const i = d.slice(s).match(/^.+?\\b/);\n-                        n = \"`\" + (i ? i[0] : d[s]) + \"`\";\n+                function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\n+                    function accept(f) {\n+                        if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\");\n+                        return f;\n                     }\n-                    throw k(`Expected ${e} but found ${n}.`);\n+                    var kind = contextIn.kind,\n+                        key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\n+                    var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\n+                    var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\n+                    var _,\n+                        done = false;\n+                    for (var i = decorators.length - 1; i >= 0; i--) {\n+                        var context = {};\n+                        for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\n+                        for (var p in contextIn.access) context.access[p] = contextIn.access[p];\n+                        context.addInitializer = function(f) {\n+                            if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\");\n+                            extraInitializers.push(accept(f || null));\n+                        };\n+                        var result = (0, decorators[i])(kind === \"accessor\" ? {\n+                            get: descriptor.get,\n+                            set: descriptor.set\n+                        } : descriptor[key], context);\n+                        if (kind === \"accessor\") {\n+                            if (result === void 0) continue;\n+                            if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\n+                            if (_ = accept(result.get)) descriptor.get = _;\n+                            if (_ = accept(result.set)) descriptor.set = _;\n+                            if (_ = accept(result.init)) initializers.unshift(_);\n+                        } else if (_ = accept(result)) {\n+                            if (kind === \"field\") initializers.unshift(_);\n+                            else descriptor[key] = _;\n+                        }\n+                    }\n+                    if (target) Object.defineProperty(target, contextIn.name, descriptor);\n+                    done = true;\n+                };\n+\n+                function __runInitializers(thisArg, initializers, value) {\n+                    var useValue = arguments.length > 2;\n+                    for (var i = 0; i < initializers.length; i++) {\n+                        value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\n+                    }\n+                    return useValue ? value : void 0;\n+                };\n+\n+                function __propKey(x) {\n+                    return typeof x === \"symbol\" ? x : \"\".concat(x);\n+                };\n+\n+                function __setFunctionName(f, name, prefix) {\n+                    if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\n+                    return Object.defineProperty(f, \"name\", {\n+                        configurable: true,\n+                        value: prefix ? \"\".concat(prefix, \" \", name) : name\n+                    });\n+                };\n+\n+                function __metadata(metadataKey, metadataValue) {\n+                    if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\n                 }\n-                t(p, \"expect\");\n-                class j extends Error {\n-                    constructor(n, i) {\n-                        super(n), this.position = i;\n+\n+                function __awaiter(thisArg, _arguments, P, generator) {\n+                    function adopt(value) {\n+                        return value instanceof P ? value : new P(function(resolve) {\n+                            resolve(value);\n+                        });\n                     }\n-                }\n-                t(j, \"JSONSyntaxError\");\n+                    return new(P || (P = Promise))(function(resolve, reject) {\n+                        function fulfilled(value) {\n+                            try {\n+                                step(generator.next(value));\n+                            } catch (e) {\n+                                reject(e);\n+                            }\n+                        }\n \n-                function k(e) {\n-                    return new j(e, {\n-                        start: s,\n-                        end: u\n-                    });\n-                }\n-                t(k, \"syntaxError\");\n+                        function rejected(value) {\n+                            try {\n+                                step(generator[\"throw\"](value));\n+                            } catch (e) {\n+                                reject(e);\n+                            }\n+                        }\n \n-                function x(e) {\n-                    if (l === e) return y(), !0;\n+                        function step(result) {\n+                            result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n+                        }\n+                        step((generator = generator.apply(thisArg, _arguments || [])).next());\n+                    });\n                 }\n-                t(x, \"skip\");\n \n-                function o() {\n-                    return u < E && (u++, r = u === E ? 0 : d.charCodeAt(u)), r;\n-                }\n-                t(o, \"ch\");\n+                function __generator(thisArg, body) {\n+                    var _ = {\n+                            label: 0,\n+                            sent: function() {\n+                                if (t[0] & 1) throw t[1];\n+                                return t[1];\n+                            },\n+                            trys: [],\n+                            ops: []\n+                        },\n+                        f,\n+                        y,\n+                        t,\n+                        g;\n+                    return g = {\n+                        next: verb(0),\n+                        \"throw\": verb(1),\n+                        \"return\": verb(2)\n+                    }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() {\n+                        return this;\n+                    }), g;\n \n-                function y() {\n-                    for (N = u; r === 9 || r === 10 || r === 13 || r === 32;) o();\n-                    if (r === 0) {\n-                        l = \"EOF\";\n-                        return;\n-                    }\n-                    switch (s = u, r) {\n-                        case 34:\n-                            return l = \"String\", D();\n-                        case 45:\n-                        case 48:\n-                        case 49:\n-                        case 50:\n-                        case 51:\n-                        case 52:\n-                        case 53:\n-                        case 54:\n-                        case 55:\n-                        case 56:\n-                        case 57:\n-                            return l = \"Number\", H();\n-                        case 102:\n-                            if (d.slice(s, s + 5) !== \"false\") break;\n-                            u += 4, o(), l = \"Boolean\";\n-                            return;\n-                        case 110:\n-                            if (d.slice(s, s + 4) !== \"null\") break;\n-                            u += 3, o(), l = \"Null\";\n-                            return;\n-                        case 116:\n-                            if (d.slice(s, s + 4) !== \"true\") break;\n-                            u += 3, o(), l = \"Boolean\";\n-                            return;\n+                    function verb(n) {\n+                        return function(v) {\n+                            return step([n, v]);\n+                        };\n                     }\n-                    l = d[s], o();\n-                }\n-                t(y, \"lex\");\n \n-                function D() {\n-                    for (o(); r !== 34 && r > 31;)\n-                        if (r === 92) switch (r = o(), r) {\n-                            case 34:\n-                            case 47:\n-                            case 92:\n-                            case 98:\n-                            case 102:\n-                            case 110:\n-                            case 114:\n-                            case 116:\n-                                o();\n-                                break;\n-                            case 117:\n-                                o(), w(), w(), w(), w();\n-                                break;\n-                            default:\n-                                throw k(\"Bad character escape sequence.\");\n-                        } else {\n-                            if (u === E) throw k(\"Unterminated string.\");\n-                            o();\n+                    function step(op) {\n+                        if (f) throw new TypeError(\"Generator is already executing.\");\n+                        while (g && (g = 0, op[0] && (_ = 0)), _) try {\n+                            if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n+                            if (y = 0, t) op = [op[0] & 2, t.value];\n+                            switch (op[0]) {\n+                                case 0:\n+                                case 1:\n+                                    t = op;\n+                                    break;\n+                                case 4:\n+                                    _.label++;\n+                                    return {\n+                                        value: op[1],\n+                                            done: false\n+                                    };\n+                                case 5:\n+                                    _.label++;\n+                                    y = op[1];\n+                                    op = [0];\n+                                    continue;\n+                                case 7:\n+                                    op = _.ops.pop();\n+                                    _.trys.pop();\n+                                    continue;\n+                                default:\n+                                    if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {\n+                                        _ = 0;\n+                                        continue;\n+                                    }\n+                                    if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {\n+                                        _.label = op[1];\n+                                        break;\n+                                    }\n+                                    if (op[0] === 6 && _.label < t[1]) {\n+                                        _.label = t[1];\n+                                        t = op;\n+                                        break;\n+                                    }\n+                                    if (t && _.label < t[2]) {\n+                                        _.label = t[2];\n+                                        _.ops.push(op);\n+                                        break;\n+                                    }\n+                                    if (t[2]) _.ops.pop();\n+                                    _.trys.pop();\n+                                    continue;\n+                            }\n+                            op = body.call(thisArg, _);\n+                        } catch (e) {\n+                            op = [6, e];\n+                            y = 0;\n+                        } finally {\n+                            f = t = 0;\n                         }\n-                    if (r === 34) {\n-                        o();\n-                        return;\n+                        if (op[0] & 5) throw op[1];\n+                        return {\n+                            value: op[0] ? op[1] : void 0,\n+                            done: true\n+                        };\n                     }\n-                    throw k(\"Unterminated string.\");\n                 }\n-                t(D, \"readString\");\n+                var __createBinding = exports.__createBinding = Object.create ? function(o, m, k, k2) {\n+                    if (k2 === undefined) k2 = k;\n+                    var desc = Object.getOwnPropertyDescriptor(m, k);\n+                    if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n+                        desc = {\n+                            enumerable: true,\n+                            get: function() {\n+                                return m[k];\n+                            }\n+                        };\n+                    }\n+                    Object.defineProperty(o, k2, desc);\n+                } : function(o, m, k, k2) {\n+                    if (k2 === undefined) k2 = k;\n+                    o[k2] = m[k];\n+                };\n \n-                function w() {\n-                    if (r >= 48 && r <= 57 || r >= 65 && r <= 70 || r >= 97 && r <= 102) return o();\n-                    throw k(\"Expected hexadecimal digit.\");\n+                function __exportStar(m, o) {\n+                    for (var p in m)\n+                        if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\n                 }\n-                t(w, \"readHex\");\n \n-                function H() {\n-                    r === 45 && o(), r === 48 ? o() : $(), r === 46 && (o(), $()), (r === 69 || r === 101) && (r = o(), (r === 43 || r === 45) && o(), $());\n+                function __values(o) {\n+                    var s = typeof Symbol === \"function\" && Symbol.iterator,\n+                        m = s && o[s],\n+                        i = 0;\n+                    if (m) return m.call(o);\n+                    if (o && typeof o.length === \"number\") return {\n+                        next: function() {\n+                            if (o && i >= o.length) o = void 0;\n+                            return {\n+                                value: o && o[i++],\n+                                done: !o\n+                            };\n+                        }\n+                    };\n+                    throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n                 }\n-                t(H, \"readNumber\");\n \n-                function $() {\n-                    if (r < 48 || r > 57) throw k(\"Expected decimal digit.\");\n-                    do o(); while (r >= 48 && r <= 57);\n-                }\n-                t($, \"readDigits\");\n-                I.CodeMirror.registerHelper(\"lint\", \"graphql-variables\", (e, n, i) => {\n-                    if (!e) return [];\n-                    let f;\n+                function __read(o, n) {\n+                    var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n+                    if (!m) return o;\n+                    var i = m.call(o),\n+                        r,\n+                        ar = [],\n+                        e;\n                     try {\n-                        f = C(e);\n-                    } catch (c) {\n-                        if (c instanceof j) return [F(i, c.position, c.message)];\n-                        throw c;\n-                    }\n-                    const {\n-                        variableToType: a\n-                    } = n;\n-                    return a ? U(i, a, f) : [];\n-                });\n-\n-                function U(e, n, i) {\n-                    var f;\n-                    const a = [];\n-                    for (const c of i.members)\n-                        if (c) {\n-                            const h = (f = c.key) === null || f === void 0 ? void 0 : f.value,\n-                                m = n[h];\n-                            if (m)\n-                                for (const [O, Q] of g(m, c.value)) a.push(F(e, O, Q));\n-                            else a.push(F(e, c.key, `Variable \"$${h}\" does not appear in any GraphQL query.`));\n+                        while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n+                    } catch (error) {\n+                        e = {\n+                            error: error\n+                        };\n+                    } finally {\n+                        try {\n+                            if (r && !r.done && (m = i[\"return\"])) m.call(i);\n+                        } finally {\n+                            if (e) throw e.error;\n                         }\n-                    return a;\n+                    }\n+                    return ar;\n                 }\n-                t(U, \"validateVariables\");\n \n-                function g(e, n) {\n-                    if (!e || !n) return [];\n-                    if (e instanceof b.GraphQLNonNull) return n.kind === \"Null\" ? [\n-                        [n, `Type \"${e}\" is non-nullable and cannot be null.`]\n-                    ] : g(e.ofType, n);\n-                    if (n.kind === \"Null\") return [];\n-                    if (e instanceof b.GraphQLList) {\n-                        const i = e.ofType;\n-                        if (n.kind === \"Array\") {\n-                            const f = n.values || [];\n-                            return L(f, a => g(i, a));\n-                        }\n-                        return g(i, n);\n-                    }\n-                    if (e instanceof b.GraphQLInputObjectType) {\n-                        if (n.kind !== \"Object\") return [\n-                            [n, `Type \"${e}\" must be an Object.`]\n-                        ];\n-                        const i = Object.create(null),\n-                            f = L(n.members, a => {\n-                                var c;\n-                                const h = (c = a == null ? void 0 : a.key) === null || c === void 0 ? void 0 : c.value;\n-                                i[h] = !0;\n-                                const m = e.getFields()[h];\n-                                if (!m) return [\n-                                    [a.key, `Type \"${e}\" does not have a field \"${h}\".`]\n-                                ];\n-                                const O = m ? m.type : void 0;\n-                                return g(O, a.value);\n-                            });\n-                        for (const a of Object.keys(e.getFields())) {\n-                            const c = e.getFields()[a];\n-                            !i[a] && c.type instanceof b.GraphQLNonNull && !c.defaultValue && f.push([n, `Object of type \"${e}\" is missing required field \"${a}\".`]);\n-                        }\n-                        return f;\n-                    }\n-                    return e.name === \"Boolean\" && n.kind !== \"Boolean\" || e.name === \"String\" && n.kind !== \"String\" || e.name === \"ID\" && n.kind !== \"Number\" && n.kind !== \"String\" || e.name === \"Float\" && n.kind !== \"Number\" || e.name === \"Int\" && (n.kind !== \"Number\" || (n.value | 0) !== n.value) ? [\n-                        [n, `Expected value of type \"${e}\".`]\n-                    ] : (e instanceof b.GraphQLEnumType || e instanceof b.GraphQLScalarType) && (n.kind !== \"String\" && n.kind !== \"Number\" && n.kind !== \"Boolean\" && n.kind !== \"Null\" || _(e.parseValue(n.value))) ? [\n-                        [n, `Expected value of type \"${e}\".`]\n-                    ] : [];\n+                /** @deprecated */\n+                function __spread() {\n+                    for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n+                    return ar;\n                 }\n-                t(g, \"validateValue\");\n \n-                function F(e, n, i) {\n-                    return {\n-                        message: i,\n-                        severity: \"error\",\n-                        type: \"validation\",\n-                        from: e.posFromIndex(n.start),\n-                        to: e.posFromIndex(n.end)\n-                    };\n+                /** @deprecated */\n+                function __spreadArrays() {\n+                    for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\n+                    for (var r = Array(s), k = 0, i = 0; i < il; i++)\n+                        for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) r[k] = a[j];\n+                    return r;\n                 }\n-                t(F, \"lintError\");\n \n-                function _(e) {\n-                    return e == null || e !== e;\n+                function __spreadArray(to, from, pack) {\n+                    if (pack || arguments.length === 2)\n+                        for (var i = 0, l = from.length, ar; i < l; i++) {\n+                            if (ar || !(i in from)) {\n+                                if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n+                                ar[i] = from[i];\n+                            }\n+                        }\n+                    return to.concat(ar || Array.prototype.slice.call(from));\n                 }\n-                t(_, \"isNullish\");\n \n-                function L(e, n) {\n-                    return Array.prototype.concat.apply([], e.map(n));\n+                function __await(v) {\n+                    return this instanceof __await ? (this.v = v, this) : new __await(v);\n                 }\n-                t(L, \"mapCat\");\n \n-                /***/\n-            }),\n+                function __asyncGenerator(thisArg, _arguments, generator) {\n+                    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n+                    var g = generator.apply(thisArg, _arguments || []),\n+                        i,\n+                        q = [];\n+                    return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function() {\n+                        return this;\n+                    }, i;\n \n-        /***/\n-        \"../../graphiql-react/dist/matchbrackets.cjs.js\":\n-            /*!******************************************************!*\\\n-              !*** ../../graphiql-react/dist/matchbrackets.cjs.js ***!\n-              \\******************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                    function verb(n) {\n+                        if (g[n]) i[n] = function(v) {\n+                            return new Promise(function(a, b) {\n+                                q.push([n, v, a, b]) > 1 || resume(n, v);\n+                            });\n+                        };\n+                    }\n \n+                    function resume(n, v) {\n+                        try {\n+                            step(g[n](v));\n+                        } catch (e) {\n+                            settle(q[0][3], e);\n+                        }\n+                    }\n \n+                    function step(r) {\n+                        r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r);\n+                    }\n \n-                var i = Object.defineProperty;\n-                var s = (e, c) => i(e, \"name\", {\n-                    value: c,\n-                    configurable: !0\n-                });\n-                const u = __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\"),\n-                    f = __webpack_require__( /*! ./matchbrackets.cjs2.js */ \"../../graphiql-react/dist/matchbrackets.cjs2.js\");\n-\n-                function b(e, c) {\n-                    for (var o = 0; o < c.length; o++) {\n-                        const t = c[o];\n-                        if (typeof t != \"string\" && !Array.isArray(t)) {\n-                            for (const r in t)\n-                                if (r !== \"default\" && !(r in e)) {\n-                                    const a = Object.getOwnPropertyDescriptor(t, r);\n-                                    a && Object.defineProperty(e, r, a.get ? a : {\n-                                        enumerable: !0,\n-                                        get: () => t[r]\n-                                    });\n-                                }\n-                        }\n+                    function fulfill(value) {\n+                        resume(\"next\", value);\n+                    }\n+\n+                    function reject(value) {\n+                        resume(\"throw\", value);\n+                    }\n+\n+                    function settle(f, v) {\n+                        if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]);\n                     }\n-                    return Object.freeze(Object.defineProperty(e, Symbol.toStringTag, {\n-                        value: \"Module\"\n-                    }));\n                 }\n-                s(b, \"_mergeNamespaces\");\n-                var n = f.requireMatchbrackets();\n-                const l = u.getDefaultExportFromCjs(n),\n-                    m = b({\n-                        __proto__: null,\n-                        default: l\n-                    }, [n]);\n-                exports.matchbrackets = m;\n \n-                /***/\n-            }),\n+                function __asyncDelegator(o) {\n+                    var i, p;\n+                    return i = {}, verb(\"next\"), verb(\"throw\", function(e) {\n+                        throw e;\n+                    }), verb(\"return\"), i[Symbol.iterator] = function() {\n+                        return this;\n+                    }, i;\n \n-        /***/\n-        \"../../graphiql-react/dist/matchbrackets.cjs2.js\":\n-            /*!*******************************************************!*\\\n-              !*** ../../graphiql-react/dist/matchbrackets.cjs2.js ***!\n-              \\*******************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+                    function verb(n, f) {\n+                        i[n] = o[n] ? function(v) {\n+                            return (p = !p) ? {\n+                                value: __await(o[n](v)),\n+                                done: false\n+                            } : f ? f(v) : v;\n+                        } : f;\n+                    }\n+                }\n \n+                function __asyncValues(o) {\n+                    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n+                    var m = o[Symbol.asyncIterator],\n+                        i;\n+                    return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function() {\n+                        return this;\n+                    }, i);\n \n+                    function verb(n) {\n+                        i[n] = o[n] && function(v) {\n+                            return new Promise(function(resolve, reject) {\n+                                v = o[n](v), settle(resolve, reject, v.done, v.value);\n+                            });\n+                        };\n+                    }\n \n-                var R = Object.defineProperty;\n-                var f = (L, y) => R(L, \"name\", {\n-                    value: y,\n-                    configurable: !0\n-                });\n-                const F = __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\");\n-                var T = {\n-                        exports: {}\n-                    },\n-                    E;\n+                    function settle(resolve, reject, d, v) {\n+                        Promise.resolve(v).then(function(v) {\n+                            resolve({\n+                                value: v,\n+                                done: d\n+                            });\n+                        }, reject);\n+                    }\n+                }\n \n-                function I() {\n-                    return E || (E = 1, function(L, y) {\n-                        (function(o) {\n-                            o(F.requireCodemirror());\n-                        })(function(o) {\n-                            var S = /MSIE \\d/.test(navigator.userAgent) && (document.documentMode == null || document.documentMode < 8),\n-                                g = o.Pos,\n-                                B = {\n-                                    \"(\": \")>\",\n-                                    \")\": \"(<\",\n-                                    \"[\": \"]>\",\n-                                    \"]\": \"[<\",\n-                                    \"{\": \"}>\",\n-                                    \"}\": \"{<\",\n-                                    \"<\": \">>\",\n-                                    \">\": \"<<\"\n-                                };\n+                function __makeTemplateObject(cooked, raw) {\n+                    if (Object.defineProperty) {\n+                        Object.defineProperty(cooked, \"raw\", {\n+                            value: raw\n+                        });\n+                    } else {\n+                        cooked.raw = raw;\n+                    }\n+                    return cooked;\n+                };\n+                var __setModuleDefault = Object.create ? function(o, v) {\n+                    Object.defineProperty(o, \"default\", {\n+                        enumerable: true,\n+                        value: v\n+                    });\n+                } : function(o, v) {\n+                    o[\"default\"] = v;\n+                };\n \n-                            function A(t) {\n-                                return t && t.bracketRegex || /[(){}[\\]]/;\n-                            }\n-                            f(A, \"bracketRegex\");\n+                function __importStar(mod) {\n+                    if (mod && mod.__esModule) return mod;\n+                    var result = {};\n+                    if (mod != null)\n+                        for (var k in mod)\n+                            if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n+                    __setModuleDefault(result, mod);\n+                    return result;\n+                }\n \n-                            function b(t, r, e) {\n-                                var s = t.getLineHandle(r.line),\n-                                    n = r.ch - 1,\n-                                    h = e && e.afterCursor;\n-                                h == null && (h = /(^| )cm-fat-cursor($| )/.test(t.getWrapperElement().className));\n-                                var l = A(e),\n-                                    u = !h && n >= 0 && l.test(s.text.charAt(n)) && B[s.text.charAt(n)] || l.test(s.text.charAt(n + 1)) && B[s.text.charAt(++n)];\n-                                if (!u) return null;\n-                                var a = u.charAt(1) == \">\" ? 1 : -1;\n-                                if (e && e.strict && a > 0 != (n == r.ch)) return null;\n-                                var k = t.getTokenTypeAt(g(r.line, n + 1)),\n-                                    i = H(t, g(r.line, n + (a > 0 ? 1 : 0)), a, k, e);\n-                                return i == null ? null : {\n-                                    from: g(r.line, n),\n-                                    to: i && i.pos,\n-                                    match: i && i.ch == u.charAt(0),\n-                                    forward: a > 0\n-                                };\n-                            }\n-                            f(b, \"findMatchingBracket\");\n+                function __importDefault(mod) {\n+                    return mod && mod.__esModule ? mod : {\n+                        default: mod\n+                    };\n+                }\n \n-                            function H(t, r, e, s, n) {\n-                                for (var h = n && n.maxScanLineLength || 1e4, l = n && n.maxScanLines || 1e3, u = [], a = A(n), k = e > 0 ? Math.min(r.line + l, t.lastLine() + 1) : Math.max(t.firstLine() - 1, r.line - l), i = r.line; i != k; i += e) {\n-                                    var c = t.getLine(i);\n-                                    if (c) {\n-                                        var v = e > 0 ? 0 : c.length - 1,\n-                                            q = e > 0 ? c.length : -1;\n-                                        if (!(c.length > h))\n-                                            for (i == r.line && (v = r.ch - (e < 0 ? 1 : 0)); v != q; v += e) {\n-                                                var d = c.charAt(v);\n-                                                if (a.test(d) && (s === void 0 || (t.getTokenTypeAt(g(i, v + 1)) || \"\") == (s || \"\"))) {\n-                                                    var m = B[d];\n-                                                    if (m && m.charAt(1) == \">\" == e > 0) u.push(d);\n-                                                    else if (u.length) u.pop();\n-                                                    else return {\n-                                                        pos: g(i, v),\n-                                                        ch: d\n-                                                    };\n-                                                }\n-                                            }\n-                                    }\n-                                }\n-                                return i - e == (e > 0 ? t.lastLine() : t.firstLine()) ? !1 : null;\n-                            }\n-                            f(H, \"scanForBracket\");\n+                function __classPrivateFieldGet(receiver, state, kind, f) {\n+                    if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\n+                    if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\n+                    return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\n+                }\n \n-                            function M(t, r, e) {\n-                                for (var s = t.state.matchBrackets.maxHighlightLineLength || 1e3, n = e && e.highlightNonMatching, h = [], l = t.listSelections(), u = 0; u < l.length; u++) {\n-                                    var a = l[u].empty() && b(t, l[u].head, e);\n-                                    if (a && (a.match || n !== !1) && t.getLine(a.from.line).length <= s) {\n-                                        var k = a.match ? \"CodeMirror-matchingbracket\" : \"CodeMirror-nonmatchingbracket\";\n-                                        h.push(t.markText(a.from, g(a.from.line, a.from.ch + 1), {\n-                                            className: k\n-                                        })), a.to && t.getLine(a.to.line).length <= s && h.push(t.markText(a.to, g(a.to.line, a.to.ch + 1), {\n-                                            className: k\n-                                        }));\n-                                    }\n-                                }\n-                                if (h.length) {\n-                                    S && t.state.focused && t.focus();\n-                                    var i = f(function() {\n-                                        t.operation(function() {\n-                                            for (var c = 0; c < h.length; c++) h[c].clear();\n-                                        });\n-                                    }, \"clear\");\n-                                    if (r) setTimeout(i, 800);\n-                                    else return i;\n-                                }\n-                            }\n-                            f(M, \"matchBrackets\");\n+                function __classPrivateFieldSet(receiver, state, value, kind, f) {\n+                    if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\n+                    if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\n+                    if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\n+                    return kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value), value;\n+                }\n \n-                            function x(t) {\n-                                t.operation(function() {\n-                                    t.state.matchBrackets.currentlyHighlighted && (t.state.matchBrackets.currentlyHighlighted(), t.state.matchBrackets.currentlyHighlighted = null), t.state.matchBrackets.currentlyHighlighted = M(t, !1, t.state.matchBrackets);\n-                                });\n-                            }\n-                            f(x, \"doMatchBrackets\");\n+                function __classPrivateFieldIn(state, receiver) {\n+                    if (receiver === null || typeof receiver !== \"object\" && typeof receiver !== \"function\") throw new TypeError(\"Cannot use 'in' operator on non-object\");\n+                    return typeof state === \"function\" ? receiver === state : state.has(receiver);\n+                }\n \n-                            function p(t) {\n-                                t.state.matchBrackets && t.state.matchBrackets.currentlyHighlighted && (t.state.matchBrackets.currentlyHighlighted(), t.state.matchBrackets.currentlyHighlighted = null);\n-                            }\n-                            f(p, \"clearHighlighted\"), o.defineOption(\"matchBrackets\", !1, function(t, r, e) {\n-                                e && e != o.Init && (t.off(\"cursorActivity\", x), t.off(\"focus\", x), t.off(\"blur\", p), p(t)), r && (t.state.matchBrackets = typeof r == \"object\" ? r : {}, t.on(\"cursorActivity\", x), t.on(\"focus\", x), t.on(\"blur\", p));\n-                            }), o.defineExtension(\"matchBrackets\", function() {\n-                                M(this, !0);\n-                            }), o.defineExtension(\"findMatchingBracket\", function(t, r, e) {\n-                                return (e || typeof r == \"boolean\") && (e ? (e.strict = r, r = e) : r = r ? {\n-                                    strict: !0\n-                                } : null), b(this, t, r);\n-                            }), o.defineExtension(\"scanForBracket\", function(t, r, e, s) {\n-                                return H(this, t, r, e, s);\n-                            });\n+                function __addDisposableResource(env, value, async) {\n+                    if (value !== null && value !== void 0) {\n+                        if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\n+                        var dispose;\n+                        if (async) {\n+                            if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\n+                            dispose = value[Symbol.asyncDispose];\n+                        }\n+                        if (dispose === void 0) {\n+                            if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\n+                            dispose = value[Symbol.dispose];\n+                        }\n+                        if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\n+                        env.stack.push({\n+                            value: value,\n+                            dispose: dispose,\n+                            async: async\n+                        });\n+                    } else if (async) {\n+                        env.stack.push({\n+                            async: true\n                         });\n-                    }()), T.exports;\n+                    }\n+                    return value;\n+                }\n+                var _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function(error, suppressed, message) {\n+                    var e = new Error(message);\n+                    return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\n+                };\n+\n+                function __disposeResources(env) {\n+                    function fail(e) {\n+                        env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\n+                        env.hasError = true;\n+                    }\n+\n+                    function next() {\n+                        while (env.stack.length) {\n+                            var rec = env.stack.pop();\n+                            try {\n+                                var result = rec.dispose && rec.dispose.call(rec.value);\n+                                if (rec.async) return Promise.resolve(result).then(next, function(e) {\n+                                    fail(e);\n+                                    return next();\n+                                });\n+                            } catch (e) {\n+                                fail(e);\n+                            }\n+                        }\n+                        if (env.hasError) throw env.error;\n+                    }\n+                    return next();\n                 }\n-                f(I, \"requireMatchbrackets\");\n-                exports.requireMatchbrackets = I;\n+                var _default = exports[\"default\"] = {\n+                    __extends,\n+                    __assign,\n+                    __rest,\n+                    __decorate,\n+                    __param,\n+                    __metadata,\n+                    __awaiter,\n+                    __generator,\n+                    __createBinding,\n+                    __exportStar,\n+                    __values,\n+                    __read,\n+                    __spread,\n+                    __spreadArrays,\n+                    __spreadArray,\n+                    __await,\n+                    __asyncGenerator,\n+                    __asyncDelegator,\n+                    __asyncValues,\n+                    __makeTemplateObject,\n+                    __importStar,\n+                    __importDefault,\n+                    __classPrivateFieldGet,\n+                    __classPrivateFieldSet,\n+                    __classPrivateFieldIn,\n+                    __addDisposableResource,\n+                    __disposeResources\n+                };\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-react/dist/mode-indent.cjs.js\":\n-            /*!****************************************************!*\\\n-              !*** ../../graphiql-react/dist/mode-indent.cjs.js ***!\n-              \\****************************************************/\n+        \"../../../node_modules/uc.micro/build/index.cjs.js\":\n+            /*!*********************************************************!*\\\n+              !*** ../../../node_modules/uc.micro/build/index.cjs.js ***!\n+              \\*********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n-                var o = Object.defineProperty;\n-                var v = (n, t) => o(n, \"name\", {\n-                    value: t,\n-                    configurable: !0\n-                });\n-\n-                function s(n, t) {\n-                    var e, i;\n-                    const {\n-                        levels: l,\n-                        indentLevel: d\n-                    } = n;\n-                    return ((!l || l.length === 0 ? d : l.at(-1) - (!((e = this.electricInput) === null || e === void 0) && e.test(t) ? 1 : 0)) || 0) * (((i = this.config) === null || i === void 0 ? void 0 : i.indentUnit) || 0);\n-                }\n-                v(s, \"indent\");\n-                exports.indent = s;\n+                var regex$5 = /[\\0-\\uD7FF\\uE000-\\uFFFF]|[\\uD800-\\uDBFF][\\uDC00-\\uDFFF]|[\\uD800-\\uDBFF](?![\\uDC00-\\uDFFF])|(?:[^\\uD800-\\uDBFF]|^)[\\uDC00-\\uDFFF]/;\n+                var regex$4 = /[\\0-\\x1F\\x7F-\\x9F]/;\n+                var regex$3 = /[\\xAD\\u0600-\\u0605\\u061C\\u06DD\\u070F\\u0890\\u0891\\u08E2\\u180E\\u200B-\\u200F\\u202A-\\u202E\\u2060-\\u2064\\u2066-\\u206F\\uFEFF\\uFFF9-\\uFFFB]|\\uD804[\\uDCBD\\uDCCD]|\\uD80D[\\uDC30-\\uDC3F]|\\uD82F[\\uDCA0-\\uDCA3]|\\uD834[\\uDD73-\\uDD7A]|\\uDB40[\\uDC01\\uDC20-\\uDC7F]/;\n+                var regex$2 = /[!-#%-\\*,-\\/:;\\?@\\[-\\]_\\{\\}\\xA1\\xA7\\xAB\\xB6\\xB7\\xBB\\xBF\\u037E\\u0387\\u055A-\\u055F\\u0589\\u058A\\u05BE\\u05C0\\u05C3\\u05C6\\u05F3\\u05F4\\u0609\\u060A\\u060C\\u060D\\u061B\\u061D-\\u061F\\u066A-\\u066D\\u06D4\\u0700-\\u070D\\u07F7-\\u07F9\\u0830-\\u083E\\u085E\\u0964\\u0965\\u0970\\u09FD\\u0A76\\u0AF0\\u0C77\\u0C84\\u0DF4\\u0E4F\\u0E5A\\u0E5B\\u0F04-\\u0F12\\u0F14\\u0F3A-\\u0F3D\\u0F85\\u0FD0-\\u0FD4\\u0FD9\\u0FDA\\u104A-\\u104F\\u10FB\\u1360-\\u1368\\u1400\\u166E\\u169B\\u169C\\u16EB-\\u16ED\\u1735\\u1736\\u17D4-\\u17D6\\u17D8-\\u17DA\\u1800-\\u180A\\u1944\\u1945\\u1A1E\\u1A1F\\u1AA0-\\u1AA6\\u1AA8-\\u1AAD\\u1B5A-\\u1B60\\u1B7D\\u1B7E\\u1BFC-\\u1BFF\\u1C3B-\\u1C3F\\u1C7E\\u1C7F\\u1CC0-\\u1CC7\\u1CD3\\u2010-\\u2027\\u2030-\\u2043\\u2045-\\u2051\\u2053-\\u205E\\u207D\\u207E\\u208D\\u208E\\u2308-\\u230B\\u2329\\u232A\\u2768-\\u2775\\u27C5\\u27C6\\u27E6-\\u27EF\\u2983-\\u2998\\u29D8-\\u29DB\\u29FC\\u29FD\\u2CF9-\\u2CFC\\u2CFE\\u2CFF\\u2D70\\u2E00-\\u2E2E\\u2E30-\\u2E4F\\u2E52-\\u2E5D\\u3001-\\u3003\\u3008-\\u3011\\u3014-\\u301F\\u3030\\u303D\\u30A0\\u30FB\\uA4FE\\uA4FF\\uA60D-\\uA60F\\uA673\\uA67E\\uA6F2-\\uA6F7\\uA874-\\uA877\\uA8CE\\uA8CF\\uA8F8-\\uA8FA\\uA8FC\\uA92E\\uA92F\\uA95F\\uA9C1-\\uA9CD\\uA9DE\\uA9DF\\uAA5C-\\uAA5F\\uAADE\\uAADF\\uAAF0\\uAAF1\\uABEB\\uFD3E\\uFD3F\\uFE10-\\uFE19\\uFE30-\\uFE52\\uFE54-\\uFE61\\uFE63\\uFE68\\uFE6A\\uFE6B\\uFF01-\\uFF03\\uFF05-\\uFF0A\\uFF0C-\\uFF0F\\uFF1A\\uFF1B\\uFF1F\\uFF20\\uFF3B-\\uFF3D\\uFF3F\\uFF5B\\uFF5D\\uFF5F-\\uFF65]|\\uD800[\\uDD00-\\uDD02\\uDF9F\\uDFD0]|\\uD801\\uDD6F|\\uD802[\\uDC57\\uDD1F\\uDD3F\\uDE50-\\uDE58\\uDE7F\\uDEF0-\\uDEF6\\uDF39-\\uDF3F\\uDF99-\\uDF9C]|\\uD803[\\uDEAD\\uDF55-\\uDF59\\uDF86-\\uDF89]|\\uD804[\\uDC47-\\uDC4D\\uDCBB\\uDCBC\\uDCBE-\\uDCC1\\uDD40-\\uDD43\\uDD74\\uDD75\\uDDC5-\\uDDC8\\uDDCD\\uDDDB\\uDDDD-\\uDDDF\\uDE38-\\uDE3D\\uDEA9]|\\uD805[\\uDC4B-\\uDC4F\\uDC5A\\uDC5B\\uDC5D\\uDCC6\\uDDC1-\\uDDD7\\uDE41-\\uDE43\\uDE60-\\uDE6C\\uDEB9\\uDF3C-\\uDF3E]|\\uD806[\\uDC3B\\uDD44-\\uDD46\\uDDE2\\uDE3F-\\uDE46\\uDE9A-\\uDE9C\\uDE9E-\\uDEA2\\uDF00-\\uDF09]|\\uD807[\\uDC41-\\uDC45\\uDC70\\uDC71\\uDEF7\\uDEF8\\uDF43-\\uDF4F\\uDFFF]|\\uD809[\\uDC70-\\uDC74]|\\uD80B[\\uDFF1\\uDFF2]|\\uD81A[\\uDE6E\\uDE6F\\uDEF5\\uDF37-\\uDF3B\\uDF44]|\\uD81B[\\uDE97-\\uDE9A\\uDFE2]|\\uD82F\\uDC9F|\\uD836[\\uDE87-\\uDE8B]|\\uD83A[\\uDD5E\\uDD5F]/;\n+                var regex$1 = /[\\$\\+<->\\^`\\|~\\xA2-\\xA6\\xA8\\xA9\\xAC\\xAE-\\xB1\\xB4\\xB8\\xD7\\xF7\\u02C2-\\u02C5\\u02D2-\\u02DF\\u02E5-\\u02EB\\u02ED\\u02EF-\\u02FF\\u0375\\u0384\\u0385\\u03F6\\u0482\\u058D-\\u058F\\u0606-\\u0608\\u060B\\u060E\\u060F\\u06DE\\u06E9\\u06FD\\u06FE\\u07F6\\u07FE\\u07FF\\u0888\\u09F2\\u09F3\\u09FA\\u09FB\\u0AF1\\u0B70\\u0BF3-\\u0BFA\\u0C7F\\u0D4F\\u0D79\\u0E3F\\u0F01-\\u0F03\\u0F13\\u0F15-\\u0F17\\u0F1A-\\u0F1F\\u0F34\\u0F36\\u0F38\\u0FBE-\\u0FC5\\u0FC7-\\u0FCC\\u0FCE\\u0FCF\\u0FD5-\\u0FD8\\u109E\\u109F\\u1390-\\u1399\\u166D\\u17DB\\u1940\\u19DE-\\u19FF\\u1B61-\\u1B6A\\u1B74-\\u1B7C\\u1FBD\\u1FBF-\\u1FC1\\u1FCD-\\u1FCF\\u1FDD-\\u1FDF\\u1FED-\\u1FEF\\u1FFD\\u1FFE\\u2044\\u2052\\u207A-\\u207C\\u208A-\\u208C\\u20A0-\\u20C0\\u2100\\u2101\\u2103-\\u2106\\u2108\\u2109\\u2114\\u2116-\\u2118\\u211E-\\u2123\\u2125\\u2127\\u2129\\u212E\\u213A\\u213B\\u2140-\\u2144\\u214A-\\u214D\\u214F\\u218A\\u218B\\u2190-\\u2307\\u230C-\\u2328\\u232B-\\u2426\\u2440-\\u244A\\u249C-\\u24E9\\u2500-\\u2767\\u2794-\\u27C4\\u27C7-\\u27E5\\u27F0-\\u2982\\u2999-\\u29D7\\u29DC-\\u29FB\\u29FE-\\u2B73\\u2B76-\\u2B95\\u2B97-\\u2BFF\\u2CE5-\\u2CEA\\u2E50\\u2E51\\u2E80-\\u2E99\\u2E9B-\\u2EF3\\u2F00-\\u2FD5\\u2FF0-\\u2FFF\\u3004\\u3012\\u3013\\u3020\\u3036\\u3037\\u303E\\u303F\\u309B\\u309C\\u3190\\u3191\\u3196-\\u319F\\u31C0-\\u31E3\\u31EF\\u3200-\\u321E\\u322A-\\u3247\\u3250\\u3260-\\u327F\\u328A-\\u32B0\\u32C0-\\u33FF\\u4DC0-\\u4DFF\\uA490-\\uA4C6\\uA700-\\uA716\\uA720\\uA721\\uA789\\uA78A\\uA828-\\uA82B\\uA836-\\uA839\\uAA77-\\uAA79\\uAB5B\\uAB6A\\uAB6B\\uFB29\\uFBB2-\\uFBC2\\uFD40-\\uFD4F\\uFDCF\\uFDFC-\\uFDFF\\uFE62\\uFE64-\\uFE66\\uFE69\\uFF04\\uFF0B\\uFF1C-\\uFF1E\\uFF3E\\uFF40\\uFF5C\\uFF5E\\uFFE0-\\uFFE6\\uFFE8-\\uFFEE\\uFFFC\\uFFFD]|\\uD800[\\uDD37-\\uDD3F\\uDD79-\\uDD89\\uDD8C-\\uDD8E\\uDD90-\\uDD9C\\uDDA0\\uDDD0-\\uDDFC]|\\uD802[\\uDC77\\uDC78\\uDEC8]|\\uD805\\uDF3F|\\uD807[\\uDFD5-\\uDFF1]|\\uD81A[\\uDF3C-\\uDF3F\\uDF45]|\\uD82F\\uDC9C|\\uD833[\\uDF50-\\uDFC3]|\\uD834[\\uDC00-\\uDCF5\\uDD00-\\uDD26\\uDD29-\\uDD64\\uDD6A-\\uDD6C\\uDD83\\uDD84\\uDD8C-\\uDDA9\\uDDAE-\\uDDEA\\uDE00-\\uDE41\\uDE45\\uDF00-\\uDF56]|\\uD835[\\uDEC1\\uDEDB\\uDEFB\\uDF15\\uDF35\\uDF4F\\uDF6F\\uDF89\\uDFA9\\uDFC3]|\\uD836[\\uDC00-\\uDDFF\\uDE37-\\uDE3A\\uDE6D-\\uDE74\\uDE76-\\uDE83\\uDE85\\uDE86]|\\uD838[\\uDD4F\\uDEFF]|\\uD83B[\\uDCAC\\uDCB0\\uDD2E\\uDEF0\\uDEF1]|\\uD83C[\\uDC00-\\uDC2B\\uDC30-\\uDC93\\uDCA0-\\uDCAE\\uDCB1-\\uDCBF\\uDCC1-\\uDCCF\\uDCD1-\\uDCF5\\uDD0D-\\uDDAD\\uDDE6-\\uDE02\\uDE10-\\uDE3B\\uDE40-\\uDE48\\uDE50\\uDE51\\uDE60-\\uDE65\\uDF00-\\uDFFF]|\\uD83D[\\uDC00-\\uDED7\\uDEDC-\\uDEEC\\uDEF0-\\uDEFC\\uDF00-\\uDF76\\uDF7B-\\uDFD9\\uDFE0-\\uDFEB\\uDFF0]|\\uD83E[\\uDC00-\\uDC0B\\uDC10-\\uDC47\\uDC50-\\uDC59\\uDC60-\\uDC87\\uDC90-\\uDCAD\\uDCB0\\uDCB1\\uDD00-\\uDE53\\uDE60-\\uDE6D\\uDE70-\\uDE7C\\uDE80-\\uDE88\\uDE90-\\uDEBD\\uDEBF-\\uDEC5\\uDECE-\\uDEDB\\uDEE0-\\uDEE8\\uDEF0-\\uDEF8\\uDF00-\\uDF92\\uDF94-\\uDFCA]/;\n+                var regex = /[ \\xA0\\u1680\\u2000-\\u200A\\u2028\\u2029\\u202F\\u205F\\u3000]/;\n+                exports.Any = regex$5;\n+                exports.Cc = regex$4;\n+                exports.Cf = regex$3;\n+                exports.P = regex$2;\n+                exports.S = regex$1;\n+                exports.Z = regex;\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-react/dist/mode.cjs.js\":\n-            /*!*********************************************!*\\\n-              !*** ../../graphiql-react/dist/mode.cjs.js ***!\n-              \\*********************************************/\n+        \"../../../node_modules/use-callback-ref/dist/es2015/assignRef.js\":\n+            /*!***********************************************************************!*\\\n+              !*** ../../../node_modules/use-callback-ref/dist/es2015/assignRef.js ***!\n+              \\***********************************************************************/\n             /***/\n-            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n+            (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n-                var n = Object.defineProperty;\n-                var s = (e, r) => n(e, \"name\", {\n-                    value: r,\n-                    configurable: !0\n-                });\n-                const o = __webpack_require__( /*! ./codemirror.cjs.js */ \"../../graphiql-react/dist/codemirror.cjs.js\"),\n-                    t = __webpack_require__( /*! graphql-language-service */ \"../../graphql-language-service/esm/index.js\"),\n-                    i = __webpack_require__( /*! ./mode-indent.cjs.js */ \"../../graphiql-react/dist/mode-indent.cjs.js\");\n-                __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\");\n-                const l = s(e => {\n-                    const r = t.onlineParser({\n-                        eatWhitespace: a => a.eatWhile(t.isIgnored),\n-                        lexRules: t.LexRules,\n-                        parseRules: t.ParseRules,\n-                        editorConfig: {\n-                            tabSize: e.tabSize\n-                        }\n-                    });\n-                    return {\n-                        config: e,\n-                        startState: r.startState,\n-                        token: r.token,\n-                        indent: i.indent,\n-                        electricInput: /^\\s*[})\\]]/,\n-                        fold: \"brace\",\n-                        lineComment: \"#\",\n-                        closeBrackets: {\n-                            pairs: '()[]{}\"\"',\n-                            explode: \"()[]{}\"\n-                        }\n-                    };\n-                }, \"graphqlModeFactory\");\n-                o.CodeMirror.defineMode(\"graphql\", l);\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.assignRef = assignRef;\n+                /**\n+                 * Assigns a value for a given ref, no matter of the ref format\n+                 * @param {RefObject} ref - a callback function or ref object\n+                 * @param value - a new value\n+                 *\n+                 * @see https://github.com/theKashey/use-callback-ref#assignref\n+                 * @example\n+                 * const refObject = useRef();\n+                 * const refFn = (ref) => {....}\n+                 *\n+                 * assignRef(refObject, \"refValue\");\n+                 * assignRef(refFn, \"refValue\");\n+                 */\n+                function assignRef(ref, value) {\n+                    if (typeof ref === 'function') {\n+                        ref(value);\n+                    } else if (ref) {\n+                        ref.current = value;\n+                    }\n+                    return ref;\n+                }\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-react/dist/mode.cjs2.js\":\n-            /*!**********************************************!*\\\n-              !*** ../../graphiql-react/dist/mode.cjs2.js ***!\n-              \\**********************************************/\n+        \"../../../node_modules/use-callback-ref/dist/es2015/createRef.js\":\n+            /*!***********************************************************************!*\\\n+              !*** ../../../node_modules/use-callback-ref/dist/es2015/createRef.js ***!\n+              \\***********************************************************************/\n             /***/\n-            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n+            (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n-                var n = Object.defineProperty;\n-                var u = (t, r) => n(t, \"name\", {\n-                    value: r,\n-                    configurable: !0\n-                });\n-                const i = __webpack_require__( /*! ./codemirror.cjs.js */ \"../../graphiql-react/dist/codemirror.cjs.js\"),\n-                    e = __webpack_require__( /*! graphql-language-service */ \"../../graphql-language-service/esm/index.js\"),\n-                    s = __webpack_require__( /*! ./mode-indent.cjs.js */ \"../../graphiql-react/dist/mode-indent.cjs.js\");\n-                __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\");\n-                i.CodeMirror.defineMode(\"graphql-variables\", t => {\n-                    const r = e.onlineParser({\n-                        eatWhitespace: a => a.eatSpace(),\n-                        lexRules: c,\n-                        parseRules: o,\n-                        editorConfig: {\n-                            tabSize: t.tabSize\n-                        }\n-                    });\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.createCallbackRef = createCallbackRef;\n+                /**\n+                 * creates a Ref object with on change callback\n+                 * @param callback\n+                 * @returns {RefObject}\n+                 *\n+                 * @see {@link useCallbackRef}\n+                 * @see https://reactjs.org/docs/refs-and-the-dom.html#creating-refs\n+                 */\n+                function createCallbackRef(callback) {\n+                    var current = null;\n                     return {\n-                        config: t,\n-                        startState: r.startState,\n-                        token: r.token,\n-                        indent: s.indent,\n-                        electricInput: /^\\s*[}\\]]/,\n-                        fold: \"brace\",\n-                        closeBrackets: {\n-                            pairs: '[]{}\"\"',\n-                            explode: \"[]{}\"\n-                        }\n-                    };\n-                });\n-                const c = {\n-                        Punctuation: /^\\[|]|\\{|\\}|:|,/,\n-                        Number: /^-?(?:0|(?:[1-9][0-9]*))(?:\\.[0-9]*)?(?:[eE][+-]?[0-9]+)?/,\n-                        String: /^\"(?:[^\"\\\\]|\\\\(?:\"|\\/|\\\\|b|f|n|r|t|u[0-9a-fA-F]{4}))*\"?/,\n-                        Keyword: /^true|false|null/\n-                    },\n-                    o = {\n-                        Document: [e.p(\"{\"), e.list(\"Variable\", e.opt(e.p(\",\"))), e.p(\"}\")],\n-                        Variable: [l(\"variable\"), e.p(\":\"), \"Value\"],\n-                        Value(t) {\n-                            switch (t.kind) {\n-                                case \"Number\":\n-                                    return \"NumberValue\";\n-                                case \"String\":\n-                                    return \"StringValue\";\n-                                case \"Punctuation\":\n-                                    switch (t.value) {\n-                                        case \"[\":\n-                                            return \"ListValue\";\n-                                        case \"{\":\n-                                            return \"ObjectValue\";\n-                                    }\n-                                    return null;\n-                                case \"Keyword\":\n-                                    switch (t.value) {\n-                                        case \"true\":\n-                                        case \"false\":\n-                                            return \"BooleanValue\";\n-                                        case \"null\":\n-                                            return \"NullValue\";\n-                                    }\n-                                    return null;\n-                            }\n+                        get current() {\n+                            return current;\n                         },\n-                        NumberValue: [e.t(\"Number\", \"number\")],\n-                        StringValue: [e.t(\"String\", \"string\")],\n-                        BooleanValue: [e.t(\"Keyword\", \"builtin\")],\n-                        NullValue: [e.t(\"Keyword\", \"keyword\")],\n-                        ListValue: [e.p(\"[\"), e.list(\"Value\", e.opt(e.p(\",\"))), e.p(\"]\")],\n-                        ObjectValue: [e.p(\"{\"), e.list(\"ObjectField\", e.opt(e.p(\",\"))), e.p(\"}\")],\n-                        ObjectField: [l(\"attribute\"), e.p(\":\"), \"Value\"]\n-                    };\n-\n-                function l(t) {\n-                    return {\n-                        style: t,\n-                        match: r => r.kind === \"String\",\n-                        update(r, a) {\n-                            r.name = a.value.slice(1, -1);\n+                        set current(value) {\n+                            var last = current;\n+                            if (last !== value) {\n+                                current = value;\n+                                callback(value, last);\n+                            }\n                         }\n                     };\n                 }\n-                u(l, \"namedKey\");\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-react/dist/mode.cjs3.js\":\n-            /*!**********************************************!*\\\n-              !*** ../../graphiql-react/dist/mode.cjs3.js ***!\n-              \\**********************************************/\n+        \"../../../node_modules/use-callback-ref/dist/es2015/index.js\":\n+            /*!*******************************************************************!*\\\n+              !*** ../../../node_modules/use-callback-ref/dist/es2015/index.js ***!\n+              \\*******************************************************************/\n             /***/\n-            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                const a = __webpack_require__( /*! ./codemirror.cjs.js */ \"../../graphiql-react/dist/codemirror.cjs.js\"),\n-                    e = __webpack_require__( /*! graphql-language-service */ \"../../graphql-language-service/esm/index.js\"),\n-                    l = __webpack_require__( /*! ./mode-indent.cjs.js */ \"../../graphiql-react/dist/mode-indent.cjs.js\");\n-                __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\");\n-                a.CodeMirror.defineMode(\"graphql-results\", r => {\n-                    const t = e.onlineParser({\n-                        eatWhitespace: u => u.eatSpace(),\n-                        lexRules: n,\n-                        parseRules: s,\n-                        editorConfig: {\n-                            tabSize: r.tabSize\n-                        }\n-                    });\n-                    return {\n-                        config: r,\n-                        startState: t.startState,\n-                        token: t.token,\n-                        indent: l.indent,\n-                        electricInput: /^\\s*[}\\]]/,\n-                        fold: \"brace\",\n-                        closeBrackets: {\n-                            pairs: '[]{}\"\"',\n-                            explode: \"[]{}\"\n-                        }\n-                    };\n-                });\n-                const n = {\n-                        Punctuation: /^\\[|]|\\{|\\}|:|,/,\n-                        Number: /^-?(?:0|(?:[1-9][0-9]*))(?:\\.[0-9]*)?(?:[eE][+-]?[0-9]+)?/,\n-                        String: /^\"(?:[^\"\\\\]|\\\\(?:\"|\\/|\\\\|b|f|n|r|t|u[0-9a-fA-F]{4}))*\"?/,\n-                        Keyword: /^true|false|null/\n-                    },\n-                    s = {\n-                        Document: [e.p(\"{\"), e.list(\"Entry\", e.p(\",\")), e.p(\"}\")],\n-                        Entry: [e.t(\"String\", \"def\"), e.p(\":\"), \"Value\"],\n-                        Value(r) {\n-                            switch (r.kind) {\n-                                case \"Number\":\n-                                    return \"NumberValue\";\n-                                case \"String\":\n-                                    return \"StringValue\";\n-                                case \"Punctuation\":\n-                                    switch (r.value) {\n-                                        case \"[\":\n-                                            return \"ListValue\";\n-                                        case \"{\":\n-                                            return \"ObjectValue\";\n-                                    }\n-                                    return null;\n-                                case \"Keyword\":\n-                                    switch (r.value) {\n-                                        case \"true\":\n-                                        case \"false\":\n-                                            return \"BooleanValue\";\n-                                        case \"null\":\n-                                            return \"NullValue\";\n-                                    }\n-                                    return null;\n-                            }\n-                        },\n-                        NumberValue: [e.t(\"Number\", \"number\")],\n-                        StringValue: [e.t(\"String\", \"string\")],\n-                        BooleanValue: [e.t(\"Keyword\", \"builtin\")],\n-                        NullValue: [e.t(\"Keyword\", \"keyword\")],\n-                        ListValue: [e.p(\"[\"), e.list(\"Value\", e.p(\",\")), e.p(\"]\")],\n-                        ObjectValue: [e.p(\"{\"), e.list(\"ObjectField\", e.p(\",\")), e.p(\"}\")],\n-                        ObjectField: [e.t(\"String\", \"property\"), e.p(\":\"), \"Value\"]\n-                    };\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                Object.defineProperty(exports, \"assignRef\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _assignRef.assignRef;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"createCallbackRef\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _createRef.createCallbackRef;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"mergeRefs\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _mergeRef.mergeRefs;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"refToCallback\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _refToCallback.refToCallback;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"transformRef\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _transformRef.transformRef;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"useCallbackRef\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _useRef.useCallbackRef;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"useMergeRefs\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _useMergeRef.useMergeRefs;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"useRefToCallback\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _refToCallback.useRefToCallback;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"useTransformRef\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _useTransformRef.useTransformRef;\n+                    }\n+                }));\n+                var _assignRef = __webpack_require__( /*! ./assignRef */ \"../../../node_modules/use-callback-ref/dist/es2015/assignRef.js\");\n+                var _useRef = __webpack_require__( /*! ./useRef */ \"../../../node_modules/use-callback-ref/dist/es2015/useRef.js\");\n+                var _createRef = __webpack_require__( /*! ./createRef */ \"../../../node_modules/use-callback-ref/dist/es2015/createRef.js\");\n+                var _mergeRef = __webpack_require__( /*! ./mergeRef */ \"../../../node_modules/use-callback-ref/dist/es2015/mergeRef.js\");\n+                var _useMergeRef = __webpack_require__( /*! ./useMergeRef */ \"../../../node_modules/use-callback-ref/dist/es2015/useMergeRef.js\");\n+                var _useTransformRef = __webpack_require__( /*! ./useTransformRef */ \"../../../node_modules/use-callback-ref/dist/es2015/useTransformRef.js\");\n+                var _transformRef = __webpack_require__( /*! ./transformRef */ \"../../../node_modules/use-callback-ref/dist/es2015/transformRef.js\");\n+                var _refToCallback = __webpack_require__( /*! ./refToCallback */ \"../../../node_modules/use-callback-ref/dist/es2015/refToCallback.js\");\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-react/dist/search.cjs.js\":\n-            /*!***********************************************!*\\\n-              !*** ../../graphiql-react/dist/search.cjs.js ***!\n-              \\***********************************************/\n+        \"../../../node_modules/use-callback-ref/dist/es2015/mergeRef.js\":\n+            /*!**********************************************************************!*\\\n+              !*** ../../../node_modules/use-callback-ref/dist/es2015/mergeRef.js ***!\n+              \\**********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                var K = Object.defineProperty;\n-                var a = (S, O) => K(S, \"name\", {\n-                    value: O,\n-                    configurable: !0\n-                });\n-                const Q = __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\"),\n-                    L = __webpack_require__( /*! ./searchcursor.cjs2.js */ \"../../graphiql-react/dist/searchcursor.cjs2.js\"),\n-                    z = __webpack_require__( /*! ./dialog.cjs.js */ \"../../graphiql-react/dist/dialog.cjs.js\");\n-\n-                function U(S, O) {\n-                    for (var i = 0; i < O.length; i++) {\n-                        const y = O[i];\n-                        if (typeof y != \"string\" && !Array.isArray(y)) {\n-                            for (const v in y)\n-                                if (v !== \"default\" && !(v in S)) {\n-                                    const h = Object.getOwnPropertyDescriptor(y, v);\n-                                    h && Object.defineProperty(S, v, h.get ? h : {\n-                                        enumerable: !0,\n-                                        get: () => y[v]\n-                                    });\n-                                }\n-                        }\n-                    }\n-                    return Object.freeze(Object.defineProperty(S, Symbol.toStringTag, {\n-                        value: \"Module\"\n-                    }));\n-                }\n-                a(U, \"_mergeNamespaces\");\n-                var B = {\n-                    exports: {}\n-                };\n-                (function(S, O) {\n-                    (function(i) {\n-                        i(Q.requireCodemirror(), L.requireSearchcursor(), z.dialogExports);\n-                    })(function(i) {\n-                        i.defineOption(\"search\", {\n-                            bottom: !1\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.mergeRefs = mergeRefs;\n+                var _assignRef = __webpack_require__( /*! ./assignRef */ \"../../../node_modules/use-callback-ref/dist/es2015/assignRef.js\");\n+                var _createRef = __webpack_require__( /*! ./createRef */ \"../../../node_modules/use-callback-ref/dist/es2015/createRef.js\");\n+                /**\n+                 * Merges two or more refs together providing a single interface to set their value\n+                 * @param {RefObject|Ref} refs\n+                 * @returns {MutableRefObject} - a new ref, which translates all changes to {refs}\n+                 *\n+                 * @see {@link useMergeRefs} to be used in ReactComponents\n+                 * @example\n+                 * const Component = React.forwardRef((props, ref) => {\n+                 *   const ownRef = useRef();\n+                 *   const domRef = mergeRefs([ref, ownRef]); // \ud83d\udc48 merge together\n+                 *   return <div ref={domRef}>...</div>\n+                 * }\n+                 */\n+                function mergeRefs(refs) {\n+                    return (0, _createRef.createCallbackRef)(function(newValue) {\n+                        return refs.forEach(function(ref) {\n+                            return (0, _assignRef.assignRef)(ref, newValue);\n                         });\n-\n-                        function y(e, n) {\n-                            return typeof e == \"string\" ? e = new RegExp(e.replace(/[\\-\\[\\]\\/\\{\\}\\(\\)\\*\\+\\?\\.\\\\\\^\\$\\|]/g, \"\\\\$&\"), n ? \"gi\" : \"g\") : e.global || (e = new RegExp(e.source, e.ignoreCase ? \"gi\" : \"g\")), {\n-                                token: function(t) {\n-                                    e.lastIndex = t.pos;\n-                                    var o = e.exec(t.string);\n-                                    if (o && o.index == t.pos) return t.pos += o[0].length || 1, \"searching\";\n-                                    o ? t.pos = o.index : t.skipToEnd();\n-                                }\n-                            };\n-                        }\n-                        a(y, \"searchOverlay\");\n-\n-                        function v() {\n-                            this.posFrom = this.posTo = this.lastQuery = this.query = null, this.overlay = null;\n-                        }\n-                        a(v, \"SearchState\");\n-\n-                        function h(e) {\n-                            return e.state.search || (e.state.search = new v());\n-                        }\n-                        a(h, \"getSearchState\");\n-\n-                        function m(e) {\n-                            return typeof e == \"string\" && e == e.toLowerCase();\n-                        }\n-                        a(m, \"queryCaseInsensitive\");\n-\n-                        function N(e, n, t) {\n-                            return e.getSearchCursor(n, t, {\n-                                caseFold: m(n),\n-                                multiline: !0\n-                            });\n-                        }\n-                        a(N, \"getSearchCursor\");\n-\n-                        function j(e, n, t, o, r) {\n-                            e.openDialog(n, o, {\n-                                value: t,\n-                                selectValueOnOpen: !0,\n-                                closeOnEnter: !1,\n-                                onClose: function() {\n-                                    w(e);\n-                                },\n-                                onKeyDown: r,\n-                                bottom: e.options.search.bottom\n-                            });\n-                        }\n-                        a(j, \"persistentDialog\");\n-\n-                        function D(e, n, t, o, r) {\n-                            e.openDialog ? e.openDialog(n, r, {\n-                                value: o,\n-                                selectValueOnOpen: !0,\n-                                bottom: e.options.search.bottom\n-                            }) : r(prompt(t, o));\n-                        }\n-                        a(D, \"dialog\");\n-\n-                        function k(e, n, t, o) {\n-                            e.openConfirm ? e.openConfirm(n, o) : confirm(t) && o[0]();\n-                        }\n-                        a(k, \"confirmDialog\");\n-\n-                        function C(e) {\n-                            return e.replace(/\\\\([nrt\\\\])/g, function(n, t) {\n-                                return t == \"n\" ? `\n-` : t == \"r\" ? \"\\r\" : t == \"t\" ? \"\t\" : t == \"\\\\\" ? \"\\\\\" : n;\n-                            });\n-                        }\n-                        a(C, \"parseString\");\n-\n-                        function T(e) {\n-                            var n = e.match(/^\\/(.*)\\/([a-z]*)$/);\n-                            if (n) try {\n-                                e = new RegExp(n[1], n[2].indexOf(\"i\") == -1 ? \"\" : \"i\");\n-                            } catch {} else e = C(e);\n-                            return (typeof e == \"string\" ? e == \"\" : e.test(\"\")) && (e = /x^/), e;\n-                        }\n-                        a(T, \"parseQuery\");\n-\n-                        function P(e, n, t) {\n-                            n.queryText = t, n.query = T(t), e.removeOverlay(n.overlay, m(n.query)), n.overlay = y(n.query, m(n.query)), e.addOverlay(n.overlay), e.showMatchesOnScrollbar && (n.annotate && (n.annotate.clear(), n.annotate = null), n.annotate = e.showMatchesOnScrollbar(n.query, m(n.query)));\n-                        }\n-                        a(P, \"startSearch\");\n-\n-                        function b(e, n, t, o) {\n-                            var r = h(e);\n-                            if (r.query) return R(e, n);\n-                            var s = e.getSelection() || r.lastQuery;\n-                            if (s instanceof RegExp && s.source == \"x^\" && (s = null), t && e.openDialog) {\n-                                var c = null,\n-                                    u = a(function(f, x) {\n-                                        i.e_stop(x), f && (f != r.queryText && (P(e, r, f), r.posFrom = r.posTo = e.getCursor()), c && (c.style.opacity = 1), R(e, x.shiftKey, function(d, g) {\n-                                            var p;\n-                                            g.line < 3 && document.querySelector && (p = e.display.wrapper.querySelector(\".CodeMirror-dialog\")) && p.getBoundingClientRect().bottom - 4 > e.cursorCoords(g, \"window\").top && ((c = p).style.opacity = .4);\n-                                        }));\n-                                    }, \"searchNext\");\n-                                j(e, E(e), s, u, function(f, x) {\n-                                    var d = i.keyName(f),\n-                                        g = e.getOption(\"extraKeys\"),\n-                                        p = g && g[d] || i.keyMap[e.getOption(\"keyMap\")][d];\n-                                    p == \"findNext\" || p == \"findPrev\" || p == \"findPersistentNext\" || p == \"findPersistentPrev\" ? (i.e_stop(f), P(e, h(e), x), e.execCommand(p)) : (p == \"find\" || p == \"findPersistent\") && (i.e_stop(f), u(x, f));\n-                                }), o && s && (P(e, r, s), R(e, n));\n-                            } else D(e, E(e), \"Search for:\", s, function(f) {\n-                                f && !r.query && e.operation(function() {\n-                                    P(e, r, f), r.posFrom = r.posTo = e.getCursor(), R(e, n);\n-                                });\n-                            });\n-                        }\n-                        a(b, \"doSearch\");\n-\n-                        function R(e, n, t) {\n-                            e.operation(function() {\n-                                var o = h(e),\n-                                    r = N(e, o.query, n ? o.posFrom : o.posTo);\n-                                !r.find(n) && (r = N(e, o.query, n ? i.Pos(e.lastLine()) : i.Pos(e.firstLine(), 0)), !r.find(n)) || (e.setSelection(r.from(), r.to()), e.scrollIntoView({\n-                                    from: r.from(),\n-                                    to: r.to()\n-                                }, 20), o.posFrom = r.from(), o.posTo = r.to(), t && t(r.from(), r.to()));\n-                            });\n-                        }\n-                        a(R, \"findNext\");\n-\n-                        function w(e) {\n-                            e.operation(function() {\n-                                var n = h(e);\n-                                n.lastQuery = n.query, n.query && (n.query = n.queryText = null, e.removeOverlay(n.overlay), n.annotate && (n.annotate.clear(), n.annotate = null));\n-                            });\n-                        }\n-                        a(w, \"clearSearch\");\n-\n-                        function l(e, n) {\n-                            var t = e ? document.createElement(e) : document.createDocumentFragment();\n-                            for (var o in n) t[o] = n[o];\n-                            for (var r = 2; r < arguments.length; r++) {\n-                                var s = arguments[r];\n-                                t.appendChild(typeof s == \"string\" ? document.createTextNode(s) : s);\n-                            }\n-                            return t;\n-                        }\n-                        a(l, \"el\");\n-\n-                        function E(e) {\n-                            return l(\"\", null, l(\"span\", {\n-                                className: \"CodeMirror-search-label\"\n-                            }, e.phrase(\"Search:\")), \" \", l(\"input\", {\n-                                type: \"text\",\n-                                style: \"width: 10em\",\n-                                className: \"CodeMirror-search-field\"\n-                            }), \" \", l(\"span\", {\n-                                style: \"color: #888\",\n-                                className: \"CodeMirror-search-hint\"\n-                            }, e.phrase(\"(Use /re/ syntax for regexp search)\")));\n-                        }\n-                        a(E, \"getQueryDialog\");\n-\n-                        function A(e) {\n-                            return l(\"\", null, \" \", l(\"input\", {\n-                                type: \"text\",\n-                                style: \"width: 10em\",\n-                                className: \"CodeMirror-search-field\"\n-                            }), \" \", l(\"span\", {\n-                                style: \"color: #888\",\n-                                className: \"CodeMirror-search-hint\"\n-                            }, e.phrase(\"(Use /re/ syntax for regexp search)\")));\n-                        }\n-                        a(A, \"getReplaceQueryDialog\");\n-\n-                        function I(e) {\n-                            return l(\"\", null, l(\"span\", {\n-                                className: \"CodeMirror-search-label\"\n-                            }, e.phrase(\"With:\")), \" \", l(\"input\", {\n-                                type: \"text\",\n-                                style: \"width: 10em\",\n-                                className: \"CodeMirror-search-field\"\n-                            }));\n-                        }\n-                        a(I, \"getReplacementQueryDialog\");\n-\n-                        function V(e) {\n-                            return l(\"\", null, l(\"span\", {\n-                                className: \"CodeMirror-search-label\"\n-                            }, e.phrase(\"Replace?\")), \" \", l(\"button\", {}, e.phrase(\"Yes\")), \" \", l(\"button\", {}, e.phrase(\"No\")), \" \", l(\"button\", {}, e.phrase(\"All\")), \" \", l(\"button\", {}, e.phrase(\"Stop\")));\n-                        }\n-                        a(V, \"getDoReplaceConfirm\");\n-\n-                        function _(e, n, t) {\n-                            e.operation(function() {\n-                                for (var o = N(e, n); o.findNext();)\n-                                    if (typeof n != \"string\") {\n-                                        var r = e.getRange(o.from(), o.to()).match(n);\n-                                        o.replace(t.replace(/\\$(\\d)/g, function(s, c) {\n-                                            return r[c];\n-                                        }));\n-                                    } else o.replace(t);\n-                            });\n-                        }\n-                        a(_, \"replaceAll\");\n-\n-                        function F(e, n) {\n-                            if (!e.getOption(\"readOnly\")) {\n-                                var t = e.getSelection() || h(e).lastQuery,\n-                                    o = n ? e.phrase(\"Replace all:\") : e.phrase(\"Replace:\"),\n-                                    r = l(\"\", null, l(\"span\", {\n-                                        className: \"CodeMirror-search-label\"\n-                                    }, o), A(e));\n-                                D(e, r, o, t, function(s) {\n-                                    s && (s = T(s), D(e, I(e), e.phrase(\"Replace with:\"), \"\", function(c) {\n-                                        if (c = C(c), n) _(e, s, c);\n-                                        else {\n-                                            w(e);\n-                                            var u = N(e, s, e.getCursor(\"from\")),\n-                                                f = a(function() {\n-                                                    var d = u.from(),\n-                                                        g;\n-                                                    !(g = u.findNext()) && (u = N(e, s), !(g = u.findNext()) || d && u.from().line == d.line && u.from().ch == d.ch) || (e.setSelection(u.from(), u.to()), e.scrollIntoView({\n-                                                        from: u.from(),\n-                                                        to: u.to()\n-                                                    }), k(e, V(e), e.phrase(\"Replace?\"), [function() {\n-                                                        x(g);\n-                                                    }, f, function() {\n-                                                        _(e, s, c);\n-                                                    }]));\n-                                                }, \"advance\"),\n-                                                x = a(function(d) {\n-                                                    u.replace(typeof s == \"string\" ? c : c.replace(/\\$(\\d)/g, function(g, p) {\n-                                                        return d[p];\n-                                                    })), f();\n-                                                }, \"doReplace\");\n-                                            f();\n-                                        }\n-                                    }));\n-                                });\n-                            }\n-                        }\n-                        a(F, \"replace\"), i.commands.find = function(e) {\n-                            w(e), b(e);\n-                        }, i.commands.findPersistent = function(e) {\n-                            w(e), b(e, !1, !0);\n-                        }, i.commands.findPersistentNext = function(e) {\n-                            b(e, !1, !0, !0);\n-                        }, i.commands.findPersistentPrev = function(e) {\n-                            b(e, !0, !0, !0);\n-                        }, i.commands.findNext = b, i.commands.findPrev = function(e) {\n-                            b(e, !0);\n-                        }, i.commands.clearSearch = w, i.commands.replace = F, i.commands.replaceAll = function(e) {\n-                            F(e, !0);\n-                        };\n-                    });\n-                })();\n-                var $ = B.exports;\n-                const W = Q.getDefaultExportFromCjs($),\n-                    Y = U({\n-                        __proto__: null,\n-                        default: W\n-                    }, [$]);\n-                exports.search = Y;\n+                    });\n+                }\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-react/dist/searchcursor.cjs.js\":\n-            /*!*****************************************************!*\\\n-              !*** ../../graphiql-react/dist/searchcursor.cjs.js ***!\n-              \\*****************************************************/\n+        \"../../../node_modules/use-callback-ref/dist/es2015/refToCallback.js\":\n+            /*!***************************************************************************!*\\\n+              !*** ../../../node_modules/use-callback-ref/dist/es2015/refToCallback.js ***!\n+              \\***************************************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+            (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n-                var n = Object.defineProperty;\n-                var u = (r, o) => n(r, \"name\", {\n-                    value: o,\n-                    configurable: !0\n-                });\n-                const i = __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\"),\n-                    f = __webpack_require__( /*! ./searchcursor.cjs2.js */ \"../../graphiql-react/dist/searchcursor.cjs2.js\");\n-\n-                function l(r, o) {\n-                    for (var c = 0; c < o.length; c++) {\n-                        const e = o[c];\n-                        if (typeof e != \"string\" && !Array.isArray(e)) {\n-                            for (const t in e)\n-                                if (t !== \"default\" && !(t in r)) {\n-                                    const s = Object.getOwnPropertyDescriptor(e, t);\n-                                    s && Object.defineProperty(r, t, s.get ? s : {\n-                                        enumerable: !0,\n-                                        get: () => e[t]\n-                                    });\n-                                }\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.refToCallback = refToCallback;\n+                exports.useRefToCallback = useRefToCallback;\n+                /**\n+                 * Unmemoized version of {@link useRefToCallback}\n+                 * @see {@link useRefToCallback}\n+                 * @param ref\n+                 */\n+                function refToCallback(ref) {\n+                    return function(newValue) {\n+                        if (typeof ref === 'function') {\n+                            ref(newValue);\n+                        } else if (ref) {\n+                            ref.current = newValue;\n                         }\n+                    };\n+                }\n+                var nullCallback = function() {\n+                    return null;\n+                };\n+                // lets maintain a weak ref to, well, ref :)\n+                // not using `kashe` to keep this package small\n+                var weakMem = new WeakMap();\n+                var weakMemoize = function(ref) {\n+                    var usedRef = ref || nullCallback;\n+                    var storedRef = weakMem.get(usedRef);\n+                    if (storedRef) {\n+                        return storedRef;\n                     }\n-                    return Object.freeze(Object.defineProperty(r, Symbol.toStringTag, {\n-                        value: \"Module\"\n-                    }));\n+                    var cb = refToCallback(usedRef);\n+                    weakMem.set(usedRef, cb);\n+                    return cb;\n+                };\n+                /**\n+                 * Transforms a given `ref` into `callback`.\n+                 *\n+                 * To transform `callback` into ref use {@link useCallbackRef|useCallbackRef(undefined, callback)}\n+                 *\n+                 * @param {ReactRef} ref\n+                 * @returns {Function}\n+                 *\n+                 * @see https://github.com/theKashey/use-callback-ref#reftocallback\n+                 *\n+                 * @example\n+                 * const ref = useRef(0);\n+                 * const setRef = useRefToCallback(ref);\n+                 * \ud83d\udc49 setRef(10);\n+                 * \u2705 ref.current === 10\n+                 */\n+                function useRefToCallback(ref) {\n+                    return weakMemoize(ref);\n                 }\n-                u(l, \"_mergeNamespaces\");\n-                var a = f.requireSearchcursor();\n-                const g = i.getDefaultExportFromCjs(a),\n-                    p = l({\n-                        __proto__: null,\n-                        default: g\n-                    }, [a]);\n-                exports.searchcursor = p;\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-react/dist/searchcursor.cjs2.js\":\n-            /*!******************************************************!*\\\n-              !*** ../../graphiql-react/dist/searchcursor.cjs2.js ***!\n-              \\******************************************************/\n+        \"../../../node_modules/use-callback-ref/dist/es2015/transformRef.js\":\n+            /*!**************************************************************************!*\\\n+              !*** ../../../node_modules/use-callback-ref/dist/es2015/transformRef.js ***!\n+              \\**************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                var W = Object.defineProperty;\n-                var o = (d, E) => W(d, \"name\", {\n-                    value: E,\n-                    configurable: !0\n-                });\n-                const G = __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\");\n-                var N = {\n-                        exports: {}\n-                    },\n-                    b;\n-\n-                function H() {\n-                    return b || (b = 1, function(d, E) {\n-                        (function(m) {\n-                            m(G.requireCodemirror());\n-                        })(function(m) {\n-                            var a = m.Pos;\n-\n-                            function B(e) {\n-                                var t = e.flags;\n-                                return t !== null && t !== void 0 ? t : (e.ignoreCase ? \"i\" : \"\") + (e.global ? \"g\" : \"\") + (e.multiline ? \"m\" : \"\");\n-                            }\n-                            o(B, \"regexpFlags\");\n-\n-                            function F(e, t) {\n-                                for (var n = B(e), r = n, l = 0; l < t.length; l++) r.indexOf(t.charAt(l)) == -1 && (r += t.charAt(l));\n-                                return n == r ? e : new RegExp(e.source, r);\n-                            }\n-                            o(F, \"ensureFlags\");\n-\n-                            function R(e) {\n-                                return /\\\\s|\\\\n|\\n|\\\\W|\\\\D|\\[\\^/.test(e.source);\n-                            }\n-                            o(R, \"maybeMultiline\");\n-\n-                            function I(e, t, n) {\n-                                t = F(t, \"g\");\n-                                for (var r = n.line, l = n.ch, i = e.lastLine(); r <= i; r++, l = 0) {\n-                                    t.lastIndex = l;\n-                                    var h = e.getLine(r),\n-                                        f = t.exec(h);\n-                                    if (f) return {\n-                                        from: a(r, f.index),\n-                                        to: a(r, f.index + f[0].length),\n-                                        match: f\n-                                    };\n-                                }\n-                            }\n-                            o(I, \"searchRegexpForward\");\n-\n-                            function j(e, t, n) {\n-                                if (!R(t)) return I(e, t, n);\n-                                t = F(t, \"gm\");\n-                                for (var r, l = 1, i = n.line, h = e.lastLine(); i <= h;) {\n-                                    for (var f = 0; f < l && !(i > h); f++) {\n-                                        var p = e.getLine(i++);\n-                                        r = r == null ? p : r + `\n-` + p;\n-                                    }\n-                                    l = l * 2, t.lastIndex = n.ch;\n-                                    var u = t.exec(r);\n-                                    if (u) {\n-                                        var s = r.slice(0, u.index).split(`\n-`),\n-                                            c = u[0].split(`\n-`),\n-                                            g = n.line + s.length - 1,\n-                                            v = s[s.length - 1].length;\n-                                        return {\n-                                            from: a(g, v),\n-                                            to: a(g + c.length - 1, c.length == 1 ? v + c[0].length : c[c.length - 1].length),\n-                                            match: u\n-                                        };\n-                                    }\n-                                }\n-                            }\n-                            o(j, \"searchRegexpForwardMultiline\");\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.transformRef = transformRef;\n+                var _assignRef = __webpack_require__( /*! ./assignRef */ \"../../../node_modules/use-callback-ref/dist/es2015/assignRef.js\");\n+                var _createRef = __webpack_require__( /*! ./createRef */ \"../../../node_modules/use-callback-ref/dist/es2015/createRef.js\");\n+                /**\n+                 * Transforms one ref to another\n+                 * @example\n+                 * ```tsx\n+                 * const ResizableWithRef = forwardRef((props, ref) =>\n+                 *   <Resizable {...props} ref={transformRef(ref, i => i ? i.resizable : null)}/>\n+                 * );\n+                 * ```\n+                 */\n+                function transformRef(ref, transformer) {\n+                    return (0, _createRef.createCallbackRef)(function(value) {\n+                        return (0, _assignRef.assignRef)(ref, transformer(value));\n+                    });\n+                }\n \n-                            function z(e, t, n) {\n-                                for (var r, l = 0; l <= e.length;) {\n-                                    t.lastIndex = l;\n-                                    var i = t.exec(e);\n-                                    if (!i) break;\n-                                    var h = i.index + i[0].length;\n-                                    if (h > e.length - n) break;\n-                                    (!r || h > r.index + r[0].length) && (r = i), l = i.index + 1;\n-                                }\n-                                return r;\n-                            }\n-                            o(z, \"lastMatchIn\");\n+                /***/\n+            }),\n \n-                            function D(e, t, n) {\n-                                t = F(t, \"g\");\n-                                for (var r = n.line, l = n.ch, i = e.firstLine(); r >= i; r--, l = -1) {\n-                                    var h = e.getLine(r),\n-                                        f = z(h, t, l < 0 ? 0 : h.length - l);\n-                                    if (f) return {\n-                                        from: a(r, f.index),\n-                                        to: a(r, f.index + f[0].length),\n-                                        match: f\n-                                    };\n-                                }\n-                            }\n-                            o(D, \"searchRegexpBackward\");\n+        /***/\n+        \"../../../node_modules/use-callback-ref/dist/es2015/useMergeRef.js\":\n+            /*!*************************************************************************!*\\\n+              !*** ../../../node_modules/use-callback-ref/dist/es2015/useMergeRef.js ***!\n+              \\*************************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                            function A(e, t, n) {\n-                                if (!R(t)) return D(e, t, n);\n-                                t = F(t, \"gm\");\n-                                for (var r, l = 1, i = e.getLine(n.line).length - n.ch, h = n.line, f = e.firstLine(); h >= f;) {\n-                                    for (var p = 0; p < l && h >= f; p++) {\n-                                        var u = e.getLine(h--);\n-                                        r = r == null ? u : u + `\n-` + r;\n-                                    }\n-                                    l *= 2;\n-                                    var s = z(r, t, i);\n-                                    if (s) {\n-                                        var c = r.slice(0, s.index).split(`\n-`),\n-                                            g = s[0].split(`\n-`),\n-                                            v = h + c.length,\n-                                            x = c[c.length - 1].length;\n-                                        return {\n-                                            from: a(v, x),\n-                                            to: a(v + g.length - 1, g.length == 1 ? x + g[0].length : g[g.length - 1].length),\n-                                            match: s\n-                                        };\n-                                    }\n-                                }\n-                            }\n-                            o(A, \"searchRegexpBackwardMultiline\");\n-                            var P, k;\n-                            String.prototype.normalize ? (P = o(function(e) {\n-                                return e.normalize(\"NFD\").toLowerCase();\n-                            }, \"doFold\"), k = o(function(e) {\n-                                return e.normalize(\"NFD\");\n-                            }, \"noFold\")) : (P = o(function(e) {\n-                                return e.toLowerCase();\n-                            }, \"doFold\"), k = o(function(e) {\n-                                return e;\n-                            }, \"noFold\"));\n-\n-                            function L(e, t, n, r) {\n-                                if (e.length == t.length) return n;\n-                                for (var l = 0, i = n + Math.max(0, e.length - t.length);;) {\n-                                    if (l == i) return l;\n-                                    var h = l + i >> 1,\n-                                        f = r(e.slice(0, h)).length;\n-                                    if (f == n) return h;\n-                                    f > n ? i = h : l = h + 1;\n-                                }\n-                            }\n-                            o(L, \"adjustPos\");\n-\n-                            function y(e, t, n, r) {\n-                                if (!t.length) return null;\n-                                var l = r ? P : k,\n-                                    i = l(t).split(/\\r|\\n\\r?/);\n-                                t: for (var h = n.line, f = n.ch, p = e.lastLine() + 1 - i.length; h <= p; h++, f = 0) {\n-                                    var u = e.getLine(h).slice(f),\n-                                        s = l(u);\n-                                    if (i.length == 1) {\n-                                        var c = s.indexOf(i[0]);\n-                                        if (c == -1) continue t;\n-                                        var n = L(u, s, c, l) + f;\n-                                        return {\n-                                            from: a(h, L(u, s, c, l) + f),\n-                                            to: a(h, L(u, s, c + i[0].length, l) + f)\n-                                        };\n-                                    } else {\n-                                        var g = s.length - i[0].length;\n-                                        if (s.slice(g) != i[0]) continue t;\n-                                        for (var v = 1; v < i.length - 1; v++)\n-                                            if (l(e.getLine(h + v)) != i[v]) continue t;\n-                                        var x = e.getLine(h + i.length - 1),\n-                                            O = l(x),\n-                                            S = i[i.length - 1];\n-                                        if (O.slice(0, S.length) != S) continue t;\n-                                        return {\n-                                            from: a(h, L(u, s, g, l) + f),\n-                                            to: a(h + i.length - 1, L(x, O, S.length, l))\n-                                        };\n-                                    }\n-                                }\n-                            }\n-                            o(y, \"searchStringForward\");\n+                \"use strict\";\n \n-                            function C(e, t, n, r) {\n-                                if (!t.length) return null;\n-                                var l = r ? P : k,\n-                                    i = l(t).split(/\\r|\\n\\r?/);\n-                                t: for (var h = n.line, f = n.ch, p = e.firstLine() - 1 + i.length; h >= p; h--, f = -1) {\n-                                    var u = e.getLine(h);\n-                                    f > -1 && (u = u.slice(0, f));\n-                                    var s = l(u);\n-                                    if (i.length == 1) {\n-                                        var c = s.lastIndexOf(i[0]);\n-                                        if (c == -1) continue t;\n-                                        return {\n-                                            from: a(h, L(u, s, c, l)),\n-                                            to: a(h, L(u, s, c + i[0].length, l))\n-                                        };\n-                                    } else {\n-                                        var g = i[i.length - 1];\n-                                        if (s.slice(0, g.length) != g) continue t;\n-                                        for (var v = 1, n = h - i.length + 1; v < i.length - 1; v++)\n-                                            if (l(e.getLine(n + v)) != i[v]) continue t;\n-                                        var x = e.getLine(h + 1 - i.length),\n-                                            O = l(x);\n-                                        if (O.slice(O.length - i[0].length) != i[0]) continue t;\n-                                        return {\n-                                            from: a(h + 1 - i.length, L(x, O, x.length - i[0].length, l)),\n-                                            to: a(h, L(u, s, g.length, l))\n-                                        };\n-                                    }\n-                                }\n-                            }\n-                            o(C, \"searchStringBackward\");\n \n-                            function w(e, t, n, r) {\n-                                this.atOccurrence = !1, this.afterEmptyMatch = !1, this.doc = e, n = n ? e.clipPos(n) : a(0, 0), this.pos = {\n-                                    from: n,\n-                                    to: n\n-                                };\n-                                var l;\n-                                typeof r == \"object\" ? l = r.caseFold : (l = r, r = null), typeof t == \"string\" ? (l == null && (l = !1), this.matches = function(i, h) {\n-                                    return (i ? C : y)(e, t, h, l);\n-                                }) : (t = F(t, \"gm\"), !r || r.multiline !== !1 ? this.matches = function(i, h) {\n-                                    return (i ? A : j)(e, t, h);\n-                                } : this.matches = function(i, h) {\n-                                    return (i ? D : I)(e, t, h);\n-                                });\n-                            }\n-                            o(w, \"SearchCursor\"), w.prototype = {\n-                                findNext: function() {\n-                                    return this.find(!1);\n-                                },\n-                                findPrevious: function() {\n-                                    return this.find(!0);\n-                                },\n-                                find: function(e) {\n-                                    var t = this.doc.clipPos(e ? this.pos.from : this.pos.to);\n-                                    if (this.afterEmptyMatch && this.atOccurrence && (t = a(t.line, t.ch), e ? (t.ch--, t.ch < 0 && (t.line--, t.ch = (this.doc.getLine(t.line) || \"\").length)) : (t.ch++, t.ch > (this.doc.getLine(t.line) || \"\").length && (t.ch = 0, t.line++)), m.cmpPos(t, this.doc.clipPos(t)) != 0)) return this.atOccurrence = !1;\n-                                    var n = this.matches(e, t);\n-                                    if (this.afterEmptyMatch = n && m.cmpPos(n.from, n.to) == 0, n) return this.pos = n, this.atOccurrence = !0, this.pos.match || !0;\n-                                    var r = a(e ? this.doc.firstLine() : this.doc.lastLine() + 1, 0);\n-                                    return this.pos = {\n-                                        from: r,\n-                                        to: r\n-                                    }, this.atOccurrence = !1;\n-                                },\n-                                from: function() {\n-                                    if (this.atOccurrence) return this.pos.from;\n-                                },\n-                                to: function() {\n-                                    if (this.atOccurrence) return this.pos.to;\n-                                },\n-                                replace: function(e, t) {\n-                                    if (this.atOccurrence) {\n-                                        var n = m.splitLines(e);\n-                                        this.doc.replaceRange(n, this.pos.from, this.pos.to, t), this.pos.to = a(this.pos.from.line + n.length - 1, n[n.length - 1].length + (n.length == 1 ? this.pos.from.ch : 0));\n-                                    }\n-                                }\n-                            }, m.defineExtension(\"getSearchCursor\", function(e, t, n) {\n-                                return new w(this.doc, e, t, n);\n-                            }), m.defineDocExtension(\"getSearchCursor\", function(e, t, n) {\n-                                return new w(this, e, t, n);\n-                            }), m.defineExtension(\"selectMatches\", function(e, t) {\n-                                for (var n = [], r = this.getSearchCursor(e, this.getCursor(\"from\"), t); r.findNext() && !(m.cmpPos(r.to(), this.getCursor(\"to\")) > 0);) n.push({\n-                                    anchor: r.from(),\n-                                    head: r.to()\n-                                });\n-                                n.length && this.setSelections(n, 0);\n-                            });\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.useMergeRefs = useMergeRefs;\n+                var _assignRef = __webpack_require__( /*! ./assignRef */ \"../../../node_modules/use-callback-ref/dist/es2015/assignRef.js\");\n+                var _useRef = __webpack_require__( /*! ./useRef */ \"../../../node_modules/use-callback-ref/dist/es2015/useRef.js\");\n+                /**\n+                 * Merges two or more refs together providing a single interface to set their value\n+                 * @param {RefObject|Ref} refs\n+                 * @returns {MutableRefObject} - a new ref, which translates all changes to {refs}\n+                 *\n+                 * @see {@link mergeRefs} a version without buit-in memoization\n+                 * @see https://github.com/theKashey/use-callback-ref#usemergerefs\n+                 * @example\n+                 * const Component = React.forwardRef((props, ref) => {\n+                 *   const ownRef = useRef();\n+                 *   const domRef = useMergeRefs([ref, ownRef]); // \ud83d\udc48 merge together\n+                 *   return <div ref={domRef}>...</div>\n+                 * }\n+                 */\n+                function useMergeRefs(refs, defaultValue) {\n+                    return (0, _useRef.useCallbackRef)(defaultValue || null, function(newValue) {\n+                        return refs.forEach(function(ref) {\n+                            return (0, _assignRef.assignRef)(ref, newValue);\n                         });\n-                    }()), N.exports;\n+                    });\n                 }\n-                o(H, \"requireSearchcursor\");\n-                exports.requireSearchcursor = H;\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-react/dist/show-hint.cjs.js\":\n-            /*!**************************************************!*\\\n-              !*** ../../graphiql-react/dist/show-hint.cjs.js ***!\n-              \\**************************************************/\n+        \"../../../node_modules/use-callback-ref/dist/es2015/useRef.js\":\n+            /*!********************************************************************!*\\\n+              !*** ../../../node_modules/use-callback-ref/dist/es2015/useRef.js ***!\n+              \\********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                var ct = Object.defineProperty;\n-                var p = (H, A) => ct(H, \"name\", {\n-                    value: A,\n-                    configurable: !0\n-                });\n-                const G = __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\");\n-\n-                function lt(H, A) {\n-                    for (var r = 0; r < A.length; r++) {\n-                        const w = A[r];\n-                        if (typeof w != \"string\" && !Array.isArray(w)) {\n-                            for (const v in w)\n-                                if (v !== \"default\" && !(v in H)) {\n-                                    const b = Object.getOwnPropertyDescriptor(w, v);\n-                                    b && Object.defineProperty(H, v, b.get ? b : {\n-                                        enumerable: !0,\n-                                        get: () => w[v]\n-                                    });\n-                                }\n-                        }\n-                    }\n-                    return Object.freeze(Object.defineProperty(H, Symbol.toStringTag, {\n-                        value: \"Module\"\n-                    }));\n-                }\n-                p(lt, \"_mergeNamespaces\");\n-                var ht = {\n-                    exports: {}\n-                };\n-                (function(H, A) {\n-                    (function(r) {\n-                        r(G.requireCodemirror());\n-                    })(function(r) {\n-                        var w = \"CodeMirror-hint\",\n-                            v = \"CodeMirror-hint-active\";\n-                        r.showHint = function(t, e, i) {\n-                            if (!e) return t.showHint(i);\n-                            i && i.async && (e.async = !0);\n-                            var n = {\n-                                hint: e\n-                            };\n-                            if (i)\n-                                for (var s in i) n[s] = i[s];\n-                            return t.showHint(n);\n-                        }, r.defineExtension(\"showHint\", function(t) {\n-                            t = tt(this, this.getCursor(\"start\"), t);\n-                            var e = this.listSelections();\n-                            if (!(e.length > 1)) {\n-                                if (this.somethingSelected()) {\n-                                    if (!t.hint.supportsSelection) return;\n-                                    for (var i = 0; i < e.length; i++)\n-                                        if (e[i].head.line != e[i].anchor.line) return;\n-                                }\n-                                this.state.completionActive && this.state.completionActive.close();\n-                                var n = this.state.completionActive = new b(this, t);\n-                                n.options.hint && (r.signal(this, \"startCompletion\", this), n.update(!0));\n-                            }\n-                        }), r.defineExtension(\"closeHint\", function() {\n-                            this.state.completionActive && this.state.completionActive.close();\n-                        });\n-\n-                        function b(t, e) {\n-                            if (this.cm = t, this.options = e, this.widget = null, this.debounce = 0, this.tick = 0, this.startPos = this.cm.getCursor(\"start\"), this.startLen = this.cm.getLine(this.startPos.line).length - this.cm.getSelection().length, this.options.updateOnCursorActivity) {\n-                                var i = this;\n-                                t.on(\"cursorActivity\", this.activityFunc = function() {\n-                                    i.cursorActivity();\n-                                });\n-                            }\n-                        }\n-                        p(b, \"Completion\");\n-                        var Q = window.requestAnimationFrame || function(t) {\n-                                return setTimeout(t, 1e3 / 60);\n-                            },\n-                            Z = window.cancelAnimationFrame || clearTimeout;\n-                        b.prototype = {\n-                            close: function() {\n-                                this.active() && (this.cm.state.completionActive = null, this.tick = null, this.options.updateOnCursorActivity && this.cm.off(\"cursorActivity\", this.activityFunc), this.widget && this.data && r.signal(this.data, \"close\"), this.widget && this.widget.close(), r.signal(this.cm, \"endCompletion\", this.cm));\n-                            },\n-                            active: function() {\n-                                return this.cm.state.completionActive == this;\n-                            },\n-                            pick: function(t, e) {\n-                                var i = t.list[e],\n-                                    n = this;\n-                                this.cm.operation(function() {\n-                                    i.hint ? i.hint(n.cm, t, i) : n.cm.replaceRange(_(i), i.from || t.from, i.to || t.to, \"complete\"), r.signal(t, \"pick\", i), n.cm.scrollIntoView();\n-                                }), this.options.closeOnPick && this.close();\n-                            },\n-                            cursorActivity: function() {\n-                                this.debounce && (Z(this.debounce), this.debounce = 0);\n-                                var t = this.startPos;\n-                                this.data && (t = this.data.from);\n-                                var e = this.cm.getCursor(),\n-                                    i = this.cm.getLine(e.line);\n-                                if (e.line != this.startPos.line || i.length - e.ch != this.startLen - this.startPos.ch || e.ch < t.ch || this.cm.somethingSelected() || !e.ch || this.options.closeCharacters.test(i.charAt(e.ch - 1))) this.close();\n-                                else {\n-                                    var n = this;\n-                                    this.debounce = Q(function() {\n-                                        n.update();\n-                                    }), this.widget && this.widget.disable();\n-                                }\n-                            },\n-                            update: function(t) {\n-                                if (this.tick != null) {\n-                                    var e = this,\n-                                        i = ++this.tick;\n-                                    U(this.options.hint, this.cm, this.options, function(n) {\n-                                        e.tick == i && e.finishUpdate(n, t);\n-                                    });\n-                                }\n-                            },\n-                            finishUpdate: function(t, e) {\n-                                this.data && r.signal(this.data, \"update\");\n-                                var i = this.widget && this.widget.picked || e && this.options.completeSingle;\n-                                this.widget && this.widget.close(), this.data = t, t && t.list.length && (i && t.list.length == 1 ? this.pick(t, 0) : (this.widget = new K(this, t), r.signal(t, \"shown\")));\n-                            }\n-                        };\n-\n-                        function tt(t, e, i) {\n-                            var n = t.options.hintOptions,\n-                                s = {};\n-                            for (var c in D) s[c] = D[c];\n-                            if (n)\n-                                for (var c in n) n[c] !== void 0 && (s[c] = n[c]);\n-                            if (i)\n-                                for (var c in i) i[c] !== void 0 && (s[c] = i[c]);\n-                            return s.hint.resolve && (s.hint = s.hint.resolve(t, e)), s;\n-                        }\n-                        p(tt, \"parseOptions\");\n-\n-                        function _(t) {\n-                            return typeof t == \"string\" ? t : t.text;\n-                        }\n-                        p(_, \"getText\");\n-\n-                        function et(t, e) {\n-                            var i = {\n-                                    Up: function() {\n-                                        e.moveFocus(-1);\n-                                    },\n-                                    Down: function() {\n-                                        e.moveFocus(1);\n-                                    },\n-                                    PageUp: function() {\n-                                        e.moveFocus(-e.menuSize() + 1, !0);\n-                                    },\n-                                    PageDown: function() {\n-                                        e.moveFocus(e.menuSize() - 1, !0);\n-                                    },\n-                                    Home: function() {\n-                                        e.setFocus(0);\n-                                    },\n-                                    End: function() {\n-                                        e.setFocus(e.length - 1);\n-                                    },\n-                                    Enter: e.pick,\n-                                    Tab: e.pick,\n-                                    Esc: e.close\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.useCallbackRef = useCallbackRef;\n+                var _react = __webpack_require__( /*! react */ \"react\");\n+                /**\n+                 * creates a MutableRef with ref change callback\n+                 * @param initialValue - initial ref value\n+                 * @param {Function} callback - a callback to run when value changes\n+                 *\n+                 * @example\n+                 * const ref = useCallbackRef(0, (newValue, oldValue) => console.log(oldValue, '->', newValue);\n+                 * ref.current = 1;\n+                 * // prints 0 -> 1\n+                 *\n+                 * @see https://reactjs.org/docs/hooks-reference.html#useref\n+                 * @see https://github.com/theKashey/use-callback-ref#usecallbackref---to-replace-reactuseref\n+                 * @returns {MutableRefObject}\n+                 */\n+                function useCallbackRef(initialValue, callback) {\n+                    var ref = (0, _react.useState)(function() {\n+                        return {\n+                            // value\n+                            value: initialValue,\n+                            // last callback\n+                            callback: callback,\n+                            // \"memoized\" public interface\n+                            facade: {\n+                                get current() {\n+                                    return ref.value;\n                                 },\n-                                n = /Mac/.test(navigator.platform);\n-                            n && (i[\"Ctrl-P\"] = function() {\n-                                e.moveFocus(-1);\n-                            }, i[\"Ctrl-N\"] = function() {\n-                                e.moveFocus(1);\n-                            });\n-                            var s = t.options.customKeys,\n-                                c = s ? {} : i;\n-\n-                            function o(u, l) {\n-                                var a;\n-                                typeof l != \"string\" ? a = p(function(S) {\n-                                    return l(S, e);\n-                                }, \"bound\") : i.hasOwnProperty(l) ? a = i[l] : a = l, c[u] = a;\n-                            }\n-                            if (p(o, \"addBinding\"), s)\n-                                for (var f in s) s.hasOwnProperty(f) && o(f, s[f]);\n-                            var h = t.options.extraKeys;\n-                            if (h)\n-                                for (var f in h) h.hasOwnProperty(f) && o(f, h[f]);\n-                            return c;\n-                        }\n-                        p(et, \"buildKeyMap\");\n-\n-                        function B(t, e) {\n-                            for (; e && e != t;) {\n-                                if (e.nodeName.toUpperCase() === \"LI\" && e.parentNode == t) return e;\n-                                e = e.parentNode;\n-                            }\n-                        }\n-                        p(B, \"getHintElement\");\n-\n-                        function K(t, e) {\n-                            this.id = \"cm-complete-\" + Math.floor(Math.random(1e6)), this.completion = t, this.data = e, this.picked = !1;\n-                            var i = this,\n-                                n = t.cm,\n-                                s = n.getInputField().ownerDocument,\n-                                c = s.defaultView || s.parentWindow,\n-                                o = this.hints = s.createElement(\"ul\");\n-                            o.setAttribute(\"role\", \"listbox\"), o.setAttribute(\"aria-expanded\", \"true\"), o.id = this.id;\n-                            var f = t.cm.options.theme;\n-                            o.className = \"CodeMirror-hints \" + f, this.selectedHint = e.selectedHint || 0;\n-                            for (var h = e.list, u = 0; u < h.length; ++u) {\n-                                var l = o.appendChild(s.createElement(\"li\")),\n-                                    a = h[u],\n-                                    S = w + (u != this.selectedHint ? \"\" : \" \" + v);\n-                                a.className != null && (S = a.className + \" \" + S), l.className = S, u == this.selectedHint && l.setAttribute(\"aria-selected\", \"true\"), l.id = this.id + \"-\" + u, l.setAttribute(\"role\", \"option\"), a.render ? a.render(l, e, a) : l.appendChild(s.createTextNode(a.displayText || _(a))), l.hintId = u;\n-                            }\n-                            var T = t.options.container || s.body,\n-                                y = n.cursorCoords(t.options.alignWithWord ? e.from : null),\n-                                k = y.left,\n-                                O = y.bottom,\n-                                j = !0,\n-                                F = 0,\n-                                E = 0;\n-                            if (T !== s.body) {\n-                                var st = [\"absolute\", \"relative\", \"fixed\"].indexOf(c.getComputedStyle(T).position) !== -1,\n-                                    W = st ? T : T.offsetParent,\n-                                    M = W.getBoundingClientRect(),\n-                                    q = s.body.getBoundingClientRect();\n-                                F = M.left - q.left - W.scrollLeft, E = M.top - q.top - W.scrollTop;\n-                            }\n-                            o.style.left = k - F + \"px\", o.style.top = O - E + \"px\";\n-                            var N = c.innerWidth || Math.max(s.body.offsetWidth, s.documentElement.offsetWidth),\n-                                L = c.innerHeight || Math.max(s.body.offsetHeight, s.documentElement.offsetHeight);\n-                            T.appendChild(o), n.getInputField().setAttribute(\"aria-autocomplete\", \"list\"), n.getInputField().setAttribute(\"aria-owns\", this.id), n.getInputField().setAttribute(\"aria-activedescendant\", this.id + \"-\" + this.selectedHint);\n-                            var m = t.options.moveOnOverlap ? o.getBoundingClientRect() : new DOMRect(),\n-                                z = t.options.paddingForScrollbar ? o.scrollHeight > o.clientHeight + 1 : !1,\n-                                x;\n-                            setTimeout(function() {\n-                                x = n.getScrollInfo();\n-                            });\n-                            var ot = m.bottom - L;\n-                            if (ot > 0) {\n-                                var P = m.bottom - m.top,\n-                                    rt = y.top - (y.bottom - m.top);\n-                                if (rt - P > 0) o.style.top = (O = y.top - P - E) + \"px\", j = !1;\n-                                else if (P > L) {\n-                                    o.style.height = L - 5 + \"px\", o.style.top = (O = y.bottom - m.top - E) + \"px\";\n-                                    var V = n.getCursor();\n-                                    e.from.ch != V.ch && (y = n.cursorCoords(V), o.style.left = (k = y.left - F) + \"px\", m = o.getBoundingClientRect());\n-                                }\n-                            }\n-                            var C = m.right - N;\n-                            if (z && (C += n.display.nativeBarWidth), C > 0 && (m.right - m.left > N && (o.style.width = N - 5 + \"px\", C -= m.right - m.left - N), o.style.left = (k = y.left - C - F) + \"px\"), z)\n-                                for (var I = o.firstChild; I; I = I.nextSibling) I.style.paddingRight = n.display.nativeBarWidth + \"px\";\n-                            if (n.addKeyMap(this.keyMap = et(t, {\n-                                    moveFocus: function(d, g) {\n-                                        i.changeActive(i.selectedHint + d, g);\n-                                    },\n-                                    setFocus: function(d) {\n-                                        i.changeActive(d);\n-                                    },\n-                                    menuSize: function() {\n-                                        return i.screenAmount();\n-                                    },\n-                                    length: h.length,\n-                                    close: function() {\n-                                        t.close();\n-                                    },\n-                                    pick: function() {\n-                                        i.pick();\n-                                    },\n-                                    data: e\n-                                })), t.options.closeOnUnfocus) {\n-                                var Y;\n-                                n.on(\"blur\", this.onBlur = function() {\n-                                    Y = setTimeout(function() {\n-                                        t.close();\n-                                    }, 100);\n-                                }), n.on(\"focus\", this.onFocus = function() {\n-                                    clearTimeout(Y);\n-                                });\n-                            }\n-                            n.on(\"scroll\", this.onScroll = function() {\n-                                var d = n.getScrollInfo(),\n-                                    g = n.getWrapperElement().getBoundingClientRect();\n-                                x || (x = n.getScrollInfo());\n-                                var X = O + x.top - d.top,\n-                                    R = X - (c.pageYOffset || (s.documentElement || s.body).scrollTop);\n-                                if (j || (R += o.offsetHeight), R <= g.top || R >= g.bottom) return t.close();\n-                                o.style.top = X + \"px\", o.style.left = k + x.left - d.left + \"px\";\n-                            }), r.on(o, \"dblclick\", function(d) {\n-                                var g = B(o, d.target || d.srcElement);\n-                                g && g.hintId != null && (i.changeActive(g.hintId), i.pick());\n-                            }), r.on(o, \"click\", function(d) {\n-                                var g = B(o, d.target || d.srcElement);\n-                                g && g.hintId != null && (i.changeActive(g.hintId), t.options.completeOnSingleClick && i.pick());\n-                            }), r.on(o, \"mousedown\", function() {\n-                                setTimeout(function() {\n-                                    n.focus();\n-                                }, 20);\n-                            });\n-                            var $ = this.getSelectedHintRange();\n-                            return ($.from !== 0 || $.to !== 0) && this.scrollToActive(), r.signal(e, \"select\", h[this.selectedHint], o.childNodes[this.selectedHint]), !0;\n-                        }\n-                        p(K, \"Widget\"), K.prototype = {\n-                            close: function() {\n-                                if (this.completion.widget == this) {\n-                                    this.completion.widget = null, this.hints.parentNode && this.hints.parentNode.removeChild(this.hints), this.completion.cm.removeKeyMap(this.keyMap);\n-                                    var t = this.completion.cm.getInputField();\n-                                    t.removeAttribute(\"aria-activedescendant\"), t.removeAttribute(\"aria-owns\");\n-                                    var e = this.completion.cm;\n-                                    this.completion.options.closeOnUnfocus && (e.off(\"blur\", this.onBlur), e.off(\"focus\", this.onFocus)), e.off(\"scroll\", this.onScroll);\n-                                }\n-                            },\n-                            disable: function() {\n-                                this.completion.cm.removeKeyMap(this.keyMap);\n-                                var t = this;\n-                                this.keyMap = {\n-                                    Enter: function() {\n-                                        t.picked = !0;\n+                                set current(value) {\n+                                    var last = ref.value;\n+                                    if (last !== value) {\n+                                        ref.value = value;\n+                                        ref.callback(value, last);\n                                     }\n-                                }, this.completion.cm.addKeyMap(this.keyMap);\n-                            },\n-                            pick: function() {\n-                                this.completion.pick(this.data, this.selectedHint);\n-                            },\n-                            changeActive: function(t, e) {\n-                                if (t >= this.data.list.length ? t = e ? this.data.list.length - 1 : 0 : t < 0 && (t = e ? 0 : this.data.list.length - 1), this.selectedHint != t) {\n-                                    var i = this.hints.childNodes[this.selectedHint];\n-                                    i && (i.className = i.className.replace(\" \" + v, \"\"), i.removeAttribute(\"aria-selected\")), i = this.hints.childNodes[this.selectedHint = t], i.className += \" \" + v, i.setAttribute(\"aria-selected\", \"true\"), this.completion.cm.getInputField().setAttribute(\"aria-activedescendant\", i.id), this.scrollToActive(), r.signal(this.data, \"select\", this.data.list[this.selectedHint], i);\n                                 }\n-                            },\n-                            scrollToActive: function() {\n-                                var t = this.getSelectedHintRange(),\n-                                    e = this.hints.childNodes[t.from],\n-                                    i = this.hints.childNodes[t.to],\n-                                    n = this.hints.firstChild;\n-                                e.offsetTop < this.hints.scrollTop ? this.hints.scrollTop = e.offsetTop - n.offsetTop : i.offsetTop + i.offsetHeight > this.hints.scrollTop + this.hints.clientHeight && (this.hints.scrollTop = i.offsetTop + i.offsetHeight - this.hints.clientHeight + n.offsetTop);\n-                            },\n-                            screenAmount: function() {\n-                                return Math.floor(this.hints.clientHeight / this.hints.firstChild.offsetHeight) || 1;\n-                            },\n-                            getSelectedHintRange: function() {\n-                                var t = this.completion.options.scrollMargin || 0;\n-                                return {\n-                                    from: Math.max(0, this.selectedHint - t),\n-                                    to: Math.min(this.data.list.length - 1, this.selectedHint + t)\n-                                };\n                             }\n                         };\n-\n-                        function it(t, e) {\n-                            if (!t.somethingSelected()) return e;\n-                            for (var i = [], n = 0; n < e.length; n++) e[n].supportsSelection && i.push(e[n]);\n-                            return i;\n-                        }\n-                        p(it, \"applicableHelpers\");\n-\n-                        function U(t, e, i, n) {\n-                            if (t.async) t(e, n, i);\n-                            else {\n-                                var s = t(e, i);\n-                                s && s.then ? s.then(n) : n(s);\n-                            }\n-                        }\n-                        p(U, \"fetchHints\");\n-\n-                        function nt(t, e) {\n-                            var i = t.getHelpers(e, \"hint\"),\n-                                n;\n-                            if (i.length) {\n-                                var s = p(function(c, o, f) {\n-                                    var h = it(c, i);\n-\n-                                    function u(l) {\n-                                        if (l == h.length) return o(null);\n-                                        U(h[l], c, f, function(a) {\n-                                            a && a.list.length > 0 ? o(a) : u(l + 1);\n-                                        });\n-                                    }\n-                                    p(u, \"run\"), u(0);\n-                                }, \"resolved\");\n-                                return s.async = !0, s.supportsSelection = !0, s;\n-                            } else return (n = t.getHelper(t.getCursor(), \"hintWords\")) ? function(c) {\n-                                return r.hint.fromList(c, {\n-                                    words: n\n-                                });\n-                            } : r.hint.anyword ? function(c, o) {\n-                                return r.hint.anyword(c, o);\n-                            } : function() {};\n-                        }\n-                        p(nt, \"resolveAutoHints\"), r.registerHelper(\"hint\", \"auto\", {\n-                            resolve: nt\n-                        }), r.registerHelper(\"hint\", \"fromList\", function(t, e) {\n-                            var i = t.getCursor(),\n-                                n = t.getTokenAt(i),\n-                                s,\n-                                c = r.Pos(i.line, n.start),\n-                                o = i;\n-                            n.start < i.ch && /\\w/.test(n.string.charAt(i.ch - n.start - 1)) ? s = n.string.substr(0, i.ch - n.start) : (s = \"\", c = i);\n-                            for (var f = [], h = 0; h < e.words.length; h++) {\n-                                var u = e.words[h];\n-                                u.slice(0, s.length) == s && f.push(u);\n-                            }\n-                            if (f.length) return {\n-                                list: f,\n-                                from: c,\n-                                to: o\n-                            };\n-                        }), r.commands.autocomplete = r.showHint;\n-                        var D = {\n-                            hint: r.hint.auto,\n-                            completeSingle: !0,\n-                            alignWithWord: !0,\n-                            closeCharacters: /[\\s()\\[\\]{};:>,]/,\n-                            closeOnPick: !0,\n-                            closeOnUnfocus: !0,\n-                            updateOnCursorActivity: !0,\n-                            completeOnSingleClick: !0,\n-                            container: null,\n-                            customKeys: null,\n-                            extraKeys: null,\n-                            paddingForScrollbar: !0,\n-                            moveOnOverlap: !0\n-                        };\n-                        r.defineOption(\"hintOptions\", null);\n-                    });\n-                })();\n-                var J = ht.exports;\n-                const at = G.getDefaultExportFromCjs(J),\n-                    ft = lt({\n-                        __proto__: null,\n-                        default: at\n-                    }, [J]);\n-                exports.showHint = ft;\n+                    })[0];\n+                    // update callback\n+                    ref.callback = callback;\n+                    return ref.facade;\n+                }\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-react/dist/sublime.cjs.js\":\n-            /*!************************************************!*\\\n-              !*** ../../graphiql-react/dist/sublime.cjs.js ***!\n-              \\************************************************/\n+        \"../../../node_modules/use-callback-ref/dist/es2015/useTransformRef.js\":\n+            /*!*****************************************************************************!*\\\n+              !*** ../../../node_modules/use-callback-ref/dist/es2015/useTransformRef.js ***!\n+              \\*****************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                var _ = Object.defineProperty;\n-                var v = (m, B) => _(m, \"name\", {\n-                    value: B,\n-                    configurable: !0\n-                });\n-                const E = __webpack_require__( /*! ./codemirror.cjs2.js */ \"../../graphiql-react/dist/codemirror.cjs2.js\"),\n-                    Y = __webpack_require__( /*! ./searchcursor.cjs2.js */ \"../../graphiql-react/dist/searchcursor.cjs2.js\"),\n-                    z = __webpack_require__( /*! ./matchbrackets.cjs2.js */ \"../../graphiql-react/dist/matchbrackets.cjs2.js\");\n-\n-                function J(m, B) {\n-                    for (var h = 0; h < B.length; h++) {\n-                        const a = B[h];\n-                        if (typeof a != \"string\" && !Array.isArray(a)) {\n-                            for (const f in a)\n-                                if (f !== \"default\" && !(f in m)) {\n-                                    const A = Object.getOwnPropertyDescriptor(a, f);\n-                                    A && Object.defineProperty(m, f, A.get ? A : {\n-                                        enumerable: !0,\n-                                        get: () => a[f]\n-                                    });\n-                                }\n-                        }\n-                    }\n-                    return Object.freeze(Object.defineProperty(m, Symbol.toStringTag, {\n-                        value: \"Module\"\n-                    }));\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.useTransformRef = useTransformRef;\n+                var _assignRef = __webpack_require__( /*! ./assignRef */ \"../../../node_modules/use-callback-ref/dist/es2015/assignRef.js\");\n+                var _useRef = __webpack_require__( /*! ./useRef */ \"../../../node_modules/use-callback-ref/dist/es2015/useRef.js\");\n+                /**\n+                 * Create a _lense_ on Ref, making it possible to transform ref value\n+                 * @param {ReactRef} ref\n+                 * @param {Function} transformer. \ud83d\udc49 Ref would be __NOT updated__ on `transformer` update.\n+                 * @returns {RefObject}\n+                 *\n+                 * @see https://github.com/theKashey/use-callback-ref#usetransformref-to-replace-reactuseimperativehandle\n+                 * @example\n+                 *\n+                 * const ResizableWithRef = forwardRef((props, ref) =>\n+                 *  <Resizable {...props} ref={useTransformRef(ref, i => i ? i.resizable : null)}/>\n+                 * );\n+                 */\n+                function useTransformRef(ref, transformer) {\n+                    return (0, _useRef.useCallbackRef)(null, function(value) {\n+                        return (0, _assignRef.assignRef)(ref, transformer(value));\n+                    });\n                 }\n-                v(J, \"_mergeNamespaces\");\n-                var G = {\n-                    exports: {}\n-                };\n-                (function(m, B) {\n-                    (function(h) {\n-                        h(E.requireCodemirror(), Y.requireSearchcursor(), z.requireMatchbrackets());\n-                    })(function(h) {\n-                        var a = h.commands,\n-                            f = h.Pos;\n-\n-                        function A(e, t, n) {\n-                            if (n < 0 && t.ch == 0) return e.clipPos(f(t.line - 1));\n-                            var r = e.getLine(t.line);\n-                            if (n > 0 && t.ch >= r.length) return e.clipPos(f(t.line + 1, 0));\n-                            for (var l = \"start\", i, o = t.ch, s = o, u = n < 0 ? 0 : r.length, d = 0; s != u; s += n, d++) {\n-                                var p = r.charAt(n < 0 ? s - 1 : s),\n-                                    c = p != \"_\" && h.isWordChar(p) ? \"w\" : \"o\";\n-                                if (c == \"w\" && p.toUpperCase() == p && (c = \"W\"), l == \"start\") c != \"o\" ? (l = \"in\", i = c) : o = s + n;\n-                                else if (l == \"in\" && i != c) {\n-                                    if (i == \"w\" && c == \"W\" && n < 0 && s--, i == \"W\" && c == \"w\" && n > 0)\n-                                        if (s == o + 1) {\n-                                            i = \"w\";\n-                                            continue;\n-                                        } else s--;\n-                                    break;\n-                                }\n-                            }\n-                            return f(t.line, s);\n-                        }\n-                        v(A, \"findPosSubword\");\n-\n-                        function T(e, t) {\n-                            e.extendSelectionsBy(function(n) {\n-                                return e.display.shift || e.doc.extend || n.empty() ? A(e.doc, n.head, t) : t < 0 ? n.from() : n.to();\n-                            });\n-                        }\n-                        v(T, \"moveSubword\"), a.goSubwordLeft = function(e) {\n-                            T(e, -1);\n-                        }, a.goSubwordRight = function(e) {\n-                            T(e, 1);\n-                        }, a.scrollLineUp = function(e) {\n-                            var t = e.getScrollInfo();\n-                            if (!e.somethingSelected()) {\n-                                var n = e.lineAtHeight(t.top + t.clientHeight, \"local\");\n-                                e.getCursor().line >= n && e.execCommand(\"goLineUp\");\n-                            }\n-                            e.scrollTo(null, t.top - e.defaultTextHeight());\n-                        }, a.scrollLineDown = function(e) {\n-                            var t = e.getScrollInfo();\n-                            if (!e.somethingSelected()) {\n-                                var n = e.lineAtHeight(t.top, \"local\") + 1;\n-                                e.getCursor().line <= n && e.execCommand(\"goLineDown\");\n-                            }\n-                            e.scrollTo(null, t.top + e.defaultTextHeight());\n-                        }, a.splitSelectionByLine = function(e) {\n-                            for (var t = e.listSelections(), n = [], r = 0; r < t.length; r++)\n-                                for (var l = t[r].from(), i = t[r].to(), o = l.line; o <= i.line; ++o) i.line > l.line && o == i.line && i.ch == 0 || n.push({\n-                                    anchor: o == l.line ? l : f(o, 0),\n-                                    head: o == i.line ? i : f(o)\n-                                });\n-                            e.setSelections(n, 0);\n-                        }, a.singleSelectionTop = function(e) {\n-                            var t = e.listSelections()[0];\n-                            e.setSelection(t.anchor, t.head, {\n-                                scroll: !1\n-                            });\n-                        }, a.selectLine = function(e) {\n-                            for (var t = e.listSelections(), n = [], r = 0; r < t.length; r++) {\n-                                var l = t[r];\n-                                n.push({\n-                                    anchor: f(l.from().line, 0),\n-                                    head: f(l.to().line + 1, 0)\n-                                });\n-                            }\n-                            e.setSelections(n);\n-                        };\n-\n-                        function x(e, t) {\n-                            if (e.isReadOnly()) return h.Pass;\n-                            e.operation(function() {\n-                                for (var n = e.listSelections().length, r = [], l = -1, i = 0; i < n; i++) {\n-                                    var o = e.listSelections()[i].head;\n-                                    if (!(o.line <= l)) {\n-                                        var s = f(o.line + (t ? 0 : 1), 0);\n-                                        e.replaceRange(`\n-`, s, null, \"+insertLine\"), e.indentLine(s.line, null, !0), r.push({\n-                                            head: s,\n-                                            anchor: s\n-                                        }), l = o.line + 1;\n-                                    }\n-                                }\n-                                e.setSelections(r);\n-                            }), e.execCommand(\"indentAuto\");\n-                        }\n-                        v(x, \"insertLine\"), a.insertLineAfter = function(e) {\n-                            return x(e, !1);\n-                        }, a.insertLineBefore = function(e) {\n-                            return x(e, !0);\n-                        };\n-\n-                        function K(e, t) {\n-                            for (var n = t.ch, r = n, l = e.getLine(t.line); n && h.isWordChar(l.charAt(n - 1));) --n;\n-                            for (; r < l.length && h.isWordChar(l.charAt(r));) ++r;\n-                            return {\n-                                from: f(t.line, n),\n-                                to: f(t.line, r),\n-                                word: l.slice(n, r)\n-                            };\n-                        }\n-                        v(K, \"wordAt\"), a.selectNextOccurrence = function(e) {\n-                            var t = e.getCursor(\"from\"),\n-                                n = e.getCursor(\"to\"),\n-                                r = e.state.sublimeFindFullWord == e.doc.sel;\n-                            if (h.cmpPos(t, n) == 0) {\n-                                var l = K(e, t);\n-                                if (!l.word) return;\n-                                e.setSelection(l.from, l.to), r = !0;\n-                            } else {\n-                                var i = e.getRange(t, n),\n-                                    o = r ? new RegExp(\"\\\\b\" + i + \"\\\\b\") : i,\n-                                    s = e.getSearchCursor(o, n),\n-                                    u = s.findNext();\n-                                if (u || (s = e.getSearchCursor(o, f(e.firstLine(), 0)), u = s.findNext()), !u || H(e.listSelections(), s.from(), s.to())) return;\n-                                e.addSelection(s.from(), s.to());\n-                            }\n-                            r && (e.state.sublimeFindFullWord = e.doc.sel);\n-                        }, a.skipAndSelectNextOccurrence = function(e) {\n-                            var t = e.getCursor(\"anchor\"),\n-                                n = e.getCursor(\"head\");\n-                            a.selectNextOccurrence(e), h.cmpPos(t, n) != 0 && e.doc.setSelections(e.doc.listSelections().filter(function(r) {\n-                                return r.anchor != t || r.head != n;\n-                            }));\n-                        };\n-\n-                        function y(e, t) {\n-                            for (var n = e.listSelections(), r = [], l = 0; l < n.length; l++) {\n-                                var i = n[l],\n-                                    o = e.findPosV(i.anchor, t, \"line\", i.anchor.goalColumn),\n-                                    s = e.findPosV(i.head, t, \"line\", i.head.goalColumn);\n-                                o.goalColumn = i.anchor.goalColumn != null ? i.anchor.goalColumn : e.cursorCoords(i.anchor, \"div\").left, s.goalColumn = i.head.goalColumn != null ? i.head.goalColumn : e.cursorCoords(i.head, \"div\").left;\n-                                var u = {\n-                                    anchor: o,\n-                                    head: s\n-                                };\n-                                r.push(i), r.push(u);\n-                            }\n-                            e.setSelections(r);\n-                        }\n-                        v(y, \"addCursorToSelection\"), a.addCursorToPrevLine = function(e) {\n-                            y(e, -1);\n-                        }, a.addCursorToNextLine = function(e) {\n-                            y(e, 1);\n-                        };\n-\n-                        function H(e, t, n) {\n-                            for (var r = 0; r < e.length; r++)\n-                                if (h.cmpPos(e[r].from(), t) == 0 && h.cmpPos(e[r].to(), n) == 0) return !0;\n-                            return !1;\n-                        }\n-                        v(H, \"isSelectedRange\");\n-                        var P = \"(){}[]\";\n-\n-                        function U(e) {\n-                            for (var t = e.listSelections(), n = [], r = 0; r < t.length; r++) {\n-                                var l = t[r],\n-                                    i = l.head,\n-                                    o = e.scanForBracket(i, -1);\n-                                if (!o) return !1;\n-                                for (;;) {\n-                                    var s = e.scanForBracket(i, 1);\n-                                    if (!s) return !1;\n-                                    if (s.ch == P.charAt(P.indexOf(o.ch) + 1)) {\n-                                        var u = f(o.pos.line, o.pos.ch + 1);\n-                                        if (h.cmpPos(u, l.from()) == 0 && h.cmpPos(s.pos, l.to()) == 0) {\n-                                            if (o = e.scanForBracket(o.pos, -1), !o) return !1;\n-                                        } else {\n-                                            n.push({\n-                                                anchor: u,\n-                                                head: s.pos\n-                                            });\n-                                            break;\n-                                        }\n-                                    }\n-                                    i = f(s.pos.line, s.pos.ch + 1);\n-                                }\n-                            }\n-                            return e.setSelections(n), !0;\n-                        }\n-                        v(U, \"selectBetweenBrackets\"), a.selectScope = function(e) {\n-                            U(e) || e.execCommand(\"selectAll\");\n-                        }, a.selectBetweenBrackets = function(e) {\n-                            if (!U(e)) return h.Pass;\n-                        };\n-\n-                        function I(e) {\n-                            return e ? /\\bpunctuation\\b/.test(e) ? e : void 0 : null;\n-                        }\n-                        v(I, \"puncType\"), a.goToBracket = function(e) {\n-                            e.extendSelectionsBy(function(t) {\n-                                var n = e.scanForBracket(t.head, 1, I(e.getTokenTypeAt(t.head)));\n-                                if (n && h.cmpPos(n.pos, t.head) != 0) return n.pos;\n-                                var r = e.scanForBracket(t.head, -1, I(e.getTokenTypeAt(f(t.head.line, t.head.ch + 1))));\n-                                return r && f(r.pos.line, r.pos.ch + 1) || t.head;\n-                            });\n-                        }, a.swapLineUp = function(e) {\n-                            if (e.isReadOnly()) return h.Pass;\n-                            for (var t = e.listSelections(), n = [], r = e.firstLine() - 1, l = [], i = 0; i < t.length; i++) {\n-                                var o = t[i],\n-                                    s = o.from().line - 1,\n-                                    u = o.to().line;\n-                                l.push({\n-                                    anchor: f(o.anchor.line - 1, o.anchor.ch),\n-                                    head: f(o.head.line - 1, o.head.ch)\n-                                }), o.to().ch == 0 && !o.empty() && --u, s > r ? n.push(s, u) : n.length && (n[n.length - 1] = u), r = u;\n-                            }\n-                            e.operation(function() {\n-                                for (var d = 0; d < n.length; d += 2) {\n-                                    var p = n[d],\n-                                        c = n[d + 1],\n-                                        b = e.getLine(p);\n-                                    e.replaceRange(\"\", f(p, 0), f(p + 1, 0), \"+swapLine\"), c > e.lastLine() ? e.replaceRange(`\n-` + b, f(e.lastLine()), null, \"+swapLine\") : e.replaceRange(b + `\n-`, f(c, 0), null, \"+swapLine\");\n-                                }\n-                                e.setSelections(l), e.scrollIntoView();\n-                            });\n-                        }, a.swapLineDown = function(e) {\n-                            if (e.isReadOnly()) return h.Pass;\n-                            for (var t = e.listSelections(), n = [], r = e.lastLine() + 1, l = t.length - 1; l >= 0; l--) {\n-                                var i = t[l],\n-                                    o = i.to().line + 1,\n-                                    s = i.from().line;\n-                                i.to().ch == 0 && !i.empty() && o--, o < r ? n.push(o, s) : n.length && (n[n.length - 1] = s), r = s;\n-                            }\n-                            e.operation(function() {\n-                                for (var u = n.length - 2; u >= 0; u -= 2) {\n-                                    var d = n[u],\n-                                        p = n[u + 1],\n-                                        c = e.getLine(d);\n-                                    d == e.lastLine() ? e.replaceRange(\"\", f(d - 1), f(d), \"+swapLine\") : e.replaceRange(\"\", f(d, 0), f(d + 1, 0), \"+swapLine\"), e.replaceRange(c + `\n-`, f(p, 0), null, \"+swapLine\");\n-                                }\n-                                e.scrollIntoView();\n-                            });\n-                        }, a.toggleCommentIndented = function(e) {\n-                            e.toggleComment({\n-                                indent: !0\n-                            });\n-                        }, a.joinLines = function(e) {\n-                            for (var t = e.listSelections(), n = [], r = 0; r < t.length; r++) {\n-                                for (var l = t[r], i = l.from(), o = i.line, s = l.to().line; r < t.length - 1 && t[r + 1].from().line == s;) s = t[++r].to().line;\n-                                n.push({\n-                                    start: o,\n-                                    end: s,\n-                                    anchor: !l.empty() && i\n-                                });\n-                            }\n-                            e.operation(function() {\n-                                for (var u = 0, d = [], p = 0; p < n.length; p++) {\n-                                    for (var c = n[p], b = c.anchor && f(c.anchor.line - u, c.anchor.ch), w, g = c.start; g <= c.end; g++) {\n-                                        var S = g - u;\n-                                        g == c.end && (w = f(S, e.getLine(S).length + 1)), S < e.lastLine() && (e.replaceRange(\" \", f(S), f(S + 1, /^\\s*/.exec(e.getLine(S + 1))[0].length)), ++u);\n-                                    }\n-                                    d.push({\n-                                        anchor: b || w,\n-                                        head: w\n-                                    });\n-                                }\n-                                e.setSelections(d, 0);\n-                            });\n-                        }, a.duplicateLine = function(e) {\n-                            e.operation(function() {\n-                                for (var t = e.listSelections().length, n = 0; n < t; n++) {\n-                                    var r = e.listSelections()[n];\n-                                    r.empty() ? e.replaceRange(e.getLine(r.head.line) + `\n-`, f(r.head.line, 0)) : e.replaceRange(e.getRange(r.from(), r.to()), r.from());\n-                                }\n-                                e.scrollIntoView();\n-                            });\n-                        };\n-\n-                        function R(e, t, n) {\n-                            if (e.isReadOnly()) return h.Pass;\n-                            for (var r = e.listSelections(), l = [], i, o = 0; o < r.length; o++) {\n-                                var s = r[o];\n-                                if (!s.empty()) {\n-                                    for (var u = s.from().line, d = s.to().line; o < r.length - 1 && r[o + 1].from().line == d;) d = r[++o].to().line;\n-                                    r[o].to().ch || d--, l.push(u, d);\n-                                }\n-                            }\n-                            l.length ? i = !0 : l.push(e.firstLine(), e.lastLine()), e.operation(function() {\n-                                for (var p = [], c = 0; c < l.length; c += 2) {\n-                                    var b = l[c],\n-                                        w = l[c + 1],\n-                                        g = f(b, 0),\n-                                        S = f(w),\n-                                        F = e.getRange(g, S, !1);\n-                                    t ? F.sort(function(k, L) {\n-                                        return k < L ? -n : k == L ? 0 : n;\n-                                    }) : F.sort(function(k, L) {\n-                                        var W = k.toUpperCase(),\n-                                            M = L.toUpperCase();\n-                                        return W != M && (k = W, L = M), k < L ? -n : k == L ? 0 : n;\n-                                    }), e.replaceRange(F, g, S), i && p.push({\n-                                        anchor: g,\n-                                        head: f(w + 1, 0)\n-                                    });\n-                                }\n-                                i && e.setSelections(p, 0);\n-                            });\n-                        }\n-                        v(R, \"sortLines\"), a.sortLines = function(e) {\n-                            R(e, !0, 1);\n-                        }, a.reverseSortLines = function(e) {\n-                            R(e, !0, -1);\n-                        }, a.sortLinesInsensitive = function(e) {\n-                            R(e, !1, 1);\n-                        }, a.reverseSortLinesInsensitive = function(e) {\n-                            R(e, !1, -1);\n-                        }, a.nextBookmark = function(e) {\n-                            var t = e.state.sublimeBookmarks;\n-                            if (t)\n-                                for (; t.length;) {\n-                                    var n = t.shift(),\n-                                        r = n.find();\n-                                    if (r) return t.push(n), e.setSelection(r.from, r.to);\n-                                }\n-                        }, a.prevBookmark = function(e) {\n-                            var t = e.state.sublimeBookmarks;\n-                            if (t)\n-                                for (; t.length;) {\n-                                    t.unshift(t.pop());\n-                                    var n = t[t.length - 1].find();\n-                                    if (!n) t.pop();\n-                                    else return e.setSelection(n.from, n.to);\n-                                }\n-                        }, a.toggleBookmark = function(e) {\n-                            for (var t = e.listSelections(), n = e.state.sublimeBookmarks || (e.state.sublimeBookmarks = []), r = 0; r < t.length; r++) {\n-                                for (var l = t[r].from(), i = t[r].to(), o = t[r].empty() ? e.findMarksAt(l) : e.findMarks(l, i), s = 0; s < o.length; s++)\n-                                    if (o[s].sublimeBookmark) {\n-                                        o[s].clear();\n-                                        for (var u = 0; u < n.length; u++) n[u] == o[s] && n.splice(u--, 1);\n-                                        break;\n-                                    }\n-                                s == o.length && n.push(e.markText(l, i, {\n-                                    sublimeBookmark: !0,\n-                                    clearWhenEmpty: !1\n-                                }));\n-                            }\n-                        }, a.clearBookmarks = function(e) {\n-                            var t = e.state.sublimeBookmarks;\n-                            if (t)\n-                                for (var n = 0; n < t.length; n++) t[n].clear();\n-                            t.length = 0;\n-                        }, a.selectBookmarks = function(e) {\n-                            var t = e.state.sublimeBookmarks,\n-                                n = [];\n-                            if (t)\n-                                for (var r = 0; r < t.length; r++) {\n-                                    var l = t[r].find();\n-                                    l ? n.push({\n-                                        anchor: l.from,\n-                                        head: l.to\n-                                    }) : t.splice(r--, 0);\n-                                }\n-                            n.length && e.setSelections(n, 0);\n-                        };\n-\n-                        function D(e, t) {\n-                            e.operation(function() {\n-                                for (var n = e.listSelections(), r = [], l = [], i = 0; i < n.length; i++) {\n-                                    var o = n[i];\n-                                    o.empty() ? (r.push(i), l.push(\"\")) : l.push(t(e.getRange(o.from(), o.to())));\n-                                }\n-                                e.replaceSelections(l, \"around\", \"case\");\n-                                for (var i = r.length - 1, s; i >= 0; i--) {\n-                                    var o = n[r[i]];\n-                                    if (!(s && h.cmpPos(o.head, s) > 0)) {\n-                                        var u = K(e, o.head);\n-                                        s = u.from, e.replaceRange(t(u.word), u.from, u.to);\n-                                    }\n-                                }\n-                            });\n-                        }\n-                        v(D, \"modifyWordOrSelection\"), a.smartBackspace = function(e) {\n-                            if (e.somethingSelected()) return h.Pass;\n-                            e.operation(function() {\n-                                for (var t = e.listSelections(), n = e.getOption(\"indentUnit\"), r = t.length - 1; r >= 0; r--) {\n-                                    var l = t[r].head,\n-                                        i = e.getRange({\n-                                            line: l.line,\n-                                            ch: 0\n-                                        }, l),\n-                                        o = h.countColumn(i, null, e.getOption(\"tabSize\")),\n-                                        s = e.findPosH(l, -1, \"char\", !1);\n-                                    if (i && !/\\S/.test(i) && o % n == 0) {\n-                                        var u = new f(l.line, h.findColumn(i, o - n, n));\n-                                        u.ch != l.ch && (s = u);\n-                                    }\n-                                    e.replaceRange(\"\", s, l, \"+delete\");\n-                                }\n-                            });\n-                        }, a.delLineRight = function(e) {\n-                            e.operation(function() {\n-                                for (var t = e.listSelections(), n = t.length - 1; n >= 0; n--) e.replaceRange(\"\", t[n].anchor, f(t[n].to().line), \"+delete\");\n-                                e.scrollIntoView();\n-                            });\n-                        }, a.upcaseAtCursor = function(e) {\n-                            D(e, function(t) {\n-                                return t.toUpperCase();\n-                            });\n-                        }, a.downcaseAtCursor = function(e) {\n-                            D(e, function(t) {\n-                                return t.toLowerCase();\n-                            });\n-                        }, a.setSublimeMark = function(e) {\n-                            e.state.sublimeMark && e.state.sublimeMark.clear(), e.state.sublimeMark = e.setBookmark(e.getCursor());\n-                        }, a.selectToSublimeMark = function(e) {\n-                            var t = e.state.sublimeMark && e.state.sublimeMark.find();\n-                            t && e.setSelection(e.getCursor(), t);\n-                        }, a.deleteToSublimeMark = function(e) {\n-                            var t = e.state.sublimeMark && e.state.sublimeMark.find();\n-                            if (t) {\n-                                var n = e.getCursor(),\n-                                    r = t;\n-                                if (h.cmpPos(n, r) > 0) {\n-                                    var l = r;\n-                                    r = n, n = l;\n-                                }\n-                                e.state.sublimeKilled = e.getRange(n, r), e.replaceRange(\"\", n, r);\n-                            }\n-                        }, a.swapWithSublimeMark = function(e) {\n-                            var t = e.state.sublimeMark && e.state.sublimeMark.find();\n-                            t && (e.state.sublimeMark.clear(), e.state.sublimeMark = e.setBookmark(e.getCursor()), e.setCursor(t));\n-                        }, a.sublimeYank = function(e) {\n-                            e.state.sublimeKilled != null && e.replaceSelection(e.state.sublimeKilled, null, \"paste\");\n-                        }, a.showInCenter = function(e) {\n-                            var t = e.cursorCoords(null, \"local\");\n-                            e.scrollTo(null, (t.top + t.bottom) / 2 - e.getScrollInfo().clientHeight / 2);\n-                        };\n-\n-                        function N(e) {\n-                            var t = e.getCursor(\"from\"),\n-                                n = e.getCursor(\"to\");\n-                            if (h.cmpPos(t, n) == 0) {\n-                                var r = K(e, t);\n-                                if (!r.word) return;\n-                                t = r.from, n = r.to;\n-                            }\n-                            return {\n-                                from: t,\n-                                to: n,\n-                                query: e.getRange(t, n),\n-                                word: r\n-                            };\n-                        }\n-                        v(N, \"getTarget\");\n-\n-                        function O(e, t) {\n-                            var n = N(e);\n-                            if (n) {\n-                                var r = n.query,\n-                                    l = e.getSearchCursor(r, t ? n.to : n.from);\n-                                (t ? l.findNext() : l.findPrevious()) ? e.setSelection(l.from(), l.to()): (l = e.getSearchCursor(r, t ? f(e.firstLine(), 0) : e.clipPos(f(e.lastLine()))), (t ? l.findNext() : l.findPrevious()) ? e.setSelection(l.from(), l.to()) : n.word && e.setSelection(n.from, n.to));\n-                            }\n-                        }\n-                        v(O, \"findAndGoTo\"), a.findUnder = function(e) {\n-                            O(e, !0);\n-                        }, a.findUnderPrevious = function(e) {\n-                            O(e, !1);\n-                        }, a.findAllUnder = function(e) {\n-                            var t = N(e);\n-                            if (t) {\n-                                for (var n = e.getSearchCursor(t.query), r = [], l = -1; n.findNext();) r.push({\n-                                    anchor: n.from(),\n-                                    head: n.to()\n-                                }), n.from().line <= t.from.line && n.from().ch <= t.from.ch && l++;\n-                                e.setSelections(r, l);\n-                            }\n-                        };\n-                        var C = h.keyMap;\n-                        C.macSublime = {\n-                            \"Cmd-Left\": \"goLineStartSmart\",\n-                            \"Shift-Tab\": \"indentLess\",\n-                            \"Shift-Ctrl-K\": \"deleteLine\",\n-                            \"Alt-Q\": \"wrapLines\",\n-                            \"Ctrl-Left\": \"goSubwordLeft\",\n-                            \"Ctrl-Right\": \"goSubwordRight\",\n-                            \"Ctrl-Alt-Up\": \"scrollLineUp\",\n-                            \"Ctrl-Alt-Down\": \"scrollLineDown\",\n-                            \"Cmd-L\": \"selectLine\",\n-                            \"Shift-Cmd-L\": \"splitSelectionByLine\",\n-                            Esc: \"singleSelectionTop\",\n-                            \"Cmd-Enter\": \"insertLineAfter\",\n-                            \"Shift-Cmd-Enter\": \"insertLineBefore\",\n-                            \"Cmd-D\": \"selectNextOccurrence\",\n-                            \"Shift-Cmd-Space\": \"selectScope\",\n-                            \"Shift-Cmd-M\": \"selectBetweenBrackets\",\n-                            \"Cmd-M\": \"goToBracket\",\n-                            \"Cmd-Ctrl-Up\": \"swapLineUp\",\n-                            \"Cmd-Ctrl-Down\": \"swapLineDown\",\n-                            \"Cmd-/\": \"toggleCommentIndented\",\n-                            \"Cmd-J\": \"joinLines\",\n-                            \"Shift-Cmd-D\": \"duplicateLine\",\n-                            F5: \"sortLines\",\n-                            \"Shift-F5\": \"reverseSortLines\",\n-                            \"Cmd-F5\": \"sortLinesInsensitive\",\n-                            \"Shift-Cmd-F5\": \"reverseSortLinesInsensitive\",\n-                            F2: \"nextBookmark\",\n-                            \"Shift-F2\": \"prevBookmark\",\n-                            \"Cmd-F2\": \"toggleBookmark\",\n-                            \"Shift-Cmd-F2\": \"clearBookmarks\",\n-                            \"Alt-F2\": \"selectBookmarks\",\n-                            Backspace: \"smartBackspace\",\n-                            \"Cmd-K Cmd-D\": \"skipAndSelectNextOccurrence\",\n-                            \"Cmd-K Cmd-K\": \"delLineRight\",\n-                            \"Cmd-K Cmd-U\": \"upcaseAtCursor\",\n-                            \"Cmd-K Cmd-L\": \"downcaseAtCursor\",\n-                            \"Cmd-K Cmd-Space\": \"setSublimeMark\",\n-                            \"Cmd-K Cmd-A\": \"selectToSublimeMark\",\n-                            \"Cmd-K Cmd-W\": \"deleteToSublimeMark\",\n-                            \"Cmd-K Cmd-X\": \"swapWithSublimeMark\",\n-                            \"Cmd-K Cmd-Y\": \"sublimeYank\",\n-                            \"Cmd-K Cmd-C\": \"showInCenter\",\n-                            \"Cmd-K Cmd-G\": \"clearBookmarks\",\n-                            \"Cmd-K Cmd-Backspace\": \"delLineLeft\",\n-                            \"Cmd-K Cmd-1\": \"foldAll\",\n-                            \"Cmd-K Cmd-0\": \"unfoldAll\",\n-                            \"Cmd-K Cmd-J\": \"unfoldAll\",\n-                            \"Ctrl-Shift-Up\": \"addCursorToPrevLine\",\n-                            \"Ctrl-Shift-Down\": \"addCursorToNextLine\",\n-                            \"Cmd-F3\": \"findUnder\",\n-                            \"Shift-Cmd-F3\": \"findUnderPrevious\",\n-                            \"Alt-F3\": \"findAllUnder\",\n-                            \"Shift-Cmd-[\": \"fold\",\n-                            \"Shift-Cmd-]\": \"unfold\",\n-                            \"Cmd-I\": \"findIncremental\",\n-                            \"Shift-Cmd-I\": \"findIncrementalReverse\",\n-                            \"Cmd-H\": \"replace\",\n-                            F3: \"findNext\",\n-                            \"Shift-F3\": \"findPrev\",\n-                            fallthrough: \"macDefault\"\n-                        }, h.normalizeKeyMap(C.macSublime), C.pcSublime = {\n-                            \"Shift-Tab\": \"indentLess\",\n-                            \"Shift-Ctrl-K\": \"deleteLine\",\n-                            \"Alt-Q\": \"wrapLines\",\n-                            \"Ctrl-T\": \"transposeChars\",\n-                            \"Alt-Left\": \"goSubwordLeft\",\n-                            \"Alt-Right\": \"goSubwordRight\",\n-                            \"Ctrl-Up\": \"scrollLineUp\",\n-                            \"Ctrl-Down\": \"scrollLineDown\",\n-                            \"Ctrl-L\": \"selectLine\",\n-                            \"Shift-Ctrl-L\": \"splitSelectionByLine\",\n-                            Esc: \"singleSelectionTop\",\n-                            \"Ctrl-Enter\": \"insertLineAfter\",\n-                            \"Shift-Ctrl-Enter\": \"insertLineBefore\",\n-                            \"Ctrl-D\": \"selectNextOccurrence\",\n-                            \"Shift-Ctrl-Space\": \"selectScope\",\n-                            \"Shift-Ctrl-M\": \"selectBetweenBrackets\",\n-                            \"Ctrl-M\": \"goToBracket\",\n-                            \"Shift-Ctrl-Up\": \"swapLineUp\",\n-                            \"Shift-Ctrl-Down\": \"swapLineDown\",\n-                            \"Ctrl-/\": \"toggleCommentIndented\",\n-                            \"Ctrl-J\": \"joinLines\",\n-                            \"Shift-Ctrl-D\": \"duplicateLine\",\n-                            F9: \"sortLines\",\n-                            \"Shift-F9\": \"reverseSortLines\",\n-                            \"Ctrl-F9\": \"sortLinesInsensitive\",\n-                            \"Shift-Ctrl-F9\": \"reverseSortLinesInsensitive\",\n-                            F2: \"nextBookmark\",\n-                            \"Shift-F2\": \"prevBookmark\",\n-                            \"Ctrl-F2\": \"toggleBookmark\",\n-                            \"Shift-Ctrl-F2\": \"clearBookmarks\",\n-                            \"Alt-F2\": \"selectBookmarks\",\n-                            Backspace: \"smartBackspace\",\n-                            \"Ctrl-K Ctrl-D\": \"skipAndSelectNextOccurrence\",\n-                            \"Ctrl-K Ctrl-K\": \"delLineRight\",\n-                            \"Ctrl-K Ctrl-U\": \"upcaseAtCursor\",\n-                            \"Ctrl-K Ctrl-L\": \"downcaseAtCursor\",\n-                            \"Ctrl-K Ctrl-Space\": \"setSublimeMark\",\n-                            \"Ctrl-K Ctrl-A\": \"selectToSublimeMark\",\n-                            \"Ctrl-K Ctrl-W\": \"deleteToSublimeMark\",\n-                            \"Ctrl-K Ctrl-X\": \"swapWithSublimeMark\",\n-                            \"Ctrl-K Ctrl-Y\": \"sublimeYank\",\n-                            \"Ctrl-K Ctrl-C\": \"showInCenter\",\n-                            \"Ctrl-K Ctrl-G\": \"clearBookmarks\",\n-                            \"Ctrl-K Ctrl-Backspace\": \"delLineLeft\",\n-                            \"Ctrl-K Ctrl-1\": \"foldAll\",\n-                            \"Ctrl-K Ctrl-0\": \"unfoldAll\",\n-                            \"Ctrl-K Ctrl-J\": \"unfoldAll\",\n-                            \"Ctrl-Alt-Up\": \"addCursorToPrevLine\",\n-                            \"Ctrl-Alt-Down\": \"addCursorToNextLine\",\n-                            \"Ctrl-F3\": \"findUnder\",\n-                            \"Shift-Ctrl-F3\": \"findUnderPrevious\",\n-                            \"Alt-F3\": \"findAllUnder\",\n-                            \"Shift-Ctrl-[\": \"fold\",\n-                            \"Shift-Ctrl-]\": \"unfold\",\n-                            \"Ctrl-I\": \"findIncremental\",\n-                            \"Shift-Ctrl-I\": \"findIncrementalReverse\",\n-                            \"Ctrl-H\": \"replace\",\n-                            F3: \"findNext\",\n-                            \"Shift-F3\": \"findPrev\",\n-                            fallthrough: \"pcDefault\"\n-                        }, h.normalizeKeyMap(C.pcSublime);\n-                        var V = C.default == C.macDefault;\n-                        C.sublime = V ? C.macSublime : C.pcSublime;\n-                    });\n-                })();\n-                var q = G.exports;\n-                const Q = E.getDefaultExportFromCjs(q),\n-                    X = J({\n-                        __proto__: null,\n-                        default: Q\n-                    }, [q]);\n-                exports.sublime = X;\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-toolkit/esm/async-helpers/index.js\":\n-            /*!*********************************************************!*\\\n-              !*** ../../graphiql-toolkit/esm/async-helpers/index.js ***!\n-              \\*********************************************************/\n+        \"../../../node_modules/use-sidecar/dist/es2015/config.js\":\n+            /*!***************************************************************!*\\\n+              !*** ../../../node_modules/use-sidecar/dist/es2015/config.js ***!\n+              \\***************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports.fetcherReturnToPromise = fetcherReturnToPromise;\n-                exports.isAsyncIterable = isAsyncIterable;\n-                exports.isObservable = isObservable;\n-                exports.isPromise = isPromise;\n-                var __awaiter = void 0 && (void 0).__awaiter || function(thisArg, _arguments, P, generator) {\n-                    function adopt(value) {\n-                        return value instanceof P ? value : new P(function(resolve) {\n-                            resolve(value);\n-                        });\n+                exports.setConfig = exports.config = void 0;\n+                var config = exports.config = {\n+                    onError: function(e) {\n+                        return console.error(e);\n                     }\n-                    return new(P || (P = Promise))(function(resolve, reject) {\n-                        function fulfilled(value) {\n-                            try {\n-                                step(generator.next(value));\n-                            } catch (e) {\n-                                reject(e);\n-                            }\n-                        }\n-\n-                        function rejected(value) {\n-                            try {\n-                                step(generator[\"throw\"](value));\n-                            } catch (e) {\n-                                reject(e);\n-                            }\n-                        }\n-\n-                        function step(result) {\n-                            result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n-                        }\n-                        step((generator = generator.apply(thisArg, _arguments || [])).next());\n-                    });\n                 };\n+                var setConfig = function(conf) {\n+                    Object.assign(config, conf);\n+                };\n+                exports.setConfig = setConfig;\n \n-                function isPromise(value) {\n-                    return typeof value === 'object' && value !== null && typeof value.then === 'function';\n-                }\n-\n-                function observableToPromise(observable) {\n-                    return new Promise((resolve, reject) => {\n-                        const subscription = observable.subscribe({\n-                            next(v) {\n-                                resolve(v);\n-                                subscription.unsubscribe();\n-                            },\n-                            error: reject,\n-                            complete() {\n-                                reject(new Error('no value resolved'));\n-                            }\n-                        });\n-                    });\n-                }\n+                /***/\n+            }),\n \n-                function isObservable(value) {\n-                    return typeof value === 'object' && value !== null && 'subscribe' in value && typeof value.subscribe === 'function';\n-                }\n+        /***/\n+        \"../../../node_modules/use-sidecar/dist/es2015/env.js\":\n+            /*!************************************************************!*\\\n+              !*** ../../../node_modules/use-sidecar/dist/es2015/env.js ***!\n+              \\************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                function isAsyncIterable(input) {\n-                    return typeof input === 'object' && input !== null && (input[Symbol.toStringTag] === 'AsyncGenerator' || Symbol.asyncIterator in input);\n-                }\n+                \"use strict\";\n \n-                function asyncIterableToPromise(input) {\n-                    var _a;\n-                    return __awaiter(this, void 0, void 0, function*() {\n-                        const iteratorReturn = (_a = ('return' in input ? input : input[Symbol.asyncIterator]()).return) === null || _a === void 0 ? void 0 : _a.bind(input);\n-                        const iteratorNext = ('next' in input ? input : input[Symbol.asyncIterator]()).next.bind(input);\n-                        const result = yield iteratorNext();\n-                        void(iteratorReturn === null || iteratorReturn === void 0 ? void 0 : iteratorReturn());\n-                        return result.value;\n-                    });\n-                }\n \n-                function fetcherReturnToPromise(fetcherResult) {\n-                    return __awaiter(this, void 0, void 0, function*() {\n-                        const result = yield fetcherResult;\n-                        if (isAsyncIterable(result)) {\n-                            return asyncIterableToPromise(result);\n-                        }\n-                        if (isObservable(result)) {\n-                            return observableToPromise(result);\n-                        }\n-                        return result;\n-                    });\n-                }\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.env = void 0;\n+                var _detectNodeEs = __webpack_require__( /*! detect-node-es */ \"../../../node_modules/detect-node-es/esm/browser.js\");\n+                var env = exports.env = {\n+                    isNode: _detectNodeEs.isNode,\n+                    forceCache: false\n+                };\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-toolkit/esm/create-fetcher/createFetcher.js\":\n-            /*!******************************************************************!*\\\n-              !*** ../../graphiql-toolkit/esm/create-fetcher/createFetcher.js ***!\n-              \\******************************************************************/\n+        \"../../../node_modules/use-sidecar/dist/es2015/exports.js\":\n+            /*!****************************************************************!*\\\n+              !*** ../../../node_modules/use-sidecar/dist/es2015/exports.js ***!\n+              \\****************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports.createGraphiQLFetcher = createGraphiQLFetcher;\n-                var _lib = __webpack_require__( /*! ./lib */ \"../../graphiql-toolkit/esm/create-fetcher/lib.js\");\n+                exports.exportSidecar = exportSidecar;\n+                var _tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.mjs\");\n+                var React = _interopRequireWildcard(__webpack_require__( /*! react */ \"react\"));\n \n-                function createGraphiQLFetcher(options) {\n-                    let httpFetch;\n-                    if (typeof window !== 'undefined' && window.fetch) {\n-                        httpFetch = window.fetch;\n-                    }\n-                    if ((options === null || options === void 0 ? void 0 : options.enableIncrementalDelivery) === null || options.enableIncrementalDelivery !== false) {\n-                        options.enableIncrementalDelivery = true;\n-                    }\n-                    if (options.fetch) {\n-                        httpFetch = options.fetch;\n-                    }\n-                    if (!httpFetch) {\n-                        throw new Error('No valid fetcher implementation available');\n-                    }\n-                    const simpleFetcher = (0, _lib.createSimpleFetcher)(options, httpFetch);\n-                    const httpFetcher = options.enableIncrementalDelivery ? (0, _lib.createMultipartFetcher)(options, httpFetch) : simpleFetcher;\n-                    return (graphQLParams, fetcherOpts) => {\n-                        if (graphQLParams.operationName === 'IntrospectionQuery') {\n-                            return (options.schemaFetcher || simpleFetcher)(graphQLParams, fetcherOpts);\n-                        }\n-                        const isSubscription = (fetcherOpts === null || fetcherOpts === void 0 ? void 0 : fetcherOpts.documentAST) ? (0, _lib.isSubscriptionWithName)(fetcherOpts.documentAST, graphQLParams.operationName || undefined) : false;\n-                        if (isSubscription) {\n-                            const wsFetcher = (0, _lib.getWsFetcher)(options, fetcherOpts);\n-                            if (!wsFetcher) {\n-                                throw new Error(`Your GraphiQL createFetcher is not properly configured for websocket subscriptions yet. ${options.subscriptionUrl ? `Provided URL ${options.subscriptionUrl} failed` : 'Please provide subscriptionUrl, wsClient or legacyClient option first.'}`);\n-                            }\n-                            return wsFetcher(graphQLParams);\n-                        }\n-                        return httpFetcher(graphQLParams, fetcherOpts);\n-                    };\n+                function _getRequireWildcardCache(e) {\n+                    if (\"function\" != typeof WeakMap) return null;\n+                    var r = new WeakMap(),\n+                        t = new WeakMap();\n+                    return (_getRequireWildcardCache = function(e) {\n+                        return e ? t : r;\n+                    })(e);\n+                }\n+\n+                function _interopRequireWildcard(e, r) {\n+                    if (!r && e && e.__esModule) return e;\n+                    if (null === e || \"object\" != typeof e && \"function\" != typeof e) return {\n+                        default: e\n+                    };\n+                    var t = _getRequireWildcardCache(r);\n+                    if (t && t.has(e)) return t.get(e);\n+                    var n = {\n+                            __proto__: null\n+                        },\n+                        a = Object.defineProperty && Object.getOwnPropertyDescriptor;\n+                    for (var u in e)\n+                        if (\"default\" !== u && Object.prototype.hasOwnProperty.call(e, u)) {\n+                            var i = a ? Object.getOwnPropertyDescriptor(e, u) : null;\n+                            i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u];\n+                        } return n.default = e, t && t.set(e, n), n;\n+                }\n+                var SideCar = function(_a) {\n+                    var sideCar = _a.sideCar,\n+                        rest = (0, _tslib.__rest)(_a, [\"sideCar\"]);\n+                    if (!sideCar) {\n+                        throw new Error('Sidecar: please provide `sideCar` property to import the right car');\n+                    }\n+                    var Target = sideCar.read();\n+                    if (!Target) {\n+                        throw new Error('Sidecar medium not found');\n+                    }\n+                    return /*#__PURE__*/ React.createElement(Target, (0, _tslib.__assign)({}, rest));\n+                };\n+                SideCar.isSideCarExport = true;\n+\n+                function exportSidecar(medium, exported) {\n+                    medium.useMedium(exported);\n+                    return SideCar;\n                 }\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-toolkit/esm/create-fetcher/index.js\":\n-            /*!**********************************************************!*\\\n-              !*** ../../graphiql-toolkit/esm/create-fetcher/index.js ***!\n-              \\**********************************************************/\n+        \"../../../node_modules/use-sidecar/dist/es2015/hoc.js\":\n+            /*!************************************************************!*\\\n+              !*** ../../../node_modules/use-sidecar/dist/es2015/hoc.js ***!\n+              \\************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                var _exportNames = {\n-                    createGraphiQLFetcher: true\n-                };\n-                Object.defineProperty(exports, \"createGraphiQLFetcher\", ({\n-                    enumerable: true,\n-                    get: function() {\n-                        return _createFetcher.createGraphiQLFetcher;\n-                    }\n-                }));\n-                var _types = __webpack_require__( /*! ./types */ \"../../graphiql-toolkit/esm/create-fetcher/types.js\");\n-                Object.keys(_types).forEach(function(key) {\n-                    if (key === \"default\" || key === \"__esModule\") return;\n-                    if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;\n-                    if (key in exports && exports[key] === _types[key]) return;\n-                    Object.defineProperty(exports, key, {\n-                        enumerable: true,\n-                        get: function() {\n-                            return _types[key];\n+                exports.sidecar = sidecar;\n+                var _tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.mjs\");\n+                var React = _interopRequireWildcard(__webpack_require__( /*! react */ \"react\"));\n+                var _hook = __webpack_require__( /*! ./hook */ \"../../../node_modules/use-sidecar/dist/es2015/hook.js\");\n+\n+                function _getRequireWildcardCache(e) {\n+                    if (\"function\" != typeof WeakMap) return null;\n+                    var r = new WeakMap(),\n+                        t = new WeakMap();\n+                    return (_getRequireWildcardCache = function(e) {\n+                        return e ? t : r;\n+                    })(e);\n+                }\n+\n+                function _interopRequireWildcard(e, r) {\n+                    if (!r && e && e.__esModule) return e;\n+                    if (null === e || \"object\" != typeof e && \"function\" != typeof e) return {\n+                        default: e\n+                    };\n+                    var t = _getRequireWildcardCache(r);\n+                    if (t && t.has(e)) return t.get(e);\n+                    var n = {\n+                            __proto__: null\n+                        },\n+                        a = Object.defineProperty && Object.getOwnPropertyDescriptor;\n+                    for (var u in e)\n+                        if (\"default\" !== u && Object.prototype.hasOwnProperty.call(e, u)) {\n+                            var i = a ? Object.getOwnPropertyDescriptor(e, u) : null;\n+                            i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u];\n+                        } return n.default = e, t && t.set(e, n), n;\n+                }\n+                // eslint-disable-next-line @typescript-eslint/ban-types\n+                function sidecar(importer, errorComponent) {\n+                    var ErrorCase = function() {\n+                        return errorComponent;\n+                    };\n+                    return function Sidecar(props) {\n+                        var _a = (0, _hook.useSidecar)(importer, props.sideCar),\n+                            Car = _a[0],\n+                            error = _a[1];\n+                        if (error && errorComponent) {\n+                            return ErrorCase;\n                         }\n-                    });\n-                });\n-                var _createFetcher = __webpack_require__( /*! ./createFetcher */ \"../../graphiql-toolkit/esm/create-fetcher/createFetcher.js\");\n+                        // @ts-expect-error type shenanigans\n+                        return Car ? /*#__PURE__*/ React.createElement(Car, (0, _tslib.__assign)({}, props)) : null;\n+                    };\n+                }\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-toolkit/esm/create-fetcher/lib.js\":\n-            /*!********************************************************!*\\\n-              !*** ../../graphiql-toolkit/esm/create-fetcher/lib.js ***!\n-              \\********************************************************/\n+        \"../../../node_modules/use-sidecar/dist/es2015/hook.js\":\n+            /*!*************************************************************!*\\\n+              !*** ../../../node_modules/use-sidecar/dist/es2015/hook.js ***!\n+              \\*************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports.isSubscriptionWithName = exports.getWsFetcher = exports.createWebsocketsFetcherFromUrl = exports.createWebsocketsFetcherFromClient = exports.createSimpleFetcher = exports.createMultipartFetcher = exports.createLegacyWebsocketsFetcher = void 0;\n-                var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n-                var _meros = __webpack_require__( /*! meros */ \"../../../node_modules/meros/browser/index.mjs\");\n-                var _pushPullAsyncIterableIterator = __webpack_require__( /*! @n1ru4l/push-pull-async-iterable-iterator */ \"../../../node_modules/@n1ru4l/push-pull-async-iterable-iterator/index.js\");\n-                var __awaiter = void 0 && (void 0).__awaiter || function(thisArg, _arguments, P, generator) {\n-                    function adopt(value) {\n-                        return value instanceof P ? value : new P(function(resolve) {\n-                            resolve(value);\n-                        });\n-                    }\n-                    return new(P || (P = Promise))(function(resolve, reject) {\n-                        function fulfilled(value) {\n-                            try {\n-                                step(generator.next(value));\n-                            } catch (e) {\n-                                reject(e);\n-                            }\n-                        }\n-\n-                        function rejected(value) {\n-                            try {\n-                                step(generator[\"throw\"](value));\n-                            } catch (e) {\n-                                reject(e);\n-                            }\n-                        }\n-\n-                        function step(result) {\n-                            result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n-                        }\n-                        step((generator = generator.apply(thisArg, _arguments || [])).next());\n-                    });\n-                };\n-                var __await = void 0 && (void 0).__await || function(v) {\n-                    return this instanceof __await ? (this.v = v, this) : new __await(v);\n-                };\n-                var __asyncValues = void 0 && (void 0).__asyncValues || function(o) {\n-                    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n-                    var m = o[Symbol.asyncIterator],\n-                        i;\n-                    return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function() {\n-                        return this;\n-                    }, i);\n+                exports.useSidecar = useSidecar;\n+                var _react = __webpack_require__( /*! react */ \"react\");\n+                var _env = __webpack_require__( /*! ./env */ \"../../../node_modules/use-sidecar/dist/es2015/env.js\");\n+                var cache = new WeakMap();\n+                var NO_OPTIONS = {};\n \n-                    function verb(n) {\n-                        i[n] = o[n] && function(v) {\n-                            return new Promise(function(resolve, reject) {\n-                                v = o[n](v), settle(resolve, reject, v.done, v.value);\n-                            });\n-                        };\n+                function useSidecar(importer, effect) {\n+                    var options = effect && effect.options || NO_OPTIONS;\n+                    if (_env.env.isNode && !options.ssr) {\n+                        return [null, null];\n                     }\n+                    // eslint-disable-next-line react-hooks/rules-of-hooks\n+                    return useRealSidecar(importer, effect);\n+                }\n \n-                    function settle(resolve, reject, d, v) {\n-                        Promise.resolve(v).then(function(v) {\n-                            resolve({\n-                                value: v,\n-                                done: d\n+                function useRealSidecar(importer, effect) {\n+                    var options = effect && effect.options || NO_OPTIONS;\n+                    var couldUseCache = _env.env.forceCache || _env.env.isNode && !!options.ssr || !options.async;\n+                    var _a = (0, _react.useState)(couldUseCache ? function() {\n+                            return cache.get(importer);\n+                        } : undefined),\n+                        Car = _a[0],\n+                        setCar = _a[1];\n+                    var _b = (0, _react.useState)(null),\n+                        error = _b[0],\n+                        setError = _b[1];\n+                    (0, _react.useEffect)(function() {\n+                        if (!Car) {\n+                            importer().then(function(car) {\n+                                var resolved = effect ? effect.read() : car.default || car;\n+                                if (!resolved) {\n+                                    console.error('Sidecar error: with importer', importer);\n+                                    var error_1;\n+                                    if (effect) {\n+                                        console.error('Sidecar error: with medium', effect);\n+                                        error_1 = new Error('Sidecar medium was not found');\n+                                    } else {\n+                                        error_1 = new Error('Sidecar was not found in exports');\n+                                    }\n+                                    setError(function() {\n+                                        return error_1;\n+                                    });\n+                                    throw error_1;\n+                                }\n+                                cache.set(importer, resolved);\n+                                setCar(function() {\n+                                    return resolved;\n+                                });\n+                            }, function(e) {\n+                                return setError(function() {\n+                                    return e;\n+                                });\n                             });\n-                        }, reject);\n-                    }\n-                };\n-                var __asyncGenerator = void 0 && (void 0).__asyncGenerator || function(thisArg, _arguments, generator) {\n-                    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n-                    var g = generator.apply(thisArg, _arguments || []),\n-                        i,\n-                        q = [];\n-                    return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function() {\n-                        return this;\n-                    }, i;\n+                        }\n+                    }, []);\n+                    return [Car, error];\n+                }\n \n-                    function verb(n) {\n-                        if (g[n]) i[n] = function(v) {\n-                            return new Promise(function(a, b) {\n-                                q.push([n, v, a, b]) > 1 || resume(n, v);\n-                            });\n-                        };\n-                    }\n+                /***/\n+            }),\n \n-                    function resume(n, v) {\n-                        try {\n-                            step(g[n](v));\n-                        } catch (e) {\n-                            settle(q[0][3], e);\n-                        }\n-                    }\n+        /***/\n+        \"../../../node_modules/use-sidecar/dist/es2015/index.js\":\n+            /*!**************************************************************!*\\\n+              !*** ../../../node_modules/use-sidecar/dist/es2015/index.js ***!\n+              \\**************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                    function step(r) {\n-                        r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r);\n-                    }\n+                \"use strict\";\n \n-                    function fulfill(value) {\n-                        resume(\"next\", value);\n-                    }\n \n-                    function reject(value) {\n-                        resume(\"throw\", value);\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                Object.defineProperty(exports, \"createMedium\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _medium.createMedium;\n                     }\n-\n-                    function settle(f, v) {\n-                        if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]);\n+                }));\n+                Object.defineProperty(exports, \"createSidecarMedium\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _medium.createSidecarMedium;\n                     }\n-                };\n-                const errorHasCode = err => {\n-                    return typeof err === 'object' && err !== null && 'code' in err;\n-                };\n-                const isSubscriptionWithName = (document, name) => {\n-                    let isSubscription = false;\n-                    (0, _graphql.visit)(document, {\n-                        OperationDefinition(node) {\n-                            var _a;\n-                            if (name === ((_a = node.name) === null || _a === void 0 ? void 0 : _a.value) && node.operation === 'subscription') {\n-                                isSubscription = true;\n-                            }\n-                        }\n-                    });\n-                    return isSubscription;\n-                };\n-                exports.isSubscriptionWithName = isSubscriptionWithName;\n-                const createSimpleFetcher = (options, httpFetch) => (graphQLParams, fetcherOpts) => __awaiter(void 0, void 0, void 0, function*() {\n-                    const data = yield httpFetch(options.url, {\n-                        method: 'POST',\n-                        body: JSON.stringify(graphQLParams),\n-                        headers: Object.assign(Object.assign({\n-                            'content-type': 'application/json'\n-                        }, options.headers), fetcherOpts === null || fetcherOpts === void 0 ? void 0 : fetcherOpts.headers)\n-                    });\n-                    return data.json();\n-                });\n-                exports.createSimpleFetcher = createSimpleFetcher;\n-                const createWebsocketsFetcherFromUrl = (url, connectionParams) => {\n-                    let wsClient;\n-                    try {\n-                        const {\n-                            createClient\n-                        } = __webpack_require__( /*! graphql-ws */ \"../../../node_modules/graphql-ws/lib/index.js\");\n-                        wsClient = createClient({\n-                            url,\n-                            connectionParams\n-                        });\n-                        return createWebsocketsFetcherFromClient(wsClient);\n-                    } catch (err) {\n-                        if (errorHasCode(err) && err.code === 'MODULE_NOT_FOUND') {\n-                            throw new Error(\"You need to install the 'graphql-ws' package to use websockets when passing a 'subscriptionUrl'\");\n-                        }\n-                        console.error(`Error creating websocket client for ${url}`, err);\n+                }));\n+                Object.defineProperty(exports, \"exportSidecar\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _exports.exportSidecar;\n                     }\n-                };\n-                exports.createWebsocketsFetcherFromUrl = createWebsocketsFetcherFromUrl;\n-                const createWebsocketsFetcherFromClient = wsClient => graphQLParams => (0, _pushPullAsyncIterableIterator.makeAsyncIterableIteratorFromSink)(sink => wsClient.subscribe(graphQLParams, Object.assign(Object.assign({}, sink), {\n-                    error(err) {\n-                        if (err instanceof CloseEvent) {\n-                            sink.error(new Error(`Socket closed with event ${err.code} ${err.reason || ''}`.trim()));\n-                        } else {\n-                            sink.error(err);\n-                        }\n+                }));\n+                Object.defineProperty(exports, \"renderCar\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _renderProp.renderCar;\n                     }\n-                })));\n-                exports.createWebsocketsFetcherFromClient = createWebsocketsFetcherFromClient;\n-                const createLegacyWebsocketsFetcher = legacyWsClient => graphQLParams => {\n-                    const observable = legacyWsClient.request(graphQLParams);\n-                    return (0, _pushPullAsyncIterableIterator.makeAsyncIterableIteratorFromSink)(sink => observable.subscribe(sink).unsubscribe);\n-                };\n-                exports.createLegacyWebsocketsFetcher = createLegacyWebsocketsFetcher;\n-                const createMultipartFetcher = (options, httpFetch) => function(graphQLParams, fetcherOpts) {\n-                    return __asyncGenerator(this, arguments, function*() {\n-                        var e_1, _a;\n-                        const response = yield __await(httpFetch(options.url, {\n-                            method: 'POST',\n-                            body: JSON.stringify(graphQLParams),\n-                            headers: Object.assign(Object.assign({\n-                                'content-type': 'application/json',\n-                                accept: 'application/json, multipart/mixed'\n-                            }, options.headers), fetcherOpts === null || fetcherOpts === void 0 ? void 0 : fetcherOpts.headers)\n-                        }).then(r => (0, _meros.meros)(r, {\n-                            multiple: true\n-                        })));\n-                        if (!(0, _pushPullAsyncIterableIterator.isAsyncIterable)(response)) {\n-                            return yield __await(yield yield __await(response.json()));\n-                        }\n-                        try {\n-                            for (var response_1 = __asyncValues(response), response_1_1; response_1_1 = yield __await(response_1.next()), !response_1_1.done;) {\n-                                const chunk = response_1_1.value;\n-                                if (chunk.some(part => !part.json)) {\n-                                    const message = chunk.map(part => `Headers::\\n${part.headers}\\n\\nBody::\\n${part.body}`);\n-                                    throw new Error(`Expected multipart chunks to be of json type. got:\\n${message}`);\n-                                }\n-                                yield yield __await(chunk.map(part => part.body));\n-                            }\n-                        } catch (e_1_1) {\n-                            e_1 = {\n-                                error: e_1_1\n-                            };\n-                        } finally {\n-                            try {\n-                                if (response_1_1 && !response_1_1.done && (_a = response_1.return)) yield __await(_a.call(response_1));\n-                            } finally {\n-                                if (e_1) throw e_1.error;\n-                            }\n-                        }\n-                    });\n-                };\n-                exports.createMultipartFetcher = createMultipartFetcher;\n-                const getWsFetcher = (options, fetcherOpts) => {\n-                    if (options.wsClient) {\n-                        return createWebsocketsFetcherFromClient(options.wsClient);\n+                }));\n+                Object.defineProperty(exports, \"setConfig\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _config.setConfig;\n                     }\n-                    if (options.subscriptionUrl) {\n-                        return createWebsocketsFetcherFromUrl(options.subscriptionUrl, Object.assign(Object.assign({}, options.wsConnectionParams), fetcherOpts === null || fetcherOpts === void 0 ? void 0 : fetcherOpts.headers));\n+                }));\n+                Object.defineProperty(exports, \"sidecar\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _hoc.sidecar;\n                     }\n-                    const legacyWebsocketsClient = options.legacyClient || options.legacyWsClient;\n-                    if (legacyWebsocketsClient) {\n-                        return createLegacyWebsocketsFetcher(legacyWebsocketsClient);\n+                }));\n+                Object.defineProperty(exports, \"useSidecar\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _hook.useSidecar;\n                     }\n-                };\n-                exports.getWsFetcher = getWsFetcher;\n+                }));\n+                var _hoc = __webpack_require__( /*! ./hoc */ \"../../../node_modules/use-sidecar/dist/es2015/hoc.js\");\n+                var _hook = __webpack_require__( /*! ./hook */ \"../../../node_modules/use-sidecar/dist/es2015/hook.js\");\n+                var _config = __webpack_require__( /*! ./config */ \"../../../node_modules/use-sidecar/dist/es2015/config.js\");\n+                var _medium = __webpack_require__( /*! ./medium */ \"../../../node_modules/use-sidecar/dist/es2015/medium.js\");\n+                var _renderProp = __webpack_require__( /*! ./renderProp */ \"../../../node_modules/use-sidecar/dist/es2015/renderProp.js\");\n+                var _exports = __webpack_require__( /*! ./exports */ \"../../../node_modules/use-sidecar/dist/es2015/exports.js\");\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-toolkit/esm/create-fetcher/types.js\":\n-            /*!**********************************************************!*\\\n-              !*** ../../graphiql-toolkit/esm/create-fetcher/types.js ***!\n-              \\**********************************************************/\n+        \"../../../node_modules/use-sidecar/dist/es2015/medium.js\":\n+            /*!***************************************************************!*\\\n+              !*** ../../../node_modules/use-sidecar/dist/es2015/medium.js ***!\n+              \\***************************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports) {\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n+                exports.createMedium = createMedium;\n+                exports.createSidecarMedium = createSidecarMedium;\n+                var _tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.mjs\");\n+\n+                function ItoI(a) {\n+                    return a;\n+                }\n+\n+                function innerCreateMedium(defaults, middleware) {\n+                    if (middleware === void 0) {\n+                        middleware = ItoI;\n+                    }\n+                    var buffer = [];\n+                    var assigned = false;\n+                    var medium = {\n+                        read: function() {\n+                            if (assigned) {\n+                                throw new Error('Sidecar: could not `read` from an `assigned` medium. `read` could be used only with `useMedium`.');\n+                            }\n+                            if (buffer.length) {\n+                                return buffer[buffer.length - 1];\n+                            }\n+                            return defaults;\n+                        },\n+                        useMedium: function(data) {\n+                            var item = middleware(data, assigned);\n+                            buffer.push(item);\n+                            return function() {\n+                                buffer = buffer.filter(function(x) {\n+                                    return x !== item;\n+                                });\n+                            };\n+                        },\n+                        assignSyncMedium: function(cb) {\n+                            assigned = true;\n+                            while (buffer.length) {\n+                                var cbs = buffer;\n+                                buffer = [];\n+                                cbs.forEach(cb);\n+                            }\n+                            buffer = {\n+                                push: function(x) {\n+                                    return cb(x);\n+                                },\n+                                filter: function() {\n+                                    return buffer;\n+                                }\n+                            };\n+                        },\n+                        assignMedium: function(cb) {\n+                            assigned = true;\n+                            var pendingQueue = [];\n+                            if (buffer.length) {\n+                                var cbs = buffer;\n+                                buffer = [];\n+                                cbs.forEach(cb);\n+                                pendingQueue = buffer;\n+                            }\n+                            var executeQueue = function() {\n+                                var cbs = pendingQueue;\n+                                pendingQueue = [];\n+                                cbs.forEach(cb);\n+                            };\n+                            var cycle = function() {\n+                                return Promise.resolve().then(executeQueue);\n+                            };\n+                            cycle();\n+                            buffer = {\n+                                push: function(x) {\n+                                    pendingQueue.push(x);\n+                                    cycle();\n+                                },\n+                                filter: function(filter) {\n+                                    pendingQueue = pendingQueue.filter(filter);\n+                                    return buffer;\n+                                }\n+                            };\n+                        }\n+                    };\n+                    return medium;\n+                }\n+\n+                function createMedium(defaults, middleware) {\n+                    if (middleware === void 0) {\n+                        middleware = ItoI;\n+                    }\n+                    return innerCreateMedium(defaults, middleware);\n+                }\n+                // eslint-disable-next-line @typescript-eslint/ban-types\n+                function createSidecarMedium(options) {\n+                    if (options === void 0) {\n+                        options = {};\n+                    }\n+                    var medium = innerCreateMedium(null);\n+                    medium.options = (0, _tslib.__assign)({\n+                        async: true,\n+                        ssr: false\n+                    }, options);\n+                    return medium;\n+                }\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-toolkit/esm/format/index.js\":\n-            /*!**************************************************!*\\\n-              !*** ../../graphiql-toolkit/esm/format/index.js ***!\n-              \\**************************************************/\n+        \"../../../node_modules/use-sidecar/dist/es2015/renderProp.js\":\n+            /*!*******************************************************************!*\\\n+              !*** ../../../node_modules/use-sidecar/dist/es2015/renderProp.js ***!\n+              \\*******************************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports) {\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports.formatError = formatError;\n-                exports.formatResult = formatResult;\n-\n-                function stringify(obj) {\n-                    return JSON.stringify(obj, null, 2);\n-                }\n-\n-                function formatSingleError(error) {\n-                    return Object.assign(Object.assign({}, error), {\n-                        message: error.message,\n-                        stack: error.stack\n-                    });\n-                }\n+                exports.renderCar = renderCar;\n+                var _tslib = __webpack_require__( /*! tslib */ \"../../../node_modules/tslib/tslib.es6.mjs\");\n+                var _react = _interopRequireWildcard(__webpack_require__( /*! react */ \"react\"));\n+                var React = _react;\n \n-                function handleSingleError(error) {\n-                    if (error instanceof Error) {\n-                        return formatSingleError(error);\n-                    }\n-                    return error;\n+                function _getRequireWildcardCache(e) {\n+                    if (\"function\" != typeof WeakMap) return null;\n+                    var r = new WeakMap(),\n+                        t = new WeakMap();\n+                    return (_getRequireWildcardCache = function(e) {\n+                        return e ? t : r;\n+                    })(e);\n+                }\n+\n+                function _interopRequireWildcard(e, r) {\n+                    if (!r && e && e.__esModule) return e;\n+                    if (null === e || \"object\" != typeof e && \"function\" != typeof e) return {\n+                        default: e\n+                    };\n+                    var t = _getRequireWildcardCache(r);\n+                    if (t && t.has(e)) return t.get(e);\n+                    var n = {\n+                            __proto__: null\n+                        },\n+                        a = Object.defineProperty && Object.getOwnPropertyDescriptor;\n+                    for (var u in e)\n+                        if (\"default\" !== u && Object.prototype.hasOwnProperty.call(e, u)) {\n+                            var i = a ? Object.getOwnPropertyDescriptor(e, u) : null;\n+                            i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u];\n+                        } return n.default = e, t && t.set(e, n), n;\n                 }\n \n-                function formatError(error) {\n-                    if (Array.isArray(error)) {\n-                        return stringify({\n-                            errors: error.map(e => handleSingleError(e))\n-                        });\n+                function renderCar(WrappedComponent, defaults) {\n+                    function State(_a) {\n+                        var stateRef = _a.stateRef,\n+                            props = _a.props;\n+                        var renderTarget = (0, _react.useCallback)(function SideTarget() {\n+                            var args = [];\n+                            for (var _i = 0; _i < arguments.length; _i++) {\n+                                args[_i] = arguments[_i];\n+                            }\n+                            (0, _react.useLayoutEffect)(function() {\n+                                stateRef.current(args);\n+                            });\n+                            return null;\n+                        }, []);\n+                        // @ts-ignore\n+                        return /*#__PURE__*/ React.createElement(WrappedComponent, (0, _tslib.__assign)({}, props, {\n+                            children: renderTarget\n+                        }));\n                     }\n-                    return stringify({\n-                        errors: [handleSingleError(error)]\n+                    var Children = /*#__PURE__*/ React.memo(function(_a) {\n+                        var stateRef = _a.stateRef,\n+                            defaultState = _a.defaultState,\n+                            children = _a.children;\n+                        var _b = (0, _react.useState)(defaultState.current),\n+                            state = _b[0],\n+                            setState = _b[1];\n+                        (0, _react.useEffect)(function() {\n+                            stateRef.current = setState;\n+                        }, []);\n+                        return children.apply(void 0, state);\n+                    }, function() {\n+                        return true;\n                     });\n-                }\n-\n-                function formatResult(result) {\n-                    return stringify(result);\n+                    return function Combiner(props) {\n+                        var defaultState = React.useRef(defaults(props));\n+                        var ref = React.useRef(function(state) {\n+                            return defaultState.current = state;\n+                        });\n+                        return /*#__PURE__*/ React.createElement(React.Fragment, null, /*#__PURE__*/ React.createElement(State, {\n+                            stateRef: ref,\n+                            props: props\n+                        }), /*#__PURE__*/ React.createElement(Children, {\n+                            stateRef: ref,\n+                            defaultState: defaultState,\n+                            children: props.children\n+                        }));\n+                    };\n                 }\n \n                 /***/\n             }),\n \n         /***/\n-        \"../../graphiql-toolkit/esm/graphql-helpers/auto-complete.js\":\n-            /*!*******************************************************************!*\\\n-              !*** ../../graphiql-toolkit/esm/graphql-helpers/auto-complete.js ***!\n-              \\*******************************************************************/\n+        \"../../../node_modules/vscode-languageserver-types/lib/esm/main.js\":\n+            /*!*************************************************************************!*\\\n+              !*** ../../../node_modules/vscode-languageserver-types/lib/esm/main.js ***!\n+              \\*************************************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n+            (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n+                /* --------------------------------------------------------------------------------------------\n+                 * Copyright (c) Microsoft Corporation. All rights reserved.\n+                 * Licensed under the MIT License. See License.txt in the project root for license information.\n+                 * ------------------------------------------------------------------------------------------ */\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports.fillLeafs = fillLeafs;\n-                var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n+                exports.uinteger = exports.integer = exports.WorkspaceSymbol = exports.WorkspaceFolder = exports.WorkspaceEdit = exports.WorkspaceChange = exports.VersionedTextDocumentIdentifier = exports.URI = exports.TextEdit = exports.TextDocumentItem = exports.TextDocumentIdentifier = exports.TextDocumentEdit = exports.TextDocument = exports.SymbolTag = exports.SymbolKind = exports.SymbolInformation = exports.SignatureInformation = exports.SemanticTokens = exports.SemanticTokenTypes = exports.SemanticTokenModifiers = exports.SelectionRange = exports.RenameFile = exports.Range = exports.Position = exports.ParameterInformation = exports.OptionalVersionedTextDocumentIdentifier = exports.MarkupKind = exports.MarkupContent = exports.MarkedString = exports.LocationLink = exports.Location = exports.InsertTextMode = exports.InsertTextFormat = exports.InsertReplaceEdit = exports.InlineValueVariableLookup = exports.InlineValueText = exports.InlineValueEvaluatableExpression = exports.InlineValueContext = exports.InlayHintLabelPart = exports.InlayHintKind = exports.InlayHint = exports.Hover = exports.FormattingOptions = exports.FoldingRangeKind = exports.FoldingRange = exports.EOL = exports.DocumentUri = exports.DocumentSymbol = exports.DocumentLink = exports.DocumentHighlightKind = exports.DocumentHighlight = exports.DiagnosticTag = exports.DiagnosticSeverity = exports.DiagnosticRelatedInformation = exports.Diagnostic = exports.DeleteFile = exports.CreateFile = exports.CompletionList = exports.CompletionItemTag = exports.CompletionItemLabelDetails = exports.CompletionItemKind = exports.CompletionItem = exports.Command = exports.ColorPresentation = exports.ColorInformation = exports.Color = exports.CodeLens = exports.CodeDescription = exports.CodeActionTriggerKind = exports.CodeActionKind = exports.CodeActionContext = exports.CodeAction = exports.ChangeAnnotationIdentifier = exports.ChangeAnnotation = exports.AnnotatedTextEdit = void 0;\n+                var DocumentUri;\n+                (function(DocumentUri) {\n+                    function is(value) {\n+                        return typeof value === 'string';\n+                    }\n+                    DocumentUri.is = is;\n+                })(DocumentUri || (exports.DocumentUri = DocumentUri = {}));\n+                var URI;\n+                (function(URI) {\n+                    function is(value) {\n+                        return typeof value === 'string';\n+                    }\n+                    URI.is = is;\n+                })(URI || (exports.URI = URI = {}));\n+                var integer;\n+                (function(integer) {\n+                    integer.MIN_VALUE = -2147483648;\n+                    integer.MAX_VALUE = 2147483647;\n \n-                function fillLeafs(schema, docString, getDefaultFieldNames) {\n-                    const insertions = [];\n-                    if (!schema || !docString) {\n+                    function is(value) {\n+                        return typeof value === 'number' && integer.MIN_VALUE <= value && value <= integer.MAX_VALUE;\n+                    }\n+                    integer.is = is;\n+                })(integer || (exports.integer = integer = {}));\n+                var uinteger;\n+                (function(uinteger) {\n+                    uinteger.MIN_VALUE = 0;\n+                    uinteger.MAX_VALUE = 2147483647;\n+\n+                    function is(value) {\n+                        return typeof value === 'number' && uinteger.MIN_VALUE <= value && value <= uinteger.MAX_VALUE;\n+                    }\n+                    uinteger.is = is;\n+                })(uinteger || (exports.uinteger = uinteger = {}));\n+                /**\n+                 * The Position namespace provides helper functions to work with\n+                 * {@link Position} literals.\n+                 */\n+                var Position;\n+                (function(Position) {\n+                    /**\n+                     * Creates a new Position literal from the given line and character.\n+                     * @param line The position's line.\n+                     * @param character The position's character.\n+                     */\n+                    function create(line, character) {\n+                        if (line === Number.MAX_VALUE) {\n+                            line = uinteger.MAX_VALUE;\n+                        }\n+                        if (character === Number.MAX_VALUE) {\n+                            character = uinteger.MAX_VALUE;\n+                        }\n+                        return {\n+                            line: line,\n+                            character: character\n+                        };\n+                    }\n+                    Position.create = create;\n+                    /**\n+                     * Checks whether the given literal conforms to the {@link Position} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.objectLiteral(candidate) && Is.uinteger(candidate.line) && Is.uinteger(candidate.character);\n+                    }\n+                    Position.is = is;\n+                })(Position || (exports.Position = Position = {}));\n+                /**\n+                 * The Range namespace provides helper functions to work with\n+                 * {@link Range} literals.\n+                 */\n+                var Range;\n+                (function(Range) {\n+                    function create(one, two, three, four) {\n+                        if (Is.uinteger(one) && Is.uinteger(two) && Is.uinteger(three) && Is.uinteger(four)) {\n+                            return {\n+                                start: Position.create(one, two),\n+                                end: Position.create(three, four)\n+                            };\n+                        } else if (Position.is(one) && Position.is(two)) {\n+                            return {\n+                                start: one,\n+                                end: two\n+                            };\n+                        } else {\n+                            throw new Error(\"Range#create called with invalid arguments[\".concat(one, \", \").concat(two, \", \").concat(three, \", \").concat(four, \"]\"));\n+                        }\n+                    }\n+                    Range.create = create;\n+                    /**\n+                     * Checks whether the given literal conforms to the {@link Range} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.objectLiteral(candidate) && Position.is(candidate.start) && Position.is(candidate.end);\n+                    }\n+                    Range.is = is;\n+                })(Range || (exports.Range = Range = {}));\n+                /**\n+                 * The Location namespace provides helper functions to work with\n+                 * {@link Location} literals.\n+                 */\n+                var Location;\n+                (function(Location) {\n+                    /**\n+                     * Creates a Location literal.\n+                     * @param uri The location's uri.\n+                     * @param range The location's range.\n+                     */\n+                    function create(uri, range) {\n+                        return {\n+                            uri: uri,\n+                            range: range\n+                        };\n+                    }\n+                    Location.create = create;\n+                    /**\n+                     * Checks whether the given literal conforms to the {@link Location} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.objectLiteral(candidate) && Range.is(candidate.range) && (Is.string(candidate.uri) || Is.undefined(candidate.uri));\n+                    }\n+                    Location.is = is;\n+                })(Location || (exports.Location = Location = {}));\n+                /**\n+                 * The LocationLink namespace provides helper functions to work with\n+                 * {@link LocationLink} literals.\n+                 */\n+                var LocationLink;\n+                (function(LocationLink) {\n+                    /**\n+                     * Creates a LocationLink literal.\n+                     * @param targetUri The definition's uri.\n+                     * @param targetRange The full range of the definition.\n+                     * @param targetSelectionRange The span of the symbol definition at the target.\n+                     * @param originSelectionRange The span of the symbol being defined in the originating source file.\n+                     */\n+                    function create(targetUri, targetRange, targetSelectionRange, originSelectionRange) {\n+                        return {\n+                            targetUri: targetUri,\n+                            targetRange: targetRange,\n+                            targetSelectionRange: targetSelectionRange,\n+                            originSelectionRange: originSelectionRange\n+                        };\n+                    }\n+                    LocationLink.create = create;\n+                    /**\n+                     * Checks whether the given literal conforms to the {@link LocationLink} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.objectLiteral(candidate) && Range.is(candidate.targetRange) && Is.string(candidate.targetUri) && Range.is(candidate.targetSelectionRange) && (Range.is(candidate.originSelectionRange) || Is.undefined(candidate.originSelectionRange));\n+                    }\n+                    LocationLink.is = is;\n+                })(LocationLink || (exports.LocationLink = LocationLink = {}));\n+                /**\n+                 * The Color namespace provides helper functions to work with\n+                 * {@link Color} literals.\n+                 */\n+                var Color;\n+                (function(Color) {\n+                    /**\n+                     * Creates a new Color literal.\n+                     */\n+                    function create(red, green, blue, alpha) {\n+                        return {\n+                            red: red,\n+                            green: green,\n+                            blue: blue,\n+                            alpha: alpha\n+                        };\n+                    }\n+                    Color.create = create;\n+                    /**\n+                     * Checks whether the given literal conforms to the {@link Color} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.objectLiteral(candidate) && Is.numberRange(candidate.red, 0, 1) && Is.numberRange(candidate.green, 0, 1) && Is.numberRange(candidate.blue, 0, 1) && Is.numberRange(candidate.alpha, 0, 1);\n+                    }\n+                    Color.is = is;\n+                })(Color || (exports.Color = Color = {}));\n+                /**\n+                 * The ColorInformation namespace provides helper functions to work with\n+                 * {@link ColorInformation} literals.\n+                 */\n+                var ColorInformation;\n+                (function(ColorInformation) {\n+                    /**\n+                     * Creates a new ColorInformation literal.\n+                     */\n+                    function create(range, color) {\n+                        return {\n+                            range: range,\n+                            color: color\n+                        };\n+                    }\n+                    ColorInformation.create = create;\n+                    /**\n+                     * Checks whether the given literal conforms to the {@link ColorInformation} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.objectLiteral(candidate) && Range.is(candidate.range) && Color.is(candidate.color);\n+                    }\n+                    ColorInformation.is = is;\n+                })(ColorInformation || (exports.ColorInformation = ColorInformation = {}));\n+                /**\n+                 * The Color namespace provides helper functions to work with\n+                 * {@link ColorPresentation} literals.\n+                 */\n+                var ColorPresentation;\n+                (function(ColorPresentation) {\n+                    /**\n+                     * Creates a new ColorInformation literal.\n+                     */\n+                    function create(label, textEdit, additionalTextEdits) {\n+                        return {\n+                            label: label,\n+                            textEdit: textEdit,\n+                            additionalTextEdits: additionalTextEdits\n+                        };\n+                    }\n+                    ColorPresentation.create = create;\n+                    /**\n+                     * Checks whether the given literal conforms to the {@link ColorInformation} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.objectLiteral(candidate) && Is.string(candidate.label) && (Is.undefined(candidate.textEdit) || TextEdit.is(candidate)) && (Is.undefined(candidate.additionalTextEdits) || Is.typedArray(candidate.additionalTextEdits, TextEdit.is));\n+                    }\n+                    ColorPresentation.is = is;\n+                })(ColorPresentation || (exports.ColorPresentation = ColorPresentation = {}));\n+                /**\n+                 * A set of predefined range kinds.\n+                 */\n+                var FoldingRangeKind;\n+                (function(FoldingRangeKind) {\n+                    /**\n+                     * Folding range for a comment\n+                     */\n+                    FoldingRangeKind.Comment = 'comment';\n+                    /**\n+                     * Folding range for an import or include\n+                     */\n+                    FoldingRangeKind.Imports = 'imports';\n+                    /**\n+                     * Folding range for a region (e.g. `#region`)\n+                     */\n+                    FoldingRangeKind.Region = 'region';\n+                })(FoldingRangeKind || (exports.FoldingRangeKind = FoldingRangeKind = {}));\n+                /**\n+                 * The folding range namespace provides helper functions to work with\n+                 * {@link FoldingRange} literals.\n+                 */\n+                var FoldingRange;\n+                (function(FoldingRange) {\n+                    /**\n+                     * Creates a new FoldingRange literal.\n+                     */\n+                    function create(startLine, endLine, startCharacter, endCharacter, kind, collapsedText) {\n+                        var result = {\n+                            startLine: startLine,\n+                            endLine: endLine\n+                        };\n+                        if (Is.defined(startCharacter)) {\n+                            result.startCharacter = startCharacter;\n+                        }\n+                        if (Is.defined(endCharacter)) {\n+                            result.endCharacter = endCharacter;\n+                        }\n+                        if (Is.defined(kind)) {\n+                            result.kind = kind;\n+                        }\n+                        if (Is.defined(collapsedText)) {\n+                            result.collapsedText = collapsedText;\n+                        }\n+                        return result;\n+                    }\n+                    FoldingRange.create = create;\n+                    /**\n+                     * Checks whether the given literal conforms to the {@link FoldingRange} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.objectLiteral(candidate) && Is.uinteger(candidate.startLine) && Is.uinteger(candidate.startLine) && (Is.undefined(candidate.startCharacter) || Is.uinteger(candidate.startCharacter)) && (Is.undefined(candidate.endCharacter) || Is.uinteger(candidate.endCharacter)) && (Is.undefined(candidate.kind) || Is.string(candidate.kind));\n+                    }\n+                    FoldingRange.is = is;\n+                })(FoldingRange || (exports.FoldingRange = FoldingRange = {}));\n+                /**\n+                 * The DiagnosticRelatedInformation namespace provides helper functions to work with\n+                 * {@link DiagnosticRelatedInformation} literals.\n+                 */\n+                var DiagnosticRelatedInformation;\n+                (function(DiagnosticRelatedInformation) {\n+                    /**\n+                     * Creates a new DiagnosticRelatedInformation literal.\n+                     */\n+                    function create(location, message) {\n+                        return {\n+                            location: location,\n+                            message: message\n+                        };\n+                    }\n+                    DiagnosticRelatedInformation.create = create;\n+                    /**\n+                     * Checks whether the given literal conforms to the {@link DiagnosticRelatedInformation} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.defined(candidate) && Location.is(candidate.location) && Is.string(candidate.message);\n+                    }\n+                    DiagnosticRelatedInformation.is = is;\n+                })(DiagnosticRelatedInformation || (exports.DiagnosticRelatedInformation = DiagnosticRelatedInformation = {}));\n+                /**\n+                 * The diagnostic's severity.\n+                 */\n+                var DiagnosticSeverity;\n+                (function(DiagnosticSeverity) {\n+                    /**\n+                     * Reports an error.\n+                     */\n+                    DiagnosticSeverity.Error = 1;\n+                    /**\n+                     * Reports a warning.\n+                     */\n+                    DiagnosticSeverity.Warning = 2;\n+                    /**\n+                     * Reports an information.\n+                     */\n+                    DiagnosticSeverity.Information = 3;\n+                    /**\n+                     * Reports a hint.\n+                     */\n+                    DiagnosticSeverity.Hint = 4;\n+                })(DiagnosticSeverity || (exports.DiagnosticSeverity = DiagnosticSeverity = {}));\n+                /**\n+                 * The diagnostic tags.\n+                 *\n+                 * @since 3.15.0\n+                 */\n+                var DiagnosticTag;\n+                (function(DiagnosticTag) {\n+                    /**\n+                     * Unused or unnecessary code.\n+                     *\n+                     * Clients are allowed to render diagnostics with this tag faded out instead of having\n+                     * an error squiggle.\n+                     */\n+                    DiagnosticTag.Unnecessary = 1;\n+                    /**\n+                     * Deprecated or obsolete code.\n+                     *\n+                     * Clients are allowed to rendered diagnostics with this tag strike through.\n+                     */\n+                    DiagnosticTag.Deprecated = 2;\n+                })(DiagnosticTag || (exports.DiagnosticTag = DiagnosticTag = {}));\n+                /**\n+                 * The CodeDescription namespace provides functions to deal with descriptions for diagnostic codes.\n+                 *\n+                 * @since 3.16.0\n+                 */\n+                var CodeDescription;\n+                (function(CodeDescription) {\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.objectLiteral(candidate) && Is.string(candidate.href);\n+                    }\n+                    CodeDescription.is = is;\n+                })(CodeDescription || (exports.CodeDescription = CodeDescription = {}));\n+                /**\n+                 * The Diagnostic namespace provides helper functions to work with\n+                 * {@link Diagnostic} literals.\n+                 */\n+                var Diagnostic;\n+                (function(Diagnostic) {\n+                    /**\n+                     * Creates a new Diagnostic literal.\n+                     */\n+                    function create(range, message, severity, code, source, relatedInformation) {\n+                        var result = {\n+                            range: range,\n+                            message: message\n+                        };\n+                        if (Is.defined(severity)) {\n+                            result.severity = severity;\n+                        }\n+                        if (Is.defined(code)) {\n+                            result.code = code;\n+                        }\n+                        if (Is.defined(source)) {\n+                            result.source = source;\n+                        }\n+                        if (Is.defined(relatedInformation)) {\n+                            result.relatedInformation = relatedInformation;\n+                        }\n+                        return result;\n+                    }\n+                    Diagnostic.create = create;\n+                    /**\n+                     * Checks whether the given literal conforms to the {@link Diagnostic} interface.\n+                     */\n+                    function is(value) {\n+                        var _a;\n+                        var candidate = value;\n+                        return Is.defined(candidate) && Range.is(candidate.range) && Is.string(candidate.message) && (Is.number(candidate.severity) || Is.undefined(candidate.severity)) && (Is.integer(candidate.code) || Is.string(candidate.code) || Is.undefined(candidate.code)) && (Is.undefined(candidate.codeDescription) || Is.string((_a = candidate.codeDescription) === null || _a === void 0 ? void 0 : _a.href)) && (Is.string(candidate.source) || Is.undefined(candidate.source)) && (Is.undefined(candidate.relatedInformation) || Is.typedArray(candidate.relatedInformation, DiagnosticRelatedInformation.is));\n+                    }\n+                    Diagnostic.is = is;\n+                })(Diagnostic || (exports.Diagnostic = Diagnostic = {}));\n+                /**\n+                 * The Command namespace provides helper functions to work with\n+                 * {@link Command} literals.\n+                 */\n+                var Command;\n+                (function(Command) {\n+                    /**\n+                     * Creates a new Command literal.\n+                     */\n+                    function create(title, command) {\n+                        var args = [];\n+                        for (var _i = 2; _i < arguments.length; _i++) {\n+                            args[_i - 2] = arguments[_i];\n+                        }\n+                        var result = {\n+                            title: title,\n+                            command: command\n+                        };\n+                        if (Is.defined(args) && args.length > 0) {\n+                            result.arguments = args;\n+                        }\n+                        return result;\n+                    }\n+                    Command.create = create;\n+                    /**\n+                     * Checks whether the given literal conforms to the {@link Command} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.defined(candidate) && Is.string(candidate.title) && Is.string(candidate.command);\n+                    }\n+                    Command.is = is;\n+                })(Command || (exports.Command = Command = {}));\n+                /**\n+                 * The TextEdit namespace provides helper function to create replace,\n+                 * insert and delete edits more easily.\n+                 */\n+                var TextEdit;\n+                (function(TextEdit) {\n+                    /**\n+                     * Creates a replace text edit.\n+                     * @param range The range of text to be replaced.\n+                     * @param newText The new text.\n+                     */\n+                    function replace(range, newText) {\n+                        return {\n+                            range: range,\n+                            newText: newText\n+                        };\n+                    }\n+                    TextEdit.replace = replace;\n+                    /**\n+                     * Creates an insert text edit.\n+                     * @param position The position to insert the text at.\n+                     * @param newText The text to be inserted.\n+                     */\n+                    function insert(position, newText) {\n+                        return {\n+                            range: {\n+                                start: position,\n+                                end: position\n+                            },\n+                            newText: newText\n+                        };\n+                    }\n+                    TextEdit.insert = insert;\n+                    /**\n+                     * Creates a delete text edit.\n+                     * @param range The range of text to be deleted.\n+                     */\n+                    function del(range) {\n+                        return {\n+                            range: range,\n+                            newText: ''\n+                        };\n+                    }\n+                    TextEdit.del = del;\n+\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.objectLiteral(candidate) && Is.string(candidate.newText) && Range.is(candidate.range);\n+                    }\n+                    TextEdit.is = is;\n+                })(TextEdit || (exports.TextEdit = TextEdit = {}));\n+                var ChangeAnnotation;\n+                (function(ChangeAnnotation) {\n+                    function create(label, needsConfirmation, description) {\n+                        var result = {\n+                            label: label\n+                        };\n+                        if (needsConfirmation !== undefined) {\n+                            result.needsConfirmation = needsConfirmation;\n+                        }\n+                        if (description !== undefined) {\n+                            result.description = description;\n+                        }\n+                        return result;\n+                    }\n+                    ChangeAnnotation.create = create;\n+\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.objectLiteral(candidate) && Is.string(candidate.label) && (Is.boolean(candidate.needsConfirmation) || candidate.needsConfirmation === undefined) && (Is.string(candidate.description) || candidate.description === undefined);\n+                    }\n+                    ChangeAnnotation.is = is;\n+                })(ChangeAnnotation || (exports.ChangeAnnotation = ChangeAnnotation = {}));\n+                var ChangeAnnotationIdentifier;\n+                (function(ChangeAnnotationIdentifier) {\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.string(candidate);\n+                    }\n+                    ChangeAnnotationIdentifier.is = is;\n+                })(ChangeAnnotationIdentifier || (exports.ChangeAnnotationIdentifier = ChangeAnnotationIdentifier = {}));\n+                var AnnotatedTextEdit;\n+                (function(AnnotatedTextEdit) {\n+                    /**\n+                     * Creates an annotated replace text edit.\n+                     *\n+                     * @param range The range of text to be replaced.\n+                     * @param newText The new text.\n+                     * @param annotation The annotation.\n+                     */\n+                    function replace(range, newText, annotation) {\n                         return {\n-                            insertions,\n-                            result: docString\n+                            range: range,\n+                            newText: newText,\n+                            annotationId: annotation\n                         };\n                     }\n-                    let ast;\n-                    try {\n-                        ast = (0, _graphql.parse)(docString);\n-                    } catch (_a) {\n+                    AnnotatedTextEdit.replace = replace;\n+                    /**\n+                     * Creates an annotated insert text edit.\n+                     *\n+                     * @param position The position to insert the text at.\n+                     * @param newText The text to be inserted.\n+                     * @param annotation The annotation.\n+                     */\n+                    function insert(position, newText, annotation) {\n                         return {\n-                            insertions,\n-                            result: docString\n+                            range: {\n+                                start: position,\n+                                end: position\n+                            },\n+                            newText: newText,\n+                            annotationId: annotation\n                         };\n                     }\n-                    const fieldNameFn = getDefaultFieldNames || defaultGetDefaultFieldNames;\n-                    const typeInfo = new _graphql.TypeInfo(schema);\n-                    (0, _graphql.visit)(ast, {\n-                        leave(node) {\n-                            typeInfo.leave(node);\n-                        },\n-                        enter(node) {\n-                            typeInfo.enter(node);\n-                            if (node.kind === 'Field' && !node.selectionSet) {\n-                                const fieldType = typeInfo.getType();\n-                                const selectionSet = buildSelectionSet(isFieldType(fieldType), fieldNameFn);\n-                                if (selectionSet && node.loc) {\n-                                    const indent = getIndentation(docString, node.loc.start);\n-                                    insertions.push({\n-                                        index: node.loc.end,\n-                                        string: ' ' + (0, _graphql.print)(selectionSet).replaceAll('\\n', '\\n' + indent)\n-                                    });\n-                                }\n-                            }\n-                        }\n-                    });\n-                    return {\n-                        insertions,\n-                        result: withInsertions(docString, insertions)\n-                    };\n-                }\n-\n-                function defaultGetDefaultFieldNames(type) {\n-                    if (!('getFields' in type)) {\n-                        return [];\n+                    AnnotatedTextEdit.insert = insert;\n+                    /**\n+                     * Creates an annotated delete text edit.\n+                     *\n+                     * @param range The range of text to be deleted.\n+                     * @param annotation The annotation.\n+                     */\n+                    function del(range, annotation) {\n+                        return {\n+                            range: range,\n+                            newText: '',\n+                            annotationId: annotation\n+                        };\n                     }\n-                    const fields = type.getFields();\n-                    if (fields.id) {\n-                        return ['id'];\n+                    AnnotatedTextEdit.del = del;\n+\n+                    function is(value) {\n+                        var candidate = value;\n+                        return TextEdit.is(candidate) && (ChangeAnnotation.is(candidate.annotationId) || ChangeAnnotationIdentifier.is(candidate.annotationId));\n                     }\n-                    if (fields.edges) {\n-                        return ['edges'];\n+                    AnnotatedTextEdit.is = is;\n+                })(AnnotatedTextEdit || (exports.AnnotatedTextEdit = AnnotatedTextEdit = {}));\n+                /**\n+                 * The TextDocumentEdit namespace provides helper function to create\n+                 * an edit that manipulates a text document.\n+                 */\n+                var TextDocumentEdit;\n+                (function(TextDocumentEdit) {\n+                    /**\n+                     * Creates a new `TextDocumentEdit`\n+                     */\n+                    function create(textDocument, edits) {\n+                        return {\n+                            textDocument: textDocument,\n+                            edits: edits\n+                        };\n                     }\n-                    if (fields.node) {\n-                        return ['node'];\n+                    TextDocumentEdit.create = create;\n+\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.defined(candidate) && OptionalVersionedTextDocumentIdentifier.is(candidate.textDocument) && Array.isArray(candidate.edits);\n                     }\n-                    const leafFieldNames = [];\n-                    for (const fieldName of Object.keys(fields)) {\n-                        if ((0, _graphql.isLeafType)(fields[fieldName].type)) {\n-                            leafFieldNames.push(fieldName);\n+                    TextDocumentEdit.is = is;\n+                })(TextDocumentEdit || (exports.TextDocumentEdit = TextDocumentEdit = {}));\n+                var CreateFile;\n+                (function(CreateFile) {\n+                    function create(uri, options, annotation) {\n+                        var result = {\n+                            kind: 'create',\n+                            uri: uri\n+                        };\n+                        if (options !== undefined && (options.overwrite !== undefined || options.ignoreIfExists !== undefined)) {\n+                            result.options = options;\n                         }\n+                        if (annotation !== undefined) {\n+                            result.annotationId = annotation;\n+                        }\n+                        return result;\n                     }\n-                    return leafFieldNames;\n-                }\n+                    CreateFile.create = create;\n \n-                function buildSelectionSet(type, getDefaultFieldNames) {\n-                    const namedType = (0, _graphql.getNamedType)(type);\n-                    if (!type || (0, _graphql.isLeafType)(type)) {\n-                        return;\n+                    function is(value) {\n+                        var candidate = value;\n+                        return candidate && candidate.kind === 'create' && Is.string(candidate.uri) && (candidate.options === undefined || (candidate.options.overwrite === undefined || Is.boolean(candidate.options.overwrite)) && (candidate.options.ignoreIfExists === undefined || Is.boolean(candidate.options.ignoreIfExists))) && (candidate.annotationId === undefined || ChangeAnnotationIdentifier.is(candidate.annotationId));\n                     }\n-                    const fieldNames = getDefaultFieldNames(namedType);\n-                    if (!Array.isArray(fieldNames) || fieldNames.length === 0 || !('getFields' in namedType)) {\n-                        return;\n+                    CreateFile.is = is;\n+                })(CreateFile || (exports.CreateFile = CreateFile = {}));\n+                var RenameFile;\n+                (function(RenameFile) {\n+                    function create(oldUri, newUri, options, annotation) {\n+                        var result = {\n+                            kind: 'rename',\n+                            oldUri: oldUri,\n+                            newUri: newUri\n+                        };\n+                        if (options !== undefined && (options.overwrite !== undefined || options.ignoreIfExists !== undefined)) {\n+                            result.options = options;\n+                        }\n+                        if (annotation !== undefined) {\n+                            result.annotationId = annotation;\n+                        }\n+                        return result;\n                     }\n-                    return {\n-                        kind: _graphql.Kind.SELECTION_SET,\n-                        selections: fieldNames.map(fieldName => {\n-                            const fieldDef = namedType.getFields()[fieldName];\n-                            const fieldType = fieldDef ? fieldDef.type : null;\n-                            return {\n-                                kind: _graphql.Kind.FIELD,\n-                                name: {\n-                                    kind: _graphql.Kind.NAME,\n-                                    value: fieldName\n-                                },\n-                                selectionSet: buildSelectionSet(fieldType, getDefaultFieldNames)\n-                            };\n-                        })\n-                    };\n-                }\n+                    RenameFile.create = create;\n \n-                function withInsertions(initial, insertions) {\n-                    if (insertions.length === 0) {\n-                        return initial;\n+                    function is(value) {\n+                        var candidate = value;\n+                        return candidate && candidate.kind === 'rename' && Is.string(candidate.oldUri) && Is.string(candidate.newUri) && (candidate.options === undefined || (candidate.options.overwrite === undefined || Is.boolean(candidate.options.overwrite)) && (candidate.options.ignoreIfExists === undefined || Is.boolean(candidate.options.ignoreIfExists))) && (candidate.annotationId === undefined || ChangeAnnotationIdentifier.is(candidate.annotationId));\n                     }\n-                    let edited = '';\n-                    let prevIndex = 0;\n-                    for (const {\n-                            index,\n-                            string\n+                    RenameFile.is = is;\n+                })(RenameFile || (exports.RenameFile = RenameFile = {}));\n+                var DeleteFile;\n+                (function(DeleteFile) {\n+                    function create(uri, options, annotation) {\n+                        var result = {\n+                            kind: 'delete',\n+                            uri: uri\n+                        };\n+                        if (options !== undefined && (options.recursive !== undefined || options.ignoreIfNotExists !== undefined)) {\n+                            result.options = options;\n+                        }\n+                        if (annotation !== undefined) {\n+                            result.annotationId = annotation;\n                         }\n-                        of insertions) {\n-                        edited += initial.slice(prevIndex, index) + string;\n-                        prevIndex = index;\n+                        return result;\n                     }\n-                    edited += initial.slice(prevIndex);\n-                    return edited;\n-                }\n+                    DeleteFile.create = create;\n \n-                function getIndentation(str, index) {\n-                    let indentStart = index;\n-                    let indentEnd = index;\n-                    while (indentStart) {\n-                        const c = str.charCodeAt(indentStart - 1);\n-                        if (c === 10 || c === 13 || c === 0x2028 || c === 0x2029) {\n-                            break;\n+                    function is(value) {\n+                        var candidate = value;\n+                        return candidate && candidate.kind === 'delete' && Is.string(candidate.uri) && (candidate.options === undefined || (candidate.options.recursive === undefined || Is.boolean(candidate.options.recursive)) && (candidate.options.ignoreIfNotExists === undefined || Is.boolean(candidate.options.ignoreIfNotExists))) && (candidate.annotationId === undefined || ChangeAnnotationIdentifier.is(candidate.annotationId));\n+                    }\n+                    DeleteFile.is = is;\n+                })(DeleteFile || (exports.DeleteFile = DeleteFile = {}));\n+                var WorkspaceEdit;\n+                (function(WorkspaceEdit) {\n+                    function is(value) {\n+                        var candidate = value;\n+                        return candidate && (candidate.changes !== undefined || candidate.documentChanges !== undefined) && (candidate.documentChanges === undefined || candidate.documentChanges.every(function(change) {\n+                            if (Is.string(change.kind)) {\n+                                return CreateFile.is(change) || RenameFile.is(change) || DeleteFile.is(change);\n+                            } else {\n+                                return TextDocumentEdit.is(change);\n+                            }\n+                        }));\n+                    }\n+                    WorkspaceEdit.is = is;\n+                })(WorkspaceEdit || (exports.WorkspaceEdit = WorkspaceEdit = {}));\n+                var TextEditChangeImpl = /** @class */ function() {\n+                    function TextEditChangeImpl(edits, changeAnnotations) {\n+                        this.edits = edits;\n+                        this.changeAnnotations = changeAnnotations;\n+                    }\n+                    TextEditChangeImpl.prototype.insert = function(position, newText, annotation) {\n+                        var edit;\n+                        var id;\n+                        if (annotation === undefined) {\n+                            edit = TextEdit.insert(position, newText);\n+                        } else if (ChangeAnnotationIdentifier.is(annotation)) {\n+                            id = annotation;\n+                            edit = AnnotatedTextEdit.insert(position, newText, annotation);\n+                        } else {\n+                            this.assertChangeAnnotations(this.changeAnnotations);\n+                            id = this.changeAnnotations.manage(annotation);\n+                            edit = AnnotatedTextEdit.insert(position, newText, id);\n                         }\n-                        indentStart--;\n-                        if (c !== 9 && c !== 11 && c !== 12 && c !== 32 && c !== 160) {\n-                            indentEnd = indentStart;\n+                        this.edits.push(edit);\n+                        if (id !== undefined) {\n+                            return id;\n                         }\n+                    };\n+                    TextEditChangeImpl.prototype.replace = function(range, newText, annotation) {\n+                        var edit;\n+                        var id;\n+                        if (annotation === undefined) {\n+                            edit = TextEdit.replace(range, newText);\n+                        } else if (ChangeAnnotationIdentifier.is(annotation)) {\n+                            id = annotation;\n+                            edit = AnnotatedTextEdit.replace(range, newText, annotation);\n+                        } else {\n+                            this.assertChangeAnnotations(this.changeAnnotations);\n+                            id = this.changeAnnotations.manage(annotation);\n+                            edit = AnnotatedTextEdit.replace(range, newText, id);\n+                        }\n+                        this.edits.push(edit);\n+                        if (id !== undefined) {\n+                            return id;\n+                        }\n+                    };\n+                    TextEditChangeImpl.prototype.delete = function(range, annotation) {\n+                        var edit;\n+                        var id;\n+                        if (annotation === undefined) {\n+                            edit = TextEdit.del(range);\n+                        } else if (ChangeAnnotationIdentifier.is(annotation)) {\n+                            id = annotation;\n+                            edit = AnnotatedTextEdit.del(range, annotation);\n+                        } else {\n+                            this.assertChangeAnnotations(this.changeAnnotations);\n+                            id = this.changeAnnotations.manage(annotation);\n+                            edit = AnnotatedTextEdit.del(range, id);\n+                        }\n+                        this.edits.push(edit);\n+                        if (id !== undefined) {\n+                            return id;\n+                        }\n+                    };\n+                    TextEditChangeImpl.prototype.add = function(edit) {\n+                        this.edits.push(edit);\n+                    };\n+                    TextEditChangeImpl.prototype.all = function() {\n+                        return this.edits;\n+                    };\n+                    TextEditChangeImpl.prototype.clear = function() {\n+                        this.edits.splice(0, this.edits.length);\n+                    };\n+                    TextEditChangeImpl.prototype.assertChangeAnnotations = function(value) {\n+                        if (value === undefined) {\n+                            throw new Error(\"Text edit change is not configured to manage change annotations.\");\n+                        }\n+                    };\n+                    return TextEditChangeImpl;\n+                }();\n+                /**\n+                 * A helper class\n+                 */\n+                var ChangeAnnotations = /** @class */ function() {\n+                    function ChangeAnnotations(annotations) {\n+                        this._annotations = annotations === undefined ? Object.create(null) : annotations;\n+                        this._counter = 0;\n+                        this._size = 0;\n                     }\n-                    return str.slice(indentStart, indentEnd);\n-                }\n-\n-                function isFieldType(fieldType) {\n-                    if (fieldType) {\n-                        return fieldType;\n-                    }\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../graphiql-toolkit/esm/graphql-helpers/index.js\":\n-            /*!***********************************************************!*\\\n-              !*** ../../graphiql-toolkit/esm/graphql-helpers/index.js ***!\n-              \\***********************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                var _autoComplete = __webpack_require__( /*! ./auto-complete */ \"../../graphiql-toolkit/esm/graphql-helpers/auto-complete.js\");\n-                Object.keys(_autoComplete).forEach(function(key) {\n-                    if (key === \"default\" || key === \"__esModule\") return;\n-                    if (key in exports && exports[key] === _autoComplete[key]) return;\n-                    Object.defineProperty(exports, key, {\n-                        enumerable: true,\n+                    ChangeAnnotations.prototype.all = function() {\n+                        return this._annotations;\n+                    };\n+                    Object.defineProperty(ChangeAnnotations.prototype, \"size\", {\n                         get: function() {\n-                            return _autoComplete[key];\n-                        }\n+                            return this._size;\n+                        },\n+                        enumerable: false,\n+                        configurable: true\n                     });\n-                });\n-                var _mergeAst = __webpack_require__( /*! ./merge-ast */ \"../../graphiql-toolkit/esm/graphql-helpers/merge-ast.js\");\n-                Object.keys(_mergeAst).forEach(function(key) {\n-                    if (key === \"default\" || key === \"__esModule\") return;\n-                    if (key in exports && exports[key] === _mergeAst[key]) return;\n-                    Object.defineProperty(exports, key, {\n-                        enumerable: true,\n-                        get: function() {\n-                            return _mergeAst[key];\n+                    ChangeAnnotations.prototype.manage = function(idOrAnnotation, annotation) {\n+                        var id;\n+                        if (ChangeAnnotationIdentifier.is(idOrAnnotation)) {\n+                            id = idOrAnnotation;\n+                        } else {\n+                            id = this.nextId();\n+                            annotation = idOrAnnotation;\n                         }\n-                    });\n-                });\n-                var _operationName = __webpack_require__( /*! ./operation-name */ \"../../graphiql-toolkit/esm/graphql-helpers/operation-name.js\");\n-                Object.keys(_operationName).forEach(function(key) {\n-                    if (key === \"default\" || key === \"__esModule\") return;\n-                    if (key in exports && exports[key] === _operationName[key]) return;\n-                    Object.defineProperty(exports, key, {\n-                        enumerable: true,\n-                        get: function() {\n-                            return _operationName[key];\n+                        if (this._annotations[id] !== undefined) {\n+                            throw new Error(\"Id \".concat(id, \" is already in use.\"));\n                         }\n-                    });\n-                });\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../graphiql-toolkit/esm/graphql-helpers/merge-ast.js\":\n-            /*!***************************************************************!*\\\n-              !*** ../../graphiql-toolkit/esm/graphql-helpers/merge-ast.js ***!\n-              \\***************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.mergeAst = mergeAst;\n-                var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n-\n-                function uniqueBy(array, iteratee) {\n-                    var _a;\n-                    const FilteredMap = new Map();\n-                    const result = [];\n-                    for (const item of array) {\n-                        if (item.kind === 'Field') {\n-                            const uniqueValue = iteratee(item);\n-                            const existing = FilteredMap.get(uniqueValue);\n-                            if ((_a = item.directives) === null || _a === void 0 ? void 0 : _a.length) {\n-                                const itemClone = Object.assign({}, item);\n-                                result.push(itemClone);\n-                            } else if ((existing === null || existing === void 0 ? void 0 : existing.selectionSet) && item.selectionSet) {\n-                                existing.selectionSet.selections = [...existing.selectionSet.selections, ...item.selectionSet.selections];\n-                            } else if (!existing) {\n-                                const itemClone = Object.assign({}, item);\n-                                FilteredMap.set(uniqueValue, itemClone);\n-                                result.push(itemClone);\n+                        if (annotation === undefined) {\n+                            throw new Error(\"No annotation provided for id \".concat(id));\n+                        }\n+                        this._annotations[id] = annotation;\n+                        this._size++;\n+                        return id;\n+                    };\n+                    ChangeAnnotations.prototype.nextId = function() {\n+                        this._counter++;\n+                        return this._counter.toString();\n+                    };\n+                    return ChangeAnnotations;\n+                }();\n+                /**\n+                 * A workspace change helps constructing changes to a workspace.\n+                 */\n+                var WorkspaceChange = exports.WorkspaceChange = /** @class */ function() {\n+                    function WorkspaceChange(workspaceEdit) {\n+                        var _this = this;\n+                        this._textEditChanges = Object.create(null);\n+                        if (workspaceEdit !== undefined) {\n+                            this._workspaceEdit = workspaceEdit;\n+                            if (workspaceEdit.documentChanges) {\n+                                this._changeAnnotations = new ChangeAnnotations(workspaceEdit.changeAnnotations);\n+                                workspaceEdit.changeAnnotations = this._changeAnnotations.all();\n+                                workspaceEdit.documentChanges.forEach(function(change) {\n+                                    if (TextDocumentEdit.is(change)) {\n+                                        var textEditChange = new TextEditChangeImpl(change.edits, _this._changeAnnotations);\n+                                        _this._textEditChanges[change.textDocument.uri] = textEditChange;\n+                                    }\n+                                });\n+                            } else if (workspaceEdit.changes) {\n+                                Object.keys(workspaceEdit.changes).forEach(function(key) {\n+                                    var textEditChange = new TextEditChangeImpl(workspaceEdit.changes[key]);\n+                                    _this._textEditChanges[key] = textEditChange;\n+                                });\n                             }\n                         } else {\n-                            result.push(item);\n+                            this._workspaceEdit = {};\n                         }\n                     }\n-                    return result;\n-                }\n-\n-                function inlineRelevantFragmentSpreads(fragmentDefinitions, selections, selectionSetType) {\n-                    var _a;\n-                    const selectionSetTypeName = selectionSetType ? (0, _graphql.getNamedType)(selectionSetType).name : null;\n-                    const outputSelections = [];\n-                    const seenSpreads = [];\n-                    for (let selection of selections) {\n-                        if (selection.kind === 'FragmentSpread') {\n-                            const fragmentName = selection.name.value;\n-                            if (!selection.directives || selection.directives.length === 0) {\n-                                if (seenSpreads.includes(fragmentName)) {\n-                                    continue;\n+                    Object.defineProperty(WorkspaceChange.prototype, \"edit\", {\n+                        /**\n+                         * Returns the underlying {@link WorkspaceEdit} literal\n+                         * use to be returned from a workspace edit operation like rename.\n+                         */\n+                        get: function() {\n+                            this.initDocumentChanges();\n+                            if (this._changeAnnotations !== undefined) {\n+                                if (this._changeAnnotations.size === 0) {\n+                                    this._workspaceEdit.changeAnnotations = undefined;\n                                 } else {\n-                                    seenSpreads.push(fragmentName);\n+                                    this._workspaceEdit.changeAnnotations = this._changeAnnotations.all();\n                                 }\n                             }\n-                            const fragmentDefinition = fragmentDefinitions[selection.name.value];\n-                            if (fragmentDefinition) {\n-                                const {\n-                                    typeCondition,\n-                                    directives,\n-                                    selectionSet\n-                                } = fragmentDefinition;\n-                                selection = {\n-                                    kind: _graphql.Kind.INLINE_FRAGMENT,\n-                                    typeCondition,\n-                                    directives,\n-                                    selectionSet\n+                            return this._workspaceEdit;\n+                        },\n+                        enumerable: false,\n+                        configurable: true\n+                    });\n+                    WorkspaceChange.prototype.getTextEditChange = function(key) {\n+                        if (OptionalVersionedTextDocumentIdentifier.is(key)) {\n+                            this.initDocumentChanges();\n+                            if (this._workspaceEdit.documentChanges === undefined) {\n+                                throw new Error('Workspace edit is not configured for document changes.');\n+                            }\n+                            var textDocument = {\n+                                uri: key.uri,\n+                                version: key.version\n+                            };\n+                            var result = this._textEditChanges[textDocument.uri];\n+                            if (!result) {\n+                                var edits = [];\n+                                var textDocumentEdit = {\n+                                    textDocument: textDocument,\n+                                    edits: edits\n                                 };\n+                                this._workspaceEdit.documentChanges.push(textDocumentEdit);\n+                                result = new TextEditChangeImpl(edits, this._changeAnnotations);\n+                                this._textEditChanges[textDocument.uri] = result;\n                             }\n-                        }\n-                        if (selection.kind === _graphql.Kind.INLINE_FRAGMENT && (!selection.directives || ((_a = selection.directives) === null || _a === void 0 ? void 0 : _a.length) === 0)) {\n-                            const fragmentTypeName = selection.typeCondition ? selection.typeCondition.name.value : null;\n-                            if (!fragmentTypeName || fragmentTypeName === selectionSetTypeName) {\n-                                outputSelections.push(...inlineRelevantFragmentSpreads(fragmentDefinitions, selection.selectionSet.selections, selectionSetType));\n-                                continue;\n+                            return result;\n+                        } else {\n+                            this.initChanges();\n+                            if (this._workspaceEdit.changes === undefined) {\n+                                throw new Error('Workspace edit is not configured for normal text edit changes.');\n                             }\n+                            var result = this._textEditChanges[key];\n+                            if (!result) {\n+                                var edits = [];\n+                                this._workspaceEdit.changes[key] = edits;\n+                                result = new TextEditChangeImpl(edits);\n+                                this._textEditChanges[key] = result;\n+                            }\n+                            return result;\n                         }\n-                        outputSelections.push(selection);\n-                    }\n-                    return outputSelections;\n-                }\n-\n-                function mergeAst(documentAST, schema) {\n-                    const typeInfo = schema ? new _graphql.TypeInfo(schema) : null;\n-                    const fragmentDefinitions = Object.create(null);\n-                    for (const definition of documentAST.definitions) {\n-                        if (definition.kind === _graphql.Kind.FRAGMENT_DEFINITION) {\n-                            fragmentDefinitions[definition.name.value] = definition;\n-                        }\n-                    }\n-                    const flattenVisitors = {\n-                        SelectionSet(node) {\n-                            const selectionSetType = typeInfo ? typeInfo.getParentType() : null;\n-                            let {\n-                                selections\n-                            } = node;\n-                            selections = inlineRelevantFragmentSpreads(fragmentDefinitions, selections, selectionSetType);\n-                            return Object.assign(Object.assign({}, node), {\n-                                selections\n-                            });\n-                        },\n-                        FragmentDefinition() {\n-                            return null;\n+                    };\n+                    WorkspaceChange.prototype.initDocumentChanges = function() {\n+                        if (this._workspaceEdit.documentChanges === undefined && this._workspaceEdit.changes === undefined) {\n+                            this._changeAnnotations = new ChangeAnnotations();\n+                            this._workspaceEdit.documentChanges = [];\n+                            this._workspaceEdit.changeAnnotations = this._changeAnnotations.all();\n                         }\n                     };\n-                    const flattenedAST = (0, _graphql.visit)(documentAST, typeInfo ? (0, _graphql.visitWithTypeInfo)(typeInfo, flattenVisitors) : flattenVisitors);\n-                    const deduplicateVisitors = {\n-                        SelectionSet(node) {\n-                            let {\n-                                selections\n-                            } = node;\n-                            selections = uniqueBy(selections, selection => selection.alias ? selection.alias.value : selection.name.value);\n-                            return Object.assign(Object.assign({}, node), {\n-                                selections\n-                            });\n-                        },\n-                        FragmentDefinition() {\n-                            return null;\n+                    WorkspaceChange.prototype.initChanges = function() {\n+                        if (this._workspaceEdit.documentChanges === undefined && this._workspaceEdit.changes === undefined) {\n+                            this._workspaceEdit.changes = Object.create(null);\n                         }\n                     };\n-                    return (0, _graphql.visit)(flattenedAST, deduplicateVisitors);\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../graphiql-toolkit/esm/graphql-helpers/operation-name.js\":\n-            /*!********************************************************************!*\\\n-              !*** ../../graphiql-toolkit/esm/graphql-helpers/operation-name.js ***!\n-              \\********************************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.getSelectedOperationName = getSelectedOperationName;\n-\n-                function getSelectedOperationName(prevOperations, prevSelectedOperationName, operations) {\n-                    if (!operations || operations.length < 1) {\n-                        return;\n-                    }\n-                    const names = operations.map(op => {\n-                        var _a;\n-                        return (_a = op.name) === null || _a === void 0 ? void 0 : _a.value;\n-                    });\n-                    if (prevSelectedOperationName && names.includes(prevSelectedOperationName)) {\n-                        return prevSelectedOperationName;\n-                    }\n-                    if (prevSelectedOperationName && prevOperations) {\n-                        const prevNames = prevOperations.map(op => {\n-                            var _a;\n-                            return (_a = op.name) === null || _a === void 0 ? void 0 : _a.value;\n-                        });\n-                        const prevIndex = prevNames.indexOf(prevSelectedOperationName);\n-                        if (prevIndex !== -1 && prevIndex < names.length) {\n-                            return names[prevIndex];\n+                    WorkspaceChange.prototype.createFile = function(uri, optionsOrAnnotation, options) {\n+                        this.initDocumentChanges();\n+                        if (this._workspaceEdit.documentChanges === undefined) {\n+                            throw new Error('Workspace edit is not configured for document changes.');\n                         }\n-                    }\n-                    return names[0];\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../graphiql-toolkit/esm/index.js\":\n-            /*!*******************************************!*\\\n-              !*** ../../graphiql-toolkit/esm/index.js ***!\n-              \\*******************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                var _asyncHelpers = __webpack_require__( /*! ./async-helpers */ \"../../graphiql-toolkit/esm/async-helpers/index.js\");\n-                Object.keys(_asyncHelpers).forEach(function(key) {\n-                    if (key === \"default\" || key === \"__esModule\") return;\n-                    if (key in exports && exports[key] === _asyncHelpers[key]) return;\n-                    Object.defineProperty(exports, key, {\n-                        enumerable: true,\n-                        get: function() {\n-                            return _asyncHelpers[key];\n+                        var annotation;\n+                        if (ChangeAnnotation.is(optionsOrAnnotation) || ChangeAnnotationIdentifier.is(optionsOrAnnotation)) {\n+                            annotation = optionsOrAnnotation;\n+                        } else {\n+                            options = optionsOrAnnotation;\n                         }\n-                    });\n-                });\n-                var _createFetcher = __webpack_require__( /*! ./create-fetcher */ \"../../graphiql-toolkit/esm/create-fetcher/index.js\");\n-                Object.keys(_createFetcher).forEach(function(key) {\n-                    if (key === \"default\" || key === \"__esModule\") return;\n-                    if (key in exports && exports[key] === _createFetcher[key]) return;\n-                    Object.defineProperty(exports, key, {\n-                        enumerable: true,\n-                        get: function() {\n-                            return _createFetcher[key];\n+                        var operation;\n+                        var id;\n+                        if (annotation === undefined) {\n+                            operation = CreateFile.create(uri, options);\n+                        } else {\n+                            id = ChangeAnnotationIdentifier.is(annotation) ? annotation : this._changeAnnotations.manage(annotation);\n+                            operation = CreateFile.create(uri, options, id);\n                         }\n-                    });\n-                });\n-                var _format = __webpack_require__( /*! ./format */ \"../../graphiql-toolkit/esm/format/index.js\");\n-                Object.keys(_format).forEach(function(key) {\n-                    if (key === \"default\" || key === \"__esModule\") return;\n-                    if (key in exports && exports[key] === _format[key]) return;\n-                    Object.defineProperty(exports, key, {\n-                        enumerable: true,\n-                        get: function() {\n-                            return _format[key];\n+                        this._workspaceEdit.documentChanges.push(operation);\n+                        if (id !== undefined) {\n+                            return id;\n                         }\n-                    });\n-                });\n-                var _graphqlHelpers = __webpack_require__( /*! ./graphql-helpers */ \"../../graphiql-toolkit/esm/graphql-helpers/index.js\");\n-                Object.keys(_graphqlHelpers).forEach(function(key) {\n-                    if (key === \"default\" || key === \"__esModule\") return;\n-                    if (key in exports && exports[key] === _graphqlHelpers[key]) return;\n-                    Object.defineProperty(exports, key, {\n-                        enumerable: true,\n-                        get: function() {\n-                            return _graphqlHelpers[key];\n+                    };\n+                    WorkspaceChange.prototype.renameFile = function(oldUri, newUri, optionsOrAnnotation, options) {\n+                        this.initDocumentChanges();\n+                        if (this._workspaceEdit.documentChanges === undefined) {\n+                            throw new Error('Workspace edit is not configured for document changes.');\n                         }\n-                    });\n-                });\n-                var _storage = __webpack_require__( /*! ./storage */ \"../../graphiql-toolkit/esm/storage/index.js\");\n-                Object.keys(_storage).forEach(function(key) {\n-                    if (key === \"default\" || key === \"__esModule\") return;\n-                    if (key in exports && exports[key] === _storage[key]) return;\n-                    Object.defineProperty(exports, key, {\n-                        enumerable: true,\n-                        get: function() {\n-                            return _storage[key];\n+                        var annotation;\n+                        if (ChangeAnnotation.is(optionsOrAnnotation) || ChangeAnnotationIdentifier.is(optionsOrAnnotation)) {\n+                            annotation = optionsOrAnnotation;\n+                        } else {\n+                            options = optionsOrAnnotation;\n                         }\n-                    });\n-                });\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../graphiql-toolkit/esm/storage/base.js\":\n-            /*!**************************************************!*\\\n-              !*** ../../graphiql-toolkit/esm/storage/base.js ***!\n-              \\**************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.StorageAPI = void 0;\n-\n-                function isQuotaError(storage, e) {\n-                    return e instanceof DOMException && (e.code === 22 || e.code === 1014 || e.name === 'QuotaExceededError' || e.name === 'NS_ERROR_DOM_QUOTA_REACHED') && storage.length !== 0;\n-                }\n-                class StorageAPI {\n-                    constructor(storage) {\n-                        if (storage) {\n-                            this.storage = storage;\n-                        } else if (storage === null) {\n-                            this.storage = null;\n-                        } else if (typeof window === 'undefined') {\n-                            this.storage = null;\n-                        } else {\n-                            this.storage = {\n-                                getItem: window.localStorage.getItem.bind(window.localStorage),\n-                                setItem: window.localStorage.setItem.bind(window.localStorage),\n-                                removeItem: window.localStorage.removeItem.bind(window.localStorage),\n-                                get length() {\n-                                    let keys = 0;\n-                                    for (const key in window.localStorage) {\n-                                        if (key.indexOf(`${STORAGE_NAMESPACE}:`) === 0) {\n-                                            keys += 1;\n-                                        }\n-                                    }\n-                                    return keys;\n-                                },\n-                                clear() {\n-                                    for (const key in window.localStorage) {\n-                                        if (key.indexOf(`${STORAGE_NAMESPACE}:`) === 0) {\n-                                            window.localStorage.removeItem(key);\n-                                        }\n-                                    }\n-                                }\n-                            };\n+                        var operation;\n+                        var id;\n+                        if (annotation === undefined) {\n+                            operation = RenameFile.create(oldUri, newUri, options);\n+                        } else {\n+                            id = ChangeAnnotationIdentifier.is(annotation) ? annotation : this._changeAnnotations.manage(annotation);\n+                            operation = RenameFile.create(oldUri, newUri, options, id);\n                         }\n-                    }\n-                    get(name) {\n-                        if (!this.storage) {\n-                            return null;\n+                        this._workspaceEdit.documentChanges.push(operation);\n+                        if (id !== undefined) {\n+                            return id;\n                         }\n-                        const key = `${STORAGE_NAMESPACE}:${name}`;\n-                        const value = this.storage.getItem(key);\n-                        if (value === 'null' || value === 'undefined') {\n-                            this.storage.removeItem(key);\n-                            return null;\n+                    };\n+                    WorkspaceChange.prototype.deleteFile = function(uri, optionsOrAnnotation, options) {\n+                        this.initDocumentChanges();\n+                        if (this._workspaceEdit.documentChanges === undefined) {\n+                            throw new Error('Workspace edit is not configured for document changes.');\n                         }\n-                        return value || null;\n-                    }\n-                    set(name, value) {\n-                        let quotaError = false;\n-                        let error = null;\n-                        if (this.storage) {\n-                            const key = `${STORAGE_NAMESPACE}:${name}`;\n-                            if (value) {\n-                                try {\n-                                    this.storage.setItem(key, value);\n-                                } catch (e) {\n-                                    error = e instanceof Error ? e : new Error(`${e}`);\n-                                    quotaError = isQuotaError(this.storage, e);\n-                                }\n-                            } else {\n-                                this.storage.removeItem(key);\n-                            }\n+                        var annotation;\n+                        if (ChangeAnnotation.is(optionsOrAnnotation) || ChangeAnnotationIdentifier.is(optionsOrAnnotation)) {\n+                            annotation = optionsOrAnnotation;\n+                        } else {\n+                            options = optionsOrAnnotation;\n+                        }\n+                        var operation;\n+                        var id;\n+                        if (annotation === undefined) {\n+                            operation = DeleteFile.create(uri, options);\n+                        } else {\n+                            id = ChangeAnnotationIdentifier.is(annotation) ? annotation : this._changeAnnotations.manage(annotation);\n+                            operation = DeleteFile.create(uri, options, id);\n+                        }\n+                        this._workspaceEdit.documentChanges.push(operation);\n+                        if (id !== undefined) {\n+                            return id;\n                         }\n+                    };\n+                    return WorkspaceChange;\n+                }();\n+                /**\n+                 * The TextDocumentIdentifier namespace provides helper functions to work with\n+                 * {@link TextDocumentIdentifier} literals.\n+                 */\n+                var TextDocumentIdentifier;\n+                (function(TextDocumentIdentifier) {\n+                    /**\n+                     * Creates a new TextDocumentIdentifier literal.\n+                     * @param uri The document's uri.\n+                     */\n+                    function create(uri) {\n                         return {\n-                            isQuotaError: quotaError,\n-                            error\n+                            uri: uri\n                         };\n                     }\n-                    clear() {\n-                        if (this.storage) {\n-                            this.storage.clear();\n-                        }\n+                    TextDocumentIdentifier.create = create;\n+                    /**\n+                     * Checks whether the given literal conforms to the {@link TextDocumentIdentifier} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.defined(candidate) && Is.string(candidate.uri);\n                     }\n-                }\n-                exports.StorageAPI = StorageAPI;\n-                const STORAGE_NAMESPACE = 'graphiql';\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../graphiql-toolkit/esm/storage/custom.js\":\n-            /*!****************************************************!*\\\n-              !*** ../../graphiql-toolkit/esm/storage/custom.js ***!\n-              \\****************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.createLocalStorage = createLocalStorage;\n-\n-                function createLocalStorage(_ref) {\n-                    let {\n-                        namespace\n-                    } = _ref;\n-                    const storageKeyPrefix = `${namespace}:`;\n-                    const getStorageKey = key => `${storageKeyPrefix}${key}`;\n-                    const storage = {\n-                        setItem: (key, value) => localStorage.setItem(getStorageKey(key), value),\n-                        getItem: key => localStorage.getItem(getStorageKey(key)),\n-                        removeItem: key => localStorage.removeItem(getStorageKey(key)),\n-                        get length() {\n-                            let keys = 0;\n-                            for (const key in window.localStorage) {\n-                                if (key.indexOf(storageKeyPrefix) === 0) {\n-                                    keys += 1;\n-                                }\n-                            }\n-                            return keys;\n-                        },\n-                        clear() {\n-                            for (const key in window.localStorage) {\n-                                if (key.indexOf(storageKeyPrefix) === 0) {\n-                                    window.localStorage.removeItem(key);\n-                                }\n-                            }\n-                        }\n-                    };\n-                    return storage;\n-                }\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../graphiql-toolkit/esm/storage/history.js\":\n-            /*!*****************************************************!*\\\n-              !*** ../../graphiql-toolkit/esm/storage/history.js ***!\n-              \\*****************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.HistoryStore = void 0;\n-                var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n-                var _query = __webpack_require__( /*! ./query */ \"../../graphiql-toolkit/esm/storage/query.js\");\n-                const MAX_QUERY_SIZE = 100000;\n-                class HistoryStore {\n-                    constructor(storage, maxHistoryLength) {\n-                        var _this = this;\n-                        this.storage = storage;\n-                        this.maxHistoryLength = maxHistoryLength;\n-                        this.updateHistory = _ref => {\n-                            let {\n-                                query,\n-                                variables,\n-                                headers,\n-                                operationName\n-                            } = _ref;\n-                            if (!this.shouldSaveQuery(query, variables, headers, this.history.fetchRecent())) {\n-                                return;\n-                            }\n-                            this.history.push({\n-                                query,\n-                                variables,\n-                                headers,\n-                                operationName\n-                            });\n-                            const historyQueries = this.history.items;\n-                            const favoriteQueries = this.favorite.items;\n-                            this.queries = historyQueries.concat(favoriteQueries);\n+                    TextDocumentIdentifier.is = is;\n+                })(TextDocumentIdentifier || (exports.TextDocumentIdentifier = TextDocumentIdentifier = {}));\n+                /**\n+                 * The VersionedTextDocumentIdentifier namespace provides helper functions to work with\n+                 * {@link VersionedTextDocumentIdentifier} literals.\n+                 */\n+                var VersionedTextDocumentIdentifier;\n+                (function(VersionedTextDocumentIdentifier) {\n+                    /**\n+                     * Creates a new VersionedTextDocumentIdentifier literal.\n+                     * @param uri The document's uri.\n+                     * @param version The document's version.\n+                     */\n+                    function create(uri, version) {\n+                        return {\n+                            uri: uri,\n+                            version: version\n                         };\n-                        this.deleteHistory = function(_ref2) {\n-                            let {\n-                                query,\n-                                variables,\n-                                headers,\n-                                operationName,\n-                                favorite\n-                            } = _ref2;\n-                            let clearFavorites = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n-\n-                            function deleteFromStore(store) {\n-                                const found = store.items.find(x => x.query === query && x.variables === variables && x.headers === headers && x.operationName === operationName);\n-                                if (found) {\n-                                    store.delete(found);\n-                                }\n-                            }\n-                            if (favorite || clearFavorites) {\n-                                deleteFromStore(_this.favorite);\n-                            }\n-                            if (!favorite || clearFavorites) {\n-                                deleteFromStore(_this.history);\n-                            }\n-                            _this.queries = [..._this.history.items, ..._this.favorite.items];\n+                    }\n+                    VersionedTextDocumentIdentifier.create = create;\n+                    /**\n+                     * Checks whether the given literal conforms to the {@link VersionedTextDocumentIdentifier} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.defined(candidate) && Is.string(candidate.uri) && Is.integer(candidate.version);\n+                    }\n+                    VersionedTextDocumentIdentifier.is = is;\n+                })(VersionedTextDocumentIdentifier || (exports.VersionedTextDocumentIdentifier = VersionedTextDocumentIdentifier = {}));\n+                /**\n+                 * The OptionalVersionedTextDocumentIdentifier namespace provides helper functions to work with\n+                 * {@link OptionalVersionedTextDocumentIdentifier} literals.\n+                 */\n+                var OptionalVersionedTextDocumentIdentifier;\n+                (function(OptionalVersionedTextDocumentIdentifier) {\n+                    /**\n+                     * Creates a new OptionalVersionedTextDocumentIdentifier literal.\n+                     * @param uri The document's uri.\n+                     * @param version The document's version.\n+                     */\n+                    function create(uri, version) {\n+                        return {\n+                            uri: uri,\n+                            version: version\n                         };\n-                        this.history = new _query.QueryStore('queries', this.storage, this.maxHistoryLength);\n-                        this.favorite = new _query.QueryStore('favorites', this.storage, null);\n-                        this.queries = [...this.history.fetchAll(), ...this.favorite.fetchAll()];\n                     }\n-                    shouldSaveQuery(query, variables, headers, lastQuerySaved) {\n-                        if (!query) {\n-                            return false;\n-                        }\n-                        try {\n-                            (0, _graphql.parse)(query);\n-                        } catch (_a) {\n-                            return false;\n-                        }\n-                        if (query.length > MAX_QUERY_SIZE) {\n-                            return false;\n-                        }\n-                        if (!lastQuerySaved) {\n-                            return true;\n-                        }\n-                        if (JSON.stringify(query) === JSON.stringify(lastQuerySaved.query)) {\n-                            if (JSON.stringify(variables) === JSON.stringify(lastQuerySaved.variables)) {\n-                                if (JSON.stringify(headers) === JSON.stringify(lastQuerySaved.headers)) {\n-                                    return false;\n-                                }\n-                                if (headers && !lastQuerySaved.headers) {\n-                                    return false;\n-                                }\n-                            }\n-                            if (variables && !lastQuerySaved.variables) {\n-                                return false;\n-                            }\n-                        }\n-                        return true;\n+                    OptionalVersionedTextDocumentIdentifier.create = create;\n+                    /**\n+                     * Checks whether the given literal conforms to the {@link OptionalVersionedTextDocumentIdentifier} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.defined(candidate) && Is.string(candidate.uri) && (candidate.version === null || Is.integer(candidate.version));\n                     }\n-                    toggleFavorite(_ref3) {\n-                        let {\n-                            query,\n-                            variables,\n-                            headers,\n-                            operationName,\n-                            label,\n-                            favorite\n-                        } = _ref3;\n-                        const item = {\n-                            query,\n-                            variables,\n-                            headers,\n-                            operationName,\n-                            label\n+                    OptionalVersionedTextDocumentIdentifier.is = is;\n+                })(OptionalVersionedTextDocumentIdentifier || (exports.OptionalVersionedTextDocumentIdentifier = OptionalVersionedTextDocumentIdentifier = {}));\n+                /**\n+                 * The TextDocumentItem namespace provides helper functions to work with\n+                 * {@link TextDocumentItem} literals.\n+                 */\n+                var TextDocumentItem;\n+                (function(TextDocumentItem) {\n+                    /**\n+                     * Creates a new TextDocumentItem literal.\n+                     * @param uri The document's uri.\n+                     * @param languageId The document's language identifier.\n+                     * @param version The document's version number.\n+                     * @param text The document's text.\n+                     */\n+                    function create(uri, languageId, version, text) {\n+                        return {\n+                            uri: uri,\n+                            languageId: languageId,\n+                            version: version,\n+                            text: text\n                         };\n-                        if (favorite) {\n-                            item.favorite = false;\n-                            this.favorite.delete(item);\n-                            this.history.push(item);\n-                        } else {\n-                            item.favorite = true;\n-                            this.favorite.push(item);\n-                            this.history.delete(item);\n-                        }\n-                        this.queries = [...this.history.items, ...this.favorite.items];\n                     }\n-                    editLabel(_ref4, index) {\n-                        let {\n-                            query,\n-                            variables,\n-                            headers,\n-                            operationName,\n-                            label,\n-                            favorite\n-                        } = _ref4;\n-                        const item = {\n-                            query,\n-                            variables,\n-                            headers,\n-                            operationName,\n-                            label\n+                    TextDocumentItem.create = create;\n+                    /**\n+                     * Checks whether the given literal conforms to the {@link TextDocumentItem} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.defined(candidate) && Is.string(candidate.uri) && Is.string(candidate.languageId) && Is.integer(candidate.version) && Is.string(candidate.text);\n+                    }\n+                    TextDocumentItem.is = is;\n+                })(TextDocumentItem || (exports.TextDocumentItem = TextDocumentItem = {}));\n+                /**\n+                 * Describes the content type that a client supports in various\n+                 * result literals like `Hover`, `ParameterInfo` or `CompletionItem`.\n+                 *\n+                 * Please note that `MarkupKinds` must not start with a `$`. This kinds\n+                 * are reserved for internal usage.\n+                 */\n+                var MarkupKind;\n+                (function(MarkupKind) {\n+                    /**\n+                     * Plain text is supported as a content format\n+                     */\n+                    MarkupKind.PlainText = 'plaintext';\n+                    /**\n+                     * Markdown is supported as a content format\n+                     */\n+                    MarkupKind.Markdown = 'markdown';\n+                    /**\n+                     * Checks whether the given value is a value of the {@link MarkupKind} type.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return candidate === MarkupKind.PlainText || candidate === MarkupKind.Markdown;\n+                    }\n+                    MarkupKind.is = is;\n+                })(MarkupKind || (exports.MarkupKind = MarkupKind = {}));\n+                var MarkupContent;\n+                (function(MarkupContent) {\n+                    /**\n+                     * Checks whether the given value conforms to the {@link MarkupContent} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.objectLiteral(value) && MarkupKind.is(candidate.kind) && Is.string(candidate.value);\n+                    }\n+                    MarkupContent.is = is;\n+                })(MarkupContent || (exports.MarkupContent = MarkupContent = {}));\n+                /**\n+                 * The kind of a completion entry.\n+                 */\n+                var CompletionItemKind;\n+                (function(CompletionItemKind) {\n+                    CompletionItemKind.Text = 1;\n+                    CompletionItemKind.Method = 2;\n+                    CompletionItemKind.Function = 3;\n+                    CompletionItemKind.Constructor = 4;\n+                    CompletionItemKind.Field = 5;\n+                    CompletionItemKind.Variable = 6;\n+                    CompletionItemKind.Class = 7;\n+                    CompletionItemKind.Interface = 8;\n+                    CompletionItemKind.Module = 9;\n+                    CompletionItemKind.Property = 10;\n+                    CompletionItemKind.Unit = 11;\n+                    CompletionItemKind.Value = 12;\n+                    CompletionItemKind.Enum = 13;\n+                    CompletionItemKind.Keyword = 14;\n+                    CompletionItemKind.Snippet = 15;\n+                    CompletionItemKind.Color = 16;\n+                    CompletionItemKind.File = 17;\n+                    CompletionItemKind.Reference = 18;\n+                    CompletionItemKind.Folder = 19;\n+                    CompletionItemKind.EnumMember = 20;\n+                    CompletionItemKind.Constant = 21;\n+                    CompletionItemKind.Struct = 22;\n+                    CompletionItemKind.Event = 23;\n+                    CompletionItemKind.Operator = 24;\n+                    CompletionItemKind.TypeParameter = 25;\n+                })(CompletionItemKind || (exports.CompletionItemKind = CompletionItemKind = {}));\n+                /**\n+                 * Defines whether the insert text in a completion item should be interpreted as\n+                 * plain text or a snippet.\n+                 */\n+                var InsertTextFormat;\n+                (function(InsertTextFormat) {\n+                    /**\n+                     * The primary text to be inserted is treated as a plain string.\n+                     */\n+                    InsertTextFormat.PlainText = 1;\n+                    /**\n+                     * The primary text to be inserted is treated as a snippet.\n+                     *\n+                     * A snippet can define tab stops and placeholders with `$1`, `$2`\n+                     * and `${3:foo}`. `$0` defines the final tab stop, it defaults to\n+                     * the end of the snippet. Placeholders with equal identifiers are linked,\n+                     * that is typing in one will update others too.\n+                     *\n+                     * See also: https://microsoft.github.io/language-server-protocol/specifications/specification-current/#snippet_syntax\n+                     */\n+                    InsertTextFormat.Snippet = 2;\n+                })(InsertTextFormat || (exports.InsertTextFormat = InsertTextFormat = {}));\n+                /**\n+                 * Completion item tags are extra annotations that tweak the rendering of a completion\n+                 * item.\n+                 *\n+                 * @since 3.15.0\n+                 */\n+                var CompletionItemTag;\n+                (function(CompletionItemTag) {\n+                    /**\n+                     * Render a completion as obsolete, usually using a strike-out.\n+                     */\n+                    CompletionItemTag.Deprecated = 1;\n+                })(CompletionItemTag || (exports.CompletionItemTag = CompletionItemTag = {}));\n+                /**\n+                 * The InsertReplaceEdit namespace provides functions to deal with insert / replace edits.\n+                 *\n+                 * @since 3.16.0\n+                 */\n+                var InsertReplaceEdit;\n+                (function(InsertReplaceEdit) {\n+                    /**\n+                     * Creates a new insert / replace edit\n+                     */\n+                    function create(newText, insert, replace) {\n+                        return {\n+                            newText: newText,\n+                            insert: insert,\n+                            replace: replace\n                         };\n-                        if (favorite) {\n-                            this.favorite.edit(Object.assign(Object.assign({}, item), {\n-                                favorite\n-                            }), index);\n-                        } else {\n-                            this.history.edit(item, index);\n-                        }\n-                        this.queries = [...this.history.items, ...this.favorite.items];\n                     }\n-                }\n-                exports.HistoryStore = HistoryStore;\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../graphiql-toolkit/esm/storage/index.js\":\n-            /*!***************************************************!*\\\n-              !*** ../../graphiql-toolkit/esm/storage/index.js ***!\n-              \\***************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports, __webpack_require__) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                var _base = __webpack_require__( /*! ./base */ \"../../graphiql-toolkit/esm/storage/base.js\");\n-                Object.keys(_base).forEach(function(key) {\n-                    if (key === \"default\" || key === \"__esModule\") return;\n-                    if (key in exports && exports[key] === _base[key]) return;\n-                    Object.defineProperty(exports, key, {\n-                        enumerable: true,\n-                        get: function() {\n-                            return _base[key];\n-                        }\n-                    });\n-                });\n-                var _history = __webpack_require__( /*! ./history */ \"../../graphiql-toolkit/esm/storage/history.js\");\n-                Object.keys(_history).forEach(function(key) {\n-                    if (key === \"default\" || key === \"__esModule\") return;\n-                    if (key in exports && exports[key] === _history[key]) return;\n-                    Object.defineProperty(exports, key, {\n-                        enumerable: true,\n-                        get: function() {\n-                            return _history[key];\n-                        }\n-                    });\n-                });\n-                var _query = __webpack_require__( /*! ./query */ \"../../graphiql-toolkit/esm/storage/query.js\");\n-                Object.keys(_query).forEach(function(key) {\n-                    if (key === \"default\" || key === \"__esModule\") return;\n-                    if (key in exports && exports[key] === _query[key]) return;\n-                    Object.defineProperty(exports, key, {\n-                        enumerable: true,\n-                        get: function() {\n-                            return _query[key];\n-                        }\n-                    });\n-                });\n-                var _custom = __webpack_require__( /*! ./custom */ \"../../graphiql-toolkit/esm/storage/custom.js\");\n-                Object.keys(_custom).forEach(function(key) {\n-                    if (key === \"default\" || key === \"__esModule\") return;\n-                    if (key in exports && exports[key] === _custom[key]) return;\n-                    Object.defineProperty(exports, key, {\n-                        enumerable: true,\n-                        get: function() {\n-                            return _custom[key];\n-                        }\n-                    });\n-                });\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../../graphiql-toolkit/esm/storage/query.js\":\n-            /*!***************************************************!*\\\n-              !*** ../../graphiql-toolkit/esm/storage/query.js ***!\n-              \\***************************************************/\n-            /***/\n-            (function(__unused_webpack_module, exports) {\n-\n-\n-\n-                Object.defineProperty(exports, \"__esModule\", ({\n-                    value: true\n-                }));\n-                exports.QueryStore = void 0;\n-                class QueryStore {\n-                    constructor(key, storage) {\n-                        let maxSize = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null;\n-                        this.key = key;\n-                        this.storage = storage;\n-                        this.maxSize = maxSize;\n-                        this.items = this.fetchAll();\n+                    InsertReplaceEdit.create = create;\n+                    /**\n+                     * Checks whether the given literal conforms to the {@link InsertReplaceEdit} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return candidate && Is.string(candidate.newText) && Range.is(candidate.insert) && Range.is(candidate.replace);\n                     }\n-                    get length() {\n-                        return this.items.length;\n+                    InsertReplaceEdit.is = is;\n+                })(InsertReplaceEdit || (exports.InsertReplaceEdit = InsertReplaceEdit = {}));\n+                /**\n+                 * How whitespace and indentation is handled during completion\n+                 * item insertion.\n+                 *\n+                 * @since 3.16.0\n+                 */\n+                var InsertTextMode;\n+                (function(InsertTextMode) {\n+                    /**\n+                     * The insertion or replace strings is taken as it is. If the\n+                     * value is multi line the lines below the cursor will be\n+                     * inserted using the indentation defined in the string value.\n+                     * The client will not apply any kind of adjustments to the\n+                     * string.\n+                     */\n+                    InsertTextMode.asIs = 1;\n+                    /**\n+                     * The editor adjusts leading whitespace of new lines so that\n+                     * they match the indentation up to the cursor of the line for\n+                     * which the item is accepted.\n+                     *\n+                     * Consider a line like this: <2tabs><cursor><3tabs>foo. Accepting a\n+                     * multi line completion item is indented using 2 tabs and all\n+                     * following lines inserted will be indented using 2 tabs as well.\n+                     */\n+                    InsertTextMode.adjustIndentation = 2;\n+                })(InsertTextMode || (exports.InsertTextMode = InsertTextMode = {}));\n+                var CompletionItemLabelDetails;\n+                (function(CompletionItemLabelDetails) {\n+                    function is(value) {\n+                        var candidate = value;\n+                        return candidate && (Is.string(candidate.detail) || candidate.detail === undefined) && (Is.string(candidate.description) || candidate.description === undefined);\n                     }\n-                    contains(item) {\n-                        return this.items.some(x => x.query === item.query && x.variables === item.variables && x.headers === item.headers && x.operationName === item.operationName);\n+                    CompletionItemLabelDetails.is = is;\n+                })(CompletionItemLabelDetails || (exports.CompletionItemLabelDetails = CompletionItemLabelDetails = {}));\n+                /**\n+                 * The CompletionItem namespace provides functions to deal with\n+                 * completion items.\n+                 */\n+                var CompletionItem;\n+                (function(CompletionItem) {\n+                    /**\n+                     * Create a completion item and seed it with a label.\n+                     * @param label The completion item's label\n+                     */\n+                    function create(label) {\n+                        return {\n+                            label: label\n+                        };\n                     }\n-                    edit(item, index) {\n-                        if (typeof index === 'number' && this.items[index]) {\n-                            const found = this.items[index];\n-                            if (found.query === item.query && found.variables === item.variables && found.headers === item.headers && found.operationName === item.operationName) {\n-                                this.items.splice(index, 1, item);\n-                                this.save();\n-                                return;\n-                            }\n-                        }\n-                        const itemIndex = this.items.findIndex(x => x.query === item.query && x.variables === item.variables && x.headers === item.headers && x.operationName === item.operationName);\n-                        if (itemIndex !== -1) {\n-                            this.items.splice(itemIndex, 1, item);\n-                            this.save();\n-                        }\n+                    CompletionItem.create = create;\n+                })(CompletionItem || (exports.CompletionItem = CompletionItem = {}));\n+                /**\n+                 * The CompletionList namespace provides functions to deal with\n+                 * completion lists.\n+                 */\n+                var CompletionList;\n+                (function(CompletionList) {\n+                    /**\n+                     * Creates a new completion list.\n+                     *\n+                     * @param items The completion items.\n+                     * @param isIncomplete The list is not complete.\n+                     */\n+                    function create(items, isIncomplete) {\n+                        return {\n+                            items: items ? items : [],\n+                            isIncomplete: !!isIncomplete\n+                        };\n                     }\n-                    delete(item) {\n-                        const itemIndex = this.items.findIndex(x => x.query === item.query && x.variables === item.variables && x.headers === item.headers && x.operationName === item.operationName);\n-                        if (itemIndex !== -1) {\n-                            this.items.splice(itemIndex, 1);\n-                            this.save();\n-                        }\n+                    CompletionList.create = create;\n+                })(CompletionList || (exports.CompletionList = CompletionList = {}));\n+                var MarkedString;\n+                (function(MarkedString) {\n+                    /**\n+                     * Creates a marked string from plain text.\n+                     *\n+                     * @param plainText The plain text.\n+                     */\n+                    function fromPlainText(plainText) {\n+                        return plainText.replace(/[\\\\`*_{}[\\]()#+\\-.!]/g, '\\\\$&'); // escape markdown syntax tokens: http://daringfireball.net/projects/markdown/syntax#backslash\n                     }\n-                    fetchRecent() {\n-                        return this.items.at(-1);\n+                    MarkedString.fromPlainText = fromPlainText;\n+                    /**\n+                     * Checks whether the given value conforms to the {@link MarkedString} type.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.string(candidate) || Is.objectLiteral(candidate) && Is.string(candidate.language) && Is.string(candidate.value);\n                     }\n-                    fetchAll() {\n-                        const raw = this.storage.get(this.key);\n-                        if (raw) {\n-                            return JSON.parse(raw)[this.key];\n-                        }\n-                        return [];\n+                    MarkedString.is = is;\n+                })(MarkedString || (exports.MarkedString = MarkedString = {}));\n+                var Hover;\n+                (function(Hover) {\n+                    /**\n+                     * Checks whether the given value conforms to the {@link Hover} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return !!candidate && Is.objectLiteral(candidate) && (MarkupContent.is(candidate.contents) || MarkedString.is(candidate.contents) || Is.typedArray(candidate.contents, MarkedString.is)) && (value.range === undefined || Range.is(value.range));\n                     }\n-                    push(item) {\n-                        const items = [...this.items, item];\n-                        if (this.maxSize && items.length > this.maxSize) {\n-                            items.shift();\n+                    Hover.is = is;\n+                })(Hover || (exports.Hover = Hover = {}));\n+                /**\n+                 * The ParameterInformation namespace provides helper functions to work with\n+                 * {@link ParameterInformation} literals.\n+                 */\n+                var ParameterInformation;\n+                (function(ParameterInformation) {\n+                    /**\n+                     * Creates a new parameter information literal.\n+                     *\n+                     * @param label A label string.\n+                     * @param documentation A doc string.\n+                     */\n+                    function create(label, documentation) {\n+                        return documentation ? {\n+                            label: label,\n+                            documentation: documentation\n+                        } : {\n+                            label: label\n+                        };\n+                    }\n+                    ParameterInformation.create = create;\n+                })(ParameterInformation || (exports.ParameterInformation = ParameterInformation = {}));\n+                /**\n+                 * The SignatureInformation namespace provides helper functions to work with\n+                 * {@link SignatureInformation} literals.\n+                 */\n+                var SignatureInformation;\n+                (function(SignatureInformation) {\n+                    function create(label, documentation) {\n+                        var parameters = [];\n+                        for (var _i = 2; _i < arguments.length; _i++) {\n+                            parameters[_i - 2] = arguments[_i];\n                         }\n-                        for (let attempts = 0; attempts < 5; attempts++) {\n-                            const response = this.storage.set(this.key, JSON.stringify({\n-                                [this.key]: items\n-                            }));\n-                            if (!(response === null || response === void 0 ? void 0 : response.error)) {\n-                                this.items = items;\n-                            } else if (response.isQuotaError && this.maxSize) {\n-                                items.shift();\n-                            } else {\n-                                return;\n-                            }\n+                        var result = {\n+                            label: label\n+                        };\n+                        if (Is.defined(documentation)) {\n+                            result.documentation = documentation;\n                         }\n-                    }\n-                    save() {\n-                        this.storage.set(this.key, JSON.stringify({\n-                            [this.key]: this.items\n-                        }));\n-                    }\n-                }\n-                exports.QueryStore = QueryStore;\n-\n-                /***/\n-            }),\n-\n-        /***/\n-        \"../node_modules/linkify-it/build/index.cjs.js\":\n-            /*!*****************************************************!*\\\n-              !*** ../node_modules/linkify-it/build/index.cjs.js ***!\n-              \\*****************************************************/\n-            /***/\n-            (function(module, __unused_webpack_exports, __webpack_require__) {\n-\n-\n-\n-                var uc_micro = __webpack_require__( /*! uc.micro */ \"../node_modules/uc.micro/build/index.cjs.js\");\n-\n-                function reFactory(opts) {\n-                    const re = {};\n-                    opts = opts || {};\n-                    re.src_Any = uc_micro.Any.source;\n-                    re.src_Cc = uc_micro.Cc.source;\n-                    re.src_Z = uc_micro.Z.source;\n-                    re.src_P = uc_micro.P.source;\n-\n-                    // \\p{\\Z\\P\\Cc\\CF} (white spaces + control + format + punctuation)\n-                    re.src_ZPCc = [re.src_Z, re.src_P, re.src_Cc].join('|');\n-\n-                    // \\p{\\Z\\Cc} (white spaces + control)\n-                    re.src_ZCc = [re.src_Z, re.src_Cc].join('|');\n-\n-                    // Experimental. List of chars, completely prohibited in links\n-                    // because can separate it from other part of text\n-                    const text_separators = '[><\\uff5c]';\n-\n-                    // All possible word characters (everything without punctuation, spaces & controls)\n-                    // Defined via punctuation & spaces to save space\n-                    // Should be something like \\p{\\L\\N\\S\\M} (\\w but without `_`)\n-                    re.src_pseudo_letter = '(?:(?!' + text_separators + '|' + re.src_ZPCc + ')' + re.src_Any + ')';\n-                    // The same as abothe but without [0-9]\n-                    // var src_pseudo_letter_non_d = '(?:(?![0-9]|' + src_ZPCc + ')' + src_Any + ')';\n-\n-                    re.src_ip4 = '(?:(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\\\.){3}(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)';\n-\n-                    // Prohibit any of \"@/[]()\" in user/pass to avoid wrong domain fetch.\n-                    re.src_auth = '(?:(?:(?!' + re.src_ZCc + '|[@/\\\\[\\\\]()]).)+@)?';\n-                    re.src_port = '(?::(?:6(?:[0-4]\\\\d{3}|5(?:[0-4]\\\\d{2}|5(?:[0-2]\\\\d|3[0-5])))|[1-5]?\\\\d{1,4}))?';\n-                    re.src_host_terminator = '(?=$|' + text_separators + '|' + re.src_ZPCc + ')' + '(?!' + (opts['---'] ? '-(?!--)|' : '-|') + '_|:\\\\d|\\\\.-|\\\\.(?!$|' + re.src_ZPCc + '))';\n-                    re.src_path = '(?:' + '[/?#]' + '(?:' + '(?!' + re.src_ZCc + '|' + text_separators + '|[()[\\\\]{}.,\"\\'?!\\\\-;]).|' + '\\\\[(?:(?!' + re.src_ZCc + '|\\\\]).)*\\\\]|' + '\\\\((?:(?!' + re.src_ZCc + '|[)]).)*\\\\)|' + '\\\\{(?:(?!' + re.src_ZCc + '|[}]).)*\\\\}|' + '\\\\\"(?:(?!' + re.src_ZCc + '|[\"]).)+\\\\\"|' + \"\\\\'(?:(?!\" + re.src_ZCc + \"|[']).)+\\\\'|\" +\n-                        // allow `I'm_king` if no pair found\n-                        \"\\\\'(?=\" + re.src_pseudo_letter + '|[-])|' +\n-                        // google has many dots in \"google search\" links (#66, #81).\n-                        // github has ... in commit range links,\n-                        // Restrict to\n-                        // - english\n-                        // - percent-encoded\n-                        // - parts of file path\n-                        // - params separator\n-                        // until more examples found.\n-                        '\\\\.{2,}[a-zA-Z0-9%/&]|' + '\\\\.(?!' + re.src_ZCc + '|[.]|$)|' + (opts['---'] ? '\\\\-(?!--(?:[^-]|$))(?:-*)|' // `---` => long dash, terminate\n-                            :\n-                            '\\\\-+|') +\n-                        // allow `,,,` in paths\n-                        ',(?!' + re.src_ZCc + '|$)|' +\n-                        // allow `;` if not followed by space-like char\n-                        ';(?!' + re.src_ZCc + '|$)|' +\n-                        // allow `!!!` in paths, but not at the end\n-                        '\\\\!+(?!' + re.src_ZCc + '|[!]|$)|' + '\\\\?(?!' + re.src_ZCc + '|[?]|$)' + ')+' + '|\\\\/' + ')?';\n-\n-                    // Allow anything in markdown spec, forbid quote (\") at the first position\n-                    // because emails enclosed in quotes are far more common\n-                    re.src_email_name = '[\\\\-;:&=\\\\+\\\\$,\\\\.a-zA-Z0-9_][\\\\-;:&=\\\\+\\\\$,\\\\\"\\\\.a-zA-Z0-9_]*';\n-                    re.src_xn = 'xn--[a-z0-9\\\\-]{1,59}';\n-\n-                    // More to read about domain names\n-                    // http://serverfault.com/questions/638260/\n-\n-                    re.src_domain_root =\n-                        // Allow letters & digits (http://test1)\n-                        '(?:' + re.src_xn + '|' + re.src_pseudo_letter + '{1,63}' + ')';\n-                    re.src_domain = '(?:' + re.src_xn + '|' + '(?:' + re.src_pseudo_letter + ')' + '|' + '(?:' + re.src_pseudo_letter + '(?:-|' + re.src_pseudo_letter + '){0,61}' + re.src_pseudo_letter + ')' + ')';\n-                    re.src_host = '(?:' +\n-                        // Don't need IP check, because digits are already allowed in normal domain names\n-                        //   src_ip4 +\n-                        // '|' +\n-                        '(?:(?:(?:' + re.src_domain + ')\\\\.)*' + re.src_domain /* _root */ + ')' + ')';\n-                    re.tpl_host_fuzzy = '(?:' + re.src_ip4 + '|' + '(?:(?:(?:' + re.src_domain + ')\\\\.)+(?:%TLDS%))' + ')';\n-                    re.tpl_host_no_ip_fuzzy = '(?:(?:(?:' + re.src_domain + ')\\\\.)+(?:%TLDS%))';\n-                    re.src_host_strict = re.src_host + re.src_host_terminator;\n-                    re.tpl_host_fuzzy_strict = re.tpl_host_fuzzy + re.src_host_terminator;\n-                    re.src_host_port_strict = re.src_host + re.src_port + re.src_host_terminator;\n-                    re.tpl_host_port_fuzzy_strict = re.tpl_host_fuzzy + re.src_port + re.src_host_terminator;\n-                    re.tpl_host_port_no_ip_fuzzy_strict = re.tpl_host_no_ip_fuzzy + re.src_port + re.src_host_terminator;\n-\n-                    //\n-                    // Main rules\n-                    //\n-\n-                    // Rude test fuzzy links by host, for quick deny\n-                    re.tpl_host_fuzzy_test = 'localhost|www\\\\.|\\\\.\\\\d{1,3}\\\\.|(?:\\\\.(?:%TLDS%)(?:' + re.src_ZPCc + '|>|$))';\n-                    re.tpl_email_fuzzy = '(^|' + text_separators + '|\"|\\\\(|' + re.src_ZCc + ')' + '(' + re.src_email_name + '@' + re.tpl_host_fuzzy_strict + ')';\n-                    re.tpl_link_fuzzy =\n-                        // Fuzzy link can't be prepended with .:/\\- and non punctuation.\n-                        // but can start with > (markdown blockquote)\n-                        '(^|(?![.:/\\\\-_@])(?:[$+<=>^`|\\uff5c]|' + re.src_ZPCc + '))' + '((?![$+<=>^`|\\uff5c])' + re.tpl_host_port_fuzzy_strict + re.src_path + ')';\n-                    re.tpl_link_no_ip_fuzzy =\n-                        // Fuzzy link can't be prepended with .:/\\- and non punctuation.\n-                        // but can start with > (markdown blockquote)\n-                        '(^|(?![.:/\\\\-_@])(?:[$+<=>^`|\\uff5c]|' + re.src_ZPCc + '))' + '((?![$+<=>^`|\\uff5c])' + re.tpl_host_port_no_ip_fuzzy_strict + re.src_path + ')';\n-                    return re;\n-                }\n-\n-                //\n-                // Helpers\n-                //\n-\n-                // Merge objects\n-                //\n-                function assign(obj /* from1, from2, from3, ... */ ) {\n-                    const sources = Array.prototype.slice.call(arguments, 1);\n-                    sources.forEach(function(source) {\n-                        if (!source) {\n-                            return;\n+                        if (Is.defined(parameters)) {\n+                            result.parameters = parameters;\n+                        } else {\n+                            result.parameters = [];\n                         }\n-                        Object.keys(source).forEach(function(key) {\n-                            obj[key] = source[key];\n-                        });\n-                    });\n-                    return obj;\n-                }\n-\n-                function _class(obj) {\n-                    return Object.prototype.toString.call(obj);\n-                }\n-\n-                function isString(obj) {\n-                    return _class(obj) === '[object String]';\n-                }\n-\n-                function isObject(obj) {\n-                    return _class(obj) === '[object Object]';\n-                }\n-\n-                function isRegExp(obj) {\n-                    return _class(obj) === '[object RegExp]';\n-                }\n-\n-                function isFunction(obj) {\n-                    return _class(obj) === '[object Function]';\n-                }\n-\n-                function escapeRE(str) {\n-                    return str.replace(/[.?*+^$[\\]\\\\(){}|-]/g, '\\\\$&');\n-                }\n-\n-                //\n-\n-                const defaultOptions = {\n-                    fuzzyLink: true,\n-                    fuzzyEmail: true,\n-                    fuzzyIP: false\n-                };\n-\n-                function isOptionsObj(obj) {\n-                    return Object.keys(obj || {}).reduce(function(acc, k) {\n-                        /* eslint-disable-next-line no-prototype-builtins */\n-                        return acc || defaultOptions.hasOwnProperty(k);\n-                    }, false);\n-                }\n-                const defaultSchemas = {\n-                    'http:': {\n-                        validate: function(text, pos, self) {\n-                            const tail = text.slice(pos);\n-                            if (!self.re.http) {\n-                                // compile lazily, because \"host\"-containing variables can change on tlds update.\n-                                self.re.http = new RegExp('^\\\\/\\\\/' + self.re.src_auth + self.re.src_host_port_strict + self.re.src_path, 'i');\n-                            }\n-                            if (self.re.http.test(tail)) {\n-                                return tail.match(self.re.http)[0].length;\n-                            }\n-                            return 0;\n+                        return result;\n+                    }\n+                    SignatureInformation.create = create;\n+                })(SignatureInformation || (exports.SignatureInformation = SignatureInformation = {}));\n+                /**\n+                 * A document highlight kind.\n+                 */\n+                var DocumentHighlightKind;\n+                (function(DocumentHighlightKind) {\n+                    /**\n+                     * A textual occurrence.\n+                     */\n+                    DocumentHighlightKind.Text = 1;\n+                    /**\n+                     * Read-access of a symbol, like reading a variable.\n+                     */\n+                    DocumentHighlightKind.Read = 2;\n+                    /**\n+                     * Write-access of a symbol, like writing to a variable.\n+                     */\n+                    DocumentHighlightKind.Write = 3;\n+                })(DocumentHighlightKind || (exports.DocumentHighlightKind = DocumentHighlightKind = {}));\n+                /**\n+                 * DocumentHighlight namespace to provide helper functions to work with\n+                 * {@link DocumentHighlight} literals.\n+                 */\n+                var DocumentHighlight;\n+                (function(DocumentHighlight) {\n+                    /**\n+                     * Create a DocumentHighlight object.\n+                     * @param range The range the highlight applies to.\n+                     * @param kind The highlight kind\n+                     */\n+                    function create(range, kind) {\n+                        var result = {\n+                            range: range\n+                        };\n+                        if (Is.number(kind)) {\n+                            result.kind = kind;\n                         }\n-                    },\n-                    'https:': 'http:',\n-                    'ftp:': 'http:',\n-                    '//': {\n-                        validate: function(text, pos, self) {\n-                            const tail = text.slice(pos);\n-                            if (!self.re.no_http) {\n-                                // compile lazily, because \"host\"-containing variables can change on tlds update.\n-                                self.re.no_http = new RegExp('^' + self.re.src_auth +\n-                                    // Don't allow single-level domains, because of false positives like '//test'\n-                                    // with code comments\n-                                    '(?:localhost|(?:(?:' + self.re.src_domain + ')\\\\.)+' + self.re.src_domain_root + ')' + self.re.src_port + self.re.src_host_terminator + self.re.src_path, 'i');\n-                            }\n-                            if (self.re.no_http.test(tail)) {\n-                                // should not be `://` & `///`, that protects from errors in protocol name\n-                                if (pos >= 3 && text[pos - 3] === ':') {\n-                                    return 0;\n-                                }\n-                                if (pos >= 3 && text[pos - 3] === '/') {\n-                                    return 0;\n-                                }\n-                                return tail.match(self.re.no_http)[0].length;\n+                        return result;\n+                    }\n+                    DocumentHighlight.create = create;\n+                })(DocumentHighlight || (exports.DocumentHighlight = DocumentHighlight = {}));\n+                /**\n+                 * A symbol kind.\n+                 */\n+                var SymbolKind;\n+                (function(SymbolKind) {\n+                    SymbolKind.File = 1;\n+                    SymbolKind.Module = 2;\n+                    SymbolKind.Namespace = 3;\n+                    SymbolKind.Package = 4;\n+                    SymbolKind.Class = 5;\n+                    SymbolKind.Method = 6;\n+                    SymbolKind.Property = 7;\n+                    SymbolKind.Field = 8;\n+                    SymbolKind.Constructor = 9;\n+                    SymbolKind.Enum = 10;\n+                    SymbolKind.Interface = 11;\n+                    SymbolKind.Function = 12;\n+                    SymbolKind.Variable = 13;\n+                    SymbolKind.Constant = 14;\n+                    SymbolKind.String = 15;\n+                    SymbolKind.Number = 16;\n+                    SymbolKind.Boolean = 17;\n+                    SymbolKind.Array = 18;\n+                    SymbolKind.Object = 19;\n+                    SymbolKind.Key = 20;\n+                    SymbolKind.Null = 21;\n+                    SymbolKind.EnumMember = 22;\n+                    SymbolKind.Struct = 23;\n+                    SymbolKind.Event = 24;\n+                    SymbolKind.Operator = 25;\n+                    SymbolKind.TypeParameter = 26;\n+                })(SymbolKind || (exports.SymbolKind = SymbolKind = {}));\n+                /**\n+                 * Symbol tags are extra annotations that tweak the rendering of a symbol.\n+                 *\n+                 * @since 3.16\n+                 */\n+                var SymbolTag;\n+                (function(SymbolTag) {\n+                    /**\n+                     * Render a symbol as obsolete, usually using a strike-out.\n+                     */\n+                    SymbolTag.Deprecated = 1;\n+                })(SymbolTag || (exports.SymbolTag = SymbolTag = {}));\n+                var SymbolInformation;\n+                (function(SymbolInformation) {\n+                    /**\n+                     * Creates a new symbol information literal.\n+                     *\n+                     * @param name The name of the symbol.\n+                     * @param kind The kind of the symbol.\n+                     * @param range The range of the location of the symbol.\n+                     * @param uri The resource of the location of symbol.\n+                     * @param containerName The name of the symbol containing the symbol.\n+                     */\n+                    function create(name, kind, range, uri, containerName) {\n+                        var result = {\n+                            name: name,\n+                            kind: kind,\n+                            location: {\n+                                uri: uri,\n+                                range: range\n                             }\n-                            return 0;\n+                        };\n+                        if (containerName) {\n+                            result.containerName = containerName;\n                         }\n-                    },\n-                    'mailto:': {\n-                        validate: function(text, pos, self) {\n-                            const tail = text.slice(pos);\n-                            if (!self.re.mailto) {\n-                                self.re.mailto = new RegExp('^' + self.re.src_email_name + '@' + self.re.src_host_strict, 'i');\n+                        return result;\n+                    }\n+                    SymbolInformation.create = create;\n+                })(SymbolInformation || (exports.SymbolInformation = SymbolInformation = {}));\n+                var WorkspaceSymbol;\n+                (function(WorkspaceSymbol) {\n+                    /**\n+                     * Create a new workspace symbol.\n+                     *\n+                     * @param name The name of the symbol.\n+                     * @param kind The kind of the symbol.\n+                     * @param uri The resource of the location of the symbol.\n+                     * @param range An options range of the location.\n+                     * @returns A WorkspaceSymbol.\n+                     */\n+                    function create(name, kind, uri, range) {\n+                        return range !== undefined ? {\n+                            name: name,\n+                            kind: kind,\n+                            location: {\n+                                uri: uri,\n+                                range: range\n                             }\n-                            if (self.re.mailto.test(tail)) {\n-                                return tail.match(self.re.mailto)[0].length;\n+                        } : {\n+                            name: name,\n+                            kind: kind,\n+                            location: {\n+                                uri: uri\n                             }\n-                            return 0;\n-                        }\n+                        };\n                     }\n-                };\n-\n-                // RE pattern for 2-character tlds (autogenerated by ./support/tlds_2char_gen.js)\n-                /* eslint-disable-next-line max-len */\n-                const tlds_2ch_src_re = 'a[cdefgilmnoqrstuwxz]|b[abdefghijmnorstvwyz]|c[acdfghiklmnoruvwxyz]|d[ejkmoz]|e[cegrstu]|f[ijkmor]|g[abdefghilmnpqrstuwy]|h[kmnrtu]|i[delmnoqrst]|j[emop]|k[eghimnprwyz]|l[abcikrstuvy]|m[acdeghklmnopqrstuvwxyz]|n[acefgilopruz]|om|p[aefghklmnrstwy]|qa|r[eosuw]|s[abcdeghijklmnortuvxyz]|t[cdfghjklmnortvwz]|u[agksyz]|v[aceginu]|w[fs]|y[et]|z[amw]';\n-\n-                // DON'T try to make PRs with changes. Extend TLDs with LinkifyIt.tlds() instead\n-                const tlds_default = 'biz|com|edu|gov|net|org|pro|web|xxx|aero|asia|coop|info|museum|name|shop|\u0440\u0444'.split('|');\n-\n-                function resetScanCache(self) {\n-                    self.__index__ = -1;\n-                    self.__text_cache__ = '';\n-                }\n-\n-                function createValidator(re) {\n-                    return function(text, pos) {\n-                        const tail = text.slice(pos);\n-                        if (re.test(tail)) {\n-                            return tail.match(re)[0].length;\n+                    WorkspaceSymbol.create = create;\n+                })(WorkspaceSymbol || (exports.WorkspaceSymbol = WorkspaceSymbol = {}));\n+                var DocumentSymbol;\n+                (function(DocumentSymbol) {\n+                    /**\n+                     * Creates a new symbol information literal.\n+                     *\n+                     * @param name The name of the symbol.\n+                     * @param detail The detail of the symbol.\n+                     * @param kind The kind of the symbol.\n+                     * @param range The range of the symbol.\n+                     * @param selectionRange The selectionRange of the symbol.\n+                     * @param children Children of the symbol.\n+                     */\n+                    function create(name, detail, kind, range, selectionRange, children) {\n+                        var result = {\n+                            name: name,\n+                            detail: detail,\n+                            kind: kind,\n+                            range: range,\n+                            selectionRange: selectionRange\n+                        };\n+                        if (children !== undefined) {\n+                            result.children = children;\n                         }\n-                        return 0;\n-                    };\n-                }\n-\n-                function createNormalizer() {\n-                    return function(match, self) {\n-                        self.normalize(match);\n-                    };\n-                }\n-\n-                // Schemas compiler. Build regexps.\n-                //\n-                function compile(self) {\n-                    // Load & clone RE patterns.\n-                    const re = self.re = reFactory(self.__opts__);\n-\n-                    // Define dynamic patterns\n-                    const tlds = self.__tlds__.slice();\n-                    self.onCompile();\n-                    if (!self.__tlds_replaced__) {\n-                        tlds.push(tlds_2ch_src_re);\n-                    }\n-                    tlds.push(re.src_xn);\n-                    re.src_tlds = tlds.join('|');\n-\n-                    function untpl(tpl) {\n-                        return tpl.replace('%TLDS%', re.src_tlds);\n+                        return result;\n                     }\n-                    re.email_fuzzy = RegExp(untpl(re.tpl_email_fuzzy), 'i');\n-                    re.link_fuzzy = RegExp(untpl(re.tpl_link_fuzzy), 'i');\n-                    re.link_no_ip_fuzzy = RegExp(untpl(re.tpl_link_no_ip_fuzzy), 'i');\n-                    re.host_fuzzy_test = RegExp(untpl(re.tpl_host_fuzzy_test), 'i');\n-\n-                    //\n-                    // Compile each schema\n-                    //\n-\n-                    const aliases = [];\n-                    self.__compiled__ = {}; // Reset compiled data\n-\n-                    function schemaError(name, val) {\n-                        throw new Error('(LinkifyIt) Invalid schema \"' + name + '\": ' + val);\n+                    DocumentSymbol.create = create;\n+                    /**\n+                     * Checks whether the given literal conforms to the {@link DocumentSymbol} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return candidate && Is.string(candidate.name) && Is.number(candidate.kind) && Range.is(candidate.range) && Range.is(candidate.selectionRange) && (candidate.detail === undefined || Is.string(candidate.detail)) && (candidate.deprecated === undefined || Is.boolean(candidate.deprecated)) && (candidate.children === undefined || Array.isArray(candidate.children)) && (candidate.tags === undefined || Array.isArray(candidate.tags));\n                     }\n-                    Object.keys(self.__schemas__).forEach(function(name) {\n-                        const val = self.__schemas__[name];\n-\n-                        // skip disabled methods\n-                        if (val === null) {\n-                            return;\n-                        }\n-                        const compiled = {\n-                            validate: null,\n-                            link: null\n-                        };\n-                        self.__compiled__[name] = compiled;\n-                        if (isObject(val)) {\n-                            if (isRegExp(val.validate)) {\n-                                compiled.validate = createValidator(val.validate);\n-                            } else if (isFunction(val.validate)) {\n-                                compiled.validate = val.validate;\n-                            } else {\n-                                schemaError(name, val);\n-                            }\n-                            if (isFunction(val.normalize)) {\n-                                compiled.normalize = val.normalize;\n-                            } else if (!val.normalize) {\n-                                compiled.normalize = createNormalizer();\n-                            } else {\n-                                schemaError(name, val);\n-                            }\n-                            return;\n-                        }\n-                        if (isString(val)) {\n-                            aliases.push(name);\n-                            return;\n-                        }\n-                        schemaError(name, val);\n-                    });\n-\n-                    //\n-                    // Compile postponed aliases\n-                    //\n-\n-                    aliases.forEach(function(alias) {\n-                        if (!self.__compiled__[self.__schemas__[alias]]) {\n-                            // Silently fail on missed schemas to avoid errons on disable.\n-                            // schemaError(alias, self.__schemas__[alias]);\n-                            return;\n-                        }\n-                        self.__compiled__[alias].validate = self.__compiled__[self.__schemas__[alias]].validate;\n-                        self.__compiled__[alias].normalize = self.__compiled__[self.__schemas__[alias]].normalize;\n-                    });\n-\n-                    //\n-                    // Fake record for guessed links\n-                    //\n-                    self.__compiled__[''] = {\n-                        validate: null,\n-                        normalize: createNormalizer()\n-                    };\n-\n-                    //\n-                    // Build schema condition\n-                    //\n-                    const slist = Object.keys(self.__compiled__).filter(function(name) {\n-                        // Filter disabled & fake schemas\n-                        return name.length > 0 && self.__compiled__[name];\n-                    }).map(escapeRE).join('|');\n-                    // (?!_) cause 1.5x slowdown\n-                    self.re.schema_test = RegExp('(^|(?!_)(?:[><\\uff5c]|' + re.src_ZPCc + '))(' + slist + ')', 'i');\n-                    self.re.schema_search = RegExp('(^|(?!_)(?:[><\\uff5c]|' + re.src_ZPCc + '))(' + slist + ')', 'ig');\n-                    self.re.schema_at_start = RegExp('^' + self.re.schema_search.source, 'i');\n-                    self.re.pretest = RegExp('(' + self.re.schema_test.source + ')|(' + self.re.host_fuzzy_test.source + ')|@', 'i');\n-\n-                    //\n-                    // Cleanup\n-                    //\n-\n-                    resetScanCache(self);\n-                }\n-\n+                    DocumentSymbol.is = is;\n+                })(DocumentSymbol || (exports.DocumentSymbol = DocumentSymbol = {}));\n                 /**\n-                 * class Match\n-                 *\n-                 * Match result. Single element of array, returned by [[LinkifyIt#match]]\n-                 **/\n-                function Match(self, shift) {\n-                    const start = self.__index__;\n-                    const end = self.__last_index__;\n-                    const text = self.__text_cache__.slice(start, end);\n-\n+                 * A set of predefined code action kinds\n+                 */\n+                var CodeActionKind;\n+                (function(CodeActionKind) {\n                     /**\n-                     * Match#schema -> String\n+                     * Empty kind.\n+                     */\n+                    CodeActionKind.Empty = '';\n+                    /**\n+                     * Base kind for quickfix actions: 'quickfix'\n+                     */\n+                    CodeActionKind.QuickFix = 'quickfix';\n+                    /**\n+                     * Base kind for refactoring actions: 'refactor'\n+                     */\n+                    CodeActionKind.Refactor = 'refactor';\n+                    /**\n+                     * Base kind for refactoring extraction actions: 'refactor.extract'\n                      *\n-                     * Prefix (protocol) for matched string.\n-                     **/\n-                    this.schema = self.__schema__.toLowerCase();\n+                     * Example extract actions:\n+                     *\n+                     * - Extract method\n+                     * - Extract function\n+                     * - Extract variable\n+                     * - Extract interface from class\n+                     * - ...\n+                     */\n+                    CodeActionKind.RefactorExtract = 'refactor.extract';\n                     /**\n-                     * Match#index -> Number\n+                     * Base kind for refactoring inline actions: 'refactor.inline'\n                      *\n-                     * First position of matched string.\n-                     **/\n-                    this.index = start + shift;\n+                     * Example inline actions:\n+                     *\n+                     * - Inline function\n+                     * - Inline variable\n+                     * - Inline constant\n+                     * - ...\n+                     */\n+                    CodeActionKind.RefactorInline = 'refactor.inline';\n                     /**\n-                     * Match#lastIndex -> Number\n+                     * Base kind for refactoring rewrite actions: 'refactor.rewrite'\n                      *\n-                     * Next position after matched string.\n-                     **/\n-                    this.lastIndex = end + shift;\n+                     * Example rewrite actions:\n+                     *\n+                     * - Convert JavaScript function to class\n+                     * - Add or remove parameter\n+                     * - Encapsulate field\n+                     * - Make method static\n+                     * - Move method to base class\n+                     * - ...\n+                     */\n+                    CodeActionKind.RefactorRewrite = 'refactor.rewrite';\n                     /**\n-                     * Match#raw -> String\n+                     * Base kind for source actions: `source`\n                      *\n-                     * Matched string.\n-                     **/\n-                    this.raw = text;\n+                     * Source code actions apply to the entire file.\n+                     */\n+                    CodeActionKind.Source = 'source';\n                     /**\n-                     * Match#text -> String\n+                     * Base kind for an organize imports source action: `source.organizeImports`\n+                     */\n+                    CodeActionKind.SourceOrganizeImports = 'source.organizeImports';\n+                    /**\n+                     * Base kind for auto-fix source actions: `source.fixAll`.\n                      *\n-                     * Notmalized text of matched string.\n-                     **/\n-                    this.text = text;\n+                     * Fix all actions automatically fix errors that have a clear fix that do not require user input.\n+                     * They should not suppress errors or perform unsafe fixes such as generating new types or classes.\n+                     *\n+                     * @since 3.15.0\n+                     */\n+                    CodeActionKind.SourceFixAll = 'source.fixAll';\n+                })(CodeActionKind || (exports.CodeActionKind = CodeActionKind = {}));\n+                /**\n+                 * The reason why code actions were requested.\n+                 *\n+                 * @since 3.17.0\n+                 */\n+                var CodeActionTriggerKind;\n+                (function(CodeActionTriggerKind) {\n                     /**\n-                     * Match#url -> String\n+                     * Code actions were explicitly requested by the user or by an extension.\n+                     */\n+                    CodeActionTriggerKind.Invoked = 1;\n+                    /**\n+                     * Code actions were requested automatically.\n                      *\n-                     * Normalized url of matched string.\n-                     **/\n-                    this.url = text;\n-                }\n-\n-                function createMatch(self, shift) {\n-                    const match = new Match(self, shift);\n-                    self.__compiled__[match.schema].normalize(match, self);\n-                    return match;\n-                }\n+                     * This typically happens when current selection in a file changes, but can\n+                     * also be triggered when file content changes.\n+                     */\n+                    CodeActionTriggerKind.Automatic = 2;\n+                })(CodeActionTriggerKind || (exports.CodeActionTriggerKind = CodeActionTriggerKind = {}));\n+                /**\n+                 * The CodeActionContext namespace provides helper functions to work with\n+                 * {@link CodeActionContext} literals.\n+                 */\n+                var CodeActionContext;\n+                (function(CodeActionContext) {\n+                    /**\n+                     * Creates a new CodeActionContext literal.\n+                     */\n+                    function create(diagnostics, only, triggerKind) {\n+                        var result = {\n+                            diagnostics: diagnostics\n+                        };\n+                        if (only !== undefined && only !== null) {\n+                            result.only = only;\n+                        }\n+                        if (triggerKind !== undefined && triggerKind !== null) {\n+                            result.triggerKind = triggerKind;\n+                        }\n+                        return result;\n+                    }\n+                    CodeActionContext.create = create;\n+                    /**\n+                     * Checks whether the given literal conforms to the {@link CodeActionContext} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.defined(candidate) && Is.typedArray(candidate.diagnostics, Diagnostic.is) && (candidate.only === undefined || Is.typedArray(candidate.only, Is.string)) && (candidate.triggerKind === undefined || candidate.triggerKind === CodeActionTriggerKind.Invoked || candidate.triggerKind === CodeActionTriggerKind.Automatic);\n+                    }\n+                    CodeActionContext.is = is;\n+                })(CodeActionContext || (exports.CodeActionContext = CodeActionContext = {}));\n+                var CodeAction;\n+                (function(CodeAction) {\n+                    function create(title, kindOrCommandOrEdit, kind) {\n+                        var result = {\n+                            title: title\n+                        };\n+                        var checkKind = true;\n+                        if (typeof kindOrCommandOrEdit === 'string') {\n+                            checkKind = false;\n+                            result.kind = kindOrCommandOrEdit;\n+                        } else if (Command.is(kindOrCommandOrEdit)) {\n+                            result.command = kindOrCommandOrEdit;\n+                        } else {\n+                            result.edit = kindOrCommandOrEdit;\n+                        }\n+                        if (checkKind && kind !== undefined) {\n+                            result.kind = kind;\n+                        }\n+                        return result;\n+                    }\n+                    CodeAction.create = create;\n \n+                    function is(value) {\n+                        var candidate = value;\n+                        return candidate && Is.string(candidate.title) && (candidate.diagnostics === undefined || Is.typedArray(candidate.diagnostics, Diagnostic.is)) && (candidate.kind === undefined || Is.string(candidate.kind)) && (candidate.edit !== undefined || candidate.command !== undefined) && (candidate.command === undefined || Command.is(candidate.command)) && (candidate.isPreferred === undefined || Is.boolean(candidate.isPreferred)) && (candidate.edit === undefined || WorkspaceEdit.is(candidate.edit));\n+                    }\n+                    CodeAction.is = is;\n+                })(CodeAction || (exports.CodeAction = CodeAction = {}));\n                 /**\n-                 * class LinkifyIt\n-                 **/\n+                 * The CodeLens namespace provides helper functions to work with\n+                 * {@link CodeLens} literals.\n+                 */\n+                var CodeLens;\n+                (function(CodeLens) {\n+                    /**\n+                     * Creates a new CodeLens literal.\n+                     */\n+                    function create(range, data) {\n+                        var result = {\n+                            range: range\n+                        };\n+                        if (Is.defined(data)) {\n+                            result.data = data;\n+                        }\n+                        return result;\n+                    }\n+                    CodeLens.create = create;\n+                    /**\n+                     * Checks whether the given literal conforms to the {@link CodeLens} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.defined(candidate) && Range.is(candidate.range) && (Is.undefined(candidate.command) || Command.is(candidate.command));\n+                    }\n+                    CodeLens.is = is;\n+                })(CodeLens || (exports.CodeLens = CodeLens = {}));\n+                /**\n+                 * The FormattingOptions namespace provides helper functions to work with\n+                 * {@link FormattingOptions} literals.\n+                 */\n+                var FormattingOptions;\n+                (function(FormattingOptions) {\n+                    /**\n+                     * Creates a new FormattingOptions literal.\n+                     */\n+                    function create(tabSize, insertSpaces) {\n+                        return {\n+                            tabSize: tabSize,\n+                            insertSpaces: insertSpaces\n+                        };\n+                    }\n+                    FormattingOptions.create = create;\n+                    /**\n+                     * Checks whether the given literal conforms to the {@link FormattingOptions} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.defined(candidate) && Is.uinteger(candidate.tabSize) && Is.boolean(candidate.insertSpaces);\n+                    }\n+                    FormattingOptions.is = is;\n+                })(FormattingOptions || (exports.FormattingOptions = FormattingOptions = {}));\n+                /**\n+                 * The DocumentLink namespace provides helper functions to work with\n+                 * {@link DocumentLink} literals.\n+                 */\n+                var DocumentLink;\n+                (function(DocumentLink) {\n+                    /**\n+                     * Creates a new DocumentLink literal.\n+                     */\n+                    function create(range, target, data) {\n+                        return {\n+                            range: range,\n+                            target: target,\n+                            data: data\n+                        };\n+                    }\n+                    DocumentLink.create = create;\n+                    /**\n+                     * Checks whether the given literal conforms to the {@link DocumentLink} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.defined(candidate) && Range.is(candidate.range) && (Is.undefined(candidate.target) || Is.string(candidate.target));\n+                    }\n+                    DocumentLink.is = is;\n+                })(DocumentLink || (exports.DocumentLink = DocumentLink = {}));\n+                /**\n+                 * The SelectionRange namespace provides helper function to work with\n+                 * SelectionRange literals.\n+                 */\n+                var SelectionRange;\n+                (function(SelectionRange) {\n+                    /**\n+                     * Creates a new SelectionRange\n+                     * @param range the range.\n+                     * @param parent an optional parent.\n+                     */\n+                    function create(range, parent) {\n+                        return {\n+                            range: range,\n+                            parent: parent\n+                        };\n+                    }\n+                    SelectionRange.create = create;\n \n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.objectLiteral(candidate) && Range.is(candidate.range) && (candidate.parent === undefined || SelectionRange.is(candidate.parent));\n+                    }\n+                    SelectionRange.is = is;\n+                })(SelectionRange || (exports.SelectionRange = SelectionRange = {}));\n                 /**\n-                 * new LinkifyIt(schemas, options)\n-                 * - schemas (Object): Optional. Additional schemas to validate (prefix/validator)\n-                 * - options (Object): { fuzzyLink|fuzzyEmail|fuzzyIP: true|false }\n-                 *\n-                 * Creates new linkifier instance with optional additional schemas.\n-                 * Can be called without `new` keyword for convenience.\n-                 *\n-                 * By default understands:\n+                 * A set of predefined token types. This set is not fixed\n+                 * an clients can specify additional token types via the\n+                 * corresponding client capabilities.\n                  *\n-                 * - `http(s)://...` , `ftp://...`, `mailto:...` & `//...` links\n-                 * - \"fuzzy\" links and emails (example.com, foo@bar.com).\n+                 * @since 3.16.0\n+                 */\n+                var SemanticTokenTypes;\n+                (function(SemanticTokenTypes) {\n+                    SemanticTokenTypes[\"namespace\"] = \"namespace\";\n+                    /**\n+                     * Represents a generic type. Acts as a fallback for types which can't be mapped to\n+                     * a specific type like class or enum.\n+                     */\n+                    SemanticTokenTypes[\"type\"] = \"type\";\n+                    SemanticTokenTypes[\"class\"] = \"class\";\n+                    SemanticTokenTypes[\"enum\"] = \"enum\";\n+                    SemanticTokenTypes[\"interface\"] = \"interface\";\n+                    SemanticTokenTypes[\"struct\"] = \"struct\";\n+                    SemanticTokenTypes[\"typeParameter\"] = \"typeParameter\";\n+                    SemanticTokenTypes[\"parameter\"] = \"parameter\";\n+                    SemanticTokenTypes[\"variable\"] = \"variable\";\n+                    SemanticTokenTypes[\"property\"] = \"property\";\n+                    SemanticTokenTypes[\"enumMember\"] = \"enumMember\";\n+                    SemanticTokenTypes[\"event\"] = \"event\";\n+                    SemanticTokenTypes[\"function\"] = \"function\";\n+                    SemanticTokenTypes[\"method\"] = \"method\";\n+                    SemanticTokenTypes[\"macro\"] = \"macro\";\n+                    SemanticTokenTypes[\"keyword\"] = \"keyword\";\n+                    SemanticTokenTypes[\"modifier\"] = \"modifier\";\n+                    SemanticTokenTypes[\"comment\"] = \"comment\";\n+                    SemanticTokenTypes[\"string\"] = \"string\";\n+                    SemanticTokenTypes[\"number\"] = \"number\";\n+                    SemanticTokenTypes[\"regexp\"] = \"regexp\";\n+                    SemanticTokenTypes[\"operator\"] = \"operator\";\n+                    /**\n+                     * @since 3.17.0\n+                     */\n+                    SemanticTokenTypes[\"decorator\"] = \"decorator\";\n+                })(SemanticTokenTypes || (exports.SemanticTokenTypes = SemanticTokenTypes = {}));\n+                /**\n+                 * A set of predefined token modifiers. This set is not fixed\n+                 * an clients can specify additional token types via the\n+                 * corresponding client capabilities.\n                  *\n-                 * `schemas` is an object, where each key/value describes protocol/rule:\n+                 * @since 3.16.0\n+                 */\n+                var SemanticTokenModifiers;\n+                (function(SemanticTokenModifiers) {\n+                    SemanticTokenModifiers[\"declaration\"] = \"declaration\";\n+                    SemanticTokenModifiers[\"definition\"] = \"definition\";\n+                    SemanticTokenModifiers[\"readonly\"] = \"readonly\";\n+                    SemanticTokenModifiers[\"static\"] = \"static\";\n+                    SemanticTokenModifiers[\"deprecated\"] = \"deprecated\";\n+                    SemanticTokenModifiers[\"abstract\"] = \"abstract\";\n+                    SemanticTokenModifiers[\"async\"] = \"async\";\n+                    SemanticTokenModifiers[\"modification\"] = \"modification\";\n+                    SemanticTokenModifiers[\"documentation\"] = \"documentation\";\n+                    SemanticTokenModifiers[\"defaultLibrary\"] = \"defaultLibrary\";\n+                })(SemanticTokenModifiers || (exports.SemanticTokenModifiers = SemanticTokenModifiers = {}));\n+                /**\n+                 * @since 3.16.0\n+                 */\n+                var SemanticTokens;\n+                (function(SemanticTokens) {\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.objectLiteral(candidate) && (candidate.resultId === undefined || typeof candidate.resultId === 'string') && Array.isArray(candidate.data) && (candidate.data.length === 0 || typeof candidate.data[0] === 'number');\n+                    }\n+                    SemanticTokens.is = is;\n+                })(SemanticTokens || (exports.SemanticTokens = SemanticTokens = {}));\n+                /**\n+                 * The InlineValueText namespace provides functions to deal with InlineValueTexts.\n                  *\n-                 * - __key__ - link prefix (usually, protocol name with `:` at the end, `skype:`\n-                 *   for example). `linkify-it` makes shure that prefix is not preceeded with\n-                 *   alphanumeric char and symbols. Only whitespaces and punctuation allowed.\n-                 * - __value__ - rule to check tail after link prefix\n-                 *   - _String_ - just alias to existing rule\n-                 *   - _Object_\n-                 *     - _validate_ - validator function (should return matched length on success),\n-                 *       or `RegExp`.\n-                 *     - _normalize_ - optional function to normalize text & url of matched result\n-                 *       (for example, for @twitter mentions).\n+                 * @since 3.17.0\n+                 */\n+                var InlineValueText;\n+                (function(InlineValueText) {\n+                    /**\n+                     * Creates a new InlineValueText literal.\n+                     */\n+                    function create(range, text) {\n+                        return {\n+                            range: range,\n+                            text: text\n+                        };\n+                    }\n+                    InlineValueText.create = create;\n+\n+                    function is(value) {\n+                        var candidate = value;\n+                        return candidate !== undefined && candidate !== null && Range.is(candidate.range) && Is.string(candidate.text);\n+                    }\n+                    InlineValueText.is = is;\n+                })(InlineValueText || (exports.InlineValueText = InlineValueText = {}));\n+                /**\n+                 * The InlineValueVariableLookup namespace provides functions to deal with InlineValueVariableLookups.\n                  *\n-                 * `options`:\n+                 * @since 3.17.0\n+                 */\n+                var InlineValueVariableLookup;\n+                (function(InlineValueVariableLookup) {\n+                    /**\n+                     * Creates a new InlineValueText literal.\n+                     */\n+                    function create(range, variableName, caseSensitiveLookup) {\n+                        return {\n+                            range: range,\n+                            variableName: variableName,\n+                            caseSensitiveLookup: caseSensitiveLookup\n+                        };\n+                    }\n+                    InlineValueVariableLookup.create = create;\n+\n+                    function is(value) {\n+                        var candidate = value;\n+                        return candidate !== undefined && candidate !== null && Range.is(candidate.range) && Is.boolean(candidate.caseSensitiveLookup) && (Is.string(candidate.variableName) || candidate.variableName === undefined);\n+                    }\n+                    InlineValueVariableLookup.is = is;\n+                })(InlineValueVariableLookup || (exports.InlineValueVariableLookup = InlineValueVariableLookup = {}));\n+                /**\n+                 * The InlineValueEvaluatableExpression namespace provides functions to deal with InlineValueEvaluatableExpression.\n                  *\n-                 * - __fuzzyLink__ - recognige URL-s without `http(s):` prefix. Default `true`.\n-                 * - __fuzzyIP__ - allow IPs in fuzzy links above. Can conflict with some texts\n-                 *   like version numbers. Default `false`.\n-                 * - __fuzzyEmail__ - recognize emails without `mailto:` prefix.\n+                 * @since 3.17.0\n+                 */\n+                var InlineValueEvaluatableExpression;\n+                (function(InlineValueEvaluatableExpression) {\n+                    /**\n+                     * Creates a new InlineValueEvaluatableExpression literal.\n+                     */\n+                    function create(range, expression) {\n+                        return {\n+                            range: range,\n+                            expression: expression\n+                        };\n+                    }\n+                    InlineValueEvaluatableExpression.create = create;\n+\n+                    function is(value) {\n+                        var candidate = value;\n+                        return candidate !== undefined && candidate !== null && Range.is(candidate.range) && (Is.string(candidate.expression) || candidate.expression === undefined);\n+                    }\n+                    InlineValueEvaluatableExpression.is = is;\n+                })(InlineValueEvaluatableExpression || (exports.InlineValueEvaluatableExpression = InlineValueEvaluatableExpression = {}));\n+                /**\n+                 * The InlineValueContext namespace provides helper functions to work with\n+                 * {@link InlineValueContext} literals.\n                  *\n-                 **/\n-                function LinkifyIt(schemas, options) {\n-                    if (!(this instanceof LinkifyIt)) {\n-                        return new LinkifyIt(schemas, options);\n+                 * @since 3.17.0\n+                 */\n+                var InlineValueContext;\n+                (function(InlineValueContext) {\n+                    /**\n+                     * Creates a new InlineValueContext literal.\n+                     */\n+                    function create(frameId, stoppedLocation) {\n+                        return {\n+                            frameId: frameId,\n+                            stoppedLocation: stoppedLocation\n+                        };\n                     }\n-                    if (!options) {\n-                        if (isOptionsObj(schemas)) {\n-                            options = schemas;\n-                            schemas = {};\n-                        }\n+                    InlineValueContext.create = create;\n+                    /**\n+                     * Checks whether the given literal conforms to the {@link InlineValueContext} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.defined(candidate) && Range.is(value.stoppedLocation);\n                     }\n-                    this.__opts__ = assign({}, defaultOptions, options);\n-\n-                    // Cache last tested result. Used to skip repeating steps on next `match` call.\n-                    this.__index__ = -1;\n-                    this.__last_index__ = -1; // Next scan position\n-                    this.__schema__ = '';\n-                    this.__text_cache__ = '';\n-                    this.__schemas__ = assign({}, defaultSchemas, schemas);\n-                    this.__compiled__ = {};\n-                    this.__tlds__ = tlds_default;\n-                    this.__tlds_replaced__ = false;\n-                    this.re = {};\n-                    compile(this);\n-                }\n-\n-                /** chainable\n-                 * LinkifyIt#add(schema, definition)\n-                 * - schema (String): rule name (fixed pattern prefix)\n-                 * - definition (String|RegExp|Object): schema definition\n+                    InlineValueContext.is = is;\n+                })(InlineValueContext || (exports.InlineValueContext = InlineValueContext = {}));\n+                /**\n+                 * Inlay hint kinds.\n                  *\n-                 * Add new rule definition. See constructor description for details.\n-                 **/\n-                LinkifyIt.prototype.add = function add(schema, definition) {\n-                    this.__schemas__[schema] = definition;\n-                    compile(this);\n-                    return this;\n-                };\n+                 * @since 3.17.0\n+                 */\n+                var InlayHintKind;\n+                (function(InlayHintKind) {\n+                    /**\n+                     * An inlay hint that for a type annotation.\n+                     */\n+                    InlayHintKind.Type = 1;\n+                    /**\n+                     * An inlay hint that is for a parameter.\n+                     */\n+                    InlayHintKind.Parameter = 2;\n \n-                /** chainable\n-                 * LinkifyIt#set(options)\n-                 * - options (Object): { fuzzyLink|fuzzyEmail|fuzzyIP: true|false }\n-                 *\n-                 * Set recognition options for links without schema.\n-                 **/\n-                LinkifyIt.prototype.set = function set(options) {\n-                    this.__opts__ = assign(this.__opts__, options);\n-                    return this;\n-                };\n+                    function is(value) {\n+                        return value === 1 || value === 2;\n+                    }\n+                    InlayHintKind.is = is;\n+                })(InlayHintKind || (exports.InlayHintKind = InlayHintKind = {}));\n+                var InlayHintLabelPart;\n+                (function(InlayHintLabelPart) {\n+                    function create(value) {\n+                        return {\n+                            value: value\n+                        };\n+                    }\n+                    InlayHintLabelPart.create = create;\n+\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.objectLiteral(candidate) && (candidate.tooltip === undefined || Is.string(candidate.tooltip) || MarkupContent.is(candidate.tooltip)) && (candidate.location === undefined || Location.is(candidate.location)) && (candidate.command === undefined || Command.is(candidate.command));\n+                    }\n+                    InlayHintLabelPart.is = is;\n+                })(InlayHintLabelPart || (exports.InlayHintLabelPart = InlayHintLabelPart = {}));\n+                var InlayHint;\n+                (function(InlayHint) {\n+                    function create(position, label, kind) {\n+                        var result = {\n+                            position: position,\n+                            label: label\n+                        };\n+                        if (kind !== undefined) {\n+                            result.kind = kind;\n+                        }\n+                        return result;\n+                    }\n+                    InlayHint.create = create;\n \n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.objectLiteral(candidate) && Position.is(candidate.position) && (Is.string(candidate.label) || Is.typedArray(candidate.label, InlayHintLabelPart.is)) && (candidate.kind === undefined || InlayHintKind.is(candidate.kind)) && candidate.textEdits === undefined || Is.typedArray(candidate.textEdits, TextEdit.is) && (candidate.tooltip === undefined || Is.string(candidate.tooltip) || MarkupContent.is(candidate.tooltip)) && (candidate.paddingLeft === undefined || Is.boolean(candidate.paddingLeft)) && (candidate.paddingRight === undefined || Is.boolean(candidate.paddingRight));\n+                    }\n+                    InlayHint.is = is;\n+                })(InlayHint || (exports.InlayHint = InlayHint = {}));\n+                var WorkspaceFolder;\n+                (function(WorkspaceFolder) {\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.objectLiteral(candidate) && URI.is(candidate.uri) && Is.string(candidate.name);\n+                    }\n+                    WorkspaceFolder.is = is;\n+                })(WorkspaceFolder || (exports.WorkspaceFolder = WorkspaceFolder = {}));\n+                var EOL = exports.EOL = ['\\n', '\\r\\n', '\\r'];\n                 /**\n-                 * LinkifyIt#test(text) -> Boolean\n-                 *\n-                 * Searches linkifiable pattern and returns `true` on success or `false` on fail.\n-                 **/\n-                LinkifyIt.prototype.test = function test(text) {\n-                    // Reset scan cache\n-                    this.__text_cache__ = text;\n-                    this.__index__ = -1;\n-                    if (!text.length) {\n-                        return false;\n+                 * @deprecated Use the text document from the new vscode-languageserver-textdocument package.\n+                 */\n+                var TextDocument;\n+                (function(TextDocument) {\n+                    /**\n+                     * Creates a new ITextDocument literal from the given uri and content.\n+                     * @param uri The document's uri.\n+                     * @param languageId The document's language Id.\n+                     * @param version The document's version.\n+                     * @param content The document's content.\n+                     */\n+                    function create(uri, languageId, version, content) {\n+                        return new FullTextDocument(uri, languageId, version, content);\n                     }\n-                    let m, ml, me, len, shift, next, re, tld_pos, at_pos;\n+                    TextDocument.create = create;\n+                    /**\n+                     * Checks whether the given literal conforms to the {@link ITextDocument} interface.\n+                     */\n+                    function is(value) {\n+                        var candidate = value;\n+                        return Is.defined(candidate) && Is.string(candidate.uri) && (Is.undefined(candidate.languageId) || Is.string(candidate.languageId)) && Is.uinteger(candidate.lineCount) && Is.func(candidate.getText) && Is.func(candidate.positionAt) && Is.func(candidate.offsetAt) ? true : false;\n+                    }\n+                    TextDocument.is = is;\n \n-                    // try to scan for link with schema - that's the most simple rule\n-                    if (this.re.schema_test.test(text)) {\n-                        re = this.re.schema_search;\n-                        re.lastIndex = 0;\n-                        while ((m = re.exec(text)) !== null) {\n-                            len = this.testSchemaAt(text, m[2], re.lastIndex);\n-                            if (len) {\n-                                this.__schema__ = m[2];\n-                                this.__index__ = m.index + m[1].length;\n-                                this.__last_index__ = m.index + m[0].length + len;\n-                                break;\n+                    function applyEdits(document, edits) {\n+                        var text = document.getText();\n+                        var sortedEdits = mergeSort(edits, function(a, b) {\n+                            var diff = a.range.start.line - b.range.start.line;\n+                            if (diff === 0) {\n+                                return a.range.start.character - b.range.start.character;\n+                            }\n+                            return diff;\n+                        });\n+                        var lastModifiedOffset = text.length;\n+                        for (var i = sortedEdits.length - 1; i >= 0; i--) {\n+                            var e = sortedEdits[i];\n+                            var startOffset = document.offsetAt(e.range.start);\n+                            var endOffset = document.offsetAt(e.range.end);\n+                            if (endOffset <= lastModifiedOffset) {\n+                                text = text.substring(0, startOffset) + e.newText + text.substring(endOffset, text.length);\n+                            } else {\n+                                throw new Error('Overlapping edit');\n                             }\n+                            lastModifiedOffset = startOffset;\n                         }\n+                        return text;\n                     }\n-                    if (this.__opts__.fuzzyLink && this.__compiled__['http:']) {\n-                        // guess schemaless links\n-                        tld_pos = text.search(this.re.host_fuzzy_test);\n-                        if (tld_pos >= 0) {\n-                            // if tld is located after found link - no need to check fuzzy pattern\n-                            if (this.__index__ < 0 || tld_pos < this.__index__) {\n-                                if ((ml = text.match(this.__opts__.fuzzyIP ? this.re.link_fuzzy : this.re.link_no_ip_fuzzy)) !== null) {\n-                                    shift = ml.index + ml[1].length;\n-                                    if (this.__index__ < 0 || shift < this.__index__) {\n-                                        this.__schema__ = '';\n-                                        this.__index__ = shift;\n-                                        this.__last_index__ = ml.index + ml[0].length;\n-                                    }\n-                                }\n+                    TextDocument.applyEdits = applyEdits;\n+\n+                    function mergeSort(data, compare) {\n+                        if (data.length <= 1) {\n+                            // sorted\n+                            return data;\n+                        }\n+                        var p = data.length / 2 | 0;\n+                        var left = data.slice(0, p);\n+                        var right = data.slice(p);\n+                        mergeSort(left, compare);\n+                        mergeSort(right, compare);\n+                        var leftIdx = 0;\n+                        var rightIdx = 0;\n+                        var i = 0;\n+                        while (leftIdx < left.length && rightIdx < right.length) {\n+                            var ret = compare(left[leftIdx], right[rightIdx]);\n+                            if (ret <= 0) {\n+                                // smaller_equal -> take left to preserve order\n+                                data[i++] = left[leftIdx++];\n+                            } else {\n+                                // greater -> take right\n+                                data[i++] = right[rightIdx++];\n                             }\n                         }\n+                        while (leftIdx < left.length) {\n+                            data[i++] = left[leftIdx++];\n+                        }\n+                        while (rightIdx < right.length) {\n+                            data[i++] = right[rightIdx++];\n+                        }\n+                        return data;\n                     }\n-                    if (this.__opts__.fuzzyEmail && this.__compiled__['mailto:']) {\n-                        // guess schemaless emails\n-                        at_pos = text.indexOf('@');\n-                        if (at_pos >= 0) {\n-                            // We can't skip this check, because this cases are possible:\n-                            // 192.168.1.1@gmail.com, my.in@example.com\n-                            if ((me = text.match(this.re.email_fuzzy)) !== null) {\n-                                shift = me.index + me[1].length;\n-                                next = me.index + me[0].length;\n-                                if (this.__index__ < 0 || shift < this.__index__ || shift === this.__index__ && next > this.__last_index__) {\n-                                    this.__schema__ = 'mailto:';\n-                                    this.__index__ = shift;\n-                                    this.__last_index__ = next;\n+                })(TextDocument || (exports.TextDocument = TextDocument = {}));\n+                /**\n+                 * @deprecated Use the text document from the new vscode-languageserver-textdocument package.\n+                 */\n+                var FullTextDocument = /** @class */ function() {\n+                    function FullTextDocument(uri, languageId, version, content) {\n+                        this._uri = uri;\n+                        this._languageId = languageId;\n+                        this._version = version;\n+                        this._content = content;\n+                        this._lineOffsets = undefined;\n+                    }\n+                    Object.defineProperty(FullTextDocument.prototype, \"uri\", {\n+                        get: function() {\n+                            return this._uri;\n+                        },\n+                        enumerable: false,\n+                        configurable: true\n+                    });\n+                    Object.defineProperty(FullTextDocument.prototype, \"languageId\", {\n+                        get: function() {\n+                            return this._languageId;\n+                        },\n+                        enumerable: false,\n+                        configurable: true\n+                    });\n+                    Object.defineProperty(FullTextDocument.prototype, \"version\", {\n+                        get: function() {\n+                            return this._version;\n+                        },\n+                        enumerable: false,\n+                        configurable: true\n+                    });\n+                    FullTextDocument.prototype.getText = function(range) {\n+                        if (range) {\n+                            var start = this.offsetAt(range.start);\n+                            var end = this.offsetAt(range.end);\n+                            return this._content.substring(start, end);\n+                        }\n+                        return this._content;\n+                    };\n+                    FullTextDocument.prototype.update = function(event, version) {\n+                        this._content = event.text;\n+                        this._version = version;\n+                        this._lineOffsets = undefined;\n+                    };\n+                    FullTextDocument.prototype.getLineOffsets = function() {\n+                        if (this._lineOffsets === undefined) {\n+                            var lineOffsets = [];\n+                            var text = this._content;\n+                            var isLineStart = true;\n+                            for (var i = 0; i < text.length; i++) {\n+                                if (isLineStart) {\n+                                    lineOffsets.push(i);\n+                                    isLineStart = false;\n+                                }\n+                                var ch = text.charAt(i);\n+                                isLineStart = ch === '\\r' || ch === '\\n';\n+                                if (ch === '\\r' && i + 1 < text.length && text.charAt(i + 1) === '\\n') {\n+                                    i++;\n                                 }\n                             }\n+                            if (isLineStart && text.length > 0) {\n+                                lineOffsets.push(text.length);\n+                            }\n+                            this._lineOffsets = lineOffsets;\n                         }\n-                    }\n-                    return this.__index__ >= 0;\n-                };\n-\n-                /**\n-                 * LinkifyIt#pretest(text) -> Boolean\n-                 *\n-                 * Very quick check, that can give false positives. Returns true if link MAY BE\n-                 * can exists. Can be used for speed optimization, when you need to check that\n-                 * link NOT exists.\n-                 **/\n-                LinkifyIt.prototype.pretest = function pretest(text) {\n-                    return this.re.pretest.test(text);\n-                };\n+                        return this._lineOffsets;\n+                    };\n+                    FullTextDocument.prototype.positionAt = function(offset) {\n+                        offset = Math.max(Math.min(offset, this._content.length), 0);\n+                        var lineOffsets = this.getLineOffsets();\n+                        var low = 0,\n+                            high = lineOffsets.length;\n+                        if (high === 0) {\n+                            return Position.create(0, offset);\n+                        }\n+                        while (low < high) {\n+                            var mid = Math.floor((low + high) / 2);\n+                            if (lineOffsets[mid] > offset) {\n+                                high = mid;\n+                            } else {\n+                                low = mid + 1;\n+                            }\n+                        }\n+                        // low is the least x for which the line offset is larger than the current offset\n+                        // or array.length if no line offset is larger than the current offset\n+                        var line = low - 1;\n+                        return Position.create(line, offset - lineOffsets[line]);\n+                    };\n+                    FullTextDocument.prototype.offsetAt = function(position) {\n+                        var lineOffsets = this.getLineOffsets();\n+                        if (position.line >= lineOffsets.length) {\n+                            return this._content.length;\n+                        } else if (position.line < 0) {\n+                            return 0;\n+                        }\n+                        var lineOffset = lineOffsets[position.line];\n+                        var nextLineOffset = position.line + 1 < lineOffsets.length ? lineOffsets[position.line + 1] : this._content.length;\n+                        return Math.max(Math.min(lineOffset + position.character, nextLineOffset), lineOffset);\n+                    };\n+                    Object.defineProperty(FullTextDocument.prototype, \"lineCount\", {\n+                        get: function() {\n+                            return this.getLineOffsets().length;\n+                        },\n+                        enumerable: false,\n+                        configurable: true\n+                    });\n+                    return FullTextDocument;\n+                }();\n+                var Is;\n+                (function(Is) {\n+                    var toString = Object.prototype.toString;\n \n-                /**\n-                 * LinkifyIt#testSchemaAt(text, name, position) -> Number\n-                 * - text (String): text to scan\n-                 * - name (String): rule (schema) name\n-                 * - position (Number): text offset to check from\n-                 *\n-                 * Similar to [[LinkifyIt#test]] but checks only specific protocol tail exactly\n-                 * at given position. Returns length of found pattern (0 on fail).\n-                 **/\n-                LinkifyIt.prototype.testSchemaAt = function testSchemaAt(text, schema, pos) {\n-                    // If not supported schema check requested - terminate\n-                    if (!this.__compiled__[schema.toLowerCase()]) {\n-                        return 0;\n+                    function defined(value) {\n+                        return typeof value !== 'undefined';\n                     }\n-                    return this.__compiled__[schema.toLowerCase()].validate(text, pos, this);\n-                };\n-\n-                /**\n-                 * LinkifyIt#match(text) -> Array|null\n-                 *\n-                 * Returns array of found link descriptions or `null` on fail. We strongly\n-                 * recommend to use [[LinkifyIt#test]] first, for best speed.\n-                 *\n-                 * ##### Result match description\n-                 *\n-                 * - __schema__ - link schema, can be empty for fuzzy links, or `//` for\n-                 *   protocol-neutral  links.\n-                 * - __index__ - offset of matched text\n-                 * - __lastIndex__ - index of next char after mathch end\n-                 * - __raw__ - matched text\n-                 * - __text__ - normalized text\n-                 * - __url__ - link, generated from matched text\n-                 **/\n-                LinkifyIt.prototype.match = function match(text) {\n-                    const result = [];\n-                    let shift = 0;\n+                    Is.defined = defined;\n \n-                    // Try to take previous element from cache, if .test() called before\n-                    if (this.__index__ >= 0 && this.__text_cache__ === text) {\n-                        result.push(createMatch(this, shift));\n-                        shift = this.__last_index__;\n+                    function undefined(value) {\n+                        return typeof value === 'undefined';\n                     }\n+                    Is.undefined = undefined;\n \n-                    // Cut head if cache was used\n-                    let tail = shift ? text.slice(shift) : text;\n+                    function boolean(value) {\n+                        return value === true || value === false;\n+                    }\n+                    Is.boolean = boolean;\n \n-                    // Scan string until end reached\n-                    while (this.test(tail)) {\n-                        result.push(createMatch(this, shift));\n-                        tail = tail.slice(this.__last_index__);\n-                        shift += this.__last_index__;\n+                    function string(value) {\n+                        return toString.call(value) === '[object String]';\n                     }\n-                    if (result.length) {\n-                        return result;\n+                    Is.string = string;\n+\n+                    function number(value) {\n+                        return toString.call(value) === '[object Number]';\n                     }\n-                    return null;\n-                };\n+                    Is.number = number;\n \n-                /**\n-                 * LinkifyIt#matchAtStart(text) -> Match|null\n-                 *\n-                 * Returns fully-formed (not fuzzy) link if it starts at the beginning\n-                 * of the string, and null otherwise.\n-                 **/\n-                LinkifyIt.prototype.matchAtStart = function matchAtStart(text) {\n-                    // Reset scan cache\n-                    this.__text_cache__ = text;\n-                    this.__index__ = -1;\n-                    if (!text.length) return null;\n-                    const m = this.re.schema_at_start.exec(text);\n-                    if (!m) return null;\n-                    const len = this.testSchemaAt(text, m[2], m[0].length);\n-                    if (!len) return null;\n-                    this.__schema__ = m[2];\n-                    this.__index__ = m.index + m[1].length;\n-                    this.__last_index__ = m.index + m[0].length + len;\n-                    return createMatch(this, 0);\n-                };\n+                    function numberRange(value, min, max) {\n+                        return toString.call(value) === '[object Number]' && min <= value && value <= max;\n+                    }\n+                    Is.numberRange = numberRange;\n \n-                /** chainable\n-                 * LinkifyIt#tlds(list [, keepOld]) -> this\n-                 * - list (Array): list of tlds\n-                 * - keepOld (Boolean): merge with current list if `true` (`false` by default)\n-                 *\n-                 * Load (or merge) new tlds list. Those are user for fuzzy links (without prefix)\n-                 * to avoid false positives. By default this algorythm used:\n-                 *\n-                 * - hostname with any 2-letter root zones are ok.\n-                 * - biz|com|edu|gov|net|org|pro|web|xxx|aero|asia|coop|info|museum|name|shop|\u0440\u0444\n-                 *   are ok.\n-                 * - encoded (`xn--...`) root zones are ok.\n-                 *\n-                 * If list is replaced, then exact match for 2-chars root zones will be checked.\n-                 **/\n-                LinkifyIt.prototype.tlds = function tlds(list, keepOld) {\n-                    list = Array.isArray(list) ? list : [list];\n-                    if (!keepOld) {\n-                        this.__tlds__ = list.slice();\n-                        this.__tlds_replaced__ = true;\n-                        compile(this);\n-                        return this;\n+                    function integer(value) {\n+                        return toString.call(value) === '[object Number]' && -2147483648 <= value && value <= 2147483647;\n                     }\n-                    this.__tlds__ = this.__tlds__.concat(list).sort().filter(function(el, idx, arr) {\n-                        return el !== arr[idx - 1];\n-                    }).reverse();\n-                    compile(this);\n-                    return this;\n-                };\n+                    Is.integer = integer;\n \n-                /**\n-                 * LinkifyIt#normalize(match)\n-                 *\n-                 * Default normalizer (if schema does not define it's own).\n-                 **/\n-                LinkifyIt.prototype.normalize = function normalize(match) {\n-                    // Do minimal possible changes by default. Need to collect feedback prior\n-                    // to move forward https://github.com/markdown-it/linkify-it/issues/1\n+                    function uinteger(value) {\n+                        return toString.call(value) === '[object Number]' && 0 <= value && value <= 2147483647;\n+                    }\n+                    Is.uinteger = uinteger;\n \n-                    if (!match.schema) {\n-                        match.url = 'http://' + match.url;\n+                    function func(value) {\n+                        return toString.call(value) === '[object Function]';\n                     }\n-                    if (match.schema === 'mailto:' && !/^mailto:/i.test(match.url)) {\n-                        match.url = 'mailto:' + match.url;\n+                    Is.func = func;\n+\n+                    function objectLiteral(value) {\n+                        // Strictly speaking class instances pass this check as well. Since the LSP\n+                        // doesn't use classes we ignore this for now. If we do we need to add something\n+                        // like this: `Object.getPrototypeOf(Object.getPrototypeOf(x)) === null`\n+                        return value !== null && typeof value === 'object';\n                     }\n-                };\n+                    Is.objectLiteral = objectLiteral;\n \n-                /**\n-                 * LinkifyIt#onCompile()\n-                 *\n-                 * Override to modify basic RegExp-s.\n-                 **/\n-                LinkifyIt.prototype.onCompile = function onCompile() {};\n-                module.exports = LinkifyIt;\n+                    function typedArray(value, check) {\n+                        return Array.isArray(value) && value.every(check);\n+                    }\n+                    Is.typedArray = typedArray;\n+                })(Is || (Is = {}));\n \n                 /***/\n             }),\n \n         /***/\n-        \"../node_modules/markdown-it/dist/index.cjs.js\":\n-            /*!*****************************************************!*\\\n-              !*** ../node_modules/markdown-it/dist/index.cjs.js ***!\n-              \\*****************************************************/\n+        \"../../codemirror-graphql/esm/hint.js\":\n+            /*!********************************************!*\\\n+              !*** ../../codemirror-graphql/esm/hint.js ***!\n+              \\********************************************/\n             /***/\n-            (function(module, __unused_webpack_exports, __webpack_require__) {\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                var mdurl = __webpack_require__( /*! mdurl */ \"../node_modules/mdurl/build/index.cjs.js\");\n-                var ucmicro = __webpack_require__( /*! uc.micro */ \"../node_modules/uc.micro/build/index.cjs.js\");\n-                var entities = __webpack_require__( /*! entities */ \"../../../node_modules/entities/lib/index.js\");\n-                var LinkifyIt = __webpack_require__( /*! linkify-it */ \"../node_modules/linkify-it/build/index.cjs.js\");\n-                var punycode = __webpack_require__( /*! punycode.js */ \"../../../node_modules/punycode.js/punycode.es6.js\");\n+                var _codemirror = _interopRequireDefault(__webpack_require__( /*! codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"));\n+                __webpack_require__( /*! codemirror/addon/hint/show-hint.js */ \"../../../node_modules/codemirror/addon/hint/show-hint.js\");\n+                var _graphqlLanguageService = __webpack_require__( /*! graphql-language-service */ \"../../graphql-language-service/esm/index.js\");\n \n-                function _interopNamespaceDefault(e) {\n-                    var n = Object.create(null);\n-                    if (e) {\n-                        Object.keys(e).forEach(function(k) {\n-                            if (k !== 'default') {\n-                                var d = Object.getOwnPropertyDescriptor(e, k);\n-                                Object.defineProperty(n, k, d.get ? d : {\n-                                    enumerable: true,\n-                                    get: function() {\n-                                        return e[k];\n-                                    }\n-                                });\n-                            }\n-                        });\n-                    }\n-                    n.default = e;\n-                    return Object.freeze(n);\n+                function _interopRequireDefault(obj) {\n+                    return obj && obj.__esModule ? obj : {\n+                        default: obj\n+                    };\n                 }\n-                var mdurl__namespace = /*#__PURE__*/ _interopNamespaceDefault(mdurl);\n-                var ucmicro__namespace = /*#__PURE__*/ _interopNamespaceDefault(ucmicro);\n+                _codemirror.default.registerHelper('hint', 'graphql', (editor, options) => {\n+                    const {\n+                        schema,\n+                        externalFragments,\n+                        autocompleteOptions\n+                    } = options;\n+                    if (!schema) {\n+                        return;\n+                    }\n+                    const cur = editor.getCursor();\n+                    const token = editor.getTokenAt(cur);\n+                    const tokenStart = token.type !== null && /\"|\\w/.test(token.string[0]) ? token.start : token.end;\n+                    const position = new _graphqlLanguageService.Position(cur.line, tokenStart);\n+                    const rawResults = (0, _graphqlLanguageService.getAutocompleteSuggestions)(schema, editor.getValue(), position, token, externalFragments, autocompleteOptions);\n+                    const results = {\n+                        list: rawResults.map(item => {\n+                            var _a;\n+                            return {\n+                                text: (_a = item === null || item === void 0 ? void 0 : item.rawInsert) !== null && _a !== void 0 ? _a : item.label,\n+                                type: item.type,\n+                                description: item.documentation,\n+                                isDeprecated: item.isDeprecated,\n+                                deprecationReason: item.deprecationReason\n+                            };\n+                        }),\n+                        from: {\n+                            line: cur.line,\n+                            ch: tokenStart\n+                        },\n+                        to: {\n+                            line: cur.line,\n+                            ch: token.end\n+                        }\n+                    };\n+                    if ((results === null || results === void 0 ? void 0 : results.list) && results.list.length > 0) {\n+                        results.from = _codemirror.default.Pos(results.from.line, results.from.ch);\n+                        results.to = _codemirror.default.Pos(results.to.line, results.to.ch);\n+                        _codemirror.default.signal(editor, 'hasCompletion', editor, results, token);\n+                    }\n+                    return results;\n+                });\n \n-                // Utilities\n-                //\n+                /***/\n+            }),\n \n-                function _class(obj) {\n-                    return Object.prototype.toString.call(obj);\n-                }\n+        /***/\n+        \"../../codemirror-graphql/esm/info.js\":\n+            /*!********************************************!*\\\n+              !*** ../../codemirror-graphql/esm/info.js ***!\n+              \\********************************************/\n+            /***/\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n \n-                function isString(obj) {\n-                    return _class(obj) === '[object String]';\n-                }\n-                const _hasOwnProperty = Object.prototype.hasOwnProperty;\n+                \"use strict\";\n \n-                function has(object, key) {\n-                    return _hasOwnProperty.call(object, key);\n-                }\n \n-                // Merge objects\n-                //\n-                function assign(obj /* from1, from2, from3, ... */ ) {\n-                    const sources = Array.prototype.slice.call(arguments, 1);\n-                    sources.forEach(function(source) {\n-                        if (!source) {\n-                            return;\n-                        }\n-                        if (typeof source !== 'object') {\n-                            throw new TypeError(source + 'must be object');\n-                        }\n-                        Object.keys(source).forEach(function(key) {\n-                            obj[key] = source[key];\n-                        });\n-                    });\n-                    return obj;\n-                }\n+                var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n+                var _codemirror = _interopRequireDefault(__webpack_require__( /*! codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"));\n+                var _getTypeInfo = _interopRequireDefault(__webpack_require__( /*! ./utils/getTypeInfo */ \"../../codemirror-graphql/esm/utils/getTypeInfo.js\"));\n+                var _SchemaReference = __webpack_require__( /*! ./utils/SchemaReference */ \"../../codemirror-graphql/esm/utils/SchemaReference.js\");\n+                __webpack_require__( /*! ./utils/info-addon */ \"../../codemirror-graphql/esm/utils/info-addon.js\");\n \n-                // Remove element from array and put another array at those position.\n-                // Useful for some operations with tokens\n-                function arrayReplaceAt(src, pos, newElements) {\n-                    return [].concat(src.slice(0, pos), newElements, src.slice(pos + 1));\n+                function _interopRequireDefault(obj) {\n+                    return obj && obj.__esModule ? obj : {\n+                        default: obj\n+                    };\n                 }\n-\n-                function isValidEntityCode(c) {\n-                    /* eslint no-bitwise:0 */\n-                    // broken sequence\n-                    if (c >= 0xD800 && c <= 0xDFFF) {\n-                        return false;\n-                    }\n-                    // never used\n-                    if (c >= 0xFDD0 && c <= 0xFDEF) {\n-                        return false;\n-                    }\n-                    if ((c & 0xFFFF) === 0xFFFF || (c & 0xFFFF) === 0xFFFE) {\n-                        return false;\n+                _codemirror.default.registerHelper('info', 'graphql', (token, options) => {\n+                    var _a;\n+                    if (!options.schema || !token.state) {\n+                        return;\n                     }\n-                    // control codes\n-                    if (c >= 0x00 && c <= 0x08) {\n-                        return false;\n+                    const {\n+                        kind,\n+                        step\n+                    } = token.state;\n+                    const typeInfo = (0, _getTypeInfo.default)(options.schema, token.state);\n+                    if (kind === 'Field' && step === 0 && typeInfo.fieldDef || kind === 'AliasedField' && step === 2 && typeInfo.fieldDef || kind === 'ObjectField' && step === 0 && typeInfo.fieldDef) {\n+                        const header = document.createElement('div');\n+                        header.className = 'CodeMirror-info-header';\n+                        renderField(header, typeInfo, options);\n+                        const into = document.createElement('div');\n+                        into.append(header);\n+                        renderDescription(into, options, typeInfo.fieldDef);\n+                        return into;\n                     }\n-                    if (c === 0x0B) {\n-                        return false;\n+                    if (kind === 'Directive' && step === 1 && typeInfo.directiveDef) {\n+                        const header = document.createElement('div');\n+                        header.className = 'CodeMirror-info-header';\n+                        renderDirective(header, typeInfo, options);\n+                        const into = document.createElement('div');\n+                        into.append(header);\n+                        renderDescription(into, options, typeInfo.directiveDef);\n+                        return into;\n                     }\n-                    if (c >= 0x0E && c <= 0x1F) {\n-                        return false;\n+                    if (kind === 'Argument' && step === 0 && typeInfo.argDef) {\n+                        const header = document.createElement('div');\n+                        header.className = 'CodeMirror-info-header';\n+                        renderArg(header, typeInfo, options);\n+                        const into = document.createElement('div');\n+                        into.append(header);\n+                        renderDescription(into, options, typeInfo.argDef);\n+                        return into;\n                     }\n-                    if (c >= 0x7F && c <= 0x9F) {\n-                        return false;\n+                    if (kind === 'EnumValue' && ((_a = typeInfo.enumValue) === null || _a === void 0 ? void 0 : _a.description)) {\n+                        const header = document.createElement('div');\n+                        header.className = 'CodeMirror-info-header';\n+                        renderEnumValue(header, typeInfo, options);\n+                        const into = document.createElement('div');\n+                        into.append(header);\n+                        renderDescription(into, options, typeInfo.enumValue);\n+                        return into;\n                     }\n-                    // out of range\n-                    if (c > 0x10FFFF) {\n-                        return false;\n+                    if (kind === 'NamedType' && typeInfo.type && typeInfo.type.description) {\n+                        const header = document.createElement('div');\n+                        header.className = 'CodeMirror-info-header';\n+                        renderType(header, typeInfo, options, typeInfo.type);\n+                        const into = document.createElement('div');\n+                        into.append(header);\n+                        renderDescription(into, options, typeInfo.type);\n+                        return into;\n                     }\n-                    return true;\n-                }\n+                });\n \n-                function fromCodePoint(c) {\n-                    /* eslint no-bitwise:0 */\n-                    if (c > 0xffff) {\n-                        c -= 0x10000;\n-                        const surrogate1 = 0xd800 + (c >> 10);\n-                        const surrogate2 = 0xdc00 + (c & 0x3ff);\n-                        return String.fromCharCode(surrogate1, surrogate2);\n-                    }\n-                    return String.fromCharCode(c);\n+                function renderField(into, typeInfo, options) {\n+                    renderQualifiedField(into, typeInfo, options);\n+                    renderTypeAnnotation(into, typeInfo, options, typeInfo.type);\n                 }\n-                const UNESCAPE_MD_RE = /\\\\([!\"#$%&'()*+,\\-./:;<=>?@[\\\\\\]^_`{|}~])/g;\n-                const ENTITY_RE = /&([a-z#][a-z0-9]{1,31});/gi;\n-                const UNESCAPE_ALL_RE = new RegExp(UNESCAPE_MD_RE.source + '|' + ENTITY_RE.source, 'gi');\n-                const DIGITAL_ENTITY_TEST_RE = /^#((?:x[a-f0-9]{1,8}|[0-9]{1,8}))$/i;\n \n-                function replaceEntityPattern(match, name) {\n-                    if (name.charCodeAt(0) === 0x23 /* # */ && DIGITAL_ENTITY_TEST_RE.test(name)) {\n-                        const code = name[1].toLowerCase() === 'x' ? parseInt(name.slice(2), 16) : parseInt(name.slice(1), 10);\n-                        if (isValidEntityCode(code)) {\n-                            return fromCodePoint(code);\n-                        }\n-                        return match;\n-                    }\n-                    const decoded = entities.decodeHTML(match);\n-                    if (decoded !== match) {\n-                        return decoded;\n-                    }\n-                    return match;\n+                function renderQualifiedField(into, typeInfo, options) {\n+                    var _a;\n+                    const fieldName = ((_a = typeInfo.fieldDef) === null || _a === void 0 ? void 0 : _a.name) || '';\n+                    text(into, fieldName, 'field-name', options, (0, _SchemaReference.getFieldReference)(typeInfo));\n                 }\n \n-                /* function replaceEntities(str) {\n-                  if (str.indexOf('&') < 0) { return str; }\n-\n-                  return str.replace(ENTITY_RE, replaceEntityPattern);\n-                } */\n-\n-                function unescapeMd(str) {\n-                    if (str.indexOf('\\\\') < 0) {\n-                        return str;\n-                    }\n-                    return str.replace(UNESCAPE_MD_RE, '$1');\n+                function renderDirective(into, typeInfo, options) {\n+                    var _a;\n+                    const name = '@' + (((_a = typeInfo.directiveDef) === null || _a === void 0 ? void 0 : _a.name) || '');\n+                    text(into, name, 'directive-name', options, (0, _SchemaReference.getDirectiveReference)(typeInfo));\n                 }\n \n-                function unescapeAll(str) {\n-                    if (str.indexOf('\\\\') < 0 && str.indexOf('&') < 0) {\n-                        return str;\n-                    }\n-                    return str.replace(UNESCAPE_ALL_RE, function(match, escaped, entity) {\n-                        if (escaped) {\n-                            return escaped;\n-                        }\n-                        return replaceEntityPattern(match, entity);\n-                    });\n+                function renderArg(into, typeInfo, options) {\n+                    var _a;\n+                    const name = ((_a = typeInfo.argDef) === null || _a === void 0 ? void 0 : _a.name) || '';\n+                    text(into, name, 'arg-name', options, (0, _SchemaReference.getArgumentReference)(typeInfo));\n+                    renderTypeAnnotation(into, typeInfo, options, typeInfo.inputType);\n                 }\n-                const HTML_ESCAPE_TEST_RE = /[&<>\"]/;\n-                const HTML_ESCAPE_REPLACE_RE = /[&<>\"]/g;\n-                const HTML_REPLACEMENTS = {\n-                    '&': '&amp;',\n-                    '<': '&lt;',\n-                    '>': '&gt;',\n-                    '\"': '&quot;'\n-                };\n \n-                function replaceUnsafeChar(ch) {\n-                    return HTML_REPLACEMENTS[ch];\n+                function renderEnumValue(into, typeInfo, options) {\n+                    var _a;\n+                    const name = ((_a = typeInfo.enumValue) === null || _a === void 0 ? void 0 : _a.name) || '';\n+                    renderType(into, typeInfo, options, typeInfo.inputType);\n+                    text(into, '.');\n+                    text(into, name, 'enum-value', options, (0, _SchemaReference.getEnumValueReference)(typeInfo));\n                 }\n \n-                function escapeHtml(str) {\n-                    if (HTML_ESCAPE_TEST_RE.test(str)) {\n-                        return str.replace(HTML_ESCAPE_REPLACE_RE, replaceUnsafeChar);\n+                function renderTypeAnnotation(into, typeInfo, options, t) {\n+                    const typeSpan = document.createElement('span');\n+                    typeSpan.className = 'type-name-pill';\n+                    if (t instanceof _graphql.GraphQLNonNull) {\n+                        renderType(typeSpan, typeInfo, options, t.ofType);\n+                        text(typeSpan, '!');\n+                    } else if (t instanceof _graphql.GraphQLList) {\n+                        text(typeSpan, '[');\n+                        renderType(typeSpan, typeInfo, options, t.ofType);\n+                        text(typeSpan, ']');\n+                    } else {\n+                        text(typeSpan, (t === null || t === void 0 ? void 0 : t.name) || '', 'type-name', options, (0, _SchemaReference.getTypeReference)(typeInfo, t));\n                     }\n-                    return str;\n-                }\n-                const REGEXP_ESCAPE_RE = /[.?*+^$[\\]\\\\(){}|-]/g;\n-\n-                function escapeRE(str) {\n-                    return str.replace(REGEXP_ESCAPE_RE, '\\\\$&');\n+                    into.append(typeSpan);\n                 }\n \n-                function isSpace(code) {\n-                    switch (code) {\n-                        case 0x09:\n-                        case 0x20:\n-                            return true;\n+                function renderType(into, typeInfo, options, t) {\n+                    if (t instanceof _graphql.GraphQLNonNull) {\n+                        renderType(into, typeInfo, options, t.ofType);\n+                        text(into, '!');\n+                    } else if (t instanceof _graphql.GraphQLList) {\n+                        text(into, '[');\n+                        renderType(into, typeInfo, options, t.ofType);\n+                        text(into, ']');\n+                    } else {\n+                        text(into, (t === null || t === void 0 ? void 0 : t.name) || '', 'type-name', options, (0, _SchemaReference.getTypeReference)(typeInfo, t));\n                     }\n-                    return false;\n                 }\n \n-                // Zs (unicode class) || [\\t\\f\\v\\r\\n]\n-                function isWhiteSpace(code) {\n-                    if (code >= 0x2000 && code <= 0x200A) {\n-                        return true;\n-                    }\n-                    switch (code) {\n-                        case 0x09: // \\t\n-                        case 0x0A: // \\n\n-                        case 0x0B: // \\v\n-                        case 0x0C: // \\f\n-                        case 0x0D: // \\r\n-                        case 0x20:\n-                        case 0xA0:\n-                        case 0x1680:\n-                        case 0x202F:\n-                        case 0x205F:\n-                        case 0x3000:\n-                            return true;\n+                function renderDescription(into, options, def) {\n+                    const {\n+                        description\n+                    } = def;\n+                    if (description) {\n+                        const descriptionDiv = document.createElement('div');\n+                        descriptionDiv.className = 'info-description';\n+                        if (options.renderDescription) {\n+                            descriptionDiv.innerHTML = options.renderDescription(description);\n+                        } else {\n+                            descriptionDiv.append(document.createTextNode(description));\n+                        }\n+                        into.append(descriptionDiv);\n                     }\n-                    return false;\n-                }\n-\n-                /* eslint-disable max-len */\n-\n-                // Currently without astral characters support.\n-                function isPunctChar(ch) {\n-                    return ucmicro__namespace.P.test(ch) || ucmicro__namespace.S.test(ch);\n+                    renderDeprecation(into, options, def);\n                 }\n \n-                // Markdown ASCII punctuation characters.\n-                //\n-                // !, \", #, $, %, &, ', (, ), *, +, ,, -, ., /, :, ;, <, =, >, ?, @, [, \\, ], ^, _, `, {, |, }, or ~\n-                // http://spec.commonmark.org/0.15/#ascii-punctuation-character\n-                //\n-                // Don't confuse with unicode punctuation !!! It lacks some chars in ascii range.\n-                //\n-                function isMdAsciiPunct(ch) {\n-                    switch (ch) {\n-                        case 0x21 /* ! */ :\n-                        case 0x22 /* \" */ :\n-                        case 0x23 /* # */ :\n-                        case 0x24 /* $ */ :\n-                        case 0x25 /* % */ :\n-                        case 0x26 /* & */ :\n-                        case 0x27 /* ' */ :\n-                        case 0x28 /* ( */ :\n-                        case 0x29 /* ) */ :\n-                        case 0x2A /* * */ :\n-                        case 0x2B /* + */ :\n-                        case 0x2C /* , */ :\n-                        case 0x2D /* - */ :\n-                        case 0x2E /* . */ :\n-                        case 0x2F /* / */ :\n-                        case 0x3A /* : */ :\n-                        case 0x3B /* ; */ :\n-                        case 0x3C /* < */ :\n-                        case 0x3D /* = */ :\n-                        case 0x3E /* > */ :\n-                        case 0x3F /* ? */ :\n-                        case 0x40 /* @ */ :\n-                        case 0x5B /* [ */ :\n-                        case 0x5C /* \\ */ :\n-                        case 0x5D /* ] */ :\n-                        case 0x5E /* ^ */ :\n-                        case 0x5F /* _ */ :\n-                        case 0x60 /* ` */ :\n-                        case 0x7B /* { */ :\n-                        case 0x7C /* | */ :\n-                        case 0x7D /* } */ :\n-                        case 0x7E /* ~ */ :\n-                            return true;\n-                        default:\n-                            return false;\n+                function renderDeprecation(into, options, def) {\n+                    const reason = def.deprecationReason;\n+                    if (reason) {\n+                        const deprecationDiv = document.createElement('div');\n+                        deprecationDiv.className = 'info-deprecation';\n+                        into.append(deprecationDiv);\n+                        const label = document.createElement('span');\n+                        label.className = 'info-deprecation-label';\n+                        label.append(document.createTextNode('Deprecated'));\n+                        deprecationDiv.append(label);\n+                        const reasonDiv = document.createElement('div');\n+                        reasonDiv.className = 'info-deprecation-reason';\n+                        if (options.renderDescription) {\n+                            reasonDiv.innerHTML = options.renderDescription(reason);\n+                        } else {\n+                            reasonDiv.append(document.createTextNode(reason));\n+                        }\n+                        deprecationDiv.append(reasonDiv);\n                     }\n                 }\n \n-                // Hepler to unify [reference labels].\n-                //\n-                function normalizeReference(str) {\n-                    // Trim and collapse whitespace\n-                    //\n-                    str = str.trim().replace(/\\s+/g, ' ');\n-\n-                    // In node v10 '\u1e9e'.toLowerCase() === '\u1e7e', which is presumed to be a bug\n-                    // fixed in v12 (couldn't find any details).\n-                    //\n-                    // So treat this one as a special case\n-                    // (remove this when node v10 is no longer supported).\n-                    //\n-                    if ('\u1e9e'.toLowerCase() === '\u1e7e') {\n-                        str = str.replace(/\u1e9e/g, '\u00df');\n+                function text(into, content, className = '', options = {\n+                    onClick: null\n+                }, ref = null) {\n+                    if (className) {\n+                        const {\n+                            onClick\n+                        } = options;\n+                        let node;\n+                        if (onClick) {\n+                            node = document.createElement('a');\n+                            node.href = 'javascript:void 0';\n+                            node.addEventListener('click', e => {\n+                                e.preventDefault();\n+                                onClick(ref, e);\n+                            });\n+                        } else {\n+                            node = document.createElement('span');\n+                        }\n+                        node.className = className;\n+                        node.append(document.createTextNode(content));\n+                        into.append(node);\n+                    } else {\n+                        into.append(document.createTextNode(content));\n                     }\n-\n-                    // .toLowerCase().toUpperCase() should get rid of all differences\n-                    // between letter variants.\n-                    //\n-                    // Simple .toLowerCase() doesn't normalize 125 code points correctly,\n-                    // and .toUpperCase doesn't normalize 6 of them (list of exceptions:\n-                    // \u0130, \u03f4, \u1e9e, \u2126, \u212a, \u212b - those are already uppercased, but have differently\n-                    // uppercased versions).\n-                    //\n-                    // Here's an example showing how it happens. Lets take greek letter omega:\n-                    // uppercase U+0398 (\u0398), U+03f4 (\u03f4) and lowercase U+03b8 (\u03b8), U+03d1 (\u03d1)\n-                    //\n-                    // Unicode entries:\n-                    // 0398;GREEK CAPITAL LETTER THETA;Lu;0;L;;;;;N;;;;03B8;\n-                    // 03B8;GREEK SMALL LETTER THETA;Ll;0;L;;;;;N;;;0398;;0398\n-                    // 03D1;GREEK THETA SYMBOL;Ll;0;L;<compat> 03B8;;;;N;GREEK SMALL LETTER SCRIPT THETA;;0398;;0398\n-                    // 03F4;GREEK CAPITAL THETA SYMBOL;Lu;0;L;<compat> 0398;;;;N;;;;03B8;\n-                    //\n-                    // Case-insensitive comparison should treat all of them as equivalent.\n-                    //\n-                    // But .toLowerCase() doesn't change \u03d1 (it's already lowercase),\n-                    // and .toUpperCase() doesn't change \u03f4 (already uppercase).\n-                    //\n-                    // Applying first lower then upper case normalizes any character:\n-                    // '\\u0398\\u03f4\\u03b8\\u03d1'.toLowerCase().toUpperCase() === '\\u0398\\u0398\\u0398\\u0398'\n-                    //\n-                    // Note: this is equivalent to unicode case folding; unicode normalization\n-                    // is a different step that is not required here.\n-                    //\n-                    // Final result should be uppercased, because it's later stored in an object\n-                    // (this avoid a conflict with Object.prototype members,\n-                    // most notably, `__proto__`)\n-                    //\n-                    return str.toLowerCase().toUpperCase();\n                 }\n \n-                // Re-export libraries commonly used in both markdown-it and its plugins,\n-                // so plugins won't have to depend on them explicitly, which reduces their\n-                // bundled size (e.g. a browser build).\n-                //\n-                const lib = {\n-                    mdurl: mdurl__namespace,\n-                    ucmicro: ucmicro__namespace\n-                };\n-                var utils = /*#__PURE__*/ Object.freeze({\n-                    __proto__: null,\n-                    arrayReplaceAt: arrayReplaceAt,\n-                    assign: assign,\n-                    escapeHtml: escapeHtml,\n-                    escapeRE: escapeRE,\n-                    fromCodePoint: fromCodePoint,\n-                    has: has,\n-                    isMdAsciiPunct: isMdAsciiPunct,\n-                    isPunctChar: isPunctChar,\n-                    isSpace: isSpace,\n-                    isString: isString,\n-                    isValidEntityCode: isValidEntityCode,\n-                    isWhiteSpace: isWhiteSpace,\n-                    lib: lib,\n-                    normalizeReference: normalizeReference,\n-                    unescapeAll: unescapeAll,\n-                    unescapeMd: unescapeMd\n-                });\n+                /***/\n+            }),\n \n-                // Parse link label\n-                //\n-                // this function assumes that first character (\"[\") already matches;\n-                // returns the end of the label\n-                //\n+        /***/\n+        \"../../codemirror-graphql/esm/jump.js\":\n+            /*!********************************************!*\\\n+              !*** ../../codemirror-graphql/esm/jump.js ***!\n+              \\********************************************/\n+            /***/\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n \n-                function parseLinkLabel(state, start, disableNested) {\n-                    let level, found, marker, prevPos;\n-                    const max = state.posMax;\n-                    const oldPos = state.pos;\n-                    state.pos = start + 1;\n-                    level = 1;\n-                    while (state.pos < max) {\n-                        marker = state.src.charCodeAt(state.pos);\n-                        if (marker === 0x5D /* ] */ ) {\n-                            level--;\n-                            if (level === 0) {\n-                                found = true;\n-                                break;\n-                            }\n-                        }\n-                        prevPos = state.pos;\n-                        state.md.inline.skipToken(state);\n-                        if (marker === 0x5B /* [ */ ) {\n-                            if (prevPos === state.pos - 1) {\n-                                // increase level if we find text `[`, which is not a part of any token\n-                                level++;\n-                            } else if (disableNested) {\n-                                state.pos = oldPos;\n-                                return -1;\n-                            }\n-                        }\n-                    }\n-                    let labelEnd = -1;\n-                    if (found) {\n-                        labelEnd = state.pos;\n-                    }\n+                \"use strict\";\n \n-                    // restore old state\n-                    state.pos = oldPos;\n-                    return labelEnd;\n-                }\n \n-                // Parse link destination\n-                //\n+                var _codemirror = _interopRequireDefault(__webpack_require__( /*! codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"));\n+                var _getTypeInfo = _interopRequireDefault(__webpack_require__( /*! ./utils/getTypeInfo */ \"../../codemirror-graphql/esm/utils/getTypeInfo.js\"));\n+                var _SchemaReference = __webpack_require__( /*! ./utils/SchemaReference */ \"../../codemirror-graphql/esm/utils/SchemaReference.js\");\n+                __webpack_require__( /*! ./utils/jump-addon */ \"../../codemirror-graphql/esm/utils/jump-addon.js\");\n \n-                function parseLinkDestination(str, start, max) {\n-                    let code;\n-                    let pos = start;\n-                    const result = {\n-                        ok: false,\n-                        pos: 0,\n-                        str: ''\n+                function _interopRequireDefault(obj) {\n+                    return obj && obj.__esModule ? obj : {\n+                        default: obj\n                     };\n-                    if (str.charCodeAt(pos) === 0x3C /* < */ ) {\n-                        pos++;\n-                        while (pos < max) {\n-                            code = str.charCodeAt(pos);\n-                            if (code === 0x0A /* \\n */ ) {\n-                                return result;\n-                            }\n-                            if (code === 0x3C /* < */ ) {\n-                                return result;\n-                            }\n-                            if (code === 0x3E /* > */ ) {\n-                                result.pos = pos + 1;\n-                                result.str = unescapeAll(str.slice(start + 1, pos));\n-                                result.ok = true;\n-                                return result;\n-                            }\n-                            if (code === 0x5C /* \\ */ && pos + 1 < max) {\n-                                pos += 2;\n-                                continue;\n-                            }\n-                            pos++;\n-                        }\n-\n-                        // no closing '>'\n-                        return result;\n+                }\n+                _codemirror.default.registerHelper('jump', 'graphql', (token, options) => {\n+                    if (!options.schema || !options.onClick || !token.state) {\n+                        return;\n                     }\n-\n-                    // this should be ... } else { ... branch\n-\n-                    let level = 0;\n-                    while (pos < max) {\n-                        code = str.charCodeAt(pos);\n-                        if (code === 0x20) {\n-                            break;\n-                        }\n-\n-                        // ascii control characters\n-                        if (code < 0x20 || code === 0x7F) {\n-                            break;\n-                        }\n-                        if (code === 0x5C /* \\ */ && pos + 1 < max) {\n-                            if (str.charCodeAt(pos + 1) === 0x20) {\n-                                break;\n-                            }\n-                            pos += 2;\n-                            continue;\n-                        }\n-                        if (code === 0x28 /* ( */ ) {\n-                            level++;\n-                            if (level > 32) {\n-                                return result;\n-                            }\n-                        }\n-                        if (code === 0x29 /* ) */ ) {\n-                            if (level === 0) {\n-                                break;\n-                            }\n-                            level--;\n-                        }\n-                        pos++;\n+                    const {\n+                        state\n+                    } = token;\n+                    const {\n+                        kind,\n+                        step\n+                    } = state;\n+                    const typeInfo = (0, _getTypeInfo.default)(options.schema, state);\n+                    if (kind === 'Field' && step === 0 && typeInfo.fieldDef || kind === 'AliasedField' && step === 2 && typeInfo.fieldDef) {\n+                        return (0, _SchemaReference.getFieldReference)(typeInfo);\n                     }\n-                    if (start === pos) {\n-                        return result;\n+                    if (kind === 'Directive' && step === 1 && typeInfo.directiveDef) {\n+                        return (0, _SchemaReference.getDirectiveReference)(typeInfo);\n                     }\n-                    if (level !== 0) {\n-                        return result;\n+                    if (kind === 'Argument' && step === 0 && typeInfo.argDef) {\n+                        return (0, _SchemaReference.getArgumentReference)(typeInfo);\n                     }\n-                    result.str = unescapeAll(str.slice(start, pos));\n-                    result.pos = pos;\n-                    result.ok = true;\n-                    return result;\n-                }\n-\n-                // Parse link title\n-                //\n-\n-                // Parse link title within `str` in [start, max] range,\n-                // or continue previous parsing if `prev_state` is defined (equal to result of last execution).\n-                //\n-                function parseLinkTitle(str, start, max, prev_state) {\n-                    let code;\n-                    let pos = start;\n-                    const state = {\n-                        // if `true`, this is a valid link title\n-                        ok: false,\n-                        // if `true`, this link can be continued on the next line\n-                        can_continue: false,\n-                        // if `ok`, it's the position of the first character after the closing marker\n-                        pos: 0,\n-                        // if `ok`, it's the unescaped title\n-                        str: '',\n-                        // expected closing marker character code\n-                        marker: 0\n-                    };\n-                    if (prev_state) {\n-                        // this is a continuation of a previous parseLinkTitle call on the next line,\n-                        // used in reference links only\n-                        state.str = prev_state.str;\n-                        state.marker = prev_state.marker;\n-                    } else {\n-                        if (pos >= max) {\n-                            return state;\n-                        }\n-                        let marker = str.charCodeAt(pos);\n-                        if (marker !== 0x22 /* \" */ && marker !== 0x27 /* ' */ && marker !== 0x28 /* ( */ ) {\n-                            return state;\n-                        }\n-                        start++;\n-                        pos++;\n-\n-                        // if opening marker is \"(\", switch it to closing marker \")\"\n-                        if (marker === 0x28) {\n-                            marker = 0x29;\n-                        }\n-                        state.marker = marker;\n+                    if (kind === 'EnumValue' && typeInfo.enumValue) {\n+                        return (0, _SchemaReference.getEnumValueReference)(typeInfo);\n                     }\n-                    while (pos < max) {\n-                        code = str.charCodeAt(pos);\n-                        if (code === state.marker) {\n-                            state.pos = pos + 1;\n-                            state.str += unescapeAll(str.slice(start, pos));\n-                            state.ok = true;\n-                            return state;\n-                        } else if (code === 0x28 /* ( */ && state.marker === 0x29 /* ) */ ) {\n-                            return state;\n-                        } else if (code === 0x5C /* \\ */ && pos + 1 < max) {\n-                            pos++;\n-                        }\n-                        pos++;\n+                    if (kind === 'NamedType' && typeInfo.type) {\n+                        return (0, _SchemaReference.getTypeReference)(typeInfo);\n                     }\n-\n-                    // no closing marker found, but this link title may continue on the next line (for references)\n-                    state.can_continue = true;\n-                    state.str += unescapeAll(str.slice(start, pos));\n-                    return state;\n-                }\n-\n-                // Just a shortcut for bulk export\n-\n-                var helpers = /*#__PURE__*/ Object.freeze({\n-                    __proto__: null,\n-                    parseLinkDestination: parseLinkDestination,\n-                    parseLinkLabel: parseLinkLabel,\n-                    parseLinkTitle: parseLinkTitle\n                 });\n \n-                /**\n-                 * class Renderer\n-                 *\n-                 * Generates HTML from parsed token stream. Each instance has independent\n-                 * copy of rules. Those can be rewritten with ease. Also, you can add new\n-                 * rules if you create plugin and adds new token types.\n-                 **/\n-\n-                const default_rules = {};\n-                default_rules.code_inline = function(tokens, idx, options, env, slf) {\n-                    const token = tokens[idx];\n-                    return '<code' + slf.renderAttrs(token) + '>' + escapeHtml(token.content) + '</code>';\n-                };\n-                default_rules.code_block = function(tokens, idx, options, env, slf) {\n-                    const token = tokens[idx];\n-                    return '<pre' + slf.renderAttrs(token) + '><code>' + escapeHtml(tokens[idx].content) + '</code></pre>\\n';\n-                };\n-                default_rules.fence = function(tokens, idx, options, env, slf) {\n-                    const token = tokens[idx];\n-                    const info = token.info ? unescapeAll(token.info).trim() : '';\n-                    let langName = '';\n-                    let langAttrs = '';\n-                    if (info) {\n-                        const arr = info.split(/(\\s+)/g);\n-                        langName = arr[0];\n-                        langAttrs = arr.slice(2).join('');\n-                    }\n-                    let highlighted;\n-                    if (options.highlight) {\n-                        highlighted = options.highlight(token.content, langName, langAttrs) || escapeHtml(token.content);\n-                    } else {\n-                        highlighted = escapeHtml(token.content);\n-                    }\n-                    if (highlighted.indexOf('<pre') === 0) {\n-                        return highlighted + '\\n';\n-                    }\n+                /***/\n+            }),\n \n-                    // If language exists, inject class gently, without modifying original token.\n-                    // May be, one day we will add .deepClone() for token and simplify this part, but\n-                    // now we prefer to keep things local.\n-                    if (info) {\n-                        const i = token.attrIndex('class');\n-                        const tmpAttrs = token.attrs ? token.attrs.slice() : [];\n-                        if (i < 0) {\n-                            tmpAttrs.push(['class', options.langPrefix + langName]);\n-                        } else {\n-                            tmpAttrs[i] = tmpAttrs[i].slice();\n-                            tmpAttrs[i][1] += ' ' + options.langPrefix + langName;\n-                        }\n+        /***/\n+        \"../../codemirror-graphql/esm/lint.js\":\n+            /*!********************************************!*\\\n+              !*** ../../codemirror-graphql/esm/lint.js ***!\n+              \\********************************************/\n+            /***/\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n \n-                        // Fake token just to render attributes\n-                        const tmpToken = {\n-                            attrs: tmpAttrs\n-                        };\n-                        return `<pre><code${slf.renderAttrs(tmpToken)}>${highlighted}</code></pre>\\n`;\n-                    }\n-                    return `<pre><code${slf.renderAttrs(token)}>${highlighted}</code></pre>\\n`;\n-                };\n-                default_rules.image = function(tokens, idx, options, env, slf) {\n-                    const token = tokens[idx];\n+                \"use strict\";\n \n-                    // \"alt\" attr MUST be set, even if empty. Because it's mandatory and\n-                    // should be placed on proper position for tests.\n-                    //\n-                    // Replace content with actual value\n \n-                    token.attrs[token.attrIndex('alt')][1] = slf.renderInlineAsText(token.children, options, env);\n-                    return slf.renderToken(tokens, idx, options);\n-                };\n-                default_rules.hardbreak = function(tokens, idx, options /*, env */ ) {\n-                    return options.xhtmlOut ? '<br />\\n' : '<br>\\n';\n-                };\n-                default_rules.softbreak = function(tokens, idx, options /*, env */ ) {\n-                    return options.breaks ? options.xhtmlOut ? '<br />\\n' : '<br>\\n' : '\\n';\n-                };\n-                default_rules.text = function(tokens, idx /*, options, env */ ) {\n-                    return escapeHtml(tokens[idx].content);\n-                };\n-                default_rules.html_block = function(tokens, idx /*, options, env */ ) {\n-                    return tokens[idx].content;\n-                };\n-                default_rules.html_inline = function(tokens, idx /*, options, env */ ) {\n-                    return tokens[idx].content;\n-                };\n+                var _codemirror = _interopRequireDefault(__webpack_require__( /*! codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"));\n+                var _graphqlLanguageService = __webpack_require__( /*! graphql-language-service */ \"../../graphql-language-service/esm/index.js\");\n \n-                /**\n-                 * new Renderer()\n-                 *\n-                 * Creates new [[Renderer]] instance and fill [[Renderer#rules]] with defaults.\n-                 **/\n-                function Renderer() {\n-                    /**\n-                     * Renderer#rules -> Object\n-                     *\n-                     * Contains render rules for tokens. Can be updated and extended.\n-                     *\n-                     * ##### Example\n-                     *\n-                     * ```javascript\n-                     * var md = require('markdown-it')();\n-                     *\n-                     * md.renderer.rules.strong_open  = function () { return '<b>'; };\n-                     * md.renderer.rules.strong_close = function () { return '</b>'; };\n-                     *\n-                     * var result = md.renderInline(...);\n-                     * ```\n-                     *\n-                     * Each rule is called as independent static function with fixed signature:\n-                     *\n-                     * ```javascript\n-                     * function my_token_render(tokens, idx, options, env, renderer) {\n-                     *   // ...\n-                     *   return renderedHTML;\n-                     * }\n-                     * ```\n-                     *\n-                     * See [source code](https://github.com/markdown-it/markdown-it/blob/master/lib/renderer.mjs)\n-                     * for more details and examples.\n-                     **/\n-                    this.rules = assign({}, default_rules);\n+                function _interopRequireDefault(obj) {\n+                    return obj && obj.__esModule ? obj : {\n+                        default: obj\n+                    };\n                 }\n-\n-                /**\n-                 * Renderer.renderAttrs(token) -> String\n-                 *\n-                 * Render token attributes to string.\n-                 **/\n-                Renderer.prototype.renderAttrs = function renderAttrs(token) {\n-                    let i, l, result;\n-                    if (!token.attrs) {\n-                        return '';\n-                    }\n-                    result = '';\n-                    for (i = 0, l = token.attrs.length; i < l; i++) {\n-                        result += ' ' + escapeHtml(token.attrs[i][0]) + '=\"' + escapeHtml(token.attrs[i][1]) + '\"';\n-                    }\n-                    return result;\n+                const SEVERITY = ['error', 'warning', 'information', 'hint'];\n+                const TYPE = {\n+                    'GraphQL: Validation': 'validation',\n+                    'GraphQL: Deprecation': 'deprecation',\n+                    'GraphQL: Syntax': 'syntax'\n                 };\n+                _codemirror.default.registerHelper('lint', 'graphql', (text, options) => {\n+                    const {\n+                        schema,\n+                        validationRules,\n+                        externalFragments\n+                    } = options;\n+                    const rawResults = (0, _graphqlLanguageService.getDiagnostics)(text, schema, validationRules, undefined, externalFragments);\n+                    const results = rawResults.map(error => ({\n+                        message: error.message,\n+                        severity: error.severity ? SEVERITY[error.severity - 1] : SEVERITY[0],\n+                        type: error.source ? TYPE[error.source] : undefined,\n+                        from: _codemirror.default.Pos(error.range.start.line, error.range.start.character),\n+                        to: _codemirror.default.Pos(error.range.end.line, error.range.end.character)\n+                    }));\n+                    return results;\n+                });\n \n-                /**\n-                 * Renderer.renderToken(tokens, idx, options) -> String\n-                 * - tokens (Array): list of tokens\n-                 * - idx (Numbed): token index to render\n-                 * - options (Object): params of parser instance\n-                 *\n-                 * Default token renderer. Can be overriden by custom function\n-                 * in [[Renderer#rules]].\n-                 **/\n-                Renderer.prototype.renderToken = function renderToken(tokens, idx, options) {\n-                    const token = tokens[idx];\n-                    let result = '';\n-\n-                    // Tight list paragraphs\n-                    if (token.hidden) {\n-                        return '';\n-                    }\n-\n-                    // Insert a newline between hidden paragraph and subsequent opening\n-                    // block-level tag.\n-                    //\n-                    // For example, here we should insert a newline before blockquote:\n-                    //  - a\n-                    //    >\n-                    //\n-                    if (token.block && token.nesting !== -1 && idx && tokens[idx - 1].hidden) {\n-                        result += '\\n';\n-                    }\n+                /***/\n+            }),\n \n-                    // Add token name, e.g. `<img`\n-                    result += (token.nesting === -1 ? '</' : '<') + token.tag;\n+        /***/\n+        \"../../codemirror-graphql/esm/mode.js\":\n+            /*!********************************************!*\\\n+              !*** ../../codemirror-graphql/esm/mode.js ***!\n+              \\********************************************/\n+            /***/\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n \n-                    // Encode attributes, e.g. `<img src=\"foo\"`\n-                    result += this.renderAttrs(token);\n+                \"use strict\";\n \n-                    // Add a slash for self-closing tags, e.g. `<img src=\"foo\" /`\n-                    if (token.nesting === 0 && options.xhtmlOut) {\n-                        result += ' /';\n-                    }\n \n-                    // Check if we need to add a newline after this tag\n-                    let needLf = false;\n-                    if (token.block) {\n-                        needLf = true;\n-                        if (token.nesting === 1) {\n-                            if (idx + 1 < tokens.length) {\n-                                const nextToken = tokens[idx + 1];\n-                                if (nextToken.type === 'inline' || nextToken.hidden) {\n-                                    // Block-level tag containing an inline tag.\n-                                    //\n-                                    needLf = false;\n-                                } else if (nextToken.nesting === -1 && nextToken.tag === token.tag) {\n-                                    // Opening tag + closing tag of the same type. E.g. `<li></li>`.\n-                                    //\n-                                    needLf = false;\n-                                }\n-                            }\n-                        }\n-                    }\n-                    result += needLf ? '>\\n' : '>';\n-                    return result;\n-                };\n+                var _codemirror = _interopRequireDefault(__webpack_require__( /*! codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"));\n+                var _modeFactory = _interopRequireDefault(__webpack_require__( /*! ./utils/mode-factory */ \"../../codemirror-graphql/esm/utils/mode-factory.js\"));\n \n-                /**\n-                 * Renderer.renderInline(tokens, options, env) -> String\n-                 * - tokens (Array): list on block tokens to render\n-                 * - options (Object): params of parser instance\n-                 * - env (Object): additional data from parsed input (references, for example)\n-                 *\n-                 * The same as [[Renderer.render]], but for single token of `inline` type.\n-                 **/\n-                Renderer.prototype.renderInline = function(tokens, options, env) {\n-                    let result = '';\n-                    const rules = this.rules;\n-                    for (let i = 0, len = tokens.length; i < len; i++) {\n-                        const type = tokens[i].type;\n-                        if (typeof rules[type] !== 'undefined') {\n-                            result += rules[type](tokens, i, options, env, this);\n-                        } else {\n-                            result += this.renderToken(tokens, i, options);\n-                        }\n-                    }\n-                    return result;\n-                };\n+                function _interopRequireDefault(obj) {\n+                    return obj && obj.__esModule ? obj : {\n+                        default: obj\n+                    };\n+                }\n+                _codemirror.default.defineMode('graphql', _modeFactory.default);\n \n-                /** internal\n-                 * Renderer.renderInlineAsText(tokens, options, env) -> String\n-                 * - tokens (Array): list on block tokens to render\n-                 * - options (Object): params of parser instance\n-                 * - env (Object): additional data from parsed input (references, for example)\n-                 *\n-                 * Special kludge for image `alt` attributes to conform CommonMark spec.\n-                 * Don't try to use it! Spec requires to show `alt` content with stripped markup,\n-                 * instead of simple escaping.\n-                 **/\n-                Renderer.prototype.renderInlineAsText = function(tokens, options, env) {\n-                    let result = '';\n-                    for (let i = 0, len = tokens.length; i < len; i++) {\n-                        switch (tokens[i].type) {\n-                            case 'text':\n-                                result += tokens[i].content;\n-                                break;\n-                            case 'image':\n-                                result += this.renderInlineAsText(tokens[i].children, options, env);\n-                                break;\n-                            case 'html_inline':\n-                            case 'html_block':\n-                                result += tokens[i].content;\n-                                break;\n-                            case 'softbreak':\n-                            case 'hardbreak':\n-                                result += '\\n';\n-                                break;\n-                                // all other tokens are skipped\n-                        }\n-                    }\n+                /***/\n+            }),\n \n-                    return result;\n-                };\n+        /***/\n+        \"../../codemirror-graphql/esm/results/mode.js\":\n+            /*!****************************************************!*\\\n+              !*** ../../codemirror-graphql/esm/results/mode.js ***!\n+              \\****************************************************/\n+            /***/\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n \n-                /**\n-                 * Renderer.render(tokens, options, env) -> String\n-                 * - tokens (Array): list on block tokens to render\n-                 * - options (Object): params of parser instance\n-                 * - env (Object): additional data from parsed input (references, for example)\n-                 *\n-                 * Takes token stream and generates HTML. Probably, you will never need to call\n-                 * this method directly.\n-                 **/\n-                Renderer.prototype.render = function(tokens, options, env) {\n-                    let result = '';\n-                    const rules = this.rules;\n-                    for (let i = 0, len = tokens.length; i < len; i++) {\n-                        const type = tokens[i].type;\n-                        if (type === 'inline') {\n-                            result += this.renderInline(tokens[i].children, options, env);\n-                        } else if (typeof rules[type] !== 'undefined') {\n-                            result += rules[type](tokens, i, options, env, this);\n-                        } else {\n-                            result += this.renderToken(tokens, i, options, env);\n-                        }\n-                    }\n-                    return result;\n-                };\n+                \"use strict\";\n \n-                /**\n-                 * class Ruler\n-                 *\n-                 * Helper class, used by [[MarkdownIt#core]], [[MarkdownIt#block]] and\n-                 * [[MarkdownIt#inline]] to manage sequences of functions (rules):\n-                 *\n-                 * - keep rules in defined order\n-                 * - assign the name to each rule\n-                 * - enable/disable rules\n-                 * - add/replace rules\n-                 * - allow assign rules to additional named chains (in the same)\n-                 * - cacheing lists of active rules\n-                 *\n-                 * You will not need use this class directly until write plugins. For simple\n-                 * rules control use [[MarkdownIt.disable]], [[MarkdownIt.enable]] and\n-                 * [[MarkdownIt.use]].\n-                 **/\n \n-                /**\n-                 * new Ruler()\n-                 **/\n-                function Ruler() {\n-                    // List of added rules. Each element is:\n-                    //\n-                    // {\n-                    //   name: XXX,\n-                    //   enabled: Boolean,\n-                    //   fn: Function(),\n-                    //   alt: [ name2, name3 ]\n-                    // }\n-                    //\n-                    this.__rules__ = [];\n+                var _codemirror = _interopRequireDefault(__webpack_require__( /*! codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"));\n+                var _graphqlLanguageService = __webpack_require__( /*! graphql-language-service */ \"../../graphql-language-service/esm/index.js\");\n+                var _modeIndent = _interopRequireDefault(__webpack_require__( /*! ../utils/mode-indent */ \"../../codemirror-graphql/esm/utils/mode-indent.js\"));\n \n-                    // Cached rule chains.\n-                    //\n-                    // First level - chain name, '' for default.\n-                    // Second level - diginal anchor for fast filtering by charcodes.\n-                    //\n-                    this.__cache__ = null;\n+                function _interopRequireDefault(obj) {\n+                    return obj && obj.__esModule ? obj : {\n+                        default: obj\n+                    };\n                 }\n-\n-                // Helper methods, should not be used directly\n-\n-                // Find rule index by name\n-                //\n-                Ruler.prototype.__find__ = function(name) {\n-                    for (let i = 0; i < this.__rules__.length; i++) {\n-                        if (this.__rules__[i].name === name) {\n-                            return i;\n-                        }\n-                    }\n-                    return -1;\n-                };\n-\n-                // Build rules lookup cache\n-                //\n-                Ruler.prototype.__compile__ = function() {\n-                    const self = this;\n-                    const chains = [''];\n-\n-                    // collect unique names\n-                    self.__rules__.forEach(function(rule) {\n-                        if (!rule.enabled) {\n-                            return;\n+                _codemirror.default.defineMode('graphql-results', config => {\n+                    const parser = (0, _graphqlLanguageService.onlineParser)({\n+                        eatWhitespace: stream => stream.eatSpace(),\n+                        lexRules: LexRules,\n+                        parseRules: ParseRules,\n+                        editorConfig: {\n+                            tabSize: config.tabSize\n                         }\n-                        rule.alt.forEach(function(altName) {\n-                            if (chains.indexOf(altName) < 0) {\n-                                chains.push(altName);\n-                            }\n-                        });\n-                    });\n-                    self.__cache__ = {};\n-                    chains.forEach(function(chain) {\n-                        self.__cache__[chain] = [];\n-                        self.__rules__.forEach(function(rule) {\n-                            if (!rule.enabled) {\n-                                return;\n-                            }\n-                            if (chain && rule.alt.indexOf(chain) < 0) {\n-                                return;\n-                            }\n-                            self.__cache__[chain].push(rule.fn);\n-                        });\n-                    });\n-                };\n-\n-                /**\n-                 * Ruler.at(name, fn [, options])\n-                 * - name (String): rule name to replace.\n-                 * - fn (Function): new rule function.\n-                 * - options (Object): new rule options (not mandatory).\n-                 *\n-                 * Replace rule by name with new function & options. Throws error if name not\n-                 * found.\n-                 *\n-                 * ##### Options:\n-                 *\n-                 * - __alt__ - array with names of \"alternate\" chains.\n-                 *\n-                 * ##### Example\n-                 *\n-                 * Replace existing typographer replacement rule with new one:\n-                 *\n-                 * ```javascript\n-                 * var md = require('markdown-it')();\n-                 *\n-                 * md.core.ruler.at('replacements', function replace(state) {\n-                 *   //...\n-                 * });\n-                 * ```\n-                 **/\n-                Ruler.prototype.at = function(name, fn, options) {\n-                    const index = this.__find__(name);\n-                    const opt = options || {};\n-                    if (index === -1) {\n-                        throw new Error('Parser rule not found: ' + name);\n-                    }\n-                    this.__rules__[index].fn = fn;\n-                    this.__rules__[index].alt = opt.alt || [];\n-                    this.__cache__ = null;\n-                };\n-\n-                /**\n-                 * Ruler.before(beforeName, ruleName, fn [, options])\n-                 * - beforeName (String): new rule will be added before this one.\n-                 * - ruleName (String): name of added rule.\n-                 * - fn (Function): rule function.\n-                 * - options (Object): rule options (not mandatory).\n-                 *\n-                 * Add new rule to chain before one with given name. See also\n-                 * [[Ruler.after]], [[Ruler.push]].\n-                 *\n-                 * ##### Options:\n-                 *\n-                 * - __alt__ - array with names of \"alternate\" chains.\n-                 *\n-                 * ##### Example\n-                 *\n-                 * ```javascript\n-                 * var md = require('markdown-it')();\n-                 *\n-                 * md.block.ruler.before('paragraph', 'my_rule', function replace(state) {\n-                 *   //...\n-                 * });\n-                 * ```\n-                 **/\n-                Ruler.prototype.before = function(beforeName, ruleName, fn, options) {\n-                    const index = this.__find__(beforeName);\n-                    const opt = options || {};\n-                    if (index === -1) {\n-                        throw new Error('Parser rule not found: ' + beforeName);\n-                    }\n-                    this.__rules__.splice(index, 0, {\n-                        name: ruleName,\n-                        enabled: true,\n-                        fn,\n-                        alt: opt.alt || []\n                     });\n-                    this.__cache__ = null;\n+                    return {\n+                        config,\n+                        startState: parser.startState,\n+                        token: parser.token,\n+                        indent: _modeIndent.default,\n+                        electricInput: /^\\s*[}\\]]/,\n+                        fold: 'brace',\n+                        closeBrackets: {\n+                            pairs: '[]{}\"\"',\n+                            explode: '[]{}'\n+                        }\n+                    };\n+                });\n+                const LexRules = {\n+                    Punctuation: /^\\[|]|\\{|\\}|:|,/,\n+                    Number: /^-?(?:0|(?:[1-9][0-9]*))(?:\\.[0-9]*)?(?:[eE][+-]?[0-9]+)?/,\n+                    String: /^\"(?:[^\"\\\\]|\\\\(?:\"|\\/|\\\\|b|f|n|r|t|u[0-9a-fA-F]{4}))*\"?/,\n+                    Keyword: /^true|false|null/\n                 };\n-\n-                /**\n-                 * Ruler.after(afterName, ruleName, fn [, options])\n-                 * - afterName (String): new rule will be added after this one.\n-                 * - ruleName (String): name of added rule.\n-                 * - fn (Function): rule function.\n-                 * - options (Object): rule options (not mandatory).\n-                 *\n-                 * Add new rule to chain after one with given name. See also\n-                 * [[Ruler.before]], [[Ruler.push]].\n-                 *\n-                 * ##### Options:\n-                 *\n-                 * - __alt__ - array with names of \"alternate\" chains.\n-                 *\n-                 * ##### Example\n-                 *\n-                 * ```javascript\n-                 * var md = require('markdown-it')();\n-                 *\n-                 * md.inline.ruler.after('text', 'my_rule', function replace(state) {\n-                 *   //...\n-                 * });\n-                 * ```\n-                 **/\n-                Ruler.prototype.after = function(afterName, ruleName, fn, options) {\n-                    const index = this.__find__(afterName);\n-                    const opt = options || {};\n-                    if (index === -1) {\n-                        throw new Error('Parser rule not found: ' + afterName);\n-                    }\n-                    this.__rules__.splice(index + 1, 0, {\n-                        name: ruleName,\n-                        enabled: true,\n-                        fn,\n-                        alt: opt.alt || []\n-                    });\n-                    this.__cache__ = null;\n+                const ParseRules = {\n+                    Document: [(0, _graphqlLanguageService.p)('{'), (0, _graphqlLanguageService.list)('Entry', (0, _graphqlLanguageService.p)(',')), (0, _graphqlLanguageService.p)('}')],\n+                    Entry: [(0, _graphqlLanguageService.t)('String', 'def'), (0, _graphqlLanguageService.p)(':'), 'Value'],\n+                    Value(token) {\n+                        switch (token.kind) {\n+                            case 'Number':\n+                                return 'NumberValue';\n+                            case 'String':\n+                                return 'StringValue';\n+                            case 'Punctuation':\n+                                switch (token.value) {\n+                                    case '[':\n+                                        return 'ListValue';\n+                                    case '{':\n+                                        return 'ObjectValue';\n+                                }\n+                                return null;\n+                            case 'Keyword':\n+                                switch (token.value) {\n+                                    case 'true':\n+                                    case 'false':\n+                                        return 'BooleanValue';\n+                                    case 'null':\n+                                        return 'NullValue';\n+                                }\n+                                return null;\n+                        }\n+                    },\n+                    NumberValue: [(0, _graphqlLanguageService.t)('Number', 'number')],\n+                    StringValue: [(0, _graphqlLanguageService.t)('String', 'string')],\n+                    BooleanValue: [(0, _graphqlLanguageService.t)('Keyword', 'builtin')],\n+                    NullValue: [(0, _graphqlLanguageService.t)('Keyword', 'keyword')],\n+                    ListValue: [(0, _graphqlLanguageService.p)('['), (0, _graphqlLanguageService.list)('Value', (0, _graphqlLanguageService.p)(',')), (0, _graphqlLanguageService.p)(']')],\n+                    ObjectValue: [(0, _graphqlLanguageService.p)('{'), (0, _graphqlLanguageService.list)('ObjectField', (0, _graphqlLanguageService.p)(',')), (0, _graphqlLanguageService.p)('}')],\n+                    ObjectField: [(0, _graphqlLanguageService.t)('String', 'property'), (0, _graphqlLanguageService.p)(':'), 'Value']\n                 };\n \n-                /**\n-                 * Ruler.push(ruleName, fn [, options])\n-                 * - ruleName (String): name of added rule.\n-                 * - fn (Function): rule function.\n-                 * - options (Object): rule options (not mandatory).\n-                 *\n-                 * Push new rule to the end of chain. See also\n-                 * [[Ruler.before]], [[Ruler.after]].\n-                 *\n-                 * ##### Options:\n-                 *\n-                 * - __alt__ - array with names of \"alternate\" chains.\n-                 *\n-                 * ##### Example\n-                 *\n-                 * ```javascript\n-                 * var md = require('markdown-it')();\n-                 *\n-                 * md.core.ruler.push('my_rule', function replace(state) {\n-                 *   //...\n-                 * });\n-                 * ```\n-                 **/\n-                Ruler.prototype.push = function(ruleName, fn, options) {\n-                    const opt = options || {};\n-                    this.__rules__.push({\n-                        name: ruleName,\n-                        enabled: true,\n-                        fn,\n-                        alt: opt.alt || []\n-                    });\n-                    this.__cache__ = null;\n-                };\n+                /***/\n+            }),\n \n-                /**\n-                 * Ruler.enable(list [, ignoreInvalid]) -> Array\n-                 * - list (String|Array): list of rule names to enable.\n-                 * - ignoreInvalid (Boolean): set `true` to ignore errors when rule not found.\n-                 *\n-                 * Enable rules with given names. If any rule name not found - throw Error.\n-                 * Errors can be disabled by second param.\n-                 *\n-                 * Returns list of found rule names (if no exception happened).\n-                 *\n-                 * See also [[Ruler.disable]], [[Ruler.enableOnly]].\n-                 **/\n-                Ruler.prototype.enable = function(list, ignoreInvalid) {\n-                    if (!Array.isArray(list)) {\n-                        list = [list];\n-                    }\n-                    const result = [];\n+        /***/\n+        \"../../codemirror-graphql/esm/utils/SchemaReference.js\":\n+            /*!*************************************************************!*\\\n+              !*** ../../codemirror-graphql/esm/utils/SchemaReference.js ***!\n+              \\*************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                    // Search by name and enable\n-                    list.forEach(function(name) {\n-                        const idx = this.__find__(name);\n-                        if (idx < 0) {\n-                            if (ignoreInvalid) {\n-                                return;\n-                            }\n-                            throw new Error('Rules manager: invalid rule name ' + name);\n-                        }\n-                        this.__rules__[idx].enabled = true;\n-                        result.push(name);\n-                    }, this);\n-                    this.__cache__ = null;\n-                    return result;\n-                };\n+                \"use strict\";\n \n-                /**\n-                 * Ruler.enableOnly(list [, ignoreInvalid])\n-                 * - list (String|Array): list of rule names to enable (whitelist).\n-                 * - ignoreInvalid (Boolean): set `true` to ignore errors when rule not found.\n-                 *\n-                 * Enable rules with given names, and disable everything else. If any rule name\n-                 * not found - throw Error. Errors can be disabled by second param.\n-                 *\n-                 * See also [[Ruler.disable]], [[Ruler.enable]].\n-                 **/\n-                Ruler.prototype.enableOnly = function(list, ignoreInvalid) {\n-                    if (!Array.isArray(list)) {\n-                        list = [list];\n-                    }\n-                    this.__rules__.forEach(function(rule) {\n-                        rule.enabled = false;\n-                    });\n-                    this.enable(list, ignoreInvalid);\n-                };\n \n-                /**\n-                 * Ruler.disable(list [, ignoreInvalid]) -> Array\n-                 * - list (String|Array): list of rule names to disable.\n-                 * - ignoreInvalid (Boolean): set `true` to ignore errors when rule not found.\n-                 *\n-                 * Disable rules with given names. If any rule name not found - throw Error.\n-                 * Errors can be disabled by second param.\n-                 *\n-                 * Returns list of found rule names (if no exception happened).\n-                 *\n-                 * See also [[Ruler.enable]], [[Ruler.enableOnly]].\n-                 **/\n-                Ruler.prototype.disable = function(list, ignoreInvalid) {\n-                    if (!Array.isArray(list)) {\n-                        list = [list];\n-                    }\n-                    const result = [];\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.getArgumentReference = getArgumentReference;\n+                exports.getDirectiveReference = getDirectiveReference;\n+                exports.getEnumValueReference = getEnumValueReference;\n+                exports.getFieldReference = getFieldReference;\n+                exports.getTypeReference = getTypeReference;\n+                var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n \n-                    // Search by name and disable\n-                    list.forEach(function(name) {\n-                        const idx = this.__find__(name);\n-                        if (idx < 0) {\n-                            if (ignoreInvalid) {\n-                                return;\n-                            }\n-                            throw new Error('Rules manager: invalid rule name ' + name);\n-                        }\n-                        this.__rules__[idx].enabled = false;\n-                        result.push(name);\n-                    }, this);\n-                    this.__cache__ = null;\n-                    return result;\n-                };\n+                function getFieldReference(typeInfo) {\n+                    return {\n+                        kind: 'Field',\n+                        schema: typeInfo.schema,\n+                        field: typeInfo.fieldDef,\n+                        type: isMetaField(typeInfo.fieldDef) ? null : typeInfo.parentType\n+                    };\n+                }\n \n-                /**\n-                 * Ruler.getRules(chainName) -> Array\n-                 *\n-                 * Return array of active functions (rules) for given chain name. It analyzes\n-                 * rules configuration, compiles caches if not exists and returns result.\n-                 *\n-                 * Default chain name is `''` (empty string). It can't be skipped. That's\n-                 * done intentionally, to keep signature monomorphic for high speed.\n-                 **/\n-                Ruler.prototype.getRules = function(chainName) {\n-                    if (this.__cache__ === null) {\n-                        this.__compile__();\n-                    }\n+                function getDirectiveReference(typeInfo) {\n+                    return {\n+                        kind: 'Directive',\n+                        schema: typeInfo.schema,\n+                        directive: typeInfo.directiveDef\n+                    };\n+                }\n \n-                    // Chain can be empty, if rules disabled. But we still have to return Array.\n-                    return this.__cache__[chainName] || [];\n-                };\n+                function getArgumentReference(typeInfo) {\n+                    return typeInfo.directiveDef ? {\n+                        kind: 'Argument',\n+                        schema: typeInfo.schema,\n+                        argument: typeInfo.argDef,\n+                        directive: typeInfo.directiveDef\n+                    } : {\n+                        kind: 'Argument',\n+                        schema: typeInfo.schema,\n+                        argument: typeInfo.argDef,\n+                        field: typeInfo.fieldDef,\n+                        type: isMetaField(typeInfo.fieldDef) ? null : typeInfo.parentType\n+                    };\n+                }\n \n-                // Token class\n+                function getEnumValueReference(typeInfo) {\n+                    return {\n+                        kind: 'EnumValue',\n+                        value: typeInfo.enumValue || undefined,\n+                        type: typeInfo.inputType ? (0, _graphql.getNamedType)(typeInfo.inputType) : undefined\n+                    };\n+                }\n \n-                /**\n-                 * class Token\n-                 **/\n+                function getTypeReference(typeInfo, type) {\n+                    return {\n+                        kind: 'Type',\n+                        schema: typeInfo.schema,\n+                        type: type || typeInfo.type\n+                    };\n+                }\n \n-                /**\n-                 * new Token(type, tag, nesting)\n-                 *\n-                 * Create new token and fill passed properties.\n-                 **/\n-                function Token(type, tag, nesting) {\n-                    /**\n-                     * Token#type -> String\n-                     *\n-                     * Type of the token (string, e.g. \"paragraph_open\")\n-                     **/\n-                    this.type = type;\n+                function isMetaField(fieldDef) {\n+                    return fieldDef.name.slice(0, 2) === '__';\n+                }\n \n-                    /**\n-                     * Token#tag -> String\n-                     *\n-                     * html tag name, e.g. \"p\"\n-                     **/\n-                    this.tag = tag;\n+                /***/\n+            }),\n \n-                    /**\n-                     * Token#attrs -> Array\n-                     *\n-                     * Html attributes. Format: `[ [ name1, value1 ], [ name2, value2 ] ]`\n-                     **/\n-                    this.attrs = null;\n+        /***/\n+        \"../../codemirror-graphql/esm/utils/forEachState.js\":\n+            /*!**********************************************************!*\\\n+              !*** ../../codemirror-graphql/esm/utils/forEachState.js ***!\n+              \\**********************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports) {\n \n-                    /**\n-                     * Token#map -> Array\n-                     *\n-                     * Source map info. Format: `[ line_begin, line_end ]`\n-                     **/\n-                    this.map = null;\n+                \"use strict\";\n \n-                    /**\n-                     * Token#nesting -> Number\n-                     *\n-                     * Level change (number in {-1, 0, 1} set), where:\n-                     *\n-                     * -  `1` means the tag is opening\n-                     * -  `0` means the tag is self-closing\n-                     * - `-1` means the tag is closing\n-                     **/\n-                    this.nesting = nesting;\n \n-                    /**\n-                     * Token#level -> Number\n-                     *\n-                     * nesting level, the same as `state.level`\n-                     **/\n-                    this.level = 0;\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports[\"default\"] = forEachState;\n \n-                    /**\n-                     * Token#children -> Array\n-                     *\n-                     * An array of child nodes (inline and img tokens)\n-                     **/\n-                    this.children = null;\n+                function forEachState(stack, fn) {\n+                    const reverseStateStack = [];\n+                    let state = stack;\n+                    while (state === null || state === void 0 ? void 0 : state.kind) {\n+                        reverseStateStack.push(state);\n+                        state = state.prevState;\n+                    }\n+                    for (let i = reverseStateStack.length - 1; i >= 0; i--) {\n+                        fn(reverseStateStack[i]);\n+                    }\n+                }\n \n-                    /**\n-                     * Token#content -> String\n-                     *\n-                     * In a case of self-closing tag (code, html, fence, etc.),\n-                     * it has contents of this tag.\n-                     **/\n-                    this.content = '';\n+                /***/\n+            }),\n \n-                    /**\n-                     * Token#markup -> String\n-                     *\n-                     * '*' or '_' for emphasis, fence string for fence, etc.\n-                     **/\n-                    this.markup = '';\n+        /***/\n+        \"../../codemirror-graphql/esm/utils/getTypeInfo.js\":\n+            /*!*********************************************************!*\\\n+              !*** ../../codemirror-graphql/esm/utils/getTypeInfo.js ***!\n+              \\*********************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                    /**\n-                     * Token#info -> String\n-                     *\n-                     * Additional information:\n-                     *\n-                     * - Info string for \"fence\" tokens\n-                     * - The value \"auto\" for autolink \"link_open\" and \"link_close\" tokens\n-                     * - The string value of the item marker for ordered-list \"list_item_open\" tokens\n-                     **/\n-                    this.info = '';\n+                \"use strict\";\n \n-                    /**\n-                     * Token#meta -> Object\n-                     *\n-                     * A place for plugins to store an arbitrary data\n-                     **/\n-                    this.meta = null;\n \n-                    /**\n-                     * Token#block -> Boolean\n-                     *\n-                     * True for block-level tokens, false for inline tokens.\n-                     * Used in renderer to calculate line breaks\n-                     **/\n-                    this.block = false;\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports[\"default\"] = getTypeInfo;\n+                var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n+                var _forEachState = _interopRequireDefault(__webpack_require__( /*! ./forEachState */ \"../../codemirror-graphql/esm/utils/forEachState.js\"));\n \n-                    /**\n-                     * Token#hidden -> Boolean\n-                     *\n-                     * If it's true, ignore this element when rendering. Used for tight lists\n-                     * to hide paragraphs.\n-                     **/\n-                    this.hidden = false;\n+                function _interopRequireDefault(obj) {\n+                    return obj && obj.__esModule ? obj : {\n+                        default: obj\n+                    };\n                 }\n \n-                /**\n-                 * Token.attrIndex(name) -> Number\n-                 *\n-                 * Search attribute index by name.\n-                 **/\n-                Token.prototype.attrIndex = function attrIndex(name) {\n-                    if (!this.attrs) {\n-                        return -1;\n-                    }\n-                    const attrs = this.attrs;\n-                    for (let i = 0, len = attrs.length; i < len; i++) {\n-                        if (attrs[i][0] === name) {\n-                            return i;\n+                function getTypeInfo(schema, tokenState) {\n+                    const info = {\n+                        schema,\n+                        type: null,\n+                        parentType: null,\n+                        inputType: null,\n+                        directiveDef: null,\n+                        fieldDef: null,\n+                        argDef: null,\n+                        argDefs: null,\n+                        objectFieldDefs: null\n+                    };\n+                    (0, _forEachState.default)(tokenState, state => {\n+                        var _a, _b;\n+                        switch (state.kind) {\n+                            case 'Query':\n+                            case 'ShortQuery':\n+                                info.type = schema.getQueryType();\n+                                break;\n+                            case 'Mutation':\n+                                info.type = schema.getMutationType();\n+                                break;\n+                            case 'Subscription':\n+                                info.type = schema.getSubscriptionType();\n+                                break;\n+                            case 'InlineFragment':\n+                            case 'FragmentDefinition':\n+                                if (state.type) {\n+                                    info.type = schema.getType(state.type);\n+                                }\n+                                break;\n+                            case 'Field':\n+                            case 'AliasedField':\n+                                info.fieldDef = info.type && state.name ? getFieldDef(schema, info.parentType, state.name) : null;\n+                                info.type = (_a = info.fieldDef) === null || _a === void 0 ? void 0 : _a.type;\n+                                break;\n+                            case 'SelectionSet':\n+                                info.parentType = info.type ? (0, _graphql.getNamedType)(info.type) : null;\n+                                break;\n+                            case 'Directive':\n+                                info.directiveDef = state.name ? schema.getDirective(state.name) : null;\n+                                break;\n+                            case 'Arguments':\n+                                const parentDef = state.prevState ? state.prevState.kind === 'Field' ? info.fieldDef : state.prevState.kind === 'Directive' ? info.directiveDef : state.prevState.kind === 'AliasedField' ? state.prevState.name && getFieldDef(schema, info.parentType, state.prevState.name) : null : null;\n+                                info.argDefs = parentDef ? parentDef.args : null;\n+                                break;\n+                            case 'Argument':\n+                                info.argDef = null;\n+                                if (info.argDefs) {\n+                                    for (let i = 0; i < info.argDefs.length; i++) {\n+                                        if (info.argDefs[i].name === state.name) {\n+                                            info.argDef = info.argDefs[i];\n+                                            break;\n+                                        }\n+                                    }\n+                                }\n+                                info.inputType = (_b = info.argDef) === null || _b === void 0 ? void 0 : _b.type;\n+                                break;\n+                            case 'EnumValue':\n+                                const enumType = info.inputType ? (0, _graphql.getNamedType)(info.inputType) : null;\n+                                info.enumValue = enumType instanceof _graphql.GraphQLEnumType ? find(enumType.getValues(), val => val.value === state.name) : null;\n+                                break;\n+                            case 'ListValue':\n+                                const nullableType = info.inputType ? (0, _graphql.getNullableType)(info.inputType) : null;\n+                                info.inputType = nullableType instanceof _graphql.GraphQLList ? nullableType.ofType : null;\n+                                break;\n+                            case 'ObjectValue':\n+                                const objectType = info.inputType ? (0, _graphql.getNamedType)(info.inputType) : null;\n+                                info.objectFieldDefs = objectType instanceof _graphql.GraphQLInputObjectType ? objectType.getFields() : null;\n+                                break;\n+                            case 'ObjectField':\n+                                const objectField = state.name && info.objectFieldDefs ? info.objectFieldDefs[state.name] : null;\n+                                info.inputType = objectField === null || objectField === void 0 ? void 0 : objectField.type;\n+                                info.fieldDef = objectField;\n+                                break;\n+                            case 'NamedType':\n+                                info.type = state.name ? schema.getType(state.name) : null;\n+                                break;\n                         }\n-                    }\n-                    return -1;\n-                };\n+                    });\n+                    return info;\n+                }\n \n-                /**\n-                 * Token.attrPush(attrData)\n-                 *\n-                 * Add `[ name, value ]` attribute to list. Init attrs if necessary\n-                 **/\n-                Token.prototype.attrPush = function attrPush(attrData) {\n-                    if (this.attrs) {\n-                        this.attrs.push(attrData);\n-                    } else {\n-                        this.attrs = [attrData];\n+                function getFieldDef(schema, type, fieldName) {\n+                    if (fieldName === _graphql.SchemaMetaFieldDef.name && schema.getQueryType() === type) {\n+                        return _graphql.SchemaMetaFieldDef;\n                     }\n-                };\n-\n-                /**\n-                 * Token.attrSet(name, value)\n-                 *\n-                 * Set `name` attribute to `value`. Override old value if exists.\n-                 **/\n-                Token.prototype.attrSet = function attrSet(name, value) {\n-                    const idx = this.attrIndex(name);\n-                    const attrData = [name, value];\n-                    if (idx < 0) {\n-                        this.attrPush(attrData);\n-                    } else {\n-                        this.attrs[idx] = attrData;\n+                    if (fieldName === _graphql.TypeMetaFieldDef.name && schema.getQueryType() === type) {\n+                        return _graphql.TypeMetaFieldDef;\n                     }\n-                };\n-\n-                /**\n-                 * Token.attrGet(name)\n-                 *\n-                 * Get the value of attribute `name`, or null if it does not exist.\n-                 **/\n-                Token.prototype.attrGet = function attrGet(name) {\n-                    const idx = this.attrIndex(name);\n-                    let value = null;\n-                    if (idx >= 0) {\n-                        value = this.attrs[idx][1];\n+                    if (fieldName === _graphql.TypeNameMetaFieldDef.name && (0, _graphql.isCompositeType)(type)) {\n+                        return _graphql.TypeNameMetaFieldDef;\n                     }\n-                    return value;\n-                };\n-\n-                /**\n-                 * Token.attrJoin(name, value)\n-                 *\n-                 * Join value to existing attribute via space. Or create new attribute if not\n-                 * exists. Useful to operate with token classes.\n-                 **/\n-                Token.prototype.attrJoin = function attrJoin(name, value) {\n-                    const idx = this.attrIndex(name);\n-                    if (idx < 0) {\n-                        this.attrPush([name, value]);\n-                    } else {\n-                        this.attrs[idx][1] = this.attrs[idx][1] + ' ' + value;\n+                    if (type && type.getFields) {\n+                        return type.getFields()[fieldName];\n                     }\n-                };\n-\n-                // Core state object\n-                //\n-\n-                function StateCore(src, md, env) {\n-                    this.src = src;\n-                    this.env = env;\n-                    this.tokens = [];\n-                    this.inlineMode = false;\n-                    this.md = md; // link to parser instance\n                 }\n \n-                // re-export Token class to use in core rules\n-                StateCore.prototype.Token = Token;\n+                function find(array, predicate) {\n+                    for (let i = 0; i < array.length; i++) {\n+                        if (predicate(array[i])) {\n+                            return array[i];\n+                        }\n+                    }\n+                }\n \n-                // Normalize input string\n+                /***/\n+            }),\n \n-                // https://spec.commonmark.org/0.29/#line-ending\n-                const NEWLINES_RE = /\\r\\n?|\\n/g;\n-                const NULL_RE = /\\0/g;\n+        /***/\n+        \"../../codemirror-graphql/esm/utils/hintList.js\":\n+            /*!******************************************************!*\\\n+              !*** ../../codemirror-graphql/esm/utils/hintList.js ***!\n+              \\******************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports) {\n \n-                function normalize(state) {\n-                    let str;\n+                \"use strict\";\n \n-                    // Normalize newlines\n-                    str = state.src.replace(NEWLINES_RE, '\\n');\n \n-                    // Replace NULL characters\n-                    str = str.replace(NULL_RE, '\\uFFFD');\n-                    state.src = str;\n-                }\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports[\"default\"] = hintList;\n \n-                function block(state) {\n-                    let token;\n-                    if (state.inlineMode) {\n-                        token = new state.Token('inline', '', 0);\n-                        token.content = state.src;\n-                        token.map = [0, 1];\n-                        token.children = [];\n-                        state.tokens.push(token);\n-                    } else {\n-                        state.md.block.parse(state.src, state.md, state.env, state.tokens);\n+                function hintList(cursor, token, list) {\n+                    const hints = filterAndSortList(list, normalizeText(token.string));\n+                    if (!hints) {\n+                        return;\n                     }\n+                    const tokenStart = token.type !== null && /\"|\\w/.test(token.string[0]) ? token.start : token.end;\n+                    return {\n+                        list: hints,\n+                        from: {\n+                            line: cursor.line,\n+                            ch: tokenStart\n+                        },\n+                        to: {\n+                            line: cursor.line,\n+                            ch: token.end\n+                        }\n+                    };\n                 }\n \n-                function inline(state) {\n-                    const tokens = state.tokens;\n-\n-                    // Parse inlines\n-                    for (let i = 0, l = tokens.length; i < l; i++) {\n-                        const tok = tokens[i];\n-                        if (tok.type === 'inline') {\n-                            state.md.inline.parse(tok.content, state.md, state.env, tok.children);\n-                        }\n+                function filterAndSortList(list, text) {\n+                    if (!text) {\n+                        return filterNonEmpty(list, entry => !entry.isDeprecated);\n                     }\n+                    const byProximity = list.map(entry => ({\n+                        proximity: getProximity(normalizeText(entry.text), text),\n+                        entry\n+                    }));\n+                    const conciseMatches = filterNonEmpty(filterNonEmpty(byProximity, pair => pair.proximity <= 2), pair => !pair.entry.isDeprecated);\n+                    const sortedMatches = conciseMatches.sort((a, b) => (a.entry.isDeprecated ? 1 : 0) - (b.entry.isDeprecated ? 1 : 0) || a.proximity - b.proximity || a.entry.text.length - b.entry.text.length);\n+                    return sortedMatches.map(pair => pair.entry);\n                 }\n \n-                // Replace link-like texts with link nodes.\n-                //\n-                // Currently restricted by `md.validateLink()` to http/https/ftp\n-                //\n+                function filterNonEmpty(array, predicate) {\n+                    const filtered = array.filter(predicate);\n+                    return filtered.length === 0 ? array : filtered;\n+                }\n \n-                function isLinkOpen$1(str) {\n-                    return /^<a[>\\s]/i.test(str);\n+                function normalizeText(text) {\n+                    return text.toLowerCase().replaceAll(/\\W/g, '');\n                 }\n \n-                function isLinkClose$1(str) {\n-                    return /^<\\/a\\s*>/i.test(str);\n+                function getProximity(suggestion, text) {\n+                    let proximity = lexicalDistance(text, suggestion);\n+                    if (suggestion.length > text.length) {\n+                        proximity -= suggestion.length - text.length - 1;\n+                        proximity += suggestion.indexOf(text) === 0 ? 0 : 0.5;\n+                    }\n+                    return proximity;\n                 }\n \n-                function linkify$1(state) {\n-                    const blockTokens = state.tokens;\n-                    if (!state.md.options.linkify) {\n-                        return;\n+                function lexicalDistance(a, b) {\n+                    let i;\n+                    let j;\n+                    const d = [];\n+                    const aLength = a.length;\n+                    const bLength = b.length;\n+                    for (i = 0; i <= aLength; i++) {\n+                        d[i] = [i];\n                     }\n-                    for (let j = 0, l = blockTokens.length; j < l; j++) {\n-                        if (blockTokens[j].type !== 'inline' || !state.md.linkify.pretest(blockTokens[j].content)) {\n-                            continue;\n+                    for (j = 1; j <= bLength; j++) {\n+                        d[0][j] = j;\n+                    }\n+                    for (i = 1; i <= aLength; i++) {\n+                        for (j = 1; j <= bLength; j++) {\n+                            const cost = a[i - 1] === b[j - 1] ? 0 : 1;\n+                            d[i][j] = Math.min(d[i - 1][j] + 1, d[i][j - 1] + 1, d[i - 1][j - 1] + cost);\n+                            if (i > 1 && j > 1 && a[i - 1] === b[j - 2] && a[i - 2] === b[j - 1]) {\n+                                d[i][j] = Math.min(d[i][j], d[i - 2][j - 2] + cost);\n+                            }\n                         }\n-                        let tokens = blockTokens[j].children;\n-                        let htmlLinkLevel = 0;\n+                    }\n+                    return d[aLength][bLength];\n+                }\n \n-                        // We scan from the end, to keep position when new tags added.\n-                        // Use reversed logic in links start/end match\n-                        for (let i = tokens.length - 1; i >= 0; i--) {\n-                            const currentToken = tokens[i];\n+                /***/\n+            }),\n \n-                            // Skip content of markdown links\n-                            if (currentToken.type === 'link_close') {\n-                                i--;\n-                                while (tokens[i].level !== currentToken.level && tokens[i].type !== 'link_open') {\n-                                    i--;\n-                                }\n-                                continue;\n-                            }\n+        /***/\n+        \"../../codemirror-graphql/esm/utils/info-addon.js\":\n+            /*!********************************************************!*\\\n+              !*** ../../codemirror-graphql/esm/utils/info-addon.js ***!\n+              \\********************************************************/\n+            /***/\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n \n-                            // Skip content of html tag links\n-                            if (currentToken.type === 'html_inline') {\n-                                if (isLinkOpen$1(currentToken.content) && htmlLinkLevel > 0) {\n-                                    htmlLinkLevel--;\n-                                }\n-                                if (isLinkClose$1(currentToken.content)) {\n-                                    htmlLinkLevel++;\n-                                }\n-                            }\n-                            if (htmlLinkLevel > 0) {\n-                                continue;\n-                            }\n-                            if (currentToken.type === 'text' && state.md.linkify.test(currentToken.content)) {\n-                                const text = currentToken.content;\n-                                let links = state.md.linkify.match(text);\n+                \"use strict\";\n \n-                                // Now split string to nodes\n-                                const nodes = [];\n-                                let level = currentToken.level;\n-                                let lastPos = 0;\n \n-                                // forbid escape sequence at the start of the string,\n-                                // this avoids http\\://example.com/ from being linkified as\n-                                // http:<a href=\"//example.com/\">//example.com/</a>\n-                                if (links.length > 0 && links[0].index === 0 && i > 0 && tokens[i - 1].type === 'text_special') {\n-                                    links = links.slice(1);\n-                                }\n-                                for (let ln = 0; ln < links.length; ln++) {\n-                                    const url = links[ln].url;\n-                                    const fullUrl = state.md.normalizeLink(url);\n-                                    if (!state.md.validateLink(fullUrl)) {\n-                                        continue;\n-                                    }\n-                                    let urlText = links[ln].text;\n+                var _codemirror = _interopRequireDefault(__webpack_require__( /*! codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"));\n \n-                                    // Linkifier might send raw hostnames like \"example.com\", where url\n-                                    // starts with domain name. So we prepend http:// in those cases,\n-                                    // and remove it afterwards.\n-                                    //\n-                                    if (!links[ln].schema) {\n-                                        urlText = state.md.normalizeLinkText('http://' + urlText).replace(/^http:\\/\\//, '');\n-                                    } else if (links[ln].schema === 'mailto:' && !/^mailto:/i.test(urlText)) {\n-                                        urlText = state.md.normalizeLinkText('mailto:' + urlText).replace(/^mailto:/, '');\n-                                    } else {\n-                                        urlText = state.md.normalizeLinkText(urlText);\n-                                    }\n-                                    const pos = links[ln].index;\n-                                    if (pos > lastPos) {\n-                                        const token = new state.Token('text', '', 0);\n-                                        token.content = text.slice(lastPos, pos);\n-                                        token.level = level;\n-                                        nodes.push(token);\n-                                    }\n-                                    const token_o = new state.Token('link_open', 'a', 1);\n-                                    token_o.attrs = [\n-                                        ['href', fullUrl]\n-                                    ];\n-                                    token_o.level = level++;\n-                                    token_o.markup = 'linkify';\n-                                    token_o.info = 'auto';\n-                                    nodes.push(token_o);\n-                                    const token_t = new state.Token('text', '', 0);\n-                                    token_t.content = urlText;\n-                                    token_t.level = level;\n-                                    nodes.push(token_t);\n-                                    const token_c = new state.Token('link_close', 'a', -1);\n-                                    token_c.level = --level;\n-                                    token_c.markup = 'linkify';\n-                                    token_c.info = 'auto';\n-                                    nodes.push(token_c);\n-                                    lastPos = links[ln].lastIndex;\n-                                }\n-                                if (lastPos < text.length) {\n-                                    const token = new state.Token('text', '', 0);\n-                                    token.content = text.slice(lastPos);\n-                                    token.level = level;\n-                                    nodes.push(token);\n-                                }\n+                function _interopRequireDefault(obj) {\n+                    return obj && obj.__esModule ? obj : {\n+                        default: obj\n+                    };\n+                }\n+                _codemirror.default.defineOption('info', false, (cm, options, old) => {\n+                    if (old && old !== _codemirror.default.Init) {\n+                        const oldOnMouseOver = cm.state.info.onMouseOver;\n+                        _codemirror.default.off(cm.getWrapperElement(), 'mouseover', oldOnMouseOver);\n+                        clearTimeout(cm.state.info.hoverTimeout);\n+                        delete cm.state.info;\n+                    }\n+                    if (options) {\n+                        const state = cm.state.info = createState(options);\n+                        state.onMouseOver = onMouseOver.bind(null, cm);\n+                        _codemirror.default.on(cm.getWrapperElement(), 'mouseover', state.onMouseOver);\n+                    }\n+                });\n \n-                                // replace current node\n-                                blockTokens[j].children = tokens = arrayReplaceAt(tokens, i, nodes);\n+                function createState(options) {\n+                    return {\n+                        options: options instanceof Function ? {\n+                            render: options\n+                        } : options === true ? {} : options\n+                    };\n+                }\n+\n+                function getHoverTime(cm) {\n+                    const {\n+                        options\n+                    } = cm.state.info;\n+                    return (options === null || options === void 0 ? void 0 : options.hoverTime) || 500;\n+                }\n+\n+                function onMouseOver(cm, e) {\n+                    const state = cm.state.info;\n+                    const target = e.target || e.srcElement;\n+                    if (!(target instanceof HTMLElement)) {\n+                        return;\n+                    }\n+                    if (target.nodeName !== 'SPAN' || state.hoverTimeout !== undefined) {\n+                        return;\n+                    }\n+                    const box = target.getBoundingClientRect();\n+                    const onMouseMove = function() {\n+                        clearTimeout(state.hoverTimeout);\n+                        state.hoverTimeout = setTimeout(onHover, hoverTime);\n+                    };\n+                    const onMouseOut = function() {\n+                        _codemirror.default.off(document, 'mousemove', onMouseMove);\n+                        _codemirror.default.off(cm.getWrapperElement(), 'mouseout', onMouseOut);\n+                        clearTimeout(state.hoverTimeout);\n+                        state.hoverTimeout = undefined;\n+                    };\n+                    const onHover = function() {\n+                        _codemirror.default.off(document, 'mousemove', onMouseMove);\n+                        _codemirror.default.off(cm.getWrapperElement(), 'mouseout', onMouseOut);\n+                        state.hoverTimeout = undefined;\n+                        onMouseHover(cm, box);\n+                    };\n+                    const hoverTime = getHoverTime(cm);\n+                    state.hoverTimeout = setTimeout(onHover, hoverTime);\n+                    _codemirror.default.on(document, 'mousemove', onMouseMove);\n+                    _codemirror.default.on(cm.getWrapperElement(), 'mouseout', onMouseOut);\n+                }\n+\n+                function onMouseHover(cm, box) {\n+                    const pos = cm.coordsChar({\n+                        left: (box.left + box.right) / 2,\n+                        top: (box.top + box.bottom) / 2\n+                    }, 'window');\n+                    const state = cm.state.info;\n+                    const {\n+                        options\n+                    } = state;\n+                    const render = options.render || cm.getHelper(pos, 'info');\n+                    if (render) {\n+                        const token = cm.getTokenAt(pos, true);\n+                        if (token) {\n+                            const info = render(token, options, cm, pos);\n+                            if (info) {\n+                                showPopup(cm, box, info);\n                             }\n                         }\n                     }\n                 }\n \n-                // Simple typographic replacements\n-                //\n-                // (c) (C) \u2192 \u00a9\n-                // (tm) (TM) \u2192 \u2122\n-                // (r) (R) \u2192 \u00ae\n-                // +- \u2192 \u00b1\n-                // ... \u2192 \u2026 (also ?.... \u2192 ?.., !.... \u2192 !..)\n-                // ???????? \u2192 ???, !!!!! \u2192 !!!, `,,` \u2192 `,`\n-                // -- \u2192 &ndash;, --- \u2192 &mdash;\n-                //\n+                function showPopup(cm, box, info) {\n+                    const popup = document.createElement('div');\n+                    popup.className = 'CodeMirror-info';\n+                    popup.append(info);\n+                    document.body.append(popup);\n+                    const popupBox = popup.getBoundingClientRect();\n+                    const popupStyle = window.getComputedStyle(popup);\n+                    const popupWidth = popupBox.right - popupBox.left + parseFloat(popupStyle.marginLeft) + parseFloat(popupStyle.marginRight);\n+                    const popupHeight = popupBox.bottom - popupBox.top + parseFloat(popupStyle.marginTop) + parseFloat(popupStyle.marginBottom);\n+                    let topPos = box.bottom;\n+                    if (popupHeight > window.innerHeight - box.bottom - 15 && box.top > window.innerHeight - box.bottom) {\n+                        topPos = box.top - popupHeight;\n+                    }\n+                    if (topPos < 0) {\n+                        topPos = box.bottom;\n+                    }\n+                    let leftPos = Math.max(0, window.innerWidth - popupWidth - 15);\n+                    if (leftPos > box.left) {\n+                        leftPos = box.left;\n+                    }\n+                    popup.style.opacity = '1';\n+                    popup.style.top = topPos + 'px';\n+                    popup.style.left = leftPos + 'px';\n+                    let popupTimeout;\n+                    const onMouseOverPopup = function() {\n+                        clearTimeout(popupTimeout);\n+                    };\n+                    const onMouseOut = function() {\n+                        clearTimeout(popupTimeout);\n+                        popupTimeout = setTimeout(hidePopup, 200);\n+                    };\n+                    const hidePopup = function() {\n+                        _codemirror.default.off(popup, 'mouseover', onMouseOverPopup);\n+                        _codemirror.default.off(popup, 'mouseout', onMouseOut);\n+                        _codemirror.default.off(cm.getWrapperElement(), 'mouseout', onMouseOut);\n+                        if (popup.style.opacity) {\n+                            popup.style.opacity = '0';\n+                            setTimeout(() => {\n+                                if (popup.parentNode) {\n+                                    popup.remove();\n+                                }\n+                            }, 600);\n+                        } else if (popup.parentNode) {\n+                            popup.remove();\n+                        }\n+                    };\n+                    _codemirror.default.on(popup, 'mouseover', onMouseOverPopup);\n+                    _codemirror.default.on(popup, 'mouseout', onMouseOut);\n+                    _codemirror.default.on(cm.getWrapperElement(), 'mouseout', onMouseOut);\n+                }\n \n-                // TODO:\n-                // - fractionals 1/2, 1/4, 3/4 -> \u00bd, \u00bc, \u00be\n-                // - multiplications 2 x 4 -> 2 \u00d7 4\n+                /***/\n+            }),\n \n-                const RARE_RE = /\\+-|\\.\\.|\\?\\?\\?\\?|!!!!|,,|--/;\n+        /***/\n+        \"../../codemirror-graphql/esm/utils/jsonParse.js\":\n+            /*!*******************************************************!*\\\n+              !*** ../../codemirror-graphql/esm/utils/jsonParse.js ***!\n+              \\*******************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports) {\n \n-                // Workaround for phantomjs - need regex without /g flag,\n-                // or root check will fail every second time\n-                const SCOPED_ABBR_TEST_RE = /\\((c|tm|r)\\)/i;\n-                const SCOPED_ABBR_RE = /\\((c|tm|r)\\)/ig;\n-                const SCOPED_ABBR = {\n-                    c: '\u00a9',\n-                    r: '\u00ae',\n-                    tm: '\u2122'\n-                };\n+                \"use strict\";\n \n-                function replaceFn(match, name) {\n-                    return SCOPED_ABBR[name.toLowerCase()];\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.JSONSyntaxError = void 0;\n+                exports[\"default\"] = jsonParse;\n+\n+                function jsonParse(str) {\n+                    string = str;\n+                    strLen = str.length;\n+                    start = end = lastEnd = -1;\n+                    ch();\n+                    lex();\n+                    const ast = parseObj();\n+                    expect('EOF');\n+                    return ast;\n+                }\n+                let string;\n+                let strLen;\n+                let start;\n+                let end;\n+                let lastEnd;\n+                let code;\n+                let kind;\n+\n+                function parseObj() {\n+                    const nodeStart = start;\n+                    const members = [];\n+                    expect('{');\n+                    if (!skip('}')) {\n+                        do {\n+                            members.push(parseMember());\n+                        } while (skip(','));\n+                        expect('}');\n+                    }\n+                    return {\n+                        kind: 'Object',\n+                        start: nodeStart,\n+                        end: lastEnd,\n+                        members\n+                    };\n                 }\n \n-                function replace_scoped(inlineTokens) {\n-                    let inside_autolink = 0;\n-                    for (let i = inlineTokens.length - 1; i >= 0; i--) {\n-                        const token = inlineTokens[i];\n-                        if (token.type === 'text' && !inside_autolink) {\n-                            token.content = token.content.replace(SCOPED_ABBR_RE, replaceFn);\n-                        }\n-                        if (token.type === 'link_open' && token.info === 'auto') {\n-                            inside_autolink--;\n-                        }\n-                        if (token.type === 'link_close' && token.info === 'auto') {\n-                            inside_autolink++;\n-                        }\n+                function parseMember() {\n+                    const nodeStart = start;\n+                    const key = kind === 'String' ? curToken() : null;\n+                    expect('String');\n+                    expect(':');\n+                    const value = parseVal();\n+                    return {\n+                        kind: 'Member',\n+                        start: nodeStart,\n+                        end: lastEnd,\n+                        key,\n+                        value\n+                    };\n+                }\n+\n+                function parseArr() {\n+                    const nodeStart = start;\n+                    const values = [];\n+                    expect('[');\n+                    if (!skip(']')) {\n+                        do {\n+                            values.push(parseVal());\n+                        } while (skip(','));\n+                        expect(']');\n                     }\n+                    return {\n+                        kind: 'Array',\n+                        start: nodeStart,\n+                        end: lastEnd,\n+                        values\n+                    };\n                 }\n \n-                function replace_rare(inlineTokens) {\n-                    let inside_autolink = 0;\n-                    for (let i = inlineTokens.length - 1; i >= 0; i--) {\n-                        const token = inlineTokens[i];\n-                        if (token.type === 'text' && !inside_autolink) {\n-                            if (RARE_RE.test(token.content)) {\n-                                token.content = token.content.replace(/\\+-/g, '\u00b1')\n-                                    // .., ..., ....... -> \u2026\n-                                    // but ?..... & !..... -> ?.. & !..\n-                                    .replace(/\\.{2,}/g, '\u2026').replace(/([?!])\u2026/g, '$1..').replace(/([?!]){4,}/g, '$1$1$1').replace(/,{2,}/g, ',')\n-                                    // em-dash\n-                                    .replace(/(^|[^-])---(?=[^-]|$)/mg, '$1\\u2014')\n-                                    // en-dash\n-                                    .replace(/(^|\\s)--(?=\\s|$)/mg, '$1\\u2013').replace(/(^|[^-\\s])--(?=[^-\\s]|$)/mg, '$1\\u2013');\n-                            }\n-                        }\n-                        if (token.type === 'link_open' && token.info === 'auto') {\n-                            inside_autolink--;\n-                        }\n-                        if (token.type === 'link_close' && token.info === 'auto') {\n-                            inside_autolink++;\n-                        }\n+                function parseVal() {\n+                    switch (kind) {\n+                        case '[':\n+                            return parseArr();\n+                        case '{':\n+                            return parseObj();\n+                        case 'String':\n+                        case 'Number':\n+                        case 'Boolean':\n+                        case 'Null':\n+                            const token = curToken();\n+                            lex();\n+                            return token;\n                     }\n+                    expect('Value');\n                 }\n \n-                function replace(state) {\n-                    let blkIdx;\n-                    if (!state.md.options.typographer) {\n+                function curToken() {\n+                    return {\n+                        kind,\n+                        start,\n+                        end,\n+                        value: JSON.parse(string.slice(start, end))\n+                    };\n+                }\n+\n+                function expect(str) {\n+                    if (kind === str) {\n+                        lex();\n                         return;\n                     }\n-                    for (blkIdx = state.tokens.length - 1; blkIdx >= 0; blkIdx--) {\n-                        if (state.tokens[blkIdx].type !== 'inline') {\n-                            continue;\n-                        }\n-                        if (SCOPED_ABBR_TEST_RE.test(state.tokens[blkIdx].content)) {\n-                            replace_scoped(state.tokens[blkIdx].children);\n-                        }\n-                        if (RARE_RE.test(state.tokens[blkIdx].content)) {\n-                            replace_rare(state.tokens[blkIdx].children);\n-                        }\n+                    let found;\n+                    if (kind === 'EOF') {\n+                        found = '[end of file]';\n+                    } else if (end - start > 1) {\n+                        found = '`' + string.slice(start, end) + '`';\n+                    } else {\n+                        const match = string.slice(start).match(/^.+?\\b/);\n+                        found = '`' + (match ? match[0] : string[start]) + '`';\n+                    }\n+                    throw syntaxError(`Expected ${str} but found ${found}.`);\n+                }\n+                class JSONSyntaxError extends Error {\n+                    constructor(message, position) {\n+                        super(message);\n+                        this.position = position;\n                     }\n                 }\n+                exports.JSONSyntaxError = JSONSyntaxError;\n \n-                // Convert straight quotation marks to typographic ones\n-                //\n+                function syntaxError(message) {\n+                    return new JSONSyntaxError(message, {\n+                        start,\n+                        end\n+                    });\n+                }\n \n-                const QUOTE_TEST_RE = /['\"]/;\n-                const QUOTE_RE = /['\"]/g;\n-                const APOSTROPHE = '\\u2019'; /* \u2019 */\n+                function skip(k) {\n+                    if (kind === k) {\n+                        lex();\n+                        return true;\n+                    }\n+                }\n \n-                function replaceAt(str, index, ch) {\n-                    return str.slice(0, index) + ch + str.slice(index + 1);\n+                function ch() {\n+                    if (end < strLen) {\n+                        end++;\n+                        code = end === strLen ? 0 : string.charCodeAt(end);\n+                    }\n+                    return code;\n                 }\n \n-                function process_inlines(tokens, state) {\n-                    let j;\n-                    const stack = [];\n-                    for (let i = 0; i < tokens.length; i++) {\n-                        const token = tokens[i];\n-                        const thisLevel = tokens[i].level;\n-                        for (j = stack.length - 1; j >= 0; j--) {\n-                            if (stack[j].level <= thisLevel) {\n+                function lex() {\n+                    lastEnd = end;\n+                    while (code === 9 || code === 10 || code === 13 || code === 32) {\n+                        ch();\n+                    }\n+                    if (code === 0) {\n+                        kind = 'EOF';\n+                        return;\n+                    }\n+                    start = end;\n+                    switch (code) {\n+                        case 34:\n+                            kind = 'String';\n+                            return readString();\n+                        case 45:\n+                        case 48:\n+                        case 49:\n+                        case 50:\n+                        case 51:\n+                        case 52:\n+                        case 53:\n+                        case 54:\n+                        case 55:\n+                        case 56:\n+                        case 57:\n+                            kind = 'Number';\n+                            return readNumber();\n+                        case 102:\n+                            if (string.slice(start, start + 5) !== 'false') {\n                                 break;\n                             }\n-                        }\n-                        stack.length = j + 1;\n-                        if (token.type !== 'text') {\n-                            continue;\n-                        }\n-                        let text = token.content;\n-                        let pos = 0;\n-                        let max = text.length;\n-\n-                        /* eslint no-labels:0,block-scoped-var:0 */\n-                        OUTER: while (pos < max) {\n-                            QUOTE_RE.lastIndex = pos;\n-                            const t = QUOTE_RE.exec(text);\n-                            if (!t) {\n+                            end += 4;\n+                            ch();\n+                            kind = 'Boolean';\n+                            return;\n+                        case 110:\n+                            if (string.slice(start, start + 4) !== 'null') {\n                                 break;\n                             }\n-                            let canOpen = true;\n-                            let canClose = true;\n-                            pos = t.index + 1;\n-                            const isSingle = t[0] === \"'\";\n-\n-                            // Find previous character,\n-                            // default to space if it's the beginning of the line\n-                            //\n-                            let lastChar = 0x20;\n-                            if (t.index - 1 >= 0) {\n-                                lastChar = text.charCodeAt(t.index - 1);\n-                            } else {\n-                                for (j = i - 1; j >= 0; j--) {\n-                                    if (tokens[j].type === 'softbreak' || tokens[j].type === 'hardbreak') break; // lastChar defaults to 0x20\n-                                    if (!tokens[j].content) continue; // should skip all tokens except 'text', 'html_inline' or 'code_inline'\n-\n-                                    lastChar = tokens[j].content.charCodeAt(tokens[j].content.length - 1);\n-                                    break;\n-                                }\n+                            end += 3;\n+                            ch();\n+                            kind = 'Null';\n+                            return;\n+                        case 116:\n+                            if (string.slice(start, start + 4) !== 'true') {\n+                                break;\n                             }\n+                            end += 3;\n+                            ch();\n+                            kind = 'Boolean';\n+                            return;\n+                    }\n+                    kind = string[start];\n+                    ch();\n+                }\n \n-                            // Find next character,\n-                            // default to space if it's the end of the line\n-                            //\n-                            let nextChar = 0x20;\n-                            if (pos < max) {\n-                                nextChar = text.charCodeAt(pos);\n-                            } else {\n-                                for (j = i + 1; j < tokens.length; j++) {\n-                                    if (tokens[j].type === 'softbreak' || tokens[j].type === 'hardbreak') break; // nextChar defaults to 0x20\n-                                    if (!tokens[j].content) continue; // should skip all tokens except 'text', 'html_inline' or 'code_inline'\n-\n-                                    nextChar = tokens[j].content.charCodeAt(0);\n+                function readString() {\n+                    ch();\n+                    while (code !== 34 && code > 31) {\n+                        if (code === 92) {\n+                            code = ch();\n+                            switch (code) {\n+                                case 34:\n+                                case 47:\n+                                case 92:\n+                                case 98:\n+                                case 102:\n+                                case 110:\n+                                case 114:\n+                                case 116:\n+                                    ch();\n                                     break;\n-                                }\n-                            }\n-                            const isLastPunctChar = isMdAsciiPunct(lastChar) || isPunctChar(String.fromCharCode(lastChar));\n-                            const isNextPunctChar = isMdAsciiPunct(nextChar) || isPunctChar(String.fromCharCode(nextChar));\n-                            const isLastWhiteSpace = isWhiteSpace(lastChar);\n-                            const isNextWhiteSpace = isWhiteSpace(nextChar);\n-                            if (isNextWhiteSpace) {\n-                                canOpen = false;\n-                            } else if (isNextPunctChar) {\n-                                if (!(isLastWhiteSpace || isLastPunctChar)) {\n-                                    canOpen = false;\n-                                }\n-                            }\n-                            if (isLastWhiteSpace) {\n-                                canClose = false;\n-                            } else if (isLastPunctChar) {\n-                                if (!(isNextWhiteSpace || isNextPunctChar)) {\n-                                    canClose = false;\n-                                }\n-                            }\n-                            if (nextChar === 0x22 /* \" */ && t[0] === '\"') {\n-                                if (lastChar >= 0x30 /* 0 */ && lastChar <= 0x39 /* 9 */ ) {\n-                                    // special case: 1\"\" - count first quote as an inch\n-                                    canClose = canOpen = false;\n-                                }\n-                            }\n-                            if (canOpen && canClose) {\n-                                // Replace quotes in the middle of punctuation sequence, but not\n-                                // in the middle of the words, i.e.:\n-                                //\n-                                // 1. foo \" bar \" baz - not replaced\n-                                // 2. foo-\"-bar-\"-baz - replaced\n-                                // 3. foo\"bar\"baz     - not replaced\n-                                //\n-                                canOpen = isLastPunctChar;\n-                                canClose = isNextPunctChar;\n-                            }\n-                            if (!canOpen && !canClose) {\n-                                // middle of word\n-                                if (isSingle) {\n-                                    token.content = replaceAt(token.content, t.index, APOSTROPHE);\n-                                }\n-                                continue;\n+                                case 117:\n+                                    ch();\n+                                    readHex();\n+                                    readHex();\n+                                    readHex();\n+                                    readHex();\n+                                    break;\n+                                default:\n+                                    throw syntaxError('Bad character escape sequence.');\n                             }\n-                            if (canClose) {\n-                                // this could be a closing quote, rewind the stack to get a match\n-                                for (j = stack.length - 1; j >= 0; j--) {\n-                                    let item = stack[j];\n-                                    if (stack[j].level < thisLevel) {\n-                                        break;\n-                                    }\n-                                    if (item.single === isSingle && stack[j].level === thisLevel) {\n-                                        item = stack[j];\n-                                        let openQuote;\n-                                        let closeQuote;\n-                                        if (isSingle) {\n-                                            openQuote = state.md.options.quotes[2];\n-                                            closeQuote = state.md.options.quotes[3];\n-                                        } else {\n-                                            openQuote = state.md.options.quotes[0];\n-                                            closeQuote = state.md.options.quotes[1];\n-                                        }\n+                        } else if (end === strLen) {\n+                            throw syntaxError('Unterminated string.');\n+                        } else {\n+                            ch();\n+                        }\n+                    }\n+                    if (code === 34) {\n+                        ch();\n+                        return;\n+                    }\n+                    throw syntaxError('Unterminated string.');\n+                }\n \n-                                        // replace token.content *before* tokens[item.token].content,\n-                                        // because, if they are pointing at the same token, replaceAt\n-                                        // could mess up indices when quote length != 1\n-                                        token.content = replaceAt(token.content, t.index, closeQuote);\n-                                        tokens[item.token].content = replaceAt(tokens[item.token].content, item.pos, openQuote);\n-                                        pos += closeQuote.length - 1;\n-                                        if (item.token === i) {\n-                                            pos += openQuote.length - 1;\n-                                        }\n-                                        text = token.content;\n-                                        max = text.length;\n-                                        stack.length = j;\n-                                        continue OUTER;\n-                                    }\n-                                }\n-                            }\n-                            if (canOpen) {\n-                                stack.push({\n-                                    token: i,\n-                                    pos: t.index,\n-                                    single: isSingle,\n-                                    level: thisLevel\n-                                });\n-                            } else if (canClose && isSingle) {\n-                                token.content = replaceAt(token.content, t.index, APOSTROPHE);\n-                            }\n+                function readHex() {\n+                    if (code >= 48 && code <= 57 || code >= 65 && code <= 70 || code >= 97 && code <= 102) {\n+                        return ch();\n+                    }\n+                    throw syntaxError('Expected hexadecimal digit.');\n+                }\n+\n+                function readNumber() {\n+                    if (code === 45) {\n+                        ch();\n+                    }\n+                    if (code === 48) {\n+                        ch();\n+                    } else {\n+                        readDigits();\n+                    }\n+                    if (code === 46) {\n+                        ch();\n+                        readDigits();\n+                    }\n+                    if (code === 69 || code === 101) {\n+                        code = ch();\n+                        if (code === 43 || code === 45) {\n+                            ch();\n                         }\n+                        readDigits();\n                     }\n                 }\n \n-                function smartquotes(state) {\n-                    /* eslint max-depth:0 */\n-                    if (!state.md.options.typographer) {\n+                function readDigits() {\n+                    if (code < 48 || code > 57) {\n+                        throw syntaxError('Expected decimal digit.');\n+                    }\n+                    do {\n+                        ch();\n+                    } while (code >= 48 && code <= 57);\n+                }\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../codemirror-graphql/esm/utils/jump-addon.js\":\n+            /*!********************************************************!*\\\n+              !*** ../../codemirror-graphql/esm/utils/jump-addon.js ***!\n+              \\********************************************************/\n+            /***/\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                var _codemirror = _interopRequireDefault(__webpack_require__( /*! codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"));\n+\n+                function _interopRequireDefault(obj) {\n+                    return obj && obj.__esModule ? obj : {\n+                        default: obj\n+                    };\n+                }\n+                _codemirror.default.defineOption('jump', false, (cm, options, old) => {\n+                    if (old && old !== _codemirror.default.Init) {\n+                        const oldOnMouseOver = cm.state.jump.onMouseOver;\n+                        _codemirror.default.off(cm.getWrapperElement(), 'mouseover', oldOnMouseOver);\n+                        const oldOnMouseOut = cm.state.jump.onMouseOut;\n+                        _codemirror.default.off(cm.getWrapperElement(), 'mouseout', oldOnMouseOut);\n+                        _codemirror.default.off(document, 'keydown', cm.state.jump.onKeyDown);\n+                        delete cm.state.jump;\n+                    }\n+                    if (options) {\n+                        const state = cm.state.jump = {\n+                            options,\n+                            onMouseOver: onMouseOver.bind(null, cm),\n+                            onMouseOut: onMouseOut.bind(null, cm),\n+                            onKeyDown: onKeyDown.bind(null, cm)\n+                        };\n+                        _codemirror.default.on(cm.getWrapperElement(), 'mouseover', state.onMouseOver);\n+                        _codemirror.default.on(cm.getWrapperElement(), 'mouseout', state.onMouseOut);\n+                        _codemirror.default.on(document, 'keydown', state.onKeyDown);\n+                    }\n+                });\n+\n+                function onMouseOver(cm, event) {\n+                    const target = event.target || event.srcElement;\n+                    if (!(target instanceof HTMLElement)) {\n                         return;\n                     }\n-                    for (let blkIdx = state.tokens.length - 1; blkIdx >= 0; blkIdx--) {\n-                        if (state.tokens[blkIdx].type !== 'inline' || !QUOTE_TEST_RE.test(state.tokens[blkIdx].content)) {\n-                            continue;\n-                        }\n-                        process_inlines(state.tokens[blkIdx].children, state);\n+                    if ((target === null || target === void 0 ? void 0 : target.nodeName) !== 'SPAN') {\n+                        return;\n+                    }\n+                    const box = target.getBoundingClientRect();\n+                    const cursor = {\n+                        left: (box.left + box.right) / 2,\n+                        top: (box.top + box.bottom) / 2\n+                    };\n+                    cm.state.jump.cursor = cursor;\n+                    if (cm.state.jump.isHoldingModifier) {\n+                        enableJumpMode(cm);\n                     }\n                 }\n \n-                // Join raw text tokens with the rest of the text\n-                //\n-                // This is set as a separate rule to provide an opportunity for plugins\n-                // to run text replacements after text join, but before escape join.\n-                //\n-                // For example, `\\:)` shouldn't be replaced with an emoji.\n-                //\n+                function onMouseOut(cm) {\n+                    if (!cm.state.jump.isHoldingModifier && cm.state.jump.cursor) {\n+                        cm.state.jump.cursor = null;\n+                        return;\n+                    }\n+                    if (cm.state.jump.isHoldingModifier && cm.state.jump.marker) {\n+                        disableJumpMode(cm);\n+                    }\n+                }\n \n-                function text_join(state) {\n-                    let curr, last;\n-                    const blockTokens = state.tokens;\n-                    const l = blockTokens.length;\n-                    for (let j = 0; j < l; j++) {\n-                        if (blockTokens[j].type !== 'inline') continue;\n-                        const tokens = blockTokens[j].children;\n-                        const max = tokens.length;\n-                        for (curr = 0; curr < max; curr++) {\n-                            if (tokens[curr].type === 'text_special') {\n-                                tokens[curr].type = 'text';\n-                            }\n+                function onKeyDown(cm, event) {\n+                    if (cm.state.jump.isHoldingModifier || !isJumpModifier(event.key)) {\n+                        return;\n+                    }\n+                    cm.state.jump.isHoldingModifier = true;\n+                    if (cm.state.jump.cursor) {\n+                        enableJumpMode(cm);\n+                    }\n+                    const onKeyUp = upEvent => {\n+                        if (upEvent.code !== event.code) {\n+                            return;\n                         }\n-                        for (curr = last = 0; curr < max; curr++) {\n-                            if (tokens[curr].type === 'text' && curr + 1 < max && tokens[curr + 1].type === 'text') {\n-                                // collapse two adjacent text nodes\n-                                tokens[curr + 1].content = tokens[curr].content + tokens[curr + 1].content;\n-                            } else {\n-                                if (curr !== last) {\n-                                    tokens[last] = tokens[curr];\n-                                }\n-                                last++;\n-                            }\n+                        cm.state.jump.isHoldingModifier = false;\n+                        if (cm.state.jump.marker) {\n+                            disableJumpMode(cm);\n+                        }\n+                        _codemirror.default.off(document, 'keyup', onKeyUp);\n+                        _codemirror.default.off(document, 'click', onClick);\n+                        cm.off('mousedown', onMouseDown);\n+                    };\n+                    const onClick = clickEvent => {\n+                        const {\n+                            destination,\n+                            options\n+                        } = cm.state.jump;\n+                        if (destination) {\n+                            options.onClick(destination, clickEvent);\n                         }\n-                        if (curr !== last) {\n-                            tokens.length = last;\n+                    };\n+                    const onMouseDown = (_, downEvent) => {\n+                        if (cm.state.jump.destination) {\n+                            downEvent.codemirrorIgnore = true;\n                         }\n-                    }\n+                    };\n+                    _codemirror.default.on(document, 'keyup', onKeyUp);\n+                    _codemirror.default.on(document, 'click', onClick);\n+                    cm.on('mousedown', onMouseDown);\n                 }\n+                const isMac = typeof navigator !== 'undefined' && navigator.userAgent.includes('Mac');\n \n-                /** internal\n-                 * class Core\n-                 *\n-                 * Top-level rules executor. Glues block/inline parsers and does intermediate\n-                 * transformations.\n-                 **/\n-\n-                const _rules$2 = [\n-                    ['normalize', normalize],\n-                    ['block', block],\n-                    ['inline', inline],\n-                    ['linkify', linkify$1],\n-                    ['replacements', replace],\n-                    ['smartquotes', smartquotes],\n-                    // `text_join` finds `text_special` tokens (for escape sequences)\n-                    // and joins them with the rest of the text\n-                    ['text_join', text_join]\n-                ];\n+                function isJumpModifier(key) {\n+                    return key === (isMac ? 'Meta' : 'Control');\n+                }\n \n-                /**\n-                 * new Core()\n-                 **/\n-                function Core() {\n-                    /**\n-                     * Core#ruler -> Ruler\n-                     *\n-                     * [[Ruler]] instance. Keep configuration of core rules.\n-                     **/\n-                    this.ruler = new Ruler();\n-                    for (let i = 0; i < _rules$2.length; i++) {\n-                        this.ruler.push(_rules$2[i][0], _rules$2[i][1]);\n+                function enableJumpMode(cm) {\n+                    if (cm.state.jump.marker) {\n+                        return;\n+                    }\n+                    const {\n+                        cursor,\n+                        options\n+                    } = cm.state.jump;\n+                    const pos = cm.coordsChar(cursor);\n+                    const token = cm.getTokenAt(pos, true);\n+                    const getDestination = options.getDestination || cm.getHelper(pos, 'jump');\n+                    if (getDestination) {\n+                        const destination = getDestination(token, options, cm);\n+                        if (destination) {\n+                            const marker = cm.markText({\n+                                line: pos.line,\n+                                ch: token.start\n+                            }, {\n+                                line: pos.line,\n+                                ch: token.end\n+                            }, {\n+                                className: 'CodeMirror-jump-token'\n+                            });\n+                            cm.state.jump.marker = marker;\n+                            cm.state.jump.destination = destination;\n+                        }\n                     }\n                 }\n \n-                /**\n-                 * Core.process(state)\n-                 *\n-                 * Executes core chain rules.\n-                 **/\n-                Core.prototype.process = function(state) {\n-                    const rules = this.ruler.getRules('');\n-                    for (let i = 0, l = rules.length; i < l; i++) {\n-                        rules[i](state);\n-                    }\n+                function disableJumpMode(cm) {\n+                    const {\n+                        marker\n+                    } = cm.state.jump;\n+                    cm.state.jump.marker = null;\n+                    cm.state.jump.destination = null;\n+                    marker.clear();\n+                }\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../codemirror-graphql/esm/utils/mode-factory.js\":\n+            /*!**********************************************************!*\\\n+              !*** ../../codemirror-graphql/esm/utils/mode-factory.js ***!\n+              \\**********************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports[\"default\"] = void 0;\n+                var _graphqlLanguageService = __webpack_require__( /*! graphql-language-service */ \"../../graphql-language-service/esm/index.js\");\n+                var _modeIndent = _interopRequireDefault(__webpack_require__( /*! ./mode-indent */ \"../../codemirror-graphql/esm/utils/mode-indent.js\"));\n+\n+                function _interopRequireDefault(obj) {\n+                    return obj && obj.__esModule ? obj : {\n+                        default: obj\n+                    };\n+                }\n+                const graphqlModeFactory = config => {\n+                    const parser = (0, _graphqlLanguageService.onlineParser)({\n+                        eatWhitespace: stream => stream.eatWhile(_graphqlLanguageService.isIgnored),\n+                        lexRules: _graphqlLanguageService.LexRules,\n+                        parseRules: _graphqlLanguageService.ParseRules,\n+                        editorConfig: {\n+                            tabSize: config.tabSize\n+                        }\n+                    });\n+                    return {\n+                        config,\n+                        startState: parser.startState,\n+                        token: parser.token,\n+                        indent: _modeIndent.default,\n+                        electricInput: /^\\s*[})\\]]/,\n+                        fold: 'brace',\n+                        lineComment: '#',\n+                        closeBrackets: {\n+                            pairs: '()[]{}\"\"',\n+                            explode: '()[]{}'\n+                        }\n+                    };\n                 };\n-                Core.prototype.State = StateCore;\n+                var _default = exports[\"default\"] = graphqlModeFactory;\n \n-                // Parser state class\n+                /***/\n+            }),\n \n-                function StateBlock(src, md, env, tokens) {\n-                    this.src = src;\n+        /***/\n+        \"../../codemirror-graphql/esm/utils/mode-indent.js\":\n+            /*!*********************************************************!*\\\n+              !*** ../../codemirror-graphql/esm/utils/mode-indent.js ***!\n+              \\*********************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports) {\n \n-                    // link to parser instance\n-                    this.md = md;\n-                    this.env = env;\n+                \"use strict\";\n \n-                    //\n-                    // Internal state vartiables\n-                    //\n \n-                    this.tokens = tokens;\n-                    this.bMarks = []; // line begin offsets for fast jumps\n-                    this.eMarks = []; // line end offsets for fast jumps\n-                    this.tShift = []; // offsets of the first non-space characters (tabs not expanded)\n-                    this.sCount = []; // indents for each line (tabs expanded)\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports[\"default\"] = indent;\n \n-                    // An amount of virtual spaces (tabs expanded) between beginning\n-                    // of each line (bMarks) and real beginning of that line.\n-                    //\n-                    // It exists only as a hack because blockquotes override bMarks\n-                    // losing information in the process.\n-                    //\n-                    // It's used only when expanding tabs, you can think about it as\n-                    // an initial tab length, e.g. bsCount=21 applied to string `\\t123`\n-                    // means first tab should be expanded to 4-21%4 === 3 spaces.\n-                    //\n-                    this.bsCount = [];\n+                function indent(state, textAfter) {\n+                    var _a, _b;\n+                    const {\n+                        levels,\n+                        indentLevel\n+                    } = state;\n+                    const level = !levels || levels.length === 0 ? indentLevel : levels.at(-1) - (((_a = this.electricInput) === null || _a === void 0 ? void 0 : _a.test(textAfter)) ? 1 : 0);\n+                    return (level || 0) * (((_b = this.config) === null || _b === void 0 ? void 0 : _b.indentUnit) || 0);\n+                }\n \n-                    // block parser variables\n+                /***/\n+            }),\n \n-                    // required block content indent (for example, if we are\n-                    // inside a list, it would be positioned after list marker)\n-                    this.blkIndent = 0;\n-                    this.line = 0; // line index in src\n-                    this.lineMax = 0; // lines count\n-                    this.tight = false; // loose/tight mode for lists\n-                    this.ddIndent = -1; // indent of the current dd block (-1 if there isn't any)\n-                    this.listIndent = -1; // indent of the current list block (-1 if there isn't any)\n+        /***/\n+        \"../../codemirror-graphql/esm/variables/hint.js\":\n+            /*!******************************************************!*\\\n+              !*** ../../codemirror-graphql/esm/variables/hint.js ***!\n+              \\******************************************************/\n+            /***/\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n \n-                    // can be 'blockquote', 'list', 'root', 'paragraph' or 'reference'\n-                    // used in lists to determine if they interrupt a paragraph\n-                    this.parentType = 'root';\n-                    this.level = 0;\n+                \"use strict\";\n \n-                    // Create caches\n-                    // Generate markers.\n-                    const s = this.src;\n-                    for (let start = 0, pos = 0, indent = 0, offset = 0, len = s.length, indent_found = false; pos < len; pos++) {\n-                        const ch = s.charCodeAt(pos);\n-                        if (!indent_found) {\n-                            if (isSpace(ch)) {\n-                                indent++;\n-                                if (ch === 0x09) {\n-                                    offset += 4 - offset % 4;\n-                                } else {\n-                                    offset++;\n-                                }\n-                                continue;\n-                            } else {\n-                                indent_found = true;\n-                            }\n+\n+                var _codemirror = _interopRequireDefault(__webpack_require__( /*! codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"));\n+                var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n+                var _forEachState = _interopRequireDefault(__webpack_require__( /*! ../utils/forEachState */ \"../../codemirror-graphql/esm/utils/forEachState.js\"));\n+                var _hintList = _interopRequireDefault(__webpack_require__( /*! ../utils/hintList */ \"../../codemirror-graphql/esm/utils/hintList.js\"));\n+\n+                function _interopRequireDefault(obj) {\n+                    return obj && obj.__esModule ? obj : {\n+                        default: obj\n+                    };\n+                }\n+                _codemirror.default.registerHelper('hint', 'graphql-variables', (editor, options) => {\n+                    const cur = editor.getCursor();\n+                    const token = editor.getTokenAt(cur);\n+                    const results = getVariablesHint(cur, token, options);\n+                    if ((results === null || results === void 0 ? void 0 : results.list) && results.list.length > 0) {\n+                        results.from = _codemirror.default.Pos(results.from.line, results.from.ch);\n+                        results.to = _codemirror.default.Pos(results.to.line, results.to.ch);\n+                        _codemirror.default.signal(editor, 'hasCompletion', editor, results, token);\n+                    }\n+                    return results;\n+                });\n+\n+                function getVariablesHint(cur, token, options) {\n+                    const state = token.state.kind === 'Invalid' ? token.state.prevState : token.state;\n+                    const {\n+                        kind,\n+                        step\n+                    } = state;\n+                    if (kind === 'Document' && step === 0) {\n+                        return (0, _hintList.default)(cur, token, [{\n+                            text: '{'\n+                        }]);\n+                    }\n+                    const {\n+                        variableToType\n+                    } = options;\n+                    if (!variableToType) {\n+                        return;\n+                    }\n+                    const typeInfo = getTypeInfo(variableToType, token.state);\n+                    if (kind === 'Document' || kind === 'Variable' && step === 0) {\n+                        const variableNames = Object.keys(variableToType);\n+                        return (0, _hintList.default)(cur, token, variableNames.map(name => ({\n+                            text: `\"${name}\": `,\n+                            type: variableToType[name]\n+                        })));\n+                    }\n+                    if ((kind === 'ObjectValue' || kind === 'ObjectField' && step === 0) && typeInfo.fields) {\n+                        const inputFields = Object.keys(typeInfo.fields).map(fieldName => typeInfo.fields[fieldName]);\n+                        return (0, _hintList.default)(cur, token, inputFields.map(field => ({\n+                            text: `\"${field.name}\": `,\n+                            type: field.type,\n+                            description: field.description\n+                        })));\n+                    }\n+                    if (kind === 'StringValue' || kind === 'NumberValue' || kind === 'BooleanValue' || kind === 'NullValue' || kind === 'ListValue' && step === 1 || kind === 'ObjectField' && step === 2 || kind === 'Variable' && step === 2) {\n+                        const namedInputType = typeInfo.type ? (0, _graphql.getNamedType)(typeInfo.type) : undefined;\n+                        if (namedInputType instanceof _graphql.GraphQLInputObjectType) {\n+                            return (0, _hintList.default)(cur, token, [{\n+                                text: '{'\n+                            }]);\n+                        }\n+                        if (namedInputType instanceof _graphql.GraphQLEnumType) {\n+                            const values = namedInputType.getValues();\n+                            return (0, _hintList.default)(cur, token, values.map(value => ({\n+                                text: `\"${value.name}\"`,\n+                                type: namedInputType,\n+                                description: value.description\n+                            })));\n                         }\n-                        if (ch === 0x0A || pos === len - 1) {\n-                            if (ch !== 0x0A) {\n-                                pos++;\n-                            }\n-                            this.bMarks.push(start);\n-                            this.eMarks.push(pos);\n-                            this.tShift.push(indent);\n-                            this.sCount.push(offset);\n-                            this.bsCount.push(0);\n-                            indent_found = false;\n-                            indent = 0;\n-                            offset = 0;\n-                            start = pos + 1;\n+                        if (namedInputType === _graphql.GraphQLBoolean) {\n+                            return (0, _hintList.default)(cur, token, [{\n+                                text: 'true',\n+                                type: _graphql.GraphQLBoolean,\n+                                description: 'Not false.'\n+                            }, {\n+                                text: 'false',\n+                                type: _graphql.GraphQLBoolean,\n+                                description: 'Not true.'\n+                            }]);\n                         }\n                     }\n+                }\n \n-                    // Push fake entry to simplify cache bounds checks\n-                    this.bMarks.push(s.length);\n-                    this.eMarks.push(s.length);\n-                    this.tShift.push(0);\n-                    this.sCount.push(0);\n-                    this.bsCount.push(0);\n-                    this.lineMax = this.bMarks.length - 1; // don't count last fake line\n+                function getTypeInfo(variableToType, tokenState) {\n+                    const info = {\n+                        type: null,\n+                        fields: null\n+                    };\n+                    (0, _forEachState.default)(tokenState, state => {\n+                        switch (state.kind) {\n+                            case 'Variable': {\n+                                info.type = variableToType[state.name];\n+                                break;\n+                            }\n+                            case 'ListValue': {\n+                                const nullableType = info.type ? (0, _graphql.getNullableType)(info.type) : undefined;\n+                                info.type = nullableType instanceof _graphql.GraphQLList ? nullableType.ofType : null;\n+                                break;\n+                            }\n+                            case 'ObjectValue': {\n+                                const objectType = info.type ? (0, _graphql.getNamedType)(info.type) : undefined;\n+                                info.fields = objectType instanceof _graphql.GraphQLInputObjectType ? objectType.getFields() : null;\n+                                break;\n+                            }\n+                            case 'ObjectField': {\n+                                const objectField = state.name && info.fields ? info.fields[state.name] : null;\n+                                info.type = objectField === null || objectField === void 0 ? void 0 : objectField.type;\n+                                break;\n+                            }\n+                        }\n+                    });\n+                    return info;\n                 }\n \n-                // Push new token to \"stream\".\n-                //\n-                StateBlock.prototype.push = function(type, tag, nesting) {\n-                    const token = new Token(type, tag, nesting);\n-                    token.block = true;\n-                    if (nesting < 0) this.level--; // closing tag\n-                    token.level = this.level;\n-                    if (nesting > 0) this.level++; // opening tag\n+                /***/\n+            }),\n \n-                    this.tokens.push(token);\n-                    return token;\n-                };\n-                StateBlock.prototype.isEmpty = function isEmpty(line) {\n-                    return this.bMarks[line] + this.tShift[line] >= this.eMarks[line];\n-                };\n-                StateBlock.prototype.skipEmptyLines = function skipEmptyLines(from) {\n-                    for (let max = this.lineMax; from < max; from++) {\n-                        if (this.bMarks[from] + this.tShift[from] < this.eMarks[from]) {\n-                            break;\n-                        }\n-                    }\n-                    return from;\n-                };\n+        /***/\n+        \"../../codemirror-graphql/esm/variables/lint.js\":\n+            /*!******************************************************!*\\\n+              !*** ../../codemirror-graphql/esm/variables/lint.js ***!\n+              \\******************************************************/\n+            /***/\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n \n-                // Skip spaces from given position.\n-                StateBlock.prototype.skipSpaces = function skipSpaces(pos) {\n-                    for (let max = this.src.length; pos < max; pos++) {\n-                        const ch = this.src.charCodeAt(pos);\n-                        if (!isSpace(ch)) {\n-                            break;\n-                        }\n-                    }\n-                    return pos;\n-                };\n+                \"use strict\";\n \n-                // Skip spaces from given position in reverse.\n-                StateBlock.prototype.skipSpacesBack = function skipSpacesBack(pos, min) {\n-                    if (pos <= min) {\n-                        return pos;\n+\n+                var _codemirror = _interopRequireDefault(__webpack_require__( /*! codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"));\n+                var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n+                var _jsonParse = _interopRequireWildcard(__webpack_require__( /*! ../utils/jsonParse */ \"../../codemirror-graphql/esm/utils/jsonParse.js\"));\n+\n+                function _getRequireWildcardCache(e) {\n+                    if (\"function\" != typeof WeakMap) return null;\n+                    var r = new WeakMap(),\n+                        t = new WeakMap();\n+                    return (_getRequireWildcardCache = function(e) {\n+                        return e ? t : r;\n+                    })(e);\n+                }\n+\n+                function _interopRequireWildcard(e, r) {\n+                    if (!r && e && e.__esModule) return e;\n+                    if (null === e || \"object\" != typeof e && \"function\" != typeof e) return {\n+                        default: e\n+                    };\n+                    var t = _getRequireWildcardCache(r);\n+                    if (t && t.has(e)) return t.get(e);\n+                    var n = {\n+                            __proto__: null\n+                        },\n+                        a = Object.defineProperty && Object.getOwnPropertyDescriptor;\n+                    for (var u in e)\n+                        if (\"default\" !== u && Object.prototype.hasOwnProperty.call(e, u)) {\n+                            var i = a ? Object.getOwnPropertyDescriptor(e, u) : null;\n+                            i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u];\n+                        } return n.default = e, t && t.set(e, n), n;\n+                }\n+\n+                function _interopRequireDefault(obj) {\n+                    return obj && obj.__esModule ? obj : {\n+                        default: obj\n+                    };\n+                }\n+                _codemirror.default.registerHelper('lint', 'graphql-variables', (text, options, editor) => {\n+                    if (!text) {\n+                        return [];\n                     }\n-                    while (pos > min) {\n-                        if (!isSpace(this.src.charCodeAt(--pos))) {\n-                            return pos + 1;\n+                    let ast;\n+                    try {\n+                        ast = (0, _jsonParse.default)(text);\n+                    } catch (error) {\n+                        if (error instanceof _jsonParse.JSONSyntaxError) {\n+                            return [lintError(editor, error.position, error.message)];\n                         }\n+                        throw error;\n                     }\n-                    return pos;\n-                };\n+                    const {\n+                        variableToType\n+                    } = options;\n+                    if (!variableToType) {\n+                        return [];\n+                    }\n+                    return validateVariables(editor, variableToType, ast);\n+                });\n \n-                // Skip char codes from given position\n-                StateBlock.prototype.skipChars = function skipChars(pos, code) {\n-                    for (let max = this.src.length; pos < max; pos++) {\n-                        if (this.src.charCodeAt(pos) !== code) {\n-                            break;\n+                function validateVariables(editor, variableToType, variablesAST) {\n+                    var _a;\n+                    const errors = [];\n+                    for (const member of variablesAST.members) {\n+                        if (member) {\n+                            const variableName = (_a = member.key) === null || _a === void 0 ? void 0 : _a.value;\n+                            const type = variableToType[variableName];\n+                            if (type) {\n+                                for (const [node, message] of validateValue(type, member.value)) {\n+                                    errors.push(lintError(editor, node, message));\n+                                }\n+                            } else {\n+                                errors.push(lintError(editor, member.key, `Variable \"$${variableName}\" does not appear in any GraphQL query.`));\n+                            }\n                         }\n                     }\n-                    return pos;\n-                };\n+                    return errors;\n+                }\n \n-                // Skip char codes reverse from given position - 1\n-                StateBlock.prototype.skipCharsBack = function skipCharsBack(pos, code, min) {\n-                    if (pos <= min) {\n-                        return pos;\n+                function validateValue(type, valueAST) {\n+                    if (!type || !valueAST) {\n+                        return [];\n                     }\n-                    while (pos > min) {\n-                        if (code !== this.src.charCodeAt(--pos)) {\n-                            return pos + 1;\n+                    if (type instanceof _graphql.GraphQLNonNull) {\n+                        if (valueAST.kind === 'Null') {\n+                            return [\n+                                [valueAST, `Type \"${type}\" is non-nullable and cannot be null.`]\n+                            ];\n                         }\n+                        return validateValue(type.ofType, valueAST);\n                     }\n-                    return pos;\n-                };\n-\n-                // cut lines range from source.\n-                StateBlock.prototype.getLines = function getLines(begin, end, indent, keepLastLF) {\n-                    if (begin >= end) {\n-                        return '';\n+                    if (valueAST.kind === 'Null') {\n+                        return [];\n                     }\n-                    const queue = new Array(end - begin);\n-                    for (let i = 0, line = begin; line < end; line++, i++) {\n-                        let lineIndent = 0;\n-                        const lineStart = this.bMarks[line];\n-                        let first = lineStart;\n-                        let last;\n-                        if (line + 1 < end || keepLastLF) {\n-                            // No need for bounds check because we have fake entry on tail.\n-                            last = this.eMarks[line] + 1;\n-                        } else {\n-                            last = this.eMarks[line];\n+                    if (type instanceof _graphql.GraphQLList) {\n+                        const itemType = type.ofType;\n+                        if (valueAST.kind === 'Array') {\n+                            const values = valueAST.values || [];\n+                            return mapCat(values, item => validateValue(itemType, item));\n                         }\n-                        while (first < last && lineIndent < indent) {\n-                            const ch = this.src.charCodeAt(first);\n-                            if (isSpace(ch)) {\n-                                if (ch === 0x09) {\n-                                    lineIndent += 4 - (lineIndent + this.bsCount[line]) % 4;\n-                                } else {\n-                                    lineIndent++;\n-                                }\n-                            } else if (first - lineStart < this.tShift[line]) {\n-                                // patched tShift masked characters to look like spaces (blockquotes, list markers)\n-                                lineIndent++;\n-                            } else {\n-                                break;\n-                            }\n-                            first++;\n+                        return validateValue(itemType, valueAST);\n+                    }\n+                    if (type instanceof _graphql.GraphQLInputObjectType) {\n+                        if (valueAST.kind !== 'Object') {\n+                            return [\n+                                [valueAST, `Type \"${type}\" must be an Object.`]\n+                            ];\n                         }\n-                        if (lineIndent > indent) {\n-                            // partially expanding tabs in code blocks, e.g '\\t\\tfoobar'\n-                            // with indent=2 becomes '  \\tfoobar'\n-                            queue[i] = new Array(lineIndent - indent + 1).join(' ') + this.src.slice(first, last);\n-                        } else {\n-                            queue[i] = this.src.slice(first, last);\n+                        const providedFields = Object.create(null);\n+                        const fieldErrors = mapCat(valueAST.members, member => {\n+                            var _a;\n+                            const fieldName = (_a = member === null || member === void 0 ? void 0 : member.key) === null || _a === void 0 ? void 0 : _a.value;\n+                            providedFields[fieldName] = true;\n+                            const inputField = type.getFields()[fieldName];\n+                            if (!inputField) {\n+                                return [\n+                                    [member.key, `Type \"${type}\" does not have a field \"${fieldName}\".`]\n+                                ];\n+                            }\n+                            const fieldType = inputField ? inputField.type : undefined;\n+                            return validateValue(fieldType, member.value);\n+                        });\n+                        for (const fieldName of Object.keys(type.getFields())) {\n+                            const field = type.getFields()[fieldName];\n+                            if (!providedFields[fieldName] && field.type instanceof _graphql.GraphQLNonNull && !field.defaultValue) {\n+                                fieldErrors.push([valueAST, `Object of type \"${type}\" is missing required field \"${fieldName}\".`]);\n+                            }\n                         }\n+                        return fieldErrors;\n                     }\n-                    return queue.join('');\n-                };\n+                    if (type.name === 'Boolean' && valueAST.kind !== 'Boolean' || type.name === 'String' && valueAST.kind !== 'String' || type.name === 'ID' && valueAST.kind !== 'Number' && valueAST.kind !== 'String' || type.name === 'Float' && valueAST.kind !== 'Number' || type.name === 'Int' && (valueAST.kind !== 'Number' || (valueAST.value | 0) !== valueAST.value)) {\n+                        return [\n+                            [valueAST, `Expected value of type \"${type}\".`]\n+                        ];\n+                    }\n+                    if ((type instanceof _graphql.GraphQLEnumType || type instanceof _graphql.GraphQLScalarType) && (valueAST.kind !== 'String' && valueAST.kind !== 'Number' && valueAST.kind !== 'Boolean' && valueAST.kind !== 'Null' || isNullish(type.parseValue(valueAST.value)))) {\n+                        return [\n+                            [valueAST, `Expected value of type \"${type}\".`]\n+                        ];\n+                    }\n+                    return [];\n+                }\n \n-                // re-export Token class to use in block rules\n-                StateBlock.prototype.Token = Token;\n+                function lintError(editor, node, message) {\n+                    return {\n+                        message,\n+                        severity: 'error',\n+                        type: 'validation',\n+                        from: editor.posFromIndex(node.start),\n+                        to: editor.posFromIndex(node.end)\n+                    };\n+                }\n \n-                // GFM table, https://github.github.com/gfm/#tables-extension-\n+                function isNullish(value) {\n+                    return value === null || value === undefined || value !== value;\n+                }\n \n-                // Limit the amount of empty autocompleted cells in a table,\n-                // see https://github.com/markdown-it/markdown-it/issues/1000,\n-                //\n-                // Both pulldown-cmark and commonmark-hs limit the number of cells this way to ~200k.\n-                // We set it to 65k, which can expand user input by a factor of x370\n-                // (256x256 square is 1.8kB expanded into 650kB).\n-                const MAX_AUTOCOMPLETED_CELLS = 0x10000;\n+                function mapCat(array, mapper) {\n+                    return Array.prototype.concat.apply([], array.map(mapper));\n+                }\n \n-                function getLine(state, line) {\n-                    const pos = state.bMarks[line] + state.tShift[line];\n-                    const max = state.eMarks[line];\n-                    return state.src.slice(pos, max);\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../codemirror-graphql/esm/variables/mode.js\":\n+            /*!******************************************************!*\\\n+              !*** ../../codemirror-graphql/esm/variables/mode.js ***!\n+              \\******************************************************/\n+            /***/\n+            (function(__unused_webpack_module, __unused_webpack_exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                var _codemirror = _interopRequireDefault(__webpack_require__( /*! codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"));\n+                var _graphqlLanguageService = __webpack_require__( /*! graphql-language-service */ \"../../graphql-language-service/esm/index.js\");\n+                var _modeIndent = _interopRequireDefault(__webpack_require__( /*! ../utils/mode-indent */ \"../../codemirror-graphql/esm/utils/mode-indent.js\"));\n+\n+                function _interopRequireDefault(obj) {\n+                    return obj && obj.__esModule ? obj : {\n+                        default: obj\n+                    };\n                 }\n+                _codemirror.default.defineMode('graphql-variables', config => {\n+                    const parser = (0, _graphqlLanguageService.onlineParser)({\n+                        eatWhitespace: stream => stream.eatSpace(),\n+                        lexRules: LexRules,\n+                        parseRules: ParseRules,\n+                        editorConfig: {\n+                            tabSize: config.tabSize\n+                        }\n+                    });\n+                    return {\n+                        config,\n+                        startState: parser.startState,\n+                        token: parser.token,\n+                        indent: _modeIndent.default,\n+                        electricInput: /^\\s*[}\\]]/,\n+                        fold: 'brace',\n+                        closeBrackets: {\n+                            pairs: '[]{}\"\"',\n+                            explode: '[]{}'\n+                        }\n+                    };\n+                });\n+                const LexRules = {\n+                    Punctuation: /^\\[|]|\\{|\\}|:|,/,\n+                    Number: /^-?(?:0|(?:[1-9][0-9]*))(?:\\.[0-9]*)?(?:[eE][+-]?[0-9]+)?/,\n+                    String: /^\"(?:[^\"\\\\]|\\\\(?:\"|\\/|\\\\|b|f|n|r|t|u[0-9a-fA-F]{4}))*\"?/,\n+                    Keyword: /^true|false|null/\n+                };\n+                const ParseRules = {\n+                    Document: [(0, _graphqlLanguageService.p)('{'), (0, _graphqlLanguageService.list)('Variable', (0, _graphqlLanguageService.opt)((0, _graphqlLanguageService.p)(','))), (0, _graphqlLanguageService.p)('}')],\n+                    Variable: [namedKey('variable'), (0, _graphqlLanguageService.p)(':'), 'Value'],\n+                    Value(token) {\n+                        switch (token.kind) {\n+                            case 'Number':\n+                                return 'NumberValue';\n+                            case 'String':\n+                                return 'StringValue';\n+                            case 'Punctuation':\n+                                switch (token.value) {\n+                                    case '[':\n+                                        return 'ListValue';\n+                                    case '{':\n+                                        return 'ObjectValue';\n+                                }\n+                                return null;\n+                            case 'Keyword':\n+                                switch (token.value) {\n+                                    case 'true':\n+                                    case 'false':\n+                                        return 'BooleanValue';\n+                                    case 'null':\n+                                        return 'NullValue';\n+                                }\n+                                return null;\n+                        }\n+                    },\n+                    NumberValue: [(0, _graphqlLanguageService.t)('Number', 'number')],\n+                    StringValue: [(0, _graphqlLanguageService.t)('String', 'string')],\n+                    BooleanValue: [(0, _graphqlLanguageService.t)('Keyword', 'builtin')],\n+                    NullValue: [(0, _graphqlLanguageService.t)('Keyword', 'keyword')],\n+                    ListValue: [(0, _graphqlLanguageService.p)('['), (0, _graphqlLanguageService.list)('Value', (0, _graphqlLanguageService.opt)((0, _graphqlLanguageService.p)(','))), (0, _graphqlLanguageService.p)(']')],\n+                    ObjectValue: [(0, _graphqlLanguageService.p)('{'), (0, _graphqlLanguageService.list)('ObjectField', (0, _graphqlLanguageService.opt)((0, _graphqlLanguageService.p)(','))), (0, _graphqlLanguageService.p)('}')],\n+                    ObjectField: [namedKey('attribute'), (0, _graphqlLanguageService.p)(':'), 'Value']\n+                };\n \n-                function escapedSplit(str) {\n-                    const result = [];\n-                    const max = str.length;\n-                    let pos = 0;\n-                    let ch = str.charCodeAt(pos);\n-                    let isEscaped = false;\n-                    let lastPos = 0;\n-                    let current = '';\n-                    while (pos < max) {\n-                        if (ch === 0x7c /* | */ ) {\n-                            if (!isEscaped) {\n-                                // pipe separating cells, '|'\n-                                result.push(current + str.substring(lastPos, pos));\n-                                current = '';\n-                                lastPos = pos + 1;\n-                            } else {\n-                                // escaped pipe, '\\|'\n-                                current += str.substring(lastPos, pos - 1);\n-                                lastPos = pos;\n-                            }\n+                function namedKey(style) {\n+                    return {\n+                        style,\n+                        match: token => token.kind === 'String',\n+                        update(state, token) {\n+                            state.name = token.value.slice(1, -1);\n                         }\n-                        isEscaped = ch === 0x5c /* \\ */ ;\n-                        pos++;\n-                        ch = str.charCodeAt(pos);\n-                    }\n-                    result.push(current + str.substring(lastPos));\n-                    return result;\n+                    };\n                 }\n \n-                function table(state, startLine, endLine, silent) {\n-                    // should have at least two lines\n-                    if (startLine + 2 > endLine) {\n-                        return false;\n-                    }\n-                    let nextLine = startLine + 1;\n-                    if (state.sCount[nextLine] < state.blkIndent) {\n-                        return false;\n-                    }\n+                /***/\n+            }),\n \n-                    // if it's indented more than 3 spaces, it should be a code block\n-                    if (state.sCount[nextLine] - state.blkIndent >= 4) {\n-                        return false;\n-                    }\n+        /***/\n+        \"../../graphiql-react/dist/index.js\":\n+            /*!******************************************!*\\\n+              !*** ../../graphiql-react/dist/index.js ***!\n+              \\******************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                    // first character of the second line should be '|', '-', ':',\n-                    // and no other characters are allowed but spaces;\n-                    // basically, this is the equivalent of /^[-:|][-:|\\s]*$/ regexp\n+                \"use strict\";\n \n-                    let pos = state.bMarks[nextLine] + state.tShift[nextLine];\n-                    if (pos >= state.eMarks[nextLine]) {\n-                        return false;\n-                    }\n-                    const firstCh = state.src.charCodeAt(pos++);\n-                    if (firstCh !== 0x7C /* | */ && firstCh !== 0x2D /* - */ && firstCh !== 0x3A /* : */ ) {\n-                        return false;\n-                    }\n-                    if (pos >= state.eMarks[nextLine]) {\n-                        return false;\n-                    }\n-                    const secondCh = state.src.charCodeAt(pos++);\n-                    if (secondCh !== 0x7C /* | */ && secondCh !== 0x2D /* - */ && secondCh !== 0x3A /* : */ && !isSpace(secondCh)) {\n-                        return false;\n+\n+                function _getRequireWildcardCache(e) {\n+                    if (\"function\" != typeof WeakMap) return null;\n+                    var r = new WeakMap(),\n+                        t = new WeakMap();\n+                    return (_getRequireWildcardCache = function(e) {\n+                        return e ? t : r;\n+                    })(e);\n+                }\n+\n+                function _interopRequireWildcard(e, r) {\n+                    if (!r && e && e.__esModule) return e;\n+                    if (null === e || \"object\" != typeof e && \"function\" != typeof e) return {\n+                        default: e\n+                    };\n+                    var t = _getRequireWildcardCache(r);\n+                    if (t && t.has(e)) return t.get(e);\n+                    var n = {\n+                            __proto__: null\n+                        },\n+                        a = Object.defineProperty && Object.getOwnPropertyDescriptor;\n+                    for (var u in e)\n+                        if (\"default\" !== u && Object.prototype.hasOwnProperty.call(e, u)) {\n+                            var i = a ? Object.getOwnPropertyDescriptor(e, u) : null;\n+                            i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u];\n+                        } return n.default = e, t && t.set(e, n), n;\n+                }\n+                var __create = Object.create;\n+                var __defProp = Object.defineProperty;\n+                var __getOwnPropDesc = Object.getOwnPropertyDescriptor;\n+                var __getOwnPropNames = Object.getOwnPropertyNames;\n+                var __getProtoOf = Object.getPrototypeOf;\n+                var __hasOwnProp = Object.prototype.hasOwnProperty;\n+                var __copyProps = (to, from, except, desc) => {\n+                    if (from && typeof from === \"object\" || typeof from === \"function\") {\n+                        for (let key of __getOwnPropNames(from))\n+                            if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, {\n+                                get: () => from[key],\n+                                enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable\n+                            });\n                     }\n+                    return to;\n+                };\n+                var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(\n+                    // If the importer is in node compatibility mode or this is not an ESM\n+                    // file that has been converted to a CommonJS file using a Babel-\n+                    // compatible transform (i.e. \"__esModule\" has not been set), then set\n+                    // \"default\" to the CommonJS \"module.exports\" for node compatibility.\n+                    isNodeMode || !mod || !mod.__esModule ? __defProp(target, \"default\", {\n+                        value: mod,\n+                        enumerable: true\n+                    }) : target, mod));\n+                Object.defineProperty(exports, Symbol.toStringTag, {\n+                    value: \"Module\"\n+                });\n+                const jsxRuntime = __webpack_require__( /*! react/jsx-runtime */ \"../../../node_modules/react/jsx-runtime.js\");\n+                const reactCompilerRuntime = __webpack_require__( /*! react-compiler-runtime */ \"../../../node_modules/react-compiler-runtime/dist/index.js\");\n+                const React = __webpack_require__( /*! react */ \"react\");\n+                const clsx = __webpack_require__( /*! clsx */ \"../../../node_modules/clsx/dist/clsx.m.js\");\n+                const graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n+                const toolkit = __webpack_require__( /*! @graphiql/toolkit */ \"../../graphiql-toolkit/dist/esm/index.js\");\n+                const graphqlLanguageService = __webpack_require__( /*! graphql-language-service */ \"../../graphql-language-service/esm/index.js\");\n+                const setValue = __webpack_require__( /*! set-value */ \"../../../node_modules/set-value/index.js\");\n+                const getValue = __webpack_require__( /*! get-value */ \"../../../node_modules/get-value/index.js\");\n+                const copyToClipboard = __webpack_require__( /*! copy-to-clipboard */ \"../../../node_modules/copy-to-clipboard/index.js\");\n+                const D = __webpack_require__( /*! @radix-ui/react-dialog */ \"../../../node_modules/@radix-ui/react-dialog/dist/index.js\");\n+                const reactVisuallyHidden = __webpack_require__( /*! @radix-ui/react-visually-hidden */ \"../../../node_modules/@radix-ui/react-visually-hidden/dist/index.js\");\n+                const reactDropdownMenu = __webpack_require__( /*! @radix-ui/react-dropdown-menu */ \"../../../node_modules/@radix-ui/react-dropdown-menu/dist/index.js\");\n+                const MarkdownIt = __webpack_require__( /*! markdown-it */ \"../../../node_modules/markdown-it/dist/index.cjs.js\");\n+                const framerMotion = __webpack_require__( /*! framer-motion */ \"../../../node_modules/framer-motion/dist/cjs/index.js\");\n+                const T = __webpack_require__( /*! @radix-ui/react-tooltip */ \"../../../node_modules/@radix-ui/react-tooltip/dist/index.js\");\n+                const react = __webpack_require__( /*! @headlessui/react */ \"../../../node_modules/@headlessui/react/dist/index.cjs\");\n+                const ReactDOM = __webpack_require__( /*! react-dom */ \"react-dom\");\n \n-                    // if first character is '-', then second character must not be a space\n-                    // (due to parsing ambiguity with list)\n-                    if (firstCh === 0x2D /* - */ && isSpace(secondCh)) {\n-                        return false;\n+                function _interopNamespaceDefault(e) {\n+                    const n = Object.create(null, {\n+                        [Symbol.toStringTag]: {\n+                            value: \"Module\"\n+                        }\n+                    });\n+                    if (e) {\n+                        for (const k in e) {\n+                            if (k !== \"default\") {\n+                                const d = Object.getOwnPropertyDescriptor(e, k);\n+                                Object.defineProperty(n, k, d.get ? d : {\n+                                    enumerable: true,\n+                                    get: () => e[k]\n+                                });\n+                            }\n+                        }\n                     }\n-                    while (pos < state.eMarks[nextLine]) {\n-                        const ch = state.src.charCodeAt(pos);\n-                        if (ch !== 0x7C /* | */ && ch !== 0x2D /* - */ && ch !== 0x3A /* : */ && !isSpace(ch)) {\n-                            return false;\n+                    n.default = e;\n+                    return Object.freeze(n);\n+                }\n+                const React__namespace = /* @__PURE__ */ _interopNamespaceDefault(React);\n+                const D__namespace = /* @__PURE__ */ _interopNamespaceDefault(D);\n+                const T__namespace = /* @__PURE__ */ _interopNamespaceDefault(T);\n+\n+                function createNullableContext(name) {\n+                    const context = React.createContext(null);\n+                    context.displayName = name;\n+                    return context;\n+                }\n+\n+                function createContextHook(context) {\n+                    function useGivenContext(options) {\n+                        var _a;\n+                        const value = React.useContext(context);\n+                        if (value === null && (options == null ? void 0 : options.nonNull)) {\n+                            throw new Error(`Tried to use \\`${((_a = options.caller) == null ? void 0 : _a.name) || \"a component\"}\\` without the necessary context. Make sure to render the \\`${context.displayName}Provider\\` component higher up the tree.`);\n                         }\n-                        pos++;\n+                        return value;\n                     }\n-                    let lineText = getLine(state, startLine + 1);\n-                    let columns = lineText.split('|');\n-                    const aligns = [];\n-                    for (let i = 0; i < columns.length; i++) {\n-                        const t = columns[i].trim();\n-                        if (!t) {\n-                            // allow empty columns before and after table, but not in between columns;\n-                            // e.g. allow ` |---| `, disallow ` ---||--- `\n-                            if (i === 0 || i === columns.length - 1) {\n-                                continue;\n+                    Object.defineProperty(useGivenContext, \"name\", {\n+                        value: `use${context.displayName}`\n+                    });\n+                    return useGivenContext;\n+                }\n+                const StorageContext = createNullableContext(\"StorageContext\");\n+\n+                function StorageContextProvider(props) {\n+                    const $ = reactCompilerRuntime.c(8);\n+                    const isInitialRender = React.useRef(true);\n+                    let t0;\n+                    if ($[0] !== props.storage) {\n+                        t0 = () => new toolkit.StorageAPI(props.storage);\n+                        $[0] = props.storage;\n+                        $[1] = t0;\n+                    } else {\n+                        t0 = $[1];\n+                    }\n+                    const [storage, setStorage] = React.useState(t0);\n+                    let t1;\n+                    let t2;\n+                    if ($[2] !== props.storage) {\n+                        t1 = () => {\n+                            if (isInitialRender.current) {\n+                                isInitialRender.current = false;\n                             } else {\n-                                return false;\n+                                setStorage(new toolkit.StorageAPI(props.storage));\n                             }\n-                        }\n-                        if (!/^:?-+:?$/.test(t)) {\n-                            return false;\n-                        }\n-                        if (t.charCodeAt(t.length - 1) === 0x3A /* : */ ) {\n-                            aligns.push(t.charCodeAt(0) === 0x3A /* : */ ? 'center' : 'right');\n-                        } else if (t.charCodeAt(0) === 0x3A /* : */ ) {\n-                            aligns.push('left');\n+                        };\n+                        t2 = [props.storage];\n+                        $[2] = props.storage;\n+                        $[3] = t1;\n+                        $[4] = t2;\n+                    } else {\n+                        t1 = $[3];\n+                        t2 = $[4];\n+                    }\n+                    React.useEffect(t1, t2);\n+                    let t3;\n+                    if ($[5] !== props.children || $[6] !== storage) {\n+                        t3 = /* @__PURE__ */ jsxRuntime.jsx(StorageContext.Provider, {\n+                            value: storage,\n+                            children: props.children\n+                        });\n+                        $[5] = props.children;\n+                        $[6] = storage;\n+                        $[7] = t3;\n+                    } else {\n+                        t3 = $[7];\n+                    }\n+                    return t3;\n+                }\n+                const useStorageContext = createContextHook(StorageContext);\n+                const SvgArgument = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 14 14\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M5.0484 1.40838C6.12624 0.33054 7.87376 0.330541 8.9516 1.40838L12.5916 5.0484C13.6695 6.12624 13.6695 7.87376 12.5916 8.9516L8.9516 12.5916C7.87376 13.6695 6.12624 13.6695 5.0484 12.5916L1.40838 8.9516C0.33054 7.87376 0.330541 6.12624 1.40838 5.0484L5.0484 1.40838Z\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.2\n+                }), /* @__PURE__ */ React__namespace.createElement(\"rect\", {\n+                    x: 6,\n+                    y: 6,\n+                    width: 2,\n+                    height: 2,\n+                    rx: 1,\n+                    fill: \"currentColor\"\n+                }));\n+                const SvgChevronDown = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 14 9\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M1 1L7 7L13 1\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.5\n+                }));\n+                const SvgChevronLeft = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 7 10\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M6 1.04819L2 5.04819L6 9.04819\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.75\n+                }));\n+                const SvgChevronUp = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 14 9\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M13 8L7 2L1 8\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.5\n+                }));\n+                const SvgClose = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 14 14\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 3,\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M1 1L12.9998 12.9997\"\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M13 1L1.00079 13.0003\"\n+                }));\n+                const SvgCopy = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"-2 -2 22 22\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M11.25 14.2105V15.235C11.25 16.3479 10.3479 17.25 9.23501 17.25H2.76499C1.65214 17.25 0.75 16.3479 0.75 15.235L0.75 8.76499C0.75 7.65214 1.65214 6.75 2.76499 6.75L3.78947 6.75\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.5\n+                }), /* @__PURE__ */ React__namespace.createElement(\"rect\", {\n+                    x: 6.75,\n+                    y: 0.75,\n+                    width: 10.5,\n+                    height: 10.5,\n+                    rx: 2.2069,\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.5\n+                }));\n+                const SvgDeprecatedArgument = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 14 14\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M5.0484 1.40838C6.12624 0.33054 7.87376 0.330541 8.9516 1.40838L12.5916 5.0484C13.6695 6.12624 13.6695 7.87376 12.5916 8.9516L8.9516 12.5916C7.87376 13.6695 6.12624 13.6695 5.0484 12.5916L1.40838 8.9516C0.33054 7.87376 0.330541 6.12624 1.40838 5.0484L5.0484 1.40838Z\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.2\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M5 9L9 5\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.2\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M5 5L9 9\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.2\n+                }));\n+                const SvgDeprecatedEnumValue = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 12 12\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M4 8L8 4\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.2\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M4 4L8 8\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.2\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    fillRule: \"evenodd\",\n+                    clipRule: \"evenodd\",\n+                    d: \"M8.5 1.2H9C9.99411 1.2 10.8 2.00589 10.8 3V9C10.8 9.99411 9.99411 10.8 9 10.8H8.5V12H9C10.6569 12 12 10.6569 12 9V3C12 1.34315 10.6569 0 9 0H8.5V1.2ZM3.5 1.2V0H3C1.34315 0 0 1.34315 0 3V9C0 10.6569 1.34315 12 3 12H3.5V10.8H3C2.00589 10.8 1.2 9.99411 1.2 9V3C1.2 2.00589 2.00589 1.2 3 1.2H3.5Z\",\n+                    fill: \"currentColor\"\n+                }));\n+                const SvgDeprecatedField = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 12 12\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"rect\", {\n+                    x: 0.6,\n+                    y: 0.6,\n+                    width: 10.8,\n+                    height: 10.8,\n+                    rx: 3.4,\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.2\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M4 8L8 4\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.2\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M4 4L8 8\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.2\n+                }));\n+                const SvgDirective = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0.5 12 12\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"rect\", {\n+                    x: 7,\n+                    y: 5.5,\n+                    width: 2,\n+                    height: 2,\n+                    rx: 1,\n+                    transform: \"rotate(90 7 5.5)\",\n+                    fill: \"currentColor\"\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    fillRule: \"evenodd\",\n+                    clipRule: \"evenodd\",\n+                    d: \"M10.8 9L10.8 9.5C10.8 10.4941 9.99411 11.3 9 11.3L3 11.3C2.00589 11.3 1.2 10.4941 1.2 9.5L1.2 9L-3.71547e-07 9L-3.93402e-07 9.5C-4.65826e-07 11.1569 1.34314 12.5 3 12.5L9 12.5C10.6569 12.5 12 11.1569 12 9.5L12 9L10.8 9ZM10.8 4L12 4L12 3.5C12 1.84315 10.6569 0.5 9 0.5L3 0.5C1.34315 0.5 -5.87117e-08 1.84315 -1.31135e-07 3.5L-1.5299e-07 4L1.2 4L1.2 3.5C1.2 2.50589 2.00589 1.7 3 1.7L9 1.7C9.99411 1.7 10.8 2.50589 10.8 3.5L10.8 4Z\",\n+                    fill: \"currentColor\"\n+                }));\n+                const SvgDocsFilled = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 20 24\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M0.75 3C0.75 1.75736 1.75736 0.75 3 0.75H17.25C17.8023 0.75 18.25 1.19772 18.25 1.75V5.25\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.5\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M0.75 3C0.75 4.24264 1.75736 5.25 3 5.25H18.25C18.8023 5.25 19.25 5.69771 19.25 6.25V22.25C19.25 22.8023 18.8023 23.25 18.25 23.25H3C1.75736 23.25 0.75 22.2426 0.75 21V3Z\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.5\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    fillRule: \"evenodd\",\n+                    clipRule: \"evenodd\",\n+                    d: \"M3 5.25C1.75736 5.25 0.75 4.24264 0.75 3V21C0.75 22.2426 1.75736 23.25 3 23.25H18.25C18.8023 23.25 19.25 22.8023 19.25 22.25V6.25C19.25 5.69771 18.8023 5.25 18.25 5.25H3ZM13 11L6 11V12.5L13 12.5V11Z\",\n+                    fill: \"currentColor\"\n+                }));\n+                const SvgDocs = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 20 24\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M0.75 3C0.75 4.24264 1.75736 5.25 3 5.25H17.25M0.75 3C0.75 1.75736 1.75736 0.75 3 0.75H16.25C16.8023 0.75 17.25 1.19772 17.25 1.75V5.25M0.75 3V21C0.75 22.2426 1.75736 23.25 3 23.25H18.25C18.8023 23.25 19.25 22.8023 19.25 22.25V6.25C19.25 5.69771 18.8023 5.25 18.25 5.25H17.25\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.5\n+                }), /* @__PURE__ */ React__namespace.createElement(\"line\", {\n+                    x1: 13,\n+                    y1: 11.75,\n+                    x2: 6,\n+                    y2: 11.75,\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.5\n+                }));\n+                const SvgEnumValue = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 12 12\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"rect\", {\n+                    x: 5,\n+                    y: 5,\n+                    width: 2,\n+                    height: 2,\n+                    rx: 1,\n+                    fill: \"currentColor\"\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    fillRule: \"evenodd\",\n+                    clipRule: \"evenodd\",\n+                    d: \"M8.5 1.2H9C9.99411 1.2 10.8 2.00589 10.8 3V9C10.8 9.99411 9.99411 10.8 9 10.8H8.5V12H9C10.6569 12 12 10.6569 12 9V3C12 1.34315 10.6569 0 9 0H8.5V1.2ZM3.5 1.2V0H3C1.34315 0 0 1.34315 0 3V9C0 10.6569 1.34315 12 3 12H3.5V10.8H3C2.00589 10.8 1.2 9.99411 1.2 9V3C1.2 2.00589 2.00589 1.2 3 1.2H3.5Z\",\n+                    fill: \"currentColor\"\n+                }));\n+                const SvgField = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 12 13\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"rect\", {\n+                    x: 0.6,\n+                    y: 1.1,\n+                    width: 10.8,\n+                    height: 10.8,\n+                    rx: 2.4,\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.2\n+                }), /* @__PURE__ */ React__namespace.createElement(\"rect\", {\n+                    x: 5,\n+                    y: 5.5,\n+                    width: 2,\n+                    height: 2,\n+                    rx: 1,\n+                    fill: \"currentColor\"\n+                }));\n+                const SvgHistory = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 24 20\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M1.59375 9.52344L4.87259 12.9944L8.07872 9.41249\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.5,\n+                    strokeLinecap: \"square\"\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M13.75 5.25V10.75H18.75\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.5,\n+                    strokeLinecap: \"square\"\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M4.95427 11.9332C4.55457 10.0629 4.74441 8.11477 5.49765 6.35686C6.25089 4.59894 7.5305 3.11772 9.16034 2.11709C10.7902 1.11647 12.6901 0.645626 14.5986 0.769388C16.5071 0.893151 18.3303 1.60543 19.8172 2.80818C21.3042 4.01093 22.3818 5.64501 22.9017 7.48548C23.4216 9.32595 23.3582 11.2823 22.7203 13.0853C22.0824 14.8883 20.9013 16.4492 19.3396 17.5532C17.778 18.6572 15.9125 19.25 14 19.25\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.5\n+                }));\n+                const SvgImplements = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 12 12\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"circle\", {\n+                    cx: 6,\n+                    cy: 6,\n+                    r: 5.4,\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.2,\n+                    strokeDasharray: \"4.241025 4.241025\",\n+                    transform: \"rotate(22.5)\",\n+                    \"transform-origin\": \"center\"\n+                }), /* @__PURE__ */ React__namespace.createElement(\"circle\", {\n+                    cx: 6,\n+                    cy: 6,\n+                    r: 1,\n+                    fill: \"currentColor\"\n+                }));\n+                const SvgKeyboardShortcut = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 19 18\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M1.5 14.5653C1.5 15.211 1.75652 15.8303 2.21314 16.2869C2.66975 16.7435 3.28905 17 3.9348 17C4.58054 17 5.19984 16.7435 5.65646 16.2869C6.11307 15.8303 6.36959 15.211 6.36959 14.5653V12.1305H3.9348C3.28905 12.1305 2.66975 12.387 2.21314 12.8437C1.75652 13.3003 1.5 13.9195 1.5 14.5653Z\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.125,\n+                    strokeLinecap: \"round\",\n+                    strokeLinejoin: \"round\"\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M3.9348 1.00063C3.28905 1.00063 2.66975 1.25715 2.21314 1.71375C1.75652 2.17035 1.5 2.78964 1.5 3.43537C1.5 4.0811 1.75652 4.70038 2.21314 5.15698C2.66975 5.61358 3.28905 5.8701 3.9348 5.8701H6.36959V3.43537C6.36959 2.78964 6.11307 2.17035 5.65646 1.71375C5.19984 1.25715 4.58054 1.00063 3.9348 1.00063Z\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.125,\n+                    strokeLinecap: \"round\",\n+                    strokeLinejoin: \"round\"\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M15.0652 12.1305H12.6304V14.5653C12.6304 15.0468 12.7732 15.5175 13.0407 15.9179C13.3083 16.3183 13.6885 16.6304 14.1334 16.8147C14.5783 16.9989 15.0679 17.0472 15.5402 16.9532C16.0125 16.8593 16.4464 16.6274 16.7869 16.2869C17.1274 15.9464 17.3593 15.5126 17.4532 15.0403C17.5472 14.568 17.4989 14.0784 17.3147 13.6335C17.1304 13.1886 16.8183 12.8084 16.4179 12.5409C16.0175 12.2733 15.5468 12.1305 15.0652 12.1305Z\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.125,\n+                    strokeLinecap: \"round\",\n+                    strokeLinejoin: \"round\"\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M12.6318 5.86775H6.36955V12.1285H12.6318V5.86775Z\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.125,\n+                    strokeLinecap: \"round\",\n+                    strokeLinejoin: \"round\"\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M17.5 3.43473C17.5 2.789 17.2435 2.16972 16.7869 1.71312C16.3303 1.25652 15.711 1 15.0652 1C14.4195 1 13.8002 1.25652 13.3435 1.71312C12.8869 2.16972 12.6304 2.789 12.6304 3.43473V5.86946H15.0652C15.711 5.86946 16.3303 5.61295 16.7869 5.15635C17.2435 4.69975 17.5 4.08046 17.5 3.43473Z\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.125,\n+                    strokeLinecap: \"round\",\n+                    strokeLinejoin: \"round\"\n+                }));\n+                const SvgMagnifyingGlass = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 13 13\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"circle\", {\n+                    cx: 5,\n+                    cy: 5,\n+                    r: 4.35,\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.3\n+                }), /* @__PURE__ */ React__namespace.createElement(\"line\", {\n+                    x1: 8.45962,\n+                    y1: 8.54038,\n+                    x2: 11.7525,\n+                    y2: 11.8333,\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.3\n+                }));\n+                const SvgMerge = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"-2 -2 22 22\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M17.2492 6V2.9569C17.2492 1.73806 16.2611 0.75 15.0423 0.75L2.9569 0.75C1.73806 0.75 0.75 1.73806 0.75 2.9569L0.75 6\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.5\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M0.749873 12V15.0431C0.749873 16.2619 1.73794 17.25 2.95677 17.25H15.0421C16.261 17.25 17.249 16.2619 17.249 15.0431V12\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.5\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M6 4.5L9 7.5L12 4.5\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.5\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M12 13.5L9 10.5L6 13.5\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.5\n+                }));\n+                const SvgPen = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 14 14\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M0.75 13.25L0.0554307 12.967C-0.0593528 13.2488 0.00743073 13.5719 0.224488 13.7851C0.441545 13.9983 0.765869 14.0592 1.04549 13.9393L0.75 13.25ZM12.8214 1.83253L12.2911 2.36286L12.2911 2.36286L12.8214 1.83253ZM12.8214 3.90194L13.3517 4.43227L12.8214 3.90194ZM10.0981 1.17859L9.56773 0.648259L10.0981 1.17859ZM12.1675 1.17859L12.6978 0.648258L12.6978 0.648257L12.1675 1.17859ZM2.58049 8.75697L3.27506 9.03994L2.58049 8.75697ZM2.70066 8.57599L3.23099 9.10632L2.70066 8.57599ZM5.2479 11.4195L4.95355 10.7297L5.2479 11.4195ZM5.42036 11.303L4.89003 10.7727L5.42036 11.303ZM4.95355 10.7297C4.08882 11.0987 3.41842 11.362 2.73535 11.6308C2.05146 11.9 1.35588 12.1743 0.454511 12.5607L1.04549 13.9393C1.92476 13.5624 2.60256 13.2951 3.28469 13.0266C3.96762 12.7578 4.65585 12.4876 5.54225 12.1093L4.95355 10.7297ZM1.44457 13.533L3.27506 9.03994L1.88592 8.474L0.0554307 12.967L1.44457 13.533ZM3.23099 9.10632L10.6284 1.70892L9.56773 0.648259L2.17033 8.04566L3.23099 9.10632ZM11.6371 1.70892L12.2911 2.36286L13.3517 1.3022L12.6978 0.648258L11.6371 1.70892ZM12.2911 3.37161L4.89003 10.7727L5.95069 11.8333L13.3517 4.43227L12.2911 3.37161ZM12.2911 2.36286C12.5696 2.64142 12.5696 3.09305 12.2911 3.37161L13.3517 4.43227C14.2161 3.56792 14.2161 2.16654 13.3517 1.3022L12.2911 2.36286ZM10.6284 1.70892C10.9069 1.43036 11.3586 1.43036 11.6371 1.70892L12.6978 0.648257C11.8335 -0.216088 10.4321 -0.216084 9.56773 0.648259L10.6284 1.70892ZM3.27506 9.03994C3.26494 9.06479 3.24996 9.08735 3.23099 9.10632L2.17033 8.04566C2.04793 8.16806 1.95123 8.31369 1.88592 8.474L3.27506 9.03994ZM5.54225 12.1093C5.69431 12.0444 5.83339 11.9506 5.95069 11.8333L4.89003 10.7727C4.90863 10.7541 4.92988 10.7398 4.95355 10.7297L5.54225 12.1093Z\",\n+                    fill: \"currentColor\"\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M11.5 4.5L9.5 2.5\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.4026,\n+                    strokeLinecap: \"round\",\n+                    strokeLinejoin: \"round\"\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M5.5 10.5L3.5 8.5\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.4026,\n+                    strokeLinecap: \"round\",\n+                    strokeLinejoin: \"round\"\n+                }));\n+                const SvgPlay = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 16 18\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M1.32226e-07 1.6609C7.22332e-08 0.907329 0.801887 0.424528 1.46789 0.777117L15.3306 8.11621C16.0401 8.49182 16.0401 9.50818 15.3306 9.88379L1.46789 17.2229C0.801886 17.5755 1.36076e-06 17.0927 1.30077e-06 16.3391L1.32226e-07 1.6609Z\",\n+                    fill: \"currentColor\"\n+                }));\n+                const SvgPlus = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 10 16\",\n+                    fill: \"currentColor\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    fillRule: \"evenodd\",\n+                    clipRule: \"evenodd\",\n+                    d: \"M4.25 9.25V13.5H5.75V9.25L10 9.25V7.75L5.75 7.75V3.5H4.25V7.75L0 7.75V9.25L4.25 9.25Z\"\n+                }));\n+                const SvgPrettify = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    width: 25,\n+                    height: 25,\n+                    viewBox: \"0 0 25 25\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M10.2852 24.0745L13.7139 18.0742\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.5625\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M14.5742 24.0749L17.1457 19.7891\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.5625\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M19.4868 24.0735L20.7229 21.7523C21.3259 20.6143 21.5457 19.3122 21.3496 18.0394C21.1535 16.7666 20.5519 15.591 19.6342 14.6874L23.7984 6.87853C24.0123 6.47728 24.0581 6.00748 23.9256 5.57249C23.7932 5.1375 23.4933 4.77294 23.0921 4.55901C22.6908 4.34509 22.221 4.29932 21.7861 4.43178C21.3511 4.56424 20.9865 4.86408 20.7726 5.26533L16.6084 13.0742C15.3474 12.8142 14.0362 12.9683 12.8699 13.5135C11.7035 14.0586 10.7443 14.9658 10.135 16.1L6 24.0735\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.5625\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M4 15L5 13L7 12L5 11L4 9L3 11L1 12L3 13L4 15Z\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.5625,\n+                    strokeLinejoin: \"round\"\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M11.5 8L12.6662 5.6662L15 4.5L12.6662 3.3338L11.5 1L10.3338 3.3338L8 4.5L10.3338 5.6662L11.5 8Z\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.5625,\n+                    strokeLinejoin: \"round\"\n+                }));\n+                const SvgReload = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 16 16\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M4.75 9.25H1.25V12.75\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1,\n+                    strokeLinecap: \"square\"\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M11.25 6.75H14.75V3.25\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1,\n+                    strokeLinecap: \"square\"\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M14.1036 6.65539C13.8 5.27698 13.0387 4.04193 11.9437 3.15131C10.8487 2.26069 9.48447 1.76694 8.0731 1.75043C6.66173 1.73392 5.28633 2.19563 4.17079 3.0604C3.05526 3.92516 2.26529 5.14206 1.92947 6.513\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M1.89635 9.34461C2.20001 10.723 2.96131 11.9581 4.05631 12.8487C5.15131 13.7393 6.51553 14.2331 7.9269 14.2496C9.33827 14.2661 10.7137 13.8044 11.8292 12.9396C12.9447 12.0748 13.7347 10.8579 14.0705 9.487\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1\n+                }));\n+                const SvgRootType = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 13 13\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"rect\", {\n+                    x: 0.6,\n+                    y: 0.6,\n+                    width: 11.8,\n+                    height: 11.8,\n+                    rx: 5.9,\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.2\n+                }), /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M4.25 7.5C4.25 6 5.75 5 6.5 6.5C7.25 8 8.75 7 8.75 5.5\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.2\n+                }));\n+                const SvgSettings = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 21 20\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    fillRule: \"evenodd\",\n+                    clipRule: \"evenodd\",\n+                    d: \"M9.29186 1.92702C9.06924 1.82745 8.87014 1.68202 8.70757 1.50024L7.86631 0.574931C7.62496 0.309957 7.30773 0.12592 6.95791 0.0479385C6.60809 -0.0300431 6.24274 0.00182978 5.91171 0.139208C5.58068 0.276585 5.3001 0.512774 5.10828 0.815537C4.91645 1.1183 4.82272 1.47288 4.83989 1.83089L4.90388 3.08019C4.91612 3.32348 4.87721 3.56662 4.78968 3.79394C4.70215 4.02126 4.56794 4.2277 4.39571 4.39994C4.22347 4.57219 4.01704 4.7064 3.78974 4.79394C3.56243 4.88147 3.3193 4.92038 3.07603 4.90814L1.8308 4.84414C1.47162 4.82563 1.11553 4.91881 0.811445 5.11086C0.507359 5.30292 0.270203 5.58443 0.132561 5.91671C-0.00508149 6.249 -0.0364554 6.61576 0.0427496 6.9666C0.121955 7.31744 0.307852 7.63514 0.5749 7.87606L1.50016 8.71204C1.68193 8.87461 1.82735 9.07373 1.92692 9.29636C2.02648 9.51898 2.07794 9.76012 2.07794 10.004C2.07794 10.2479 2.02648 10.489 1.92692 10.7116C1.82735 10.9343 1.68193 11.1334 1.50016 11.296L0.5749 12.1319C0.309856 12.3729 0.125575 12.6898 0.0471809 13.0393C-0.0312128 13.3888 9.64098e-05 13.754 0.13684 14.0851C0.273583 14.4162 0.509106 14.6971 0.811296 14.8894C1.11349 15.0817 1.46764 15.1762 1.82546 15.1599L3.0707 15.0959C3.31397 15.0836 3.5571 15.1225 3.7844 15.2101C4.01171 15.2976 4.21814 15.4318 4.39037 15.6041C4.56261 15.7763 4.69682 15.9827 4.78435 16.2101C4.87188 16.4374 4.91078 16.6805 4.89855 16.9238L4.83455 18.1691C4.81605 18.5283 4.90921 18.8844 5.10126 19.1885C5.2933 19.4926 5.5748 19.7298 5.90707 19.8674C6.23934 20.0051 6.60608 20.0365 6.9569 19.9572C7.30772 19.878 7.6254 19.6921 7.86631 19.4251L8.7129 18.4998C8.87547 18.318 9.07458 18.1725 9.29719 18.073C9.51981 17.9734 9.76093 17.9219 10.0048 17.9219C10.2487 17.9219 10.4898 17.9734 10.7124 18.073C10.935 18.1725 11.1341 18.318 11.2967 18.4998L12.1326 19.4251C12.3735 19.6921 12.6912 19.878 13.042 19.9572C13.3929 20.0365 13.7596 20.0051 14.0919 19.8674C14.4241 19.7298 14.7056 19.4926 14.8977 19.1885C15.0897 18.8844 15.1829 18.5283 15.1644 18.1691L15.1004 16.9238C15.0882 16.6805 15.1271 16.4374 15.2146 16.2101C15.3021 15.9827 15.4363 15.7763 15.6086 15.6041C15.7808 15.4318 15.9872 15.2976 16.2145 15.2101C16.4418 15.1225 16.685 15.0836 16.9282 15.0959L18.1735 15.1599C18.5326 15.1784 18.8887 15.0852 19.1928 14.8931C19.4969 14.7011 19.7341 14.4196 19.8717 14.0873C20.0093 13.755 20.0407 13.3882 19.9615 13.0374C19.8823 12.6866 19.6964 12.3689 19.4294 12.1279L18.5041 11.292C18.3223 11.1294 18.1769 10.9303 18.0774 10.7076C17.9778 10.485 17.9263 10.2439 17.9263 10C17.9263 9.75612 17.9778 9.51499 18.0774 9.29236C18.1769 9.06973 18.3223 8.87062 18.5041 8.70804L19.4294 7.87206C19.6964 7.63114 19.8823 7.31344 19.9615 6.9626C20.0407 6.61176 20.0093 6.245 19.8717 5.91271C19.7341 5.58043 19.4969 5.29892 19.1928 5.10686C18.8887 4.91481 18.5326 4.82163 18.1735 4.84014L16.9282 4.90414C16.685 4.91638 16.4418 4.87747 16.2145 4.78994C15.9872 4.7024 15.7808 4.56818 15.6086 4.39594C15.4363 4.2237 15.3021 4.01726 15.2146 3.78994C15.1271 3.56262 15.0882 3.31948 15.1004 3.07619L15.1644 1.83089C15.1829 1.4717 15.0897 1.11559 14.8977 0.811487C14.7056 0.507385 14.4241 0.270217 14.0919 0.132568C13.7596 -0.00508182 13.3929 -0.0364573 13.042 0.0427519C12.6912 0.121961 12.3735 0.307869 12.1326 0.574931L11.2914 1.50024C11.1288 1.68202 10.9297 1.82745 10.7071 1.92702C10.4845 2.02659 10.2433 2.07805 9.99947 2.07805C9.7556 2.07805 9.51448 2.02659 9.29186 1.92702ZM14.3745 10C14.3745 12.4162 12.4159 14.375 9.99977 14.375C7.58365 14.375 5.625 12.4162 5.625 10C5.625 7.58375 7.58365 5.625 9.99977 5.625C12.4159 5.625 14.3745 7.58375 14.3745 10Z\",\n+                    fill: \"currentColor\"\n+                }));\n+                const SvgStarFilled = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 14 14\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M6.5782 1.07092C6.71096 0.643026 7.28904 0.643027 7.4218 1.07092L8.59318 4.84622C8.65255 5.03758 8.82284 5.16714 9.01498 5.16714L12.8056 5.16714C13.2353 5.16714 13.4139 5.74287 13.0663 6.00732L9.99962 8.34058C9.84418 8.45885 9.77913 8.66848 9.83851 8.85984L11.0099 12.6351C11.1426 13.063 10.675 13.4189 10.3274 13.1544L7.26069 10.8211C7.10524 10.7029 6.89476 10.7029 6.73931 10.8211L3.6726 13.1544C3.32502 13.4189 2.85735 13.063 2.99012 12.6351L4.16149 8.85984C4.22087 8.66848 4.15582 8.45885 4.00038 8.34058L0.933671 6.00732C0.586087 5.74287 0.764722 5.16714 1.19436 5.16714L4.98502 5.16714C5.17716 5.16714 5.34745 5.03758 5.40682 4.84622L6.5782 1.07092Z\",\n+                    fill: \"currentColor\",\n+                    stroke: \"currentColor\"\n+                }));\n+                const SvgStar = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 14 14\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M6.5782 1.07092C6.71096 0.643026 7.28904 0.643027 7.4218 1.07092L8.59318 4.84622C8.65255 5.03758 8.82284 5.16714 9.01498 5.16714L12.8056 5.16714C13.2353 5.16714 13.4139 5.74287 13.0663 6.00732L9.99962 8.34058C9.84418 8.45885 9.77913 8.66848 9.83851 8.85984L11.0099 12.6351C11.1426 13.063 10.675 13.4189 10.3274 13.1544L7.26069 10.8211C7.10524 10.7029 6.89476 10.7029 6.73931 10.8211L3.6726 13.1544C3.32502 13.4189 2.85735 13.063 2.99012 12.6351L4.16149 8.85984C4.22087 8.66848 4.15582 8.45885 4.00038 8.34058L0.933671 6.00732C0.586087 5.74287 0.764722 5.16714 1.19436 5.16714L4.98502 5.16714C5.17716 5.16714 5.34745 5.03758 5.40682 4.84622L6.5782 1.07092Z\",\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.5\n+                }));\n+                const SvgStop = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 16 16\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"rect\", {\n+                    width: 16,\n+                    height: 16,\n+                    rx: 2,\n+                    fill: \"currentColor\"\n+                }));\n+                const SvgTrash = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    width: \"1em\",\n+                    height: \"5em\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    fillRule: \"evenodd\",\n+                    \"aria-hidden\": \"true\",\n+                    viewBox: \"0 0 23 23\",\n+                    style: {\n+                        height: \"1.5em\"\n+                    },\n+                    clipRule: \"evenodd\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"path\", {\n+                    d: \"M19 24h-14c-1.104 0-2-.896-2-2v-17h-1v-2h6v-1.5c0-.827.673-1.5 1.5-1.5h5c.825 0 1.5.671 1.5 1.5v1.5h6v2h-1v17c0 1.104-.896 2-2 2zm0-19h-14v16.5c0 .276.224.5.5.5h13c.276 0 .5-.224.5-.5v-16.5zm-7 7.586l3.293-3.293 1.414 1.414-3.293 3.293 3.293 3.293-1.414 1.414-3.293-3.293-3.293 3.293-1.414-1.414 3.293-3.293-3.293-3.293 1.414-1.414 3.293 3.293zm2-10.586h-4v1h4v-1z\",\n+                    fill: \"currentColor\",\n+                    strokeWidth: 0.25,\n+                    stroke: \"currentColor\"\n+                }));\n+                const SvgType = ({\n+                    title,\n+                    titleId,\n+                    ...props\n+                }) => /* @__PURE__ */ React__namespace.createElement(\"svg\", {\n+                    height: \"1em\",\n+                    viewBox: \"0 0 13 13\",\n+                    fill: \"none\",\n+                    xmlns: \"http://www.w3.org/2000/svg\",\n+                    \"aria-labelledby\": titleId,\n+                    ...props\n+                }, title ? /* @__PURE__ */ React__namespace.createElement(\"title\", {\n+                    id: titleId\n+                }, title) : null, /* @__PURE__ */ React__namespace.createElement(\"rect\", {\n+                    x: 0.6,\n+                    y: 0.6,\n+                    width: 11.8,\n+                    height: 11.8,\n+                    rx: 5.9,\n+                    stroke: \"currentColor\",\n+                    strokeWidth: 1.2\n+                }), /* @__PURE__ */ React__namespace.createElement(\"rect\", {\n+                    x: 5.5,\n+                    y: 5.5,\n+                    width: 2,\n+                    height: 2,\n+                    rx: 1,\n+                    fill: \"currentColor\"\n+                }));\n+                const ArgumentIcon = generateIcon(SvgArgument);\n+                const ChevronDownIcon = generateIcon(SvgChevronDown);\n+                const ChevronLeftIcon = generateIcon(SvgChevronLeft);\n+                const ChevronUpIcon = generateIcon(SvgChevronUp);\n+                const CloseIcon = generateIcon(SvgClose);\n+                const CopyIcon = generateIcon(SvgCopy);\n+                const DeprecatedArgumentIcon = generateIcon(SvgDeprecatedArgument);\n+                const DeprecatedEnumValueIcon = generateIcon(SvgDeprecatedEnumValue);\n+                const DeprecatedFieldIcon = generateIcon(SvgDeprecatedField);\n+                const DirectiveIcon = generateIcon(SvgDirective);\n+                const DocsFilledIcon = generateIcon(SvgDocsFilled);\n+                const DocsIcon = generateIcon(SvgDocs);\n+                const EnumValueIcon = generateIcon(SvgEnumValue);\n+                const FieldIcon = generateIcon(SvgField);\n+                const HistoryIcon = generateIcon(SvgHistory);\n+                const ImplementsIcon = generateIcon(SvgImplements);\n+                const KeyboardShortcutIcon = generateIcon(SvgKeyboardShortcut);\n+                const MagnifyingGlassIcon = generateIcon(SvgMagnifyingGlass);\n+                const MergeIcon = generateIcon(SvgMerge);\n+                const PenIcon = generateIcon(SvgPen);\n+                const PlayIcon = generateIcon(SvgPlay);\n+                const PlusIcon = generateIcon(SvgPlus);\n+                const PrettifyIcon = generateIcon(SvgPrettify);\n+                const ReloadIcon = generateIcon(SvgReload);\n+                const RootTypeIcon = generateIcon(SvgRootType);\n+                const SettingsIcon = generateIcon(SvgSettings);\n+                const StarFilledIcon = generateIcon(SvgStarFilled);\n+                const StarIcon = generateIcon(SvgStar);\n+                const StopIcon = generateIcon(SvgStop);\n+                const TrashIcon = generateIcon(SvgTrash);\n+                const TypeIcon = generateIcon(SvgType);\n+\n+                function generateIcon(RawComponent) {\n+                    const title = RawComponent.name.replace(\"Svg\", \"\").replaceAll(/([A-Z])/g, \" $1\").trimStart().toLowerCase() + \" icon\";\n+\n+                    function IconComponent(props) {\n+                        const $ = reactCompilerRuntime.c(2);\n+                        let t0;\n+                        if ($[0] !== props) {\n+                            t0 = /* @__PURE__ */ jsxRuntime.jsx(RawComponent, {\n+                                title,\n+                                ...props\n+                            });\n+                            $[0] = props;\n+                            $[1] = t0;\n                         } else {\n-                            aligns.push('');\n+                            t0 = $[1];\n                         }\n+                        return t0;\n                     }\n-                    lineText = getLine(state, startLine).trim();\n-                    if (lineText.indexOf('|') === -1) {\n-                        return false;\n+                    IconComponent.displayName = RawComponent.name;\n+                    return IconComponent;\n+                }\n+                const UnStyledButton = React.forwardRef((props, ref) => {\n+                    const $ = reactCompilerRuntime.c(6);\n+                    let t0;\n+                    if ($[0] !== props.className) {\n+                        t0 = clsx.clsx(\"graphiql-un-styled\", props.className);\n+                        $[0] = props.className;\n+                        $[1] = t0;\n+                    } else {\n+                        t0 = $[1];\n                     }\n-                    if (state.sCount[startLine] - state.blkIndent >= 4) {\n-                        return false;\n+                    let t1;\n+                    if ($[2] !== props || $[3] !== ref || $[4] !== t0) {\n+                        t1 = /* @__PURE__ */ jsxRuntime.jsx(\"button\", {\n+                            ...props,\n+                            ref,\n+                            className: t0\n+                        });\n+                        $[2] = props;\n+                        $[3] = ref;\n+                        $[4] = t0;\n+                        $[5] = t1;\n+                    } else {\n+                        t1 = $[5];\n                     }\n-                    columns = escapedSplit(lineText);\n-                    if (columns.length && columns[0] === '') columns.shift();\n-                    if (columns.length && columns[columns.length - 1] === '') columns.pop();\n-\n-                    // header row will define an amount of columns in the entire table,\n-                    // and align row should be exactly the same (the rest of the rows can differ)\n-                    const columnCount = columns.length;\n-                    if (columnCount === 0 || columnCount !== aligns.length) {\n-                        return false;\n+                    return t1;\n+                });\n+                UnStyledButton.displayName = \"UnStyledButton\";\n+                const Button$1 = React.forwardRef((props, ref) => {\n+                    const $ = reactCompilerRuntime.c(7);\n+                    let t0;\n+                    if ($[0] !== props.className || $[1] !== props.state) {\n+                        t0 = clsx.clsx(\"graphiql-button\", {\n+                            success: \"graphiql-button-success\",\n+                            error: \"graphiql-button-error\"\n+                        } [props.state], props.className);\n+                        $[0] = props.className;\n+                        $[1] = props.state;\n+                        $[2] = t0;\n+                    } else {\n+                        t0 = $[2];\n                     }\n-                    if (silent) {\n-                        return true;\n+                    let t1;\n+                    if ($[3] !== props || $[4] !== ref || $[5] !== t0) {\n+                        t1 = /* @__PURE__ */ jsxRuntime.jsx(\"button\", {\n+                            ...props,\n+                            ref,\n+                            className: t0\n+                        });\n+                        $[3] = props;\n+                        $[4] = ref;\n+                        $[5] = t0;\n+                        $[6] = t1;\n+                    } else {\n+                        t1 = $[6];\n                     }\n-                    const oldParentType = state.parentType;\n-                    state.parentType = 'table';\n-\n-                    // use 'blockquote' lists for termination because it's\n-                    // the most similar to tables\n-                    const terminatorRules = state.md.block.ruler.getRules('blockquote');\n-                    const token_to = state.push('table_open', 'table', 1);\n-                    const tableLines = [startLine, 0];\n-                    token_to.map = tableLines;\n-                    const token_tho = state.push('thead_open', 'thead', 1);\n-                    token_tho.map = [startLine, startLine + 1];\n-                    const token_htro = state.push('tr_open', 'tr', 1);\n-                    token_htro.map = [startLine, startLine + 1];\n-                    for (let i = 0; i < columns.length; i++) {\n-                        const token_ho = state.push('th_open', 'th', 1);\n-                        if (aligns[i]) {\n-                            token_ho.attrs = [\n-                                ['style', 'text-align:' + aligns[i]]\n-                            ];\n-                        }\n-                        const token_il = state.push('inline', '', 0);\n-                        token_il.content = columns[i].trim();\n-                        token_il.children = [];\n-                        state.push('th_close', 'th', -1);\n+                    return t1;\n+                });\n+                Button$1.displayName = \"Button\";\n+                const ButtonGroup = React.forwardRef((props, ref) => {\n+                    const $ = reactCompilerRuntime.c(6);\n+                    let t0;\n+                    if ($[0] !== props.className) {\n+                        t0 = clsx.clsx(\"graphiql-button-group\", props.className);\n+                        $[0] = props.className;\n+                        $[1] = t0;\n+                    } else {\n+                        t0 = $[1];\n                     }\n-                    state.push('tr_close', 'tr', -1);\n-                    state.push('thead_close', 'thead', -1);\n-                    let tbodyLines;\n-                    let autocompletedCells = 0;\n-                    for (nextLine = startLine + 2; nextLine < endLine; nextLine++) {\n-                        if (state.sCount[nextLine] < state.blkIndent) {\n-                            break;\n-                        }\n-                        let terminate = false;\n-                        for (let i = 0, l = terminatorRules.length; i < l; i++) {\n-                            if (terminatorRules[i](state, nextLine, endLine, true)) {\n-                                terminate = true;\n-                                break;\n-                            }\n-                        }\n-                        if (terminate) {\n-                            break;\n-                        }\n-                        lineText = getLine(state, nextLine).trim();\n-                        if (!lineText) {\n-                            break;\n-                        }\n-                        if (state.sCount[nextLine] - state.blkIndent >= 4) {\n-                            break;\n-                        }\n-                        columns = escapedSplit(lineText);\n-                        if (columns.length && columns[0] === '') columns.shift();\n-                        if (columns.length && columns[columns.length - 1] === '') columns.pop();\n+                    let t1;\n+                    if ($[2] !== props || $[3] !== ref || $[4] !== t0) {\n+                        t1 = /* @__PURE__ */ jsxRuntime.jsx(\"div\", {\n+                            ...props,\n+                            ref,\n+                            className: t0\n+                        });\n+                        $[2] = props;\n+                        $[3] = ref;\n+                        $[4] = t0;\n+                        $[5] = t1;\n+                    } else {\n+                        t1 = $[5];\n+                    }\n+                    return t1;\n+                });\n+                ButtonGroup.displayName = \"ButtonGroup\";\n+                const createComponentGroup = (root, children) => Object.entries(children).reduce((r, [key, value]) => {\n+                    r[key] = value;\n+                    return r;\n+                }, root);\n+                const DialogClose = React.forwardRef((props, ref) => {\n+                    const $ = reactCompilerRuntime.c(8);\n+                    let t0;\n+                    if ($[0] !== props.className) {\n+                        t0 = clsx.clsx(\"graphiql-dialog-close\", props.className);\n+                        $[0] = props.className;\n+                        $[1] = t0;\n+                    } else {\n+                        t0 = $[1];\n+                    }\n+                    let t1;\n+                    let t2;\n+                    if ($[2] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t1 = /* @__PURE__ */ jsxRuntime.jsx(reactVisuallyHidden.Root, {\n+                            children: \"Close dialog\"\n+                        });\n+                        t2 = /* @__PURE__ */ jsxRuntime.jsx(CloseIcon, {});\n+                        $[2] = t1;\n+                        $[3] = t2;\n+                    } else {\n+                        t1 = $[2];\n+                        t2 = $[3];\n+                    }\n+                    let t3;\n+                    if ($[4] !== props || $[5] !== ref || $[6] !== t0) {\n+                        t3 = /* @__PURE__ */ jsxRuntime.jsx(D__namespace.Close, {\n+                            asChild: true,\n+                            children: /* @__PURE__ */ jsxRuntime.jsxs(UnStyledButton, {\n+                                ...props,\n+                                ref,\n+                                type: \"button\",\n+                                className: t0,\n+                                children: [t1, t2]\n+                            })\n+                        });\n+                        $[4] = props;\n+                        $[5] = ref;\n+                        $[6] = t0;\n+                        $[7] = t3;\n+                    } else {\n+                        t3 = $[7];\n+                    }\n+                    return t3;\n+                });\n+                DialogClose.displayName = \"Dialog.Close\";\n \n-                        // note: autocomplete count can be negative if user specifies more columns than header,\n-                        // but that does not affect intended use (which is limiting expansion)\n-                        autocompletedCells += columnCount - columns.length;\n-                        if (autocompletedCells > MAX_AUTOCOMPLETED_CELLS) {\n-                            break;\n-                        }\n-                        if (nextLine === startLine + 2) {\n-                            const token_tbo = state.push('tbody_open', 'tbody', 1);\n-                            token_tbo.map = tbodyLines = [startLine + 2, 0];\n-                        }\n-                        const token_tro = state.push('tr_open', 'tr', 1);\n-                        token_tro.map = [nextLine, nextLine + 1];\n-                        for (let i = 0; i < columnCount; i++) {\n-                            const token_tdo = state.push('td_open', 'td', 1);\n-                            if (aligns[i]) {\n-                                token_tdo.attrs = [\n-                                    ['style', 'text-align:' + aligns[i]]\n-                                ];\n-                            }\n-                            const token_il = state.push('inline', '', 0);\n-                            token_il.content = columns[i] ? columns[i].trim() : '';\n-                            token_il.children = [];\n-                            state.push('td_close', 'td', -1);\n-                        }\n-                        state.push('tr_close', 'tr', -1);\n+                function DialogRoot(t0) {\n+                    const $ = reactCompilerRuntime.c(9);\n+                    let children;\n+                    let props;\n+                    if ($[0] !== t0) {\n+                        ({\n+                            children,\n+                            ...props\n+                        } = t0);\n+                        $[0] = t0;\n+                        $[1] = children;\n+                        $[2] = props;\n+                    } else {\n+                        children = $[1];\n+                        props = $[2];\n                     }\n-                    if (tbodyLines) {\n-                        state.push('tbody_close', 'tbody', -1);\n-                        tbodyLines[1] = nextLine;\n+                    let t1;\n+                    if ($[3] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t1 = /* @__PURE__ */ jsxRuntime.jsx(D__namespace.Overlay, {\n+                            className: \"graphiql-dialog-overlay\"\n+                        });\n+                        $[3] = t1;\n+                    } else {\n+                        t1 = $[3];\n                     }\n-                    state.push('table_close', 'table', -1);\n-                    tableLines[1] = nextLine;\n-                    state.parentType = oldParentType;\n-                    state.line = nextLine;\n-                    return true;\n+                    let t2;\n+                    if ($[4] !== children) {\n+                        t2 = /* @__PURE__ */ jsxRuntime.jsxs(D__namespace.Portal, {\n+                            children: [t1, /* @__PURE__ */ jsxRuntime.jsx(D__namespace.Content, {\n+                                className: \"graphiql-dialog\",\n+                                children\n+                            })]\n+                        });\n+                        $[4] = children;\n+                        $[5] = t2;\n+                    } else {\n+                        t2 = $[5];\n+                    }\n+                    let t3;\n+                    if ($[6] !== props || $[7] !== t2) {\n+                        t3 = /* @__PURE__ */ jsxRuntime.jsx(D__namespace.Root, {\n+                            ...props,\n+                            children: t2\n+                        });\n+                        $[6] = props;\n+                        $[7] = t2;\n+                        $[8] = t3;\n+                    } else {\n+                        t3 = $[8];\n+                    }\n+                    return t3;\n                 }\n+                const Dialog = createComponentGroup(DialogRoot, {\n+                    Close: DialogClose,\n+                    Title: D__namespace.Title,\n+                    Trigger: D__namespace.Trigger,\n+                    Description: D__namespace.Description\n+                });\n+                const Button = React.forwardRef((props, ref) => {\n+                    const $ = reactCompilerRuntime.c(6);\n+                    let t0;\n+                    if ($[0] !== props.className) {\n+                        t0 = clsx.clsx(\"graphiql-un-styled\", props.className);\n+                        $[0] = props.className;\n+                        $[1] = t0;\n+                    } else {\n+                        t0 = $[1];\n+                    }\n+                    let t1;\n+                    if ($[2] !== props || $[3] !== ref || $[4] !== t0) {\n+                        t1 = /* @__PURE__ */ jsxRuntime.jsx(reactDropdownMenu.Trigger, {\n+                            asChild: true,\n+                            children: /* @__PURE__ */ jsxRuntime.jsx(\"button\", {\n+                                ...props,\n+                                ref,\n+                                className: t0\n+                            })\n+                        });\n+                        $[2] = props;\n+                        $[3] = ref;\n+                        $[4] = t0;\n+                        $[5] = t1;\n+                    } else {\n+                        t1 = $[5];\n+                    }\n+                    return t1;\n+                });\n+                Button.displayName = \"DropdownMenuButton\";\n \n-                // Code block (4 spaces padded)\n-\n-                function code(state, startLine, endLine /*, silent */ ) {\n-                    if (state.sCount[startLine] - state.blkIndent < 4) {\n-                        return false;\n+                function Content(t0) {\n+                    const $ = reactCompilerRuntime.c(14);\n+                    let children;\n+                    let className;\n+                    let props;\n+                    let t1;\n+                    let t2;\n+                    if ($[0] !== t0) {\n+                        ({\n+                            children,\n+                            align: t1,\n+                            sideOffset: t2,\n+                            className,\n+                            ...props\n+                        } = t0);\n+                        $[0] = t0;\n+                        $[1] = children;\n+                        $[2] = className;\n+                        $[3] = props;\n+                        $[4] = t1;\n+                        $[5] = t2;\n+                    } else {\n+                        children = $[1];\n+                        className = $[2];\n+                        props = $[3];\n+                        t1 = $[4];\n+                        t2 = $[5];\n+                    }\n+                    const align = t1 === void 0 ? \"start\" : t1;\n+                    const sideOffset = t2 === void 0 ? 5 : t2;\n+                    let t3;\n+                    if ($[6] !== className) {\n+                        t3 = clsx.clsx(\"graphiql-dropdown-content\", className);\n+                        $[6] = className;\n+                        $[7] = t3;\n+                    } else {\n+                        t3 = $[7];\n                     }\n-                    let nextLine = startLine + 1;\n-                    let last = nextLine;\n-                    while (nextLine < endLine) {\n-                        if (state.isEmpty(nextLine)) {\n-                            nextLine++;\n-                            continue;\n-                        }\n-                        if (state.sCount[nextLine] - state.blkIndent >= 4) {\n-                            nextLine++;\n-                            last = nextLine;\n-                            continue;\n-                        }\n-                        break;\n+                    let t4;\n+                    if ($[8] !== align || $[9] !== children || $[10] !== props || $[11] !== sideOffset || $[12] !== t3) {\n+                        t4 = /* @__PURE__ */ jsxRuntime.jsx(reactDropdownMenu.Portal, {\n+                            children: /* @__PURE__ */ jsxRuntime.jsx(reactDropdownMenu.Content, {\n+                                align,\n+                                sideOffset,\n+                                className: t3,\n+                                ...props,\n+                                children\n+                            })\n+                        });\n+                        $[8] = align;\n+                        $[9] = children;\n+                        $[10] = props;\n+                        $[11] = sideOffset;\n+                        $[12] = t3;\n+                        $[13] = t4;\n+                    } else {\n+                        t4 = $[13];\n                     }\n-                    state.line = last;\n-                    const token = state.push('code_block', 'code', 0);\n-                    token.content = state.getLines(startLine, last, 4 + state.blkIndent, false) + '\\n';\n-                    token.map = [startLine, state.line];\n-                    return true;\n+                    return t4;\n                 }\n-\n-                // fences (``` lang, ~~~ lang)\n-\n-                function fence(state, startLine, endLine, silent) {\n-                    let pos = state.bMarks[startLine] + state.tShift[startLine];\n-                    let max = state.eMarks[startLine];\n-\n-                    // if it's indented more than 3 spaces, it should be a code block\n-                    if (state.sCount[startLine] - state.blkIndent >= 4) {\n-                        return false;\n+                const Item = ({\n+                    className,\n+                    children,\n+                    ...props\n+                }) => /* @__PURE__ */ jsxRuntime.jsx(reactDropdownMenu.Item, {\n+                    className: clsx.clsx(\"graphiql-dropdown-item\", className),\n+                    ...props,\n+                    children\n+                });\n+                const DropdownMenu = createComponentGroup(reactDropdownMenu.Root, {\n+                    Button,\n+                    Item,\n+                    Content\n+                });\n+                const markdown = new MarkdownIt({\n+                    breaks: true,\n+                    linkify: true\n+                });\n+                const MarkdownContent = React.forwardRef((t0, ref) => {\n+                    const $ = reactCompilerRuntime.c(18);\n+                    let children;\n+                    let onlyShowFirstChild;\n+                    let props;\n+                    let type;\n+                    if ($[0] !== t0) {\n+                        ({\n+                            children,\n+                            onlyShowFirstChild,\n+                            type,\n+                            ...props\n+                        } = t0);\n+                        $[0] = t0;\n+                        $[1] = children;\n+                        $[2] = onlyShowFirstChild;\n+                        $[3] = props;\n+                        $[4] = type;\n+                    } else {\n+                        children = $[1];\n+                        onlyShowFirstChild = $[2];\n+                        props = $[3];\n+                        type = $[4];\n+                    }\n+                    const t1 = `graphiql-markdown-${type}`;\n+                    const t2 = onlyShowFirstChild && \"graphiql-markdown-preview\";\n+                    let t3;\n+                    if ($[5] !== props.className || $[6] !== t1 || $[7] !== t2) {\n+                        t3 = clsx.clsx(t1, t2, props.className);\n+                        $[5] = props.className;\n+                        $[6] = t1;\n+                        $[7] = t2;\n+                        $[8] = t3;\n+                    } else {\n+                        t3 = $[8];\n                     }\n-                    if (pos + 3 > max) {\n-                        return false;\n+                    let t4;\n+                    if ($[9] !== children) {\n+                        t4 = markdown.render(children);\n+                        $[9] = children;\n+                        $[10] = t4;\n+                    } else {\n+                        t4 = $[10];\n                     }\n-                    const marker = state.src.charCodeAt(pos);\n-                    if (marker !== 0x7E /* ~ */ && marker !== 0x60 /* ` */ ) {\n-                        return false;\n+                    let t5;\n+                    if ($[11] !== t4) {\n+                        t5 = {\n+                            __html: t4\n+                        };\n+                        $[11] = t4;\n+                        $[12] = t5;\n+                    } else {\n+                        t5 = $[12];\n+                    }\n+                    let t6;\n+                    if ($[13] !== props || $[14] !== ref || $[15] !== t3 || $[16] !== t5) {\n+                        t6 = /* @__PURE__ */ jsxRuntime.jsx(\"div\", {\n+                            ...props,\n+                            ref,\n+                            className: t3,\n+                            dangerouslySetInnerHTML: t5\n+                        });\n+                        $[13] = props;\n+                        $[14] = ref;\n+                        $[15] = t3;\n+                        $[16] = t5;\n+                        $[17] = t6;\n+                    } else {\n+                        t6 = $[17];\n                     }\n+                    return t6;\n+                });\n+                MarkdownContent.displayName = \"MarkdownContent\";\n+                const Spinner = React.forwardRef((props, ref) => {\n+                    const $ = reactCompilerRuntime.c(6);\n+                    let t0;\n+                    if ($[0] !== props.className) {\n+                        t0 = clsx.clsx(\"graphiql-spinner\", props.className);\n+                        $[0] = props.className;\n+                        $[1] = t0;\n+                    } else {\n+                        t0 = $[1];\n+                    }\n+                    let t1;\n+                    if ($[2] !== props || $[3] !== ref || $[4] !== t0) {\n+                        t1 = /* @__PURE__ */ jsxRuntime.jsx(\"div\", {\n+                            ...props,\n+                            ref,\n+                            className: t0\n+                        });\n+                        $[2] = props;\n+                        $[3] = ref;\n+                        $[4] = t0;\n+                        $[5] = t1;\n+                    } else {\n+                        t1 = $[5];\n+                    }\n+                    return t1;\n+                });\n+                Spinner.displayName = \"Spinner\";\n \n-                    // scan marker length\n-                    let mem = pos;\n-                    pos = state.skipChars(pos, marker);\n-                    let len = pos - mem;\n-                    if (len < 3) {\n-                        return false;\n+                function TooltipRoot(t0) {\n+                    const $ = reactCompilerRuntime.c(10);\n+                    const {\n+                        children,\n+                        align: t1,\n+                        side: t2,\n+                        sideOffset: t3,\n+                        label\n+                    } = t0;\n+                    const align = t1 === void 0 ? \"start\" : t1;\n+                    const side = t2 === void 0 ? \"bottom\" : t2;\n+                    const sideOffset = t3 === void 0 ? 5 : t3;\n+                    let t4;\n+                    if ($[0] !== children) {\n+                        t4 = /* @__PURE__ */ jsxRuntime.jsx(T__namespace.Trigger, {\n+                            asChild: true,\n+                            children\n+                        });\n+                        $[0] = children;\n+                        $[1] = t4;\n+                    } else {\n+                        t4 = $[1];\n                     }\n-                    const markup = state.src.slice(mem, pos);\n-                    const params = state.src.slice(pos, max);\n-                    if (marker === 0x60 /* ` */ ) {\n-                        if (params.indexOf(String.fromCharCode(marker)) >= 0) {\n-                            return false;\n-                        }\n+                    let t5;\n+                    if ($[2] !== align || $[3] !== label || $[4] !== side || $[5] !== sideOffset) {\n+                        t5 = /* @__PURE__ */ jsxRuntime.jsx(T__namespace.Portal, {\n+                            children: /* @__PURE__ */ jsxRuntime.jsx(T__namespace.Content, {\n+                                className: \"graphiql-tooltip\",\n+                                align,\n+                                side,\n+                                sideOffset,\n+                                children: label\n+                            })\n+                        });\n+                        $[2] = align;\n+                        $[3] = label;\n+                        $[4] = side;\n+                        $[5] = sideOffset;\n+                        $[6] = t5;\n+                    } else {\n+                        t5 = $[6];\n+                    }\n+                    let t6;\n+                    if ($[7] !== t4 || $[8] !== t5) {\n+                        t6 = /* @__PURE__ */ jsxRuntime.jsxs(T__namespace.Root, {\n+                            children: [t4, t5]\n+                        });\n+                        $[7] = t4;\n+                        $[8] = t5;\n+                        $[9] = t6;\n+                    } else {\n+                        t6 = $[9];\n+                    }\n+                    return t6;\n+                }\n+                const Tooltip = createComponentGroup(TooltipRoot, {\n+                    Provider: T__namespace.Provider\n+                });\n+                const TabRoot = React.forwardRef((t0, ref) => {\n+                    const $ = reactCompilerRuntime.c(16);\n+                    let children;\n+                    let className;\n+                    let isActive;\n+                    let props;\n+                    let value;\n+                    if ($[0] !== t0) {\n+                        ({\n+                            isActive,\n+                            value,\n+                            children,\n+                            className,\n+                            ...props\n+                        } = t0);\n+                        $[0] = t0;\n+                        $[1] = children;\n+                        $[2] = className;\n+                        $[3] = isActive;\n+                        $[4] = props;\n+                        $[5] = value;\n+                    } else {\n+                        children = $[1];\n+                        className = $[2];\n+                        isActive = $[3];\n+                        props = $[4];\n+                        value = $[5];\n+                    }\n+                    const t1 = isActive ? \"true\" : void 0;\n+                    const t2 = isActive && \"graphiql-tab-active\";\n+                    let t3;\n+                    if ($[6] !== className || $[7] !== t2) {\n+                        t3 = clsx.clsx(\"graphiql-tab\", t2, className);\n+                        $[6] = className;\n+                        $[7] = t2;\n+                        $[8] = t3;\n+                    } else {\n+                        t3 = $[8];\n+                    }\n+                    let t4;\n+                    if ($[9] !== children || $[10] !== props || $[11] !== ref || $[12] !== t1 || $[13] !== t3 || $[14] !== value) {\n+                        t4 = /* @__PURE__ */ jsxRuntime.jsx(framerMotion.Reorder.Item, {\n+                            ...props,\n+                            ref,\n+                            value,\n+                            \"aria-selected\": t1,\n+                            role: \"tab\",\n+                            className: t3,\n+                            children\n+                        });\n+                        $[9] = children;\n+                        $[10] = props;\n+                        $[11] = ref;\n+                        $[12] = t1;\n+                        $[13] = t3;\n+                        $[14] = value;\n+                        $[15] = t4;\n+                    } else {\n+                        t4 = $[15];\n+                    }\n+                    return t4;\n+                });\n+                TabRoot.displayName = \"Tab\";\n+                const TabButton = React.forwardRef((props, ref) => {\n+                    const $ = reactCompilerRuntime.c(6);\n+                    let t0;\n+                    if ($[0] !== props.className) {\n+                        t0 = clsx.clsx(\"graphiql-tab-button\", props.className);\n+                        $[0] = props.className;\n+                        $[1] = t0;\n+                    } else {\n+                        t0 = $[1];\n+                    }\n+                    let t1;\n+                    if ($[2] !== props || $[3] !== ref || $[4] !== t0) {\n+                        t1 = /* @__PURE__ */ jsxRuntime.jsx(UnStyledButton, {\n+                            ...props,\n+                            ref,\n+                            type: \"button\",\n+                            className: t0,\n+                            children: props.children\n+                        });\n+                        $[2] = props;\n+                        $[3] = ref;\n+                        $[4] = t0;\n+                        $[5] = t1;\n+                    } else {\n+                        t1 = $[5];\n+                    }\n+                    return t1;\n+                });\n+                TabButton.displayName = \"Tab.Button\";\n+                const TabClose = React.forwardRef((props, ref) => {\n+                    const $ = reactCompilerRuntime.c(7);\n+                    let t0;\n+                    if ($[0] !== props.className) {\n+                        t0 = clsx.clsx(\"graphiql-tab-close\", props.className);\n+                        $[0] = props.className;\n+                        $[1] = t0;\n+                    } else {\n+                        t0 = $[1];\n+                    }\n+                    let t1;\n+                    if ($[2] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t1 = /* @__PURE__ */ jsxRuntime.jsx(CloseIcon, {});\n+                        $[2] = t1;\n+                    } else {\n+                        t1 = $[2];\n+                    }\n+                    let t2;\n+                    if ($[3] !== props || $[4] !== ref || $[5] !== t0) {\n+                        t2 = /* @__PURE__ */ jsxRuntime.jsx(Tooltip, {\n+                            label: \"Close Tab\",\n+                            children: /* @__PURE__ */ jsxRuntime.jsx(UnStyledButton, {\n+                                \"aria-label\": \"Close Tab\",\n+                                ...props,\n+                                ref,\n+                                type: \"button\",\n+                                className: t0,\n+                                children: t1\n+                            })\n+                        });\n+                        $[3] = props;\n+                        $[4] = ref;\n+                        $[5] = t0;\n+                        $[6] = t2;\n+                    } else {\n+                        t2 = $[6];\n+                    }\n+                    return t2;\n+                });\n+                TabClose.displayName = \"Tab.Close\";\n+                const Tab = createComponentGroup(TabRoot, {\n+                    Button: TabButton,\n+                    Close: TabClose\n+                });\n+                const Tabs = React.forwardRef((t0, ref) => {\n+                    const $ = reactCompilerRuntime.c(15);\n+                    let children;\n+                    let className;\n+                    let onReorder;\n+                    let props;\n+                    let values;\n+                    if ($[0] !== t0) {\n+                        ({\n+                            values,\n+                            onReorder,\n+                            children,\n+                            className,\n+                            ...props\n+                        } = t0);\n+                        $[0] = t0;\n+                        $[1] = children;\n+                        $[2] = className;\n+                        $[3] = onReorder;\n+                        $[4] = props;\n+                        $[5] = values;\n+                    } else {\n+                        children = $[1];\n+                        className = $[2];\n+                        onReorder = $[3];\n+                        props = $[4];\n+                        values = $[5];\n+                    }\n+                    let t1;\n+                    if ($[6] !== className) {\n+                        t1 = clsx.clsx(\"graphiql-tabs\", className);\n+                        $[6] = className;\n+                        $[7] = t1;\n+                    } else {\n+                        t1 = $[7];\n+                    }\n+                    let t2;\n+                    if ($[8] !== children || $[9] !== onReorder || $[10] !== props || $[11] !== ref || $[12] !== t1 || $[13] !== values) {\n+                        t2 = /* @__PURE__ */ jsxRuntime.jsx(framerMotion.Reorder.Group, {\n+                            ...props,\n+                            ref,\n+                            values,\n+                            onReorder,\n+                            axis: \"x\",\n+                            role: \"tablist\",\n+                            className: t1,\n+                            children\n+                        });\n+                        $[8] = children;\n+                        $[9] = onReorder;\n+                        $[10] = props;\n+                        $[11] = ref;\n+                        $[12] = t1;\n+                        $[13] = values;\n+                        $[14] = t2;\n+                    } else {\n+                        t2 = $[14];\n                     }\n+                    return t2;\n+                });\n+                Tabs.displayName = \"Tabs\";\n+                const HistoryContext = createNullableContext(\"HistoryContext\");\n \n-                    // Since start is found, we can report success here in validation mode\n-                    if (silent) {\n-                        return true;\n+                function HistoryContextProvider(t0) {\n+                    const $ = reactCompilerRuntime.c(11);\n+                    const {\n+                        maxHistoryLength: t1,\n+                        children\n+                    } = t0;\n+                    const maxHistoryLength = t1 === void 0 ? DEFAULT_HISTORY_LENGTH : t1;\n+                    const storage = useStorageContext();\n+                    let t2;\n+                    if ($[0] !== maxHistoryLength || $[1] !== storage) {\n+                        t2 = () => new toolkit.HistoryStore(storage || new toolkit.StorageAPI(null), maxHistoryLength);\n+                        $[0] = maxHistoryLength;\n+                        $[1] = storage;\n+                        $[2] = t2;\n+                    } else {\n+                        t2 = $[2];\n+                    }\n+                    const [historyStore] = React.useState(t2);\n+                    let t3;\n+                    if ($[3] !== historyStore.queries) {\n+                        t3 = () => historyStore.queries || [];\n+                        $[3] = historyStore.queries;\n+                        $[4] = t3;\n+                    } else {\n+                        t3 = $[4];\n+                    }\n+                    const [items, setItems] = React.useState(t3);\n+                    let t4;\n+                    if ($[5] !== historyStore || $[6] !== items) {\n+                        t4 = {\n+                            addToHistory(operation) {\n+                                historyStore.updateHistory(operation);\n+                                setItems(historyStore.queries);\n+                            },\n+                            editLabel(operation_0, index) {\n+                                historyStore.editLabel(operation_0, index);\n+                                setItems(historyStore.queries);\n+                            },\n+                            items,\n+                            toggleFavorite(operation_1) {\n+                                historyStore.toggleFavorite(operation_1);\n+                                setItems(historyStore.queries);\n+                            },\n+                            setActive: _temp$8,\n+                            deleteFromHistory(item_0, clearFavorites) {\n+                                historyStore.deleteHistory(item_0, clearFavorites);\n+                                setItems(historyStore.queries);\n+                            }\n+                        };\n+                        $[5] = historyStore;\n+                        $[6] = items;\n+                        $[7] = t4;\n+                    } else {\n+                        t4 = $[7];\n                     }\n+                    const value = t4;\n+                    let t5;\n+                    if ($[8] !== children || $[9] !== value) {\n+                        t5 = /* @__PURE__ */ jsxRuntime.jsx(HistoryContext.Provider, {\n+                            value,\n+                            children\n+                        });\n+                        $[8] = children;\n+                        $[9] = value;\n+                        $[10] = t5;\n+                    } else {\n+                        t5 = $[10];\n+                    }\n+                    return t5;\n+                }\n \n-                    // search end of block\n-                    let nextLine = startLine;\n-                    let haveEndMarker = false;\n-                    for (;;) {\n-                        nextLine++;\n-                        if (nextLine >= endLine) {\n-                            // unclosed block should be autoclosed by end of document.\n-                            // also block seems to be autoclosed by end of parent\n-                            break;\n-                        }\n-                        pos = mem = state.bMarks[nextLine] + state.tShift[nextLine];\n-                        max = state.eMarks[nextLine];\n-                        if (pos < max && state.sCount[nextLine] < state.blkIndent) {\n-                            // non-empty line with negative indent should stop the list:\n-                            // - ```\n-                            //  test\n-                            break;\n-                        }\n-                        if (state.src.charCodeAt(pos) !== marker) {\n-                            continue;\n-                        }\n-                        if (state.sCount[nextLine] - state.blkIndent >= 4) {\n-                            // closing fence should be indented less than 4 spaces\n-                            continue;\n-                        }\n-                        pos = state.skipChars(pos, marker);\n+                function _temp$8(item) {\n+                    return item;\n+                }\n+                const useHistoryContext = createContextHook(HistoryContext);\n+                const DEFAULT_HISTORY_LENGTH = 20;\n \n-                        // closing code fence must be at least as long as the opening one\n-                        if (pos - mem < len) {\n-                            continue;\n+                function History() {\n+                    const {\n+                        items: all,\n+                        deleteFromHistory\n+                    } = useHistoryContext({\n+                        nonNull: true\n+                    });\n+                    let items = all.slice().map((item, i) => ({\n+                        ...item,\n+                        index: i\n+                    })).reverse();\n+                    const favorites = items.filter(item_0 => item_0.favorite);\n+                    if (favorites.length) {\n+                        items = items.filter(item_1 => !item_1.favorite);\n+                    }\n+                    const [clearStatus, setClearStatus] = React.useState(null);\n+                    React.useEffect(() => {\n+                        if (clearStatus) {\n+                            setTimeout(() => {\n+                                setClearStatus(null);\n+                            }, 2e3);\n                         }\n-\n-                        // make sure tail has spaces only\n-                        pos = state.skipSpaces(pos);\n-                        if (pos < max) {\n-                            continue;\n+                    }, [clearStatus]);\n+                    const handleClearStatus = () => {\n+                        try {\n+                            for (const item_2 of items) {\n+                                deleteFromHistory(item_2, true);\n+                            }\n+                            setClearStatus(\"success\");\n+                        } catch {\n+                            setClearStatus(\"error\");\n                         }\n-                        haveEndMarker = true;\n-                        // found!\n-                        break;\n-                    }\n-\n-                    // If a fence has heading spaces, they should be removed from its inner block\n-                    len = state.sCount[startLine];\n-                    state.line = nextLine + (haveEndMarker ? 1 : 0);\n-                    const token = state.push('fence', 'code', 0);\n-                    token.info = params;\n-                    token.content = state.getLines(startLine + 1, nextLine, len, true);\n-                    token.markup = markup;\n-                    token.map = [startLine, state.line];\n-                    return true;\n+                    };\n+                    return /* @__PURE__ */ jsxRuntime.jsxs(\"section\", {\n+                        \"aria-label\": \"History\",\n+                        className: \"graphiql-history\",\n+                        children: [ /* @__PURE__ */ jsxRuntime.jsxs(\"div\", {\n+                            className: \"graphiql-history-header\",\n+                            children: [\"History\", (clearStatus || items.length > 0) && /* @__PURE__ */ jsxRuntime.jsx(Button$1, {\n+                                type: \"button\",\n+                                state: clearStatus || void 0,\n+                                disabled: !items.length,\n+                                onClick: handleClearStatus,\n+                                children: {\n+                                    success: \"Cleared\",\n+                                    error: \"Failed to Clear\"\n+                                } [clearStatus] || \"Clear\"\n+                            })]\n+                        }), Boolean(favorites.length) && /* @__PURE__ */ jsxRuntime.jsx(\"ul\", {\n+                            className: \"graphiql-history-items\",\n+                            children: favorites.map(item_3 => /* @__PURE__ */ jsxRuntime.jsx(HistoryItem, {\n+                                item: item_3\n+                            }, item_3.index))\n+                        }), Boolean(favorites.length) && Boolean(items.length) && /* @__PURE__ */ jsxRuntime.jsx(\"div\", {\n+                            className: \"graphiql-history-item-spacer\"\n+                        }), Boolean(items.length) && /* @__PURE__ */ jsxRuntime.jsx(\"ul\", {\n+                            className: \"graphiql-history-items\",\n+                            children: items.map(item_4 => /* @__PURE__ */ jsxRuntime.jsx(HistoryItem, {\n+                                item: item_4\n+                            }, item_4.index))\n+                        })]\n+                    });\n                 }\n \n-                // Block quotes\n-\n-                function blockquote(state, startLine, endLine, silent) {\n-                    let pos = state.bMarks[startLine] + state.tShift[startLine];\n-                    let max = state.eMarks[startLine];\n-                    const oldLineMax = state.lineMax;\n-\n-                    // if it's indented more than 3 spaces, it should be a code block\n-                    if (state.sCount[startLine] - state.blkIndent >= 4) {\n-                        return false;\n+                function HistoryItem(props) {\n+                    const $ = reactCompilerRuntime.c(40);\n+                    let t0;\n+                    if ($[0] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t0 = {\n+                            nonNull: true,\n+                            caller: HistoryItem\n+                        };\n+                        $[0] = t0;\n+                    } else {\n+                        t0 = $[0];\n                     }\n-\n-                    // check the block quote marker\n-                    if (state.src.charCodeAt(pos) !== 0x3E /* > */ ) {\n-                        return false;\n+                    const {\n+                        editLabel,\n+                        toggleFavorite,\n+                        deleteFromHistory,\n+                        setActive\n+                    } = useHistoryContext(t0);\n+                    let t1;\n+                    if ($[1] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t1 = {\n+                            nonNull: true,\n+                            caller: HistoryItem\n+                        };\n+                        $[1] = t1;\n+                    } else {\n+                        t1 = $[1];\n                     }\n-\n-                    // we know that it's going to be a valid blockquote,\n-                    // so no point trying to find the end of it in silent mode\n-                    if (silent) {\n-                        return true;\n+                    const {\n+                        headerEditor,\n+                        queryEditor,\n+                        variableEditor\n+                    } = useEditorContext(t1);\n+                    const inputRef = React.useRef(null);\n+                    const buttonRef = React.useRef(null);\n+                    const [isEditable, setIsEditable] = React.useState(false);\n+                    let t2;\n+                    let t3;\n+                    if ($[2] !== isEditable) {\n+                        t2 = () => {\n+                            var _a;\n+                            if (isEditable) {\n+                                (_a = inputRef.current) == null ? void 0 : _a.focus();\n+                            }\n+                        };\n+                        t3 = [isEditable];\n+                        $[2] = isEditable;\n+                        $[3] = t2;\n+                        $[4] = t3;\n+                    } else {\n+                        t2 = $[3];\n+                        t3 = $[4];\n                     }\n-                    const oldBMarks = [];\n-                    const oldBSCount = [];\n-                    const oldSCount = [];\n-                    const oldTShift = [];\n-                    const terminatorRules = state.md.block.ruler.getRules('blockquote');\n-                    const oldParentType = state.parentType;\n-                    state.parentType = 'blockquote';\n-                    let lastLineEmpty = false;\n-                    let nextLine;\n-\n-                    // Search the end of the block\n-                    //\n-                    // Block ends with either:\n-                    //  1. an empty line outside:\n-                    //     ```\n-                    //     > test\n-                    //\n-                    //     ```\n-                    //  2. an empty line inside:\n-                    //     ```\n-                    //     >\n-                    //     test\n-                    //     ```\n-                    //  3. another tag:\n-                    //     ```\n-                    //     > test\n-                    //      - - -\n-                    //     ```\n-                    for (nextLine = startLine; nextLine < endLine; nextLine++) {\n-                        // check if it's outdented, i.e. it's inside list item and indented\n-                        // less than said list item:\n-                        //\n-                        // ```\n-                        // 1. anything\n-                        //    > current blockquote\n-                        // 2. checking this line\n-                        // ```\n-                        const isOutdented = state.sCount[nextLine] < state.blkIndent;\n-                        pos = state.bMarks[nextLine] + state.tShift[nextLine];\n-                        max = state.eMarks[nextLine];\n-                        if (pos >= max) {\n-                            // Case 1: line is not inside the blockquote, and this line is empty.\n-                            break;\n-                        }\n-                        if (state.src.charCodeAt(pos++) === 0x3E /* > */ && !isOutdented) {\n-                            // This line is inside the blockquote.\n+                    React.useEffect(t2, t3);\n+                    let t4;\n+                    if ($[5] !== props.item.label || $[6] !== props.item.operationName || $[7] !== props.item.query) {\n+                        t4 = props.item.label || props.item.operationName || formatQuery(props.item.query);\n+                        $[5] = props.item.label;\n+                        $[6] = props.item.operationName;\n+                        $[7] = props.item.query;\n+                        $[8] = t4;\n+                    } else {\n+                        t4 = $[8];\n+                    }\n+                    const displayName = t4;\n+                    let t5;\n+                    if ($[9] !== editLabel || $[10] !== props.item) {\n+                        t5 = () => {\n+                            var _a;\n+                            setIsEditable(false);\n+                            const {\n+                                index,\n+                                ...item\n+                            } = props.item;\n+                            editLabel({\n+                                ...item,\n+                                label: (_a = inputRef.current) == null ? void 0 : _a.value\n+                            }, index);\n+                        };\n+                        $[9] = editLabel;\n+                        $[10] = props.item;\n+                        $[11] = t5;\n+                    } else {\n+                        t5 = $[11];\n+                    }\n+                    const handleSave = t5;\n+                    let t6;\n+                    if ($[12] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t6 = () => {\n+                            setIsEditable(false);\n+                        };\n+                        $[12] = t6;\n+                    } else {\n+                        t6 = $[12];\n+                    }\n+                    const handleClose = t6;\n+                    let t7;\n+                    if ($[13] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t7 = e => {\n+                            e.stopPropagation();\n+                            setIsEditable(true);\n+                        };\n+                        $[13] = t7;\n+                    } else {\n+                        t7 = $[13];\n+                    }\n+                    const handleEditLabel = t7;\n+                    let t8;\n+                    if ($[14] !== headerEditor || $[15] !== props.item || $[16] !== queryEditor || $[17] !== setActive || $[18] !== variableEditor) {\n+                        t8 = () => {\n+                            const {\n+                                query,\n+                                variables,\n+                                headers\n+                            } = props.item;\n+                            queryEditor == null ? void 0 : queryEditor.setValue(query !== null && query !== void 0 ? query : \"\");\n+                            variableEditor == null ? void 0 : variableEditor.setValue(variables !== null && variables !== void 0 ? variables : \"\");\n+                            headerEditor == null ? void 0 : headerEditor.setValue(headers !== null && headers !== void 0 ? headers : \"\");\n+                            setActive(props.item);\n+                        };\n+                        $[14] = headerEditor;\n+                        $[15] = props.item;\n+                        $[16] = queryEditor;\n+                        $[17] = setActive;\n+                        $[18] = variableEditor;\n+                        $[19] = t8;\n+                    } else {\n+                        t8 = $[19];\n+                    }\n+                    const handleHistoryItemClick = t8;\n+                    let t9;\n+                    if ($[20] !== deleteFromHistory || $[21] !== props.item) {\n+                        t9 = e_0 => {\n+                            e_0.stopPropagation();\n+                            deleteFromHistory(props.item);\n+                        };\n+                        $[20] = deleteFromHistory;\n+                        $[21] = props.item;\n+                        $[22] = t9;\n+                    } else {\n+                        t9 = $[22];\n+                    }\n+                    const handleDeleteItemFromHistory = t9;\n+                    let t10;\n+                    if ($[23] !== props.item || $[24] !== toggleFavorite) {\n+                        t10 = e_1 => {\n+                            e_1.stopPropagation();\n+                            toggleFavorite(props.item);\n+                        };\n+                        $[23] = props.item;\n+                        $[24] = toggleFavorite;\n+                        $[25] = t10;\n+                    } else {\n+                        t10 = $[25];\n+                    }\n+                    const handleToggleFavorite = t10;\n+                    const t11 = isEditable && \"editable\";\n+                    let t12;\n+                    if ($[26] !== t11) {\n+                        t12 = clsx.clsx(\"graphiql-history-item\", t11);\n+                        $[26] = t11;\n+                        $[27] = t12;\n+                    } else {\n+                        t12 = $[27];\n+                    }\n+                    let t13;\n+                    if ($[28] !== displayName || $[29] !== editLabel || $[30] !== handleDeleteItemFromHistory || $[31] !== handleHistoryItemClick || $[32] !== handleSave || $[33] !== handleToggleFavorite || $[34] !== isEditable || $[35] !== props.item) {\n+                        t13 = isEditable ? /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, {\n+                            children: [ /* @__PURE__ */ jsxRuntime.jsx(\"input\", {\n+                                type: \"text\",\n+                                defaultValue: props.item.label,\n+                                ref: inputRef,\n+                                onKeyDown: e_2 => {\n+                                    if (e_2.key === \"Esc\") {\n+                                        setIsEditable(false);\n+                                    } else {\n+                                        if (e_2.key === \"Enter\") {\n+                                            setIsEditable(false);\n+                                            editLabel({\n+                                                ...props.item,\n+                                                label: e_2.currentTarget.value\n+                                            });\n+                                        }\n+                                    }\n+                                },\n+                                placeholder: \"Type a label\"\n+                            }), /* @__PURE__ */ jsxRuntime.jsx(UnStyledButton, {\n+                                type: \"button\",\n+                                ref: buttonRef,\n+                                onClick: handleSave,\n+                                children: \"Save\"\n+                            }), /* @__PURE__ */ jsxRuntime.jsx(UnStyledButton, {\n+                                type: \"button\",\n+                                ref: buttonRef,\n+                                onClick: handleClose,\n+                                children: /* @__PURE__ */ jsxRuntime.jsx(CloseIcon, {})\n+                            })]\n+                        }) : /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, {\n+                            children: [ /* @__PURE__ */ jsxRuntime.jsx(Tooltip, {\n+                                label: \"Set active\",\n+                                children: /* @__PURE__ */ jsxRuntime.jsx(UnStyledButton, {\n+                                    type: \"button\",\n+                                    className: \"graphiql-history-item-label\",\n+                                    onClick: handleHistoryItemClick,\n+                                    \"aria-label\": \"Set active\",\n+                                    children: displayName\n+                                })\n+                            }), /* @__PURE__ */ jsxRuntime.jsx(Tooltip, {\n+                                label: \"Edit label\",\n+                                children: /* @__PURE__ */ jsxRuntime.jsx(UnStyledButton, {\n+                                    type: \"button\",\n+                                    className: \"graphiql-history-item-action\",\n+                                    onClick: handleEditLabel,\n+                                    \"aria-label\": \"Edit label\",\n+                                    children: /* @__PURE__ */ jsxRuntime.jsx(PenIcon, {\n+                                        \"aria-hidden\": \"true\"\n+                                    })\n+                                })\n+                            }), /* @__PURE__ */ jsxRuntime.jsx(Tooltip, {\n+                                label: props.item.favorite ? \"Remove favorite\" : \"Add favorite\",\n+                                children: /* @__PURE__ */ jsxRuntime.jsx(UnStyledButton, {\n+                                    type: \"button\",\n+                                    className: \"graphiql-history-item-action\",\n+                                    onClick: handleToggleFavorite,\n+                                    \"aria-label\": props.item.favorite ? \"Remove favorite\" : \"Add favorite\",\n+                                    children: props.item.favorite ? /* @__PURE__ */ jsxRuntime.jsx(StarFilledIcon, {\n+                                        \"aria-hidden\": \"true\"\n+                                    }) : /* @__PURE__ */ jsxRuntime.jsx(StarIcon, {\n+                                        \"aria-hidden\": \"true\"\n+                                    })\n+                                })\n+                            }), /* @__PURE__ */ jsxRuntime.jsx(Tooltip, {\n+                                label: \"Delete from history\",\n+                                children: /* @__PURE__ */ jsxRuntime.jsx(UnStyledButton, {\n+                                    type: \"button\",\n+                                    className: \"graphiql-history-item-action\",\n+                                    onClick: handleDeleteItemFromHistory,\n+                                    \"aria-label\": \"Delete from history\",\n+                                    children: /* @__PURE__ */ jsxRuntime.jsx(TrashIcon, {\n+                                        \"aria-hidden\": \"true\"\n+                                    })\n+                                })\n+                            })]\n+                        });\n+                        $[28] = displayName;\n+                        $[29] = editLabel;\n+                        $[30] = handleDeleteItemFromHistory;\n+                        $[31] = handleHistoryItemClick;\n+                        $[32] = handleSave;\n+                        $[33] = handleToggleFavorite;\n+                        $[34] = isEditable;\n+                        $[35] = props.item;\n+                        $[36] = t13;\n+                    } else {\n+                        t13 = $[36];\n+                    }\n+                    let t14;\n+                    if ($[37] !== t12 || $[38] !== t13) {\n+                        t14 = /* @__PURE__ */ jsxRuntime.jsx(\"li\", {\n+                            className: t12,\n+                            children: t13\n+                        });\n+                        $[37] = t12;\n+                        $[38] = t13;\n+                        $[39] = t14;\n+                    } else {\n+                        t14 = $[39];\n+                    }\n+                    return t14;\n+                }\n \n-                            // set offset past spaces and \">\"\n-                            let initial = state.sCount[nextLine] + 1;\n-                            let spaceAfterMarker;\n-                            let adjustTab;\n+                function formatQuery(query) {\n+                    return query == null ? void 0 : query.split(\"\\n\").map(line => line.replace(/#(.*)/, \"\")).join(\" \").replaceAll(\"{\", \" { \").replaceAll(\"}\", \" } \").replaceAll(/[\\s]{2,}/g, \" \");\n+                }\n+                const ExecutionContext = createNullableContext(\"ExecutionContext\");\n \n-                            // skip one optional space after '>'\n-                            if (state.src.charCodeAt(pos) === 0x20 /* space */ ) {\n-                                // ' >   test '\n-                                //     ^ -- position start of line here:\n-                                pos++;\n-                                initial++;\n-                                adjustTab = false;\n-                                spaceAfterMarker = true;\n-                            } else if (state.src.charCodeAt(pos) === 0x09 /* tab */ ) {\n-                                spaceAfterMarker = true;\n-                                if ((state.bsCount[nextLine] + initial) % 4 === 3) {\n-                                    // '  >\\t  test '\n-                                    //       ^ -- position start of line here (tab has width===1)\n-                                    pos++;\n-                                    initial++;\n-                                    adjustTab = false;\n-                                } else {\n-                                    // ' >\\t  test '\n-                                    //    ^ -- position start of line here + shift bsCount slightly\n-                                    //         to make extra space appear\n-                                    adjustTab = true;\n+                function ExecutionContextProvider(t0) {\n+                    const $ = reactCompilerRuntime.c(27);\n+                    const {\n+                        fetcher,\n+                        getDefaultFieldNames,\n+                        children,\n+                        operationName\n+                    } = t0;\n+                    if (!fetcher) {\n+                        throw new TypeError(\"The `ExecutionContextProvider` component requires a `fetcher` function to be passed as prop.\");\n+                    }\n+                    let t1;\n+                    if ($[0] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t1 = {\n+                            nonNull: true,\n+                            caller: ExecutionContextProvider\n+                        };\n+                        $[0] = t1;\n+                    } else {\n+                        t1 = $[0];\n+                    }\n+                    const {\n+                        externalFragments,\n+                        headerEditor,\n+                        queryEditor,\n+                        responseEditor,\n+                        variableEditor,\n+                        updateActiveTabValues\n+                    } = useEditorContext(t1);\n+                    const history = useHistoryContext();\n+                    let t2;\n+                    if ($[1] !== getDefaultFieldNames) {\n+                        t2 = {\n+                            getDefaultFieldNames,\n+                            caller: ExecutionContextProvider\n+                        };\n+                        $[1] = getDefaultFieldNames;\n+                        $[2] = t2;\n+                    } else {\n+                        t2 = $[2];\n+                    }\n+                    const autoCompleteLeafs = useAutoCompleteLeafs(t2);\n+                    const [isFetching, setIsFetching] = React.useState(false);\n+                    const [subscription, setSubscription] = React.useState(null);\n+                    const queryIdRef = React.useRef(0);\n+                    let t3;\n+                    if ($[3] !== subscription) {\n+                        t3 = () => {\n+                            subscription == null ? void 0 : subscription.unsubscribe();\n+                            setIsFetching(false);\n+                            setSubscription(null);\n+                        };\n+                        $[3] = subscription;\n+                        $[4] = t3;\n+                    } else {\n+                        t3 = $[4];\n+                    }\n+                    const stop = t3;\n+                    let t4;\n+                    if ($[5] !== autoCompleteLeafs || $[6] !== externalFragments || $[7] !== fetcher || $[8] !== headerEditor || $[9] !== history || $[10] !== operationName || $[11] !== queryEditor || $[12] !== responseEditor || $[13] !== stop || $[14] !== subscription || $[15] !== updateActiveTabValues || $[16] !== variableEditor) {\n+                        t4 = async () => {\n+                            var _ref, _headers2, _queryEditor$document;\n+                            if (!queryEditor || !responseEditor) {\n+                                return;\n+                            }\n+                            if (subscription) {\n+                                stop();\n+                                return;\n+                            }\n+                            const setResponse = value => {\n+                                responseEditor.setValue(value);\n+                                updateActiveTabValues({\n+                                    response: value\n+                                });\n+                            };\n+                            queryIdRef.current = queryIdRef.current + 1;\n+                            const queryId = queryIdRef.current;\n+                            let query = autoCompleteLeafs() || queryEditor.getValue();\n+                            const variablesString = variableEditor == null ? void 0 : variableEditor.getValue();\n+                            let variables;\n+                            try {\n+                                variables = tryParseJsonObject({\n+                                    json: variablesString,\n+                                    errorMessageParse: \"Variables are invalid JSON\",\n+                                    errorMessageType: \"Variables are not a JSON object.\"\n+                                });\n+                            } catch (t52) {\n+                                const error = t52;\n+                                setResponse(error instanceof Error ? error.message : `${error}`);\n+                                return;\n+                            }\n+                            const headersString = headerEditor == null ? void 0 : headerEditor.getValue();\n+                            let headers;\n+                            try {\n+                                headers = tryParseJsonObject({\n+                                    json: headersString,\n+                                    errorMessageParse: \"Headers are invalid JSON\",\n+                                    errorMessageType: \"Headers are not a JSON object.\"\n+                                });\n+                            } catch (t62) {\n+                                const error_0 = t62;\n+                                setResponse(error_0 instanceof Error ? error_0.message : `${error_0}`);\n+                                return;\n+                            }\n+                            if (externalFragments) {\n+                                const fragmentDependencies = queryEditor.documentAST ? graphqlLanguageService.getFragmentDependenciesForAST(queryEditor.documentAST, externalFragments) : [];\n+                                if (fragmentDependencies.length > 0) {\n+                                    query = query + (\"\\n\" + fragmentDependencies.map(_temp$7).join(\"\\n\"));\n                                 }\n-                            } else {\n-                                spaceAfterMarker = false;\n                             }\n-                            let offset = initial;\n-                            oldBMarks.push(state.bMarks[nextLine]);\n-                            state.bMarks[nextLine] = pos;\n-                            while (pos < max) {\n-                                const ch = state.src.charCodeAt(pos);\n-                                if (isSpace(ch)) {\n-                                    if (ch === 0x09) {\n-                                        offset += 4 - (offset + state.bsCount[nextLine] + (adjustTab ? 1 : 0)) % 4;\n+                            setResponse(\"\");\n+                            setIsFetching(true);\n+                            const opName = (_ref = operationName !== null && operationName !== void 0 ? operationName : queryEditor.operationName) !== null && _ref !== void 0 ? _ref : void 0;\n+                            history == null ? void 0 : history.addToHistory({\n+                                query,\n+                                variables: variablesString,\n+                                headers: headersString,\n+                                operationName: opName\n+                            });\n+                            const _headers = (_headers2 = headers) !== null && _headers2 !== void 0 ? _headers2 : void 0;\n+                            const documentAST = (_queryEditor$document = queryEditor.documentAST) !== null && _queryEditor$document !== void 0 ? _queryEditor$document : void 0;\n+                            try {\n+                                const fullResponse = {};\n+                                const handleResponse = result => {\n+                                    if (queryId !== queryIdRef.current) {\n+                                        return;\n+                                    }\n+                                    let maybeMultipart = Array.isArray(result) ? result : false;\n+                                    if (!maybeMultipart && typeof result === \"object\" && result !== null && \"hasNext\" in result) {\n+                                        maybeMultipart = [result];\n+                                    }\n+                                    if (maybeMultipart) {\n+                                        for (const part of maybeMultipart) {\n+                                            mergeIncrementalResult(fullResponse, part);\n+                                        }\n+                                        setIsFetching(false);\n+                                        setResponse(toolkit.formatResult(fullResponse));\n                                     } else {\n-                                        offset++;\n+                                        const response = toolkit.formatResult(result);\n+                                        setIsFetching(false);\n+                                        setResponse(response);\n                                     }\n+                                };\n+                                const fetch2 = fetcher({\n+                                    query,\n+                                    variables,\n+                                    operationName: opName\n+                                }, {\n+                                    headers: _headers,\n+                                    documentAST\n+                                });\n+                                const value_0 = await Promise.resolve(fetch2);\n+                                if (toolkit.isObservable(value_0)) {\n+                                    setSubscription(value_0.subscribe({\n+                                        next(result_0) {\n+                                            handleResponse(result_0);\n+                                        },\n+                                        error(error_2) {\n+                                            setIsFetching(false);\n+                                            if (error_2) {\n+                                                setResponse(toolkit.formatError(error_2));\n+                                            }\n+                                            setSubscription(null);\n+                                        },\n+                                        complete() {\n+                                            setIsFetching(false);\n+                                            setSubscription(null);\n+                                        }\n+                                    }));\n                                 } else {\n-                                    break;\n+                                    if (toolkit.isAsyncIterable(value_0)) {\n+                                        setSubscription({\n+                                            unsubscribe: () => {\n+                                                var _a, _b;\n+                                                return (_b = (_a = value_0[Symbol.asyncIterator]()).return) == null ? void 0 : _b.call(_a);\n+                                            }\n+                                        });\n+                                        await handleAsyncResults(handleResponse, value_0);\n+                                        setIsFetching(false);\n+                                        setSubscription(null);\n+                                    } else {\n+                                        handleResponse(value_0);\n+                                    }\n                                 }\n-                                pos++;\n+                            } catch (t72) {\n+                                const error_1 = t72;\n+                                setIsFetching(false);\n+                                setResponse(toolkit.formatError(error_1));\n+                                setSubscription(null);\n+                            }\n+                        };\n+                        $[5] = autoCompleteLeafs;\n+                        $[6] = externalFragments;\n+                        $[7] = fetcher;\n+                        $[8] = headerEditor;\n+                        $[9] = history;\n+                        $[10] = operationName;\n+                        $[11] = queryEditor;\n+                        $[12] = responseEditor;\n+                        $[13] = stop;\n+                        $[14] = subscription;\n+                        $[15] = updateActiveTabValues;\n+                        $[16] = variableEditor;\n+                        $[17] = t4;\n+                    } else {\n+                        t4 = $[17];\n+                    }\n+                    const run = t4;\n+                    const isSubscribed = Boolean(subscription);\n+                    const t5 = operationName !== null && operationName !== void 0 ? operationName : null;\n+                    let t6;\n+                    if ($[18] !== isFetching || $[19] !== isSubscribed || $[20] !== run || $[21] !== stop || $[22] !== t5) {\n+                        t6 = {\n+                            isFetching,\n+                            isSubscribed,\n+                            operationName: t5,\n+                            run,\n+                            stop\n+                        };\n+                        $[18] = isFetching;\n+                        $[19] = isSubscribed;\n+                        $[20] = run;\n+                        $[21] = stop;\n+                        $[22] = t5;\n+                        $[23] = t6;\n+                    } else {\n+                        t6 = $[23];\n+                    }\n+                    const value_1 = t6;\n+                    let t7;\n+                    if ($[24] !== children || $[25] !== value_1) {\n+                        t7 = /* @__PURE__ */ jsxRuntime.jsx(ExecutionContext.Provider, {\n+                            value: value_1,\n+                            children\n+                        });\n+                        $[24] = children;\n+                        $[25] = value_1;\n+                        $[26] = t7;\n+                    } else {\n+                        t7 = $[26];\n+                    }\n+                    return t7;\n+                }\n+\n+                function _temp$7(node) {\n+                    return graphql.print(node);\n+                }\n+                async function handleAsyncResults(onResponse, value) {\n+                    for await (const result of value) {\n+                        onResponse(result);\n+                    }\n+                }\n+                const useExecutionContext = createContextHook(ExecutionContext);\n+\n+                function tryParseJsonObject({\n+                    json,\n+                    errorMessageParse,\n+                    errorMessageType\n+                }) {\n+                    let parsed;\n+                    try {\n+                        parsed = json && json.trim() !== \"\" ? JSON.parse(json) : void 0;\n+                    } catch (error) {\n+                        throw new Error(`${errorMessageParse}: ${error instanceof Error ? error.message : error}.`);\n+                    }\n+                    const isObject = typeof parsed === \"object\" && parsed !== null && !Array.isArray(parsed);\n+                    if (parsed !== void 0 && !isObject) {\n+                        throw new Error(errorMessageType);\n+                    }\n+                    return parsed;\n+                }\n+                const pathsMap = /* @__PURE__ */ new WeakMap();\n+\n+                function mergeIncrementalResult(executionResult, incrementalResult) {\n+                    var _incrementalResult$pa;\n+                    var _a, _b, _c;\n+                    let path = [\"data\", ...((_incrementalResult$pa = incrementalResult.path) !== null && _incrementalResult$pa !== void 0 ? _incrementalResult$pa : [])];\n+                    for (const result of [executionResult, incrementalResult]) {\n+                        if (result.pending) {\n+                            let paths = pathsMap.get(executionResult);\n+                            if (paths === void 0) {\n+                                paths = /* @__PURE__ */ new Map();\n+                                pathsMap.set(executionResult, paths);\n+                            }\n+                            for (const {\n+                                    id,\n+                                    path: pendingPath\n+                                }\n+                                of result.pending) {\n+                                paths.set(id, [\"data\", ...pendingPath]);\n                             }\n-                            lastLineEmpty = pos >= max;\n-                            oldBSCount.push(state.bsCount[nextLine]);\n-                            state.bsCount[nextLine] = state.sCount[nextLine] + 1 + (spaceAfterMarker ? 1 : 0);\n-                            oldSCount.push(state.sCount[nextLine]);\n-                            state.sCount[nextLine] = offset - initial;\n-                            oldTShift.push(state.tShift[nextLine]);\n-                            state.tShift[nextLine] = pos - state.bMarks[nextLine];\n-                            continue;\n                         }\n-\n-                        // Case 2: line is not inside the blockquote, and the last line was empty.\n-                        if (lastLineEmpty) {\n-                            break;\n+                    }\n+                    const {\n+                        items\n+                    } = incrementalResult;\n+                    if (items) {\n+                        const {\n+                            id\n+                        } = incrementalResult;\n+                        if (id) {\n+                            path = (_a = pathsMap.get(executionResult)) == null ? void 0 : _a.get(id);\n+                            if (path === void 0) {\n+                                throw new Error(\"Invalid incremental delivery format.\");\n+                            }\n+                            const list = getValue(executionResult, path.join(\".\"));\n+                            list.push(...items);\n+                        } else {\n+                            var _incrementalResult$pa2;\n+                            path = [\"data\", ...((_incrementalResult$pa2 = incrementalResult.path) !== null && _incrementalResult$pa2 !== void 0 ? _incrementalResult$pa2 : [])];\n+                            for (const item of items) {\n+                                setValue(executionResult, path.join(\".\"), item);\n+                                path[path.length - 1]++;\n+                            }\n                         }\n-\n-                        // Case 3: another tag found.\n-                        let terminate = false;\n-                        for (let i = 0, l = terminatorRules.length; i < l; i++) {\n-                            if (terminatorRules[i](state, nextLine, endLine, true)) {\n-                                terminate = true;\n-                                break;\n+                    }\n+                    const {\n+                        data\n+                    } = incrementalResult;\n+                    if (data) {\n+                        const {\n+                            id\n+                        } = incrementalResult;\n+                        if (id) {\n+                            path = (_b = pathsMap.get(executionResult)) == null ? void 0 : _b.get(id);\n+                            if (path === void 0) {\n+                                throw new Error(\"Invalid incremental delivery format.\");\n+                            }\n+                            const {\n+                                subPath\n+                            } = incrementalResult;\n+                            if (subPath !== void 0) {\n+                                path = [...path, ...subPath];\n                             }\n                         }\n-                        if (terminate) {\n-                            // Quirk to enforce \"hard termination mode\" for paragraphs;\n-                            // normally if you call `tokenize(state, startLine, nextLine)`,\n-                            // paragraphs will look below nextLine for paragraph continuation,\n-                            // but if blockquote is terminated by another tag, they shouldn't\n-                            state.lineMax = nextLine;\n-                            if (state.blkIndent !== 0) {\n-                                // state.blkIndent was non-zero, we now set it to zero,\n-                                // so we need to re-calculate all offsets to appear as\n-                                // if indent wasn't changed\n-                                oldBMarks.push(state.bMarks[nextLine]);\n-                                oldBSCount.push(state.bsCount[nextLine]);\n-                                oldTShift.push(state.tShift[nextLine]);\n-                                oldSCount.push(state.sCount[nextLine]);\n-                                state.sCount[nextLine] -= state.blkIndent;\n+                        setValue(executionResult, path.join(\".\"), data, {\n+                            merge: true\n+                        });\n+                    }\n+                    if (incrementalResult.errors) {\n+                        executionResult.errors || (executionResult.errors = []);\n+                        executionResult.errors.push(...incrementalResult.errors);\n+                    }\n+                    if (incrementalResult.extensions) {\n+                        setValue(executionResult, \"extensions\", incrementalResult.extensions, {\n+                            merge: true\n+                        });\n+                    }\n+                    if (incrementalResult.incremental) {\n+                        for (const incrementalSubResult of incrementalResult.incremental) {\n+                            mergeIncrementalResult(executionResult, incrementalSubResult);\n+                        }\n+                    }\n+                    if (incrementalResult.completed) {\n+                        for (const {\n+                                id,\n+                                errors\n+                            }\n+                            of incrementalResult.completed) {\n+                            (_c = pathsMap.get(executionResult)) == null ? void 0 : _c.delete(id);\n+                            if (errors) {\n+                                executionResult.errors || (executionResult.errors = []);\n+                                executionResult.errors.push(...errors);\n                             }\n-                            break;\n                         }\n-                        oldBMarks.push(state.bMarks[nextLine]);\n-                        oldBSCount.push(state.bsCount[nextLine]);\n-                        oldTShift.push(state.tShift[nextLine]);\n-                        oldSCount.push(state.sCount[nextLine]);\n-\n-                        // A negative indentation means that this is a paragraph continuation\n-                        //\n-                        state.sCount[nextLine] = -1;\n                     }\n-                    const oldIndent = state.blkIndent;\n-                    state.blkIndent = 0;\n-                    const token_o = state.push('blockquote_open', 'blockquote', 1);\n-                    token_o.markup = '>';\n-                    const lines = [startLine, 0];\n-                    token_o.map = lines;\n-                    state.md.block.tokenize(state, startLine, nextLine);\n-                    const token_c = state.push('blockquote_close', 'blockquote', -1);\n-                    token_c.markup = '>';\n-                    state.lineMax = oldLineMax;\n-                    state.parentType = oldParentType;\n-                    lines[1] = state.line;\n+                }\n+                const isMacOs = typeof navigator !== \"undefined\" && navigator.userAgent.includes(\"Mac\");\n+                const DEFAULT_EDITOR_THEME = \"graphiql\";\n+                const DEFAULT_KEY_MAP = \"sublime\";\n+                const commonKeys = {\n+                    // Persistent search box in Query Editor\n+                    [isMacOs ? \"Cmd-F\" : \"Ctrl-F\"]: \"findPersistent\",\n+                    \"Cmd-G\": \"findPersistent\",\n+                    \"Ctrl-G\": \"findPersistent\",\n+                    // Editor improvements\n+                    \"Ctrl-Left\": \"goSubwordLeft\",\n+                    \"Ctrl-Right\": \"goSubwordRight\",\n+                    \"Alt-Left\": \"goGroupLeft\",\n+                    \"Alt-Right\": \"goGroupRight\"\n+                };\n+                async function importCodeMirror(addons, options) {\n+                    const CodeMirror = await Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror */ \"../../../node_modules/codemirror/lib/codemirror.js\"))).then(c =>\n+                        // Depending on bundler and settings the dynamic import either returns a\n+                        // function (e.g. parcel) or an object containing a `default` property\n+                        typeof c === \"function\" ? c : c.default);\n+                    await Promise.all((options == null ? void 0 : options.useCommonAddons) === false ? addons : [Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror/addon/hint/show-hint.js */ \"../../../node_modules/codemirror/addon/hint/show-hint.js\"))), Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror/addon/edit/matchbrackets.js */ \"../../../node_modules/codemirror/addon/edit/matchbrackets.js\"))), Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror/addon/edit/closebrackets.js */ \"../../../node_modules/codemirror/addon/edit/closebrackets.js\"))), Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror/addon/fold/brace-fold.js */ \"../../../node_modules/codemirror/addon/fold/brace-fold.js\"))), Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror/addon/fold/foldgutter.js */ \"../../../node_modules/codemirror/addon/fold/foldgutter.js\"))), Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror/addon/lint/lint.js */ \"../../../node_modules/codemirror/addon/lint/lint.js\"))), Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror/addon/search/searchcursor.js */ \"../../../node_modules/codemirror/addon/search/searchcursor.js\"))), Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror/addon/search/jump-to-line.js */ \"../../../node_modules/codemirror/addon/search/jump-to-line.js\"))), Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror/addon/dialog/dialog.js */ \"../../../node_modules/codemirror/addon/dialog/dialog.js\"))), // @ts-expect-error\n+                        Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror/keymap/sublime.js */ \"../../../node_modules/codemirror/keymap/sublime.js\"))), ...addons\n+                    ]);\n+                    return CodeMirror;\n+                }\n+                const printDefault = ast => {\n+                    if (!ast) {\n+                        return \"\";\n+                    }\n+                    return graphql.print(ast);\n+                };\n \n-                    // Restore original tShift; this might not be necessary since the parser\n-                    // has already been here, but just to make sure we can do that.\n-                    for (let i = 0; i < oldTShift.length; i++) {\n-                        state.bMarks[i + startLine] = oldBMarks[i];\n-                        state.tShift[i + startLine] = oldTShift[i];\n-                        state.sCount[i + startLine] = oldSCount[i];\n-                        state.bsCount[i + startLine] = oldBSCount[i];\n+                function DefaultValue(t0) {\n+                    const $ = reactCompilerRuntime.c(12);\n+                    const {\n+                        field\n+                    } = t0;\n+                    if (!(\"defaultValue\" in field) || field.defaultValue === void 0) {\n+                        return null;\n                     }\n-                    state.blkIndent = oldIndent;\n-                    return true;\n+                    const t1 = field.defaultValue;\n+                    const t2 = field.type;\n+                    let t3;\n+                    let t4;\n+                    let t5;\n+                    let t6;\n+                    if ($[0] !== field.defaultValue || $[1] !== field.type) {\n+                        t6 = Symbol.for(\"react.early_return_sentinel\");\n+                        bb0: {\n+                            const ast = graphql.astFromValue(t1, t2);\n+                            if (!ast) {\n+                                t6 = null;\n+                                break bb0;\n+                            }\n+                            t5 = \" = \";\n+                            t3 = \"graphiql-doc-explorer-default-value\";\n+                            t4 = printDefault(ast);\n+                        }\n+                        $[0] = field.defaultValue;\n+                        $[1] = field.type;\n+                        $[2] = t3;\n+                        $[3] = t4;\n+                        $[4] = t5;\n+                        $[5] = t6;\n+                    } else {\n+                        t3 = $[2];\n+                        t4 = $[3];\n+                        t5 = $[4];\n+                        t6 = $[5];\n+                    }\n+                    if (t6 !== Symbol.for(\"react.early_return_sentinel\")) {\n+                        return t6;\n+                    }\n+                    let t7;\n+                    if ($[6] !== t3 || $[7] !== t4) {\n+                        t7 = /* @__PURE__ */ jsxRuntime.jsx(\"span\", {\n+                            className: t3,\n+                            children: t4\n+                        });\n+                        $[6] = t3;\n+                        $[7] = t4;\n+                        $[8] = t7;\n+                    } else {\n+                        t7 = $[8];\n+                    }\n+                    let t8;\n+                    if ($[9] !== t5 || $[10] !== t7) {\n+                        t8 = /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, {\n+                            children: [t5, t7]\n+                        });\n+                        $[9] = t5;\n+                        $[10] = t7;\n+                        $[11] = t8;\n+                    } else {\n+                        t8 = $[11];\n+                    }\n+                    return t8;\n                 }\n+                const SchemaContext = createNullableContext(\"SchemaContext\");\n \n-                // Horizontal rule\n-\n-                function hr(state, startLine, endLine, silent) {\n-                    const max = state.eMarks[startLine];\n-                    // if it's indented more than 3 spaces, it should be a code block\n-                    if (state.sCount[startLine] - state.blkIndent >= 4) {\n-                        return false;\n+                function SchemaContextProvider(t0) {\n+                    const $ = reactCompilerRuntime.c(38);\n+                    let fetcher;\n+                    let onSchemaChange;\n+                    let props;\n+                    if ($[0] !== t0) {\n+                        ({\n+                            fetcher,\n+                            onSchemaChange,\n+                            ...props\n+                        } = t0);\n+                        $[0] = t0;\n+                        $[1] = fetcher;\n+                        $[2] = onSchemaChange;\n+                        $[3] = props;\n+                    } else {\n+                        fetcher = $[1];\n+                        onSchemaChange = $[2];\n+                        props = $[3];\n+                    }\n+                    if (!fetcher) {\n+                        throw new TypeError(\"The `SchemaContextProvider` component requires a `fetcher` function to be passed as prop.\");\n+                    }\n+                    let t1;\n+                    if ($[4] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t1 = {\n+                            nonNull: true,\n+                            caller: SchemaContextProvider\n+                        };\n+                        $[4] = t1;\n+                    } else {\n+                        t1 = $[4];\n                     }\n-                    let pos = state.bMarks[startLine] + state.tShift[startLine];\n-                    const marker = state.src.charCodeAt(pos++);\n-\n-                    // Check hr marker\n-                    if (marker !== 0x2A /* * */ && marker !== 0x2D /* - */ && marker !== 0x5F /* _ */ ) {\n-                        return false;\n+                    const {\n+                        initialHeaders,\n+                        headerEditor\n+                    } = useEditorContext(t1);\n+                    const [schema, setSchema] = React.useState();\n+                    const [isFetching, setIsFetching] = React.useState(false);\n+                    const [fetchError, setFetchError] = React.useState(null);\n+                    const counterRef = React.useRef(0);\n+                    let t2;\n+                    let t3;\n+                    if ($[5] !== props.schema) {\n+                        t2 = () => {\n+                            setSchema(graphql.isSchema(props.schema) || props.schema == null ? props.schema : void 0);\n+                            counterRef.current = counterRef.current + 1;\n+                        };\n+                        t3 = [props.schema];\n+                        $[5] = props.schema;\n+                        $[6] = t2;\n+                        $[7] = t3;\n+                    } else {\n+                        t2 = $[6];\n+                        t3 = $[7];\n                     }\n-\n-                    // markers can be mixed with spaces, but there should be at least 3 of them\n-\n-                    let cnt = 1;\n-                    while (pos < max) {\n-                        const ch = state.src.charCodeAt(pos++);\n-                        if (ch !== marker && !isSpace(ch)) {\n-                            return false;\n-                        }\n-                        if (ch === marker) {\n-                            cnt++;\n-                        }\n+                    React.useEffect(t2, t3);\n+                    const headersRef = React.useRef(initialHeaders);\n+                    let t4;\n+                    if ($[8] !== headerEditor) {\n+                        t4 = () => {\n+                            if (headerEditor) {\n+                                headersRef.current = headerEditor.getValue();\n+                            }\n+                        };\n+                        $[8] = headerEditor;\n+                        $[9] = t4;\n+                    } else {\n+                        t4 = $[9];\n                     }\n-                    if (cnt < 3) {\n-                        return false;\n+                    React.useEffect(t4);\n+                    let t5;\n+                    if ($[10] !== props.inputValueDeprecation || $[11] !== props.introspectionQueryName || $[12] !== props.schemaDescription) {\n+                        t5 = {\n+                            inputValueDeprecation: props.inputValueDeprecation,\n+                            introspectionQueryName: props.introspectionQueryName,\n+                            schemaDescription: props.schemaDescription\n+                        };\n+                        $[10] = props.inputValueDeprecation;\n+                        $[11] = props.introspectionQueryName;\n+                        $[12] = props.schemaDescription;\n+                        $[13] = t5;\n+                    } else {\n+                        t5 = $[13];\n                     }\n-                    if (silent) {\n-                        return true;\n+                    const {\n+                        introspectionQuery,\n+                        introspectionQueryName,\n+                        introspectionQuerySansSubscriptions\n+                    } = useIntrospectionQuery(t5);\n+                    let t6;\n+                    if ($[14] !== fetcher || $[15] !== introspectionQuery || $[16] !== introspectionQueryName || $[17] !== introspectionQuerySansSubscriptions || $[18] !== onSchemaChange || $[19] !== props.schema) {\n+                        t6 = () => {\n+                            if (graphql.isSchema(props.schema) || props.schema === null) {\n+                                return;\n+                            }\n+                            const counter = counterRef.current = counterRef.current + 1;\n+                            const maybeIntrospectionData = props.schema;\n+                            const fetchIntrospectionData = async function fetchIntrospectionData2() {\n+                                if (maybeIntrospectionData) {\n+                                    return maybeIntrospectionData;\n+                                }\n+                                const parsedHeaders = parseHeaderString(headersRef.current);\n+                                if (!parsedHeaders.isValidJSON) {\n+                                    setFetchError(\"Introspection failed as headers are invalid.\");\n+                                    return;\n+                                }\n+                                const fetcherOpts = parsedHeaders.headers ? {\n+                                    headers: parsedHeaders.headers\n+                                } : {};\n+                                const fetch2 = toolkit.fetcherReturnToPromise(fetcher({\n+                                    query: introspectionQuery,\n+                                    operationName: introspectionQueryName\n+                                }, fetcherOpts));\n+                                if (!toolkit.isPromise(fetch2)) {\n+                                    setFetchError(\"Fetcher did not return a Promise for introspection.\");\n+                                    return;\n+                                }\n+                                setIsFetching(true);\n+                                setFetchError(null);\n+                                let result = await fetch2;\n+                                if (typeof result !== \"object\" || result === null || !(\"data\" in result)) {\n+                                    const fetch22 = toolkit.fetcherReturnToPromise(fetcher({\n+                                        query: introspectionQuerySansSubscriptions,\n+                                        operationName: introspectionQueryName\n+                                    }, fetcherOpts));\n+                                    if (!toolkit.isPromise(fetch22)) {\n+                                        throw new Error(\"Fetcher did not return a Promise for introspection.\");\n+                                    }\n+                                    result = await fetch22;\n+                                }\n+                                setIsFetching(false);\n+                                if ((result == null ? void 0 : result.data) && \"__schema\" in result.data) {\n+                                    return result.data;\n+                                }\n+                                const responseString = typeof result === \"string\" ? result : toolkit.formatResult(result);\n+                                setFetchError(responseString);\n+                            };\n+                            fetchIntrospectionData().then(introspectionData => {\n+                                if (counter !== counterRef.current || !introspectionData) {\n+                                    return;\n+                                }\n+                                try {\n+                                    const newSchema = graphql.buildClientSchema(introspectionData);\n+                                    setSchema(newSchema);\n+                                    if (onSchemaChange) {\n+                                        onSchemaChange(newSchema);\n+                                    }\n+                                } catch (t72) {\n+                                    const error = t72;\n+                                    setFetchError(toolkit.formatError(error));\n+                                }\n+                            }).catch(error_0 => {\n+                                if (counter !== counterRef.current) {\n+                                    return;\n+                                }\n+                                setFetchError(toolkit.formatError(error_0));\n+                                setIsFetching(false);\n+                            });\n+                        };\n+                        $[14] = fetcher;\n+                        $[15] = introspectionQuery;\n+                        $[16] = introspectionQueryName;\n+                        $[17] = introspectionQuerySansSubscriptions;\n+                        $[18] = onSchemaChange;\n+                        $[19] = props.schema;\n+                        $[20] = t6;\n+                    } else {\n+                        t6 = $[20];\n                     }\n-                    state.line = startLine + 1;\n-                    const token = state.push('hr', 'hr', 0);\n-                    token.map = [startLine, state.line];\n-                    token.markup = Array(cnt + 1).join(String.fromCharCode(marker));\n-                    return true;\n+                    const introspect = t6;\n+                    let t7;\n+                    let t8;\n+                    if ($[21] !== introspect) {\n+                        t7 = () => {\n+                            introspect();\n+                        };\n+                        t8 = [introspect];\n+                        $[21] = introspect;\n+                        $[22] = t7;\n+                        $[23] = t8;\n+                    } else {\n+                        t7 = $[22];\n+                        t8 = $[23];\n+                    }\n+                    React.useEffect(t7, t8);\n+                    let t9;\n+                    if ($[24] !== introspect) {\n+                        t9 = () => {\n+                            const triggerIntrospection = function triggerIntrospection2(event) {\n+                                if (event.ctrlKey && event.key === \"R\") {\n+                                    introspect();\n+                                }\n+                            };\n+                            window.addEventListener(\"keydown\", triggerIntrospection);\n+                            return () => {\n+                                window.removeEventListener(\"keydown\", triggerIntrospection);\n+                            };\n+                        };\n+                        $[24] = introspect;\n+                        $[25] = t9;\n+                    } else {\n+                        t9 = $[25];\n+                    }\n+                    React.useEffect(t9);\n+                    let t10;\n+                    if ($[26] !== props.dangerouslyAssumeSchemaIsValid || $[27] !== schema) {\n+                        t10 = !schema || props.dangerouslyAssumeSchemaIsValid ? [] : graphql.validateSchema(schema);\n+                        $[26] = props.dangerouslyAssumeSchemaIsValid;\n+                        $[27] = schema;\n+                        $[28] = t10;\n+                    } else {\n+                        t10 = $[28];\n+                    }\n+                    const validationErrors = t10;\n+                    let t11;\n+                    if ($[29] !== fetchError || $[30] !== introspect || $[31] !== isFetching || $[32] !== schema || $[33] !== validationErrors) {\n+                        t11 = {\n+                            fetchError,\n+                            introspect,\n+                            isFetching,\n+                            schema,\n+                            validationErrors\n+                        };\n+                        $[29] = fetchError;\n+                        $[30] = introspect;\n+                        $[31] = isFetching;\n+                        $[32] = schema;\n+                        $[33] = validationErrors;\n+                        $[34] = t11;\n+                    } else {\n+                        t11 = $[34];\n+                    }\n+                    const value = t11;\n+                    let t12;\n+                    if ($[35] !== props.children || $[36] !== value) {\n+                        t12 = /* @__PURE__ */ jsxRuntime.jsx(SchemaContext.Provider, {\n+                            value,\n+                            children: props.children\n+                        });\n+                        $[35] = props.children;\n+                        $[36] = value;\n+                        $[37] = t12;\n+                    } else {\n+                        t12 = $[37];\n+                    }\n+                    return t12;\n                 }\n+                const useSchemaContext = createContextHook(SchemaContext);\n \n-                // Lists\n-\n-                // Search `[-+*][\\n ]`, returns next pos after marker on success\n-                // or -1 on fail.\n-                function skipBulletListMarker(state, startLine) {\n-                    const max = state.eMarks[startLine];\n-                    let pos = state.bMarks[startLine] + state.tShift[startLine];\n-                    const marker = state.src.charCodeAt(pos++);\n-                    // Check bullet\n-                    if (marker !== 0x2A /* * */ && marker !== 0x2D /* - */ && marker !== 0x2B /* + */ ) {\n-                        return -1;\n+                function useIntrospectionQuery({\n+                    inputValueDeprecation,\n+                    introspectionQueryName,\n+                    schemaDescription\n+                }) {\n+                    const queryName = introspectionQueryName || \"IntrospectionQuery\";\n+                    let query = graphql.getIntrospectionQuery({\n+                        inputValueDeprecation,\n+                        schemaDescription\n+                    });\n+                    if (introspectionQueryName) {\n+                        query = query.replace(\"query IntrospectionQuery\", `query ${queryName}`);\n                     }\n-                    if (pos < max) {\n-                        const ch = state.src.charCodeAt(pos);\n-                        if (!isSpace(ch)) {\n-                            // \" -test \" - is not a list item\n-                            return -1;\n+                    const querySansSubscriptions = query.replace(\"subscriptionType { name }\", \"\");\n+                    return {\n+                        introspectionQueryName: queryName,\n+                        introspectionQuery: query,\n+                        introspectionQuerySansSubscriptions: querySansSubscriptions\n+                    };\n+                }\n+\n+                function parseHeaderString(headersString) {\n+                    let headers = null;\n+                    let isValidJSON = true;\n+                    try {\n+                        if (headersString) {\n+                            headers = JSON.parse(headersString);\n                         }\n+                    } catch {\n+                        isValidJSON = false;\n                     }\n-                    return pos;\n+                    return {\n+                        headers,\n+                        isValidJSON\n+                    };\n                 }\n+                const initialNavStackItem = {\n+                    name: \"Docs\"\n+                };\n+                const ExplorerContext = createNullableContext(\"ExplorerContext\");\n \n-                // Search `\\d+[.)][\\n ]`, returns next pos after marker on success\n-                // or -1 on fail.\n-                function skipOrderedListMarker(state, startLine) {\n-                    const start = state.bMarks[startLine] + state.tShift[startLine];\n-                    const max = state.eMarks[startLine];\n-                    let pos = start;\n-\n-                    // List marker should have at least 2 chars (digit + dot)\n-                    if (pos + 1 >= max) {\n-                        return -1;\n+                function ExplorerContextProvider(props) {\n+                    const $ = reactCompilerRuntime.c(14);\n+                    let t0;\n+                    if ($[0] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t0 = {\n+                            nonNull: true,\n+                            caller: ExplorerContextProvider\n+                        };\n+                        $[0] = t0;\n+                    } else {\n+                        t0 = $[0];\n                     }\n-                    let ch = state.src.charCodeAt(pos++);\n-                    if (ch < 0x30 /* 0 */ || ch > 0x39 /* 9 */ ) {\n-                        return -1;\n+                    const {\n+                        schema,\n+                        validationErrors\n+                    } = useSchemaContext(t0);\n+                    let t1;\n+                    if ($[1] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t1 = [initialNavStackItem];\n+                        $[1] = t1;\n+                    } else {\n+                        t1 = $[1];\n                     }\n-                    for (;;) {\n-                        // EOL -> fail\n-                        if (pos >= max) {\n-                            return -1;\n-                        }\n-                        ch = state.src.charCodeAt(pos++);\n-                        if (ch >= 0x30 /* 0 */ && ch <= 0x39 /* 9 */ ) {\n-                            // List marker should have no more than 9 digits\n-                            // (prevents integer overflow in browsers)\n-                            if (pos - start >= 10) {\n-                                return -1;\n+                    const [navStack, setNavStack] = React.useState(t1);\n+                    let t2;\n+                    if ($[2] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t2 = item => {\n+                            setNavStack(currentState => {\n+                                const lastItem = currentState.at(-1);\n+                                return lastItem.def === item.def ? currentState : [...currentState, item];\n+                            });\n+                        };\n+                        $[2] = t2;\n+                    } else {\n+                        t2 = $[2];\n+                    }\n+                    const push = t2;\n+                    let t3;\n+                    if ($[3] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t3 = () => {\n+                            setNavStack(_temp$6);\n+                        };\n+                        $[3] = t3;\n+                    } else {\n+                        t3 = $[3];\n+                    }\n+                    const pop = t3;\n+                    let t4;\n+                    if ($[4] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t4 = () => {\n+                            setNavStack(_temp2$3);\n+                        };\n+                        $[4] = t4;\n+                    } else {\n+                        t4 = $[4];\n+                    }\n+                    const reset = t4;\n+                    let t5;\n+                    let t6;\n+                    if ($[5] !== schema || $[6] !== validationErrors) {\n+                        t5 = () => {\n+                            if (schema == null || validationErrors.length > 0) {\n+                                reset();\n+                            } else {\n+                                setNavStack(oldNavStack => {\n+                                    if (oldNavStack.length === 1) {\n+                                        return oldNavStack;\n+                                    }\n+                                    const newNavStack = [initialNavStackItem];\n+                                    let lastEntity = null;\n+                                    for (const item_0 of oldNavStack) {\n+                                        if (item_0 === initialNavStackItem) {\n+                                            continue;\n+                                        }\n+                                        if (item_0.def) {\n+                                            if (graphql.isNamedType(item_0.def)) {\n+                                                const newType = schema.getType(item_0.def.name);\n+                                                if (newType) {\n+                                                    newNavStack.push({\n+                                                        name: item_0.name,\n+                                                        def: newType\n+                                                    });\n+                                                    lastEntity = newType;\n+                                                } else {\n+                                                    break;\n+                                                }\n+                                            } else {\n+                                                if (lastEntity === null) {\n+                                                    break;\n+                                                } else {\n+                                                    if (graphql.isObjectType(lastEntity) || graphql.isInputObjectType(lastEntity)) {\n+                                                        const field = lastEntity.getFields()[item_0.name];\n+                                                        if (field) {\n+                                                            newNavStack.push({\n+                                                                name: item_0.name,\n+                                                                def: field\n+                                                            });\n+                                                        } else {\n+                                                            break;\n+                                                        }\n+                                                    } else {\n+                                                        if (graphql.isScalarType(lastEntity) || graphql.isEnumType(lastEntity) || graphql.isInterfaceType(lastEntity) || graphql.isUnionType(lastEntity)) {\n+                                                            break;\n+                                                        } else {\n+                                                            const field_0 = lastEntity;\n+                                                            const arg = field_0.args.find(a => a.name === item_0.name);\n+                                                            if (arg) {\n+                                                                newNavStack.push({\n+                                                                    name: item_0.name,\n+                                                                    def: field_0\n+                                                                });\n+                                                            } else {\n+                                                                break;\n+                                                            }\n+                                                        }\n+                                                    }\n+                                                }\n+                                            }\n+                                        } else {\n+                                            lastEntity = null;\n+                                            newNavStack.push(item_0);\n+                                        }\n+                                    }\n+                                    return newNavStack;\n+                                });\n                             }\n-                            continue;\n-                        }\n-\n-                        // found valid marker\n-                        if (ch === 0x29 /* ) */ || ch === 0x2e /* . */ ) {\n-                            break;\n-                        }\n-                        return -1;\n+                        };\n+                        t6 = [schema, validationErrors];\n+                        $[5] = schema;\n+                        $[6] = validationErrors;\n+                        $[7] = t5;\n+                        $[8] = t6;\n+                    } else {\n+                        t5 = $[7];\n+                        t6 = $[8];\n                     }\n-                    if (pos < max) {\n-                        ch = state.src.charCodeAt(pos);\n-                        if (!isSpace(ch)) {\n-                            // \" 1.test \" - is not a list item\n-                            return -1;\n-                        }\n+                    React.useEffect(t5, t6);\n+                    let t7;\n+                    if ($[9] !== navStack) {\n+                        t7 = {\n+                            explorerNavStack: navStack,\n+                            push,\n+                            pop,\n+                            reset\n+                        };\n+                        $[9] = navStack;\n+                        $[10] = t7;\n+                    } else {\n+                        t7 = $[10];\n                     }\n-                    return pos;\n+                    const value = t7;\n+                    let t8;\n+                    if ($[11] !== props.children || $[12] !== value) {\n+                        t8 = /* @__PURE__ */ jsxRuntime.jsx(ExplorerContext.Provider, {\n+                            value,\n+                            children: props.children\n+                        });\n+                        $[11] = props.children;\n+                        $[12] = value;\n+                        $[13] = t8;\n+                    } else {\n+                        t8 = $[13];\n+                    }\n+                    return t8;\n                 }\n \n-                function markTightParagraphs(state, idx) {\n-                    const level = state.level + 2;\n-                    for (let i = idx + 2, l = state.tokens.length - 2; i < l; i++) {\n-                        if (state.tokens[i].level === level && state.tokens[i].type === 'paragraph_open') {\n-                            state.tokens[i + 2].hidden = true;\n-                            state.tokens[i].hidden = true;\n-                            i += 2;\n-                        }\n-                    }\n+                function _temp2$3(currentState_1) {\n+                    return currentState_1.length === 1 ? currentState_1 : [initialNavStackItem];\n                 }\n \n-                function list(state, startLine, endLine, silent) {\n-                    let max, pos, start, token;\n-                    let nextLine = startLine;\n-                    let tight = true;\n+                function _temp$6(currentState_0) {\n+                    return currentState_0.length > 1 ? currentState_0.slice(0, -1) : currentState_0;\n+                }\n+                const useExplorerContext = createContextHook(ExplorerContext);\n \n-                    // if it's indented more than 3 spaces, it should be a code block\n-                    if (state.sCount[nextLine] - state.blkIndent >= 4) {\n-                        return false;\n+                function renderType(type, renderNamedType) {\n+                    if (graphql.isNonNullType(type)) {\n+                        return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, {\n+                            children: [renderType(type.ofType, renderNamedType), \"!\"]\n+                        });\n                     }\n-\n-                    // Special case:\n-                    //  - item 1\n-                    //   - item 2\n-                    //    - item 3\n-                    //     - item 4\n-                    //      - this one is a paragraph continuation\n-                    if (state.listIndent >= 0 && state.sCount[nextLine] - state.listIndent >= 4 && state.sCount[nextLine] < state.blkIndent) {\n-                        return false;\n+                    if (graphql.isListType(type)) {\n+                        return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, {\n+                            children: [\"[\", renderType(type.ofType, renderNamedType), \"]\"]\n+                        });\n                     }\n-                    let isTerminatingParagraph = false;\n+                    return renderNamedType(type);\n+                }\n \n-                    // limit conditions when list can interrupt\n-                    // a paragraph (validation mode only)\n-                    if (silent && state.parentType === 'paragraph') {\n-                        // Next list item should still terminate previous list item;\n-                        //\n-                        // This code can fail if plugins use blkIndent as well as lists,\n-                        // but I hope the spec gets fixed long before that happens.\n-                        //\n-                        if (state.sCount[nextLine] >= state.blkIndent) {\n-                            isTerminatingParagraph = true;\n-                        }\n+                function TypeLink(props) {\n+                    const $ = reactCompilerRuntime.c(6);\n+                    let t0;\n+                    if ($[0] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t0 = {\n+                            nonNull: true,\n+                            caller: TypeLink\n+                        };\n+                        $[0] = t0;\n+                    } else {\n+                        t0 = $[0];\n                     }\n-\n-                    // Detect list type and position after marker\n-                    let isOrdered;\n-                    let markerValue;\n-                    let posAfterMarker;\n-                    if ((posAfterMarker = skipOrderedListMarker(state, nextLine)) >= 0) {\n-                        isOrdered = true;\n-                        start = state.bMarks[nextLine] + state.tShift[nextLine];\n-                        markerValue = Number(state.src.slice(start, posAfterMarker - 1));\n-\n-                        // If we're starting a new ordered list right after\n-                        // a paragraph, it should start with 1.\n-                        if (isTerminatingParagraph && markerValue !== 1) return false;\n-                    } else if ((posAfterMarker = skipBulletListMarker(state, nextLine)) >= 0) {\n-                        isOrdered = false;\n+                    const {\n+                        push\n+                    } = useExplorerContext(t0);\n+                    if (!props.type) {\n+                        return null;\n+                    }\n+                    let t1;\n+                    if ($[1] !== push) {\n+                        t1 = namedType => /* @__PURE__ */ jsxRuntime.jsx(\"a\", {\n+                            className: \"graphiql-doc-explorer-type-name\",\n+                            onClick: event => {\n+                                event.preventDefault();\n+                                push({\n+                                    name: namedType.name,\n+                                    def: namedType\n+                                });\n+                            },\n+                            href: \"#\",\n+                            children: namedType.name\n+                        });\n+                        $[1] = push;\n+                        $[2] = t1;\n                     } else {\n-                        return false;\n+                        t1 = $[2];\n                     }\n-\n-                    // If we're starting a new unordered list right after\n-                    // a paragraph, first line should not be empty.\n-                    if (isTerminatingParagraph) {\n-                        if (state.skipSpaces(posAfterMarker) >= state.eMarks[nextLine]) return false;\n+                    let t2;\n+                    if ($[3] !== props.type || $[4] !== t1) {\n+                        t2 = renderType(props.type, t1);\n+                        $[3] = props.type;\n+                        $[4] = t1;\n+                        $[5] = t2;\n+                    } else {\n+                        t2 = $[5];\n                     }\n+                    return t2;\n+                }\n \n-                    // For validation mode we can terminate immediately\n-                    if (silent) {\n-                        return true;\n+                function Argument(t0) {\n+                    const $ = reactCompilerRuntime.c(19);\n+                    const {\n+                        arg,\n+                        showDefaultValue,\n+                        inline\n+                    } = t0;\n+                    let t1;\n+                    if ($[0] !== arg.name) {\n+                        t1 = /* @__PURE__ */ jsxRuntime.jsx(\"span\", {\n+                            className: \"graphiql-doc-explorer-argument-name\",\n+                            children: arg.name\n+                        });\n+                        $[0] = arg.name;\n+                        $[1] = t1;\n+                    } else {\n+                        t1 = $[1];\n+                    }\n+                    let t2;\n+                    if ($[2] !== arg.type) {\n+                        t2 = /* @__PURE__ */ jsxRuntime.jsx(TypeLink, {\n+                            type: arg.type\n+                        });\n+                        $[2] = arg.type;\n+                        $[3] = t2;\n+                    } else {\n+                        t2 = $[3];\n+                    }\n+                    let t3;\n+                    if ($[4] !== arg || $[5] !== showDefaultValue) {\n+                        t3 = showDefaultValue !== false && /* @__PURE__ */ jsxRuntime.jsx(DefaultValue, {\n+                            field: arg\n+                        });\n+                        $[4] = arg;\n+                        $[5] = showDefaultValue;\n+                        $[6] = t3;\n+                    } else {\n+                        t3 = $[6];\n+                    }\n+                    let t4;\n+                    if ($[7] !== t1 || $[8] !== t2 || $[9] !== t3) {\n+                        t4 = /* @__PURE__ */ jsxRuntime.jsxs(\"span\", {\n+                            children: [t1, \": \", t2, t3]\n+                        });\n+                        $[7] = t1;\n+                        $[8] = t2;\n+                        $[9] = t3;\n+                        $[10] = t4;\n+                    } else {\n+                        t4 = $[10];\n+                    }\n+                    const definition = t4;\n+                    if (inline) {\n+                        return definition;\n+                    }\n+                    let t5;\n+                    if ($[11] !== arg.description) {\n+                        t5 = arg.description ? /* @__PURE__ */ jsxRuntime.jsx(MarkdownContent, {\n+                            type: \"description\",\n+                            children: arg.description\n+                        }) : null;\n+                        $[11] = arg.description;\n+                        $[12] = t5;\n+                    } else {\n+                        t5 = $[12];\n+                    }\n+                    let t6;\n+                    if ($[13] !== arg.deprecationReason) {\n+                        t6 = arg.deprecationReason ? /* @__PURE__ */ jsxRuntime.jsxs(\"div\", {\n+                            className: \"graphiql-doc-explorer-argument-deprecation\",\n+                            children: [ /* @__PURE__ */ jsxRuntime.jsx(\"div\", {\n+                                className: \"graphiql-doc-explorer-argument-deprecation-label\",\n+                                children: \"Deprecated\"\n+                            }), /* @__PURE__ */ jsxRuntime.jsx(MarkdownContent, {\n+                                type: \"deprecation\",\n+                                children: arg.deprecationReason\n+                            })]\n+                        }) : null;\n+                        $[13] = arg.deprecationReason;\n+                        $[14] = t6;\n+                    } else {\n+                        t6 = $[14];\n+                    }\n+                    let t7;\n+                    if ($[15] !== definition || $[16] !== t5 || $[17] !== t6) {\n+                        t7 = /* @__PURE__ */ jsxRuntime.jsxs(\"div\", {\n+                            className: \"graphiql-doc-explorer-argument\",\n+                            children: [definition, t5, t6]\n+                        });\n+                        $[15] = definition;\n+                        $[16] = t5;\n+                        $[17] = t6;\n+                        $[18] = t7;\n+                    } else {\n+                        t7 = $[18];\n                     }\n+                    return t7;\n+                }\n \n-                    // We should terminate list on style change. Remember first one to compare.\n-                    const markerCharCode = state.src.charCodeAt(posAfterMarker - 1);\n+                function DeprecationReason(props) {\n+                    const $ = reactCompilerRuntime.c(3);\n+                    let t0;\n+                    if ($[0] !== props.children || $[1] !== props.preview) {\n+                        var _props$preview;\n+                        t0 = props.children ? /* @__PURE__ */ jsxRuntime.jsxs(\"div\", {\n+                            className: \"graphiql-doc-explorer-deprecation\",\n+                            children: [ /* @__PURE__ */ jsxRuntime.jsx(\"div\", {\n+                                className: \"graphiql-doc-explorer-deprecation-label\",\n+                                children: \"Deprecated\"\n+                            }), /* @__PURE__ */ jsxRuntime.jsx(MarkdownContent, {\n+                                type: \"deprecation\",\n+                                onlyShowFirstChild: (_props$preview = props.preview) !== null && _props$preview !== void 0 ? _props$preview : true,\n+                                children: props.children\n+                            })]\n+                        }) : null;\n+                        $[0] = props.children;\n+                        $[1] = props.preview;\n+                        $[2] = t0;\n+                    } else {\n+                        t0 = $[2];\n+                    }\n+                    return t0;\n+                }\n \n-                    // Start list\n-                    const listTokIdx = state.tokens.length;\n-                    if (isOrdered) {\n-                        token = state.push('ordered_list_open', 'ol', 1);\n-                        if (markerValue !== 1) {\n-                            token.attrs = [\n-                                ['start', markerValue]\n-                            ];\n-                        }\n+                function Directive(t0) {\n+                    const $ = reactCompilerRuntime.c(2);\n+                    const {\n+                        directive\n+                    } = t0;\n+                    let t1;\n+                    if ($[0] !== directive.name.value) {\n+                        t1 = /* @__PURE__ */ jsxRuntime.jsxs(\"span\", {\n+                            className: \"graphiql-doc-explorer-directive\",\n+                            children: [\"@\", directive.name.value]\n+                        });\n+                        $[0] = directive.name.value;\n+                        $[1] = t1;\n                     } else {\n-                        token = state.push('bullet_list_open', 'ul', 1);\n+                        t1 = $[1];\n                     }\n-                    const listLines = [nextLine, 0];\n-                    token.map = listLines;\n-                    token.markup = String.fromCharCode(markerCharCode);\n+                    return t1;\n+                }\n \n-                    //\n-                    // Iterate list items\n-                    //\n+                function ExplorerSection(props) {\n+                    const $ = reactCompilerRuntime.c(10);\n+                    const Icon2 = TYPE_TO_ICON[props.title];\n+                    let t0;\n+                    if ($[0] !== Icon2) {\n+                        t0 = /* @__PURE__ */ jsxRuntime.jsx(Icon2, {});\n+                        $[0] = Icon2;\n+                        $[1] = t0;\n+                    } else {\n+                        t0 = $[1];\n+                    }\n+                    let t1;\n+                    if ($[2] !== props.title || $[3] !== t0) {\n+                        t1 = /* @__PURE__ */ jsxRuntime.jsxs(\"div\", {\n+                            className: \"graphiql-doc-explorer-section-title\",\n+                            children: [t0, props.title]\n+                        });\n+                        $[2] = props.title;\n+                        $[3] = t0;\n+                        $[4] = t1;\n+                    } else {\n+                        t1 = $[4];\n+                    }\n+                    let t2;\n+                    if ($[5] !== props.children) {\n+                        t2 = /* @__PURE__ */ jsxRuntime.jsx(\"div\", {\n+                            className: \"graphiql-doc-explorer-section-content\",\n+                            children: props.children\n+                        });\n+                        $[5] = props.children;\n+                        $[6] = t2;\n+                    } else {\n+                        t2 = $[6];\n+                    }\n+                    let t3;\n+                    if ($[7] !== t1 || $[8] !== t2) {\n+                        t3 = /* @__PURE__ */ jsxRuntime.jsxs(\"div\", {\n+                            children: [t1, t2]\n+                        });\n+                        $[7] = t1;\n+                        $[8] = t2;\n+                        $[9] = t3;\n+                    } else {\n+                        t3 = $[9];\n+                    }\n+                    return t3;\n+                }\n+                const TYPE_TO_ICON = {\n+                    Arguments: ArgumentIcon,\n+                    \"Deprecated Arguments\": DeprecatedArgumentIcon,\n+                    \"Deprecated Enum Values\": DeprecatedEnumValueIcon,\n+                    \"Deprecated Fields\": DeprecatedFieldIcon,\n+                    Directives: DirectiveIcon,\n+                    \"Enum Values\": EnumValueIcon,\n+                    Fields: FieldIcon,\n+                    Implements: ImplementsIcon,\n+                    Implementations: TypeIcon,\n+                    \"Possible Types\": TypeIcon,\n+                    \"Root Types\": RootTypeIcon,\n+                    Type: TypeIcon,\n+                    \"All Schema Types\": TypeIcon\n+                };\n+\n+                function FieldDocumentation(props) {\n+                    const $ = reactCompilerRuntime.c(15);\n+                    let t0;\n+                    if ($[0] !== props.field.description) {\n+                        t0 = props.field.description ? /* @__PURE__ */ jsxRuntime.jsx(MarkdownContent, {\n+                            type: \"description\",\n+                            children: props.field.description\n+                        }) : null;\n+                        $[0] = props.field.description;\n+                        $[1] = t0;\n+                    } else {\n+                        t0 = $[1];\n+                    }\n+                    let t1;\n+                    if ($[2] !== props.field.deprecationReason) {\n+                        t1 = /* @__PURE__ */ jsxRuntime.jsx(DeprecationReason, {\n+                            preview: false,\n+                            children: props.field.deprecationReason\n+                        });\n+                        $[2] = props.field.deprecationReason;\n+                        $[3] = t1;\n+                    } else {\n+                        t1 = $[3];\n+                    }\n+                    let t2;\n+                    if ($[4] !== props.field.type) {\n+                        t2 = /* @__PURE__ */ jsxRuntime.jsx(ExplorerSection, {\n+                            title: \"Type\",\n+                            children: /* @__PURE__ */ jsxRuntime.jsx(TypeLink, {\n+                                type: props.field.type\n+                            })\n+                        });\n+                        $[4] = props.field.type;\n+                        $[5] = t2;\n+                    } else {\n+                        t2 = $[5];\n+                    }\n+                    let t3;\n+                    let t4;\n+                    if ($[6] !== props.field) {\n+                        t3 = /* @__PURE__ */ jsxRuntime.jsx(Arguments, {\n+                            field: props.field\n+                        });\n+                        t4 = /* @__PURE__ */ jsxRuntime.jsx(Directives, {\n+                            field: props.field\n+                        });\n+                        $[6] = props.field;\n+                        $[7] = t3;\n+                        $[8] = t4;\n+                    } else {\n+                        t3 = $[7];\n+                        t4 = $[8];\n+                    }\n+                    let t5;\n+                    if ($[9] !== t0 || $[10] !== t1 || $[11] !== t2 || $[12] !== t3 || $[13] !== t4) {\n+                        t5 = /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, {\n+                            children: [t0, t1, t2, t3, t4]\n+                        });\n+                        $[9] = t0;\n+                        $[10] = t1;\n+                        $[11] = t2;\n+                        $[12] = t3;\n+                        $[13] = t4;\n+                        $[14] = t5;\n+                    } else {\n+                        t5 = $[14];\n+                    }\n+                    return t5;\n+                }\n \n-                    let prevEmptyEnd = false;\n-                    const terminatorRules = state.md.block.ruler.getRules('list');\n-                    const oldParentType = state.parentType;\n-                    state.parentType = 'list';\n-                    while (nextLine < endLine) {\n-                        pos = posAfterMarker;\n-                        max = state.eMarks[nextLine];\n-                        const initial = state.sCount[nextLine] + posAfterMarker - (state.bMarks[nextLine] + state.tShift[nextLine]);\n-                        let offset = initial;\n-                        while (pos < max) {\n-                            const ch = state.src.charCodeAt(pos);\n-                            if (ch === 0x09) {\n-                                offset += 4 - (offset + state.bsCount[nextLine]) % 4;\n-                            } else if (ch === 0x20) {\n-                                offset++;\n+                function Arguments(t0) {\n+                    const $ = reactCompilerRuntime.c(12);\n+                    const {\n+                        field\n+                    } = t0;\n+                    const [showDeprecated, setShowDeprecated] = React.useState(false);\n+                    let t1;\n+                    if ($[0] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t1 = () => {\n+                            setShowDeprecated(true);\n+                        };\n+                        $[0] = t1;\n+                    } else {\n+                        t1 = $[0];\n+                    }\n+                    const handleShowDeprecated = t1;\n+                    if (!(\"args\" in field)) {\n+                        return null;\n+                    }\n+                    let args;\n+                    let deprecatedArgs;\n+                    let t2;\n+                    if ($[1] !== field.args) {\n+                        args = [];\n+                        deprecatedArgs = [];\n+                        for (const argument of field.args) {\n+                            if (argument.deprecationReason) {\n+                                deprecatedArgs.push(argument);\n                             } else {\n-                                break;\n+                                args.push(argument);\n                             }\n-                            pos++;\n-                        }\n-                        const contentStart = pos;\n-                        let indentAfterMarker;\n-                        if (contentStart >= max) {\n-                            // trimming space in \"-    \\n  3\" case, indent is 1 here\n-                            indentAfterMarker = 1;\n-                        } else {\n-                            indentAfterMarker = offset - initial;\n                         }\n+                        t2 = args.length > 0 ? /* @__PURE__ */ jsxRuntime.jsx(ExplorerSection, {\n+                            title: \"Arguments\",\n+                            children: args.map(_temp$5)\n+                        }) : null;\n+                        $[1] = field.args;\n+                        $[2] = args;\n+                        $[3] = deprecatedArgs;\n+                        $[4] = t2;\n+                    } else {\n+                        args = $[2];\n+                        deprecatedArgs = $[3];\n+                        t2 = $[4];\n+                    }\n+                    let t3;\n+                    if ($[5] !== args.length || $[6] !== deprecatedArgs || $[7] !== showDeprecated) {\n+                        t3 = deprecatedArgs.length > 0 ? showDeprecated || args.length === 0 ? /* @__PURE__ */ jsxRuntime.jsx(ExplorerSection, {\n+                            title: \"Deprecated Arguments\",\n+                            children: deprecatedArgs.map(_temp2$2)\n+                        }) : /* @__PURE__ */ jsxRuntime.jsx(Button$1, {\n+                            type: \"button\",\n+                            onClick: handleShowDeprecated,\n+                            children: \"Show Deprecated Arguments\"\n+                        }) : null;\n+                        $[5] = args.length;\n+                        $[6] = deprecatedArgs;\n+                        $[7] = showDeprecated;\n+                        $[8] = t3;\n+                    } else {\n+                        t3 = $[8];\n+                    }\n+                    let t4;\n+                    if ($[9] !== t2 || $[10] !== t3) {\n+                        t4 = /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, {\n+                            children: [t2, t3]\n+                        });\n+                        $[9] = t2;\n+                        $[10] = t3;\n+                        $[11] = t4;\n+                    } else {\n+                        t4 = $[11];\n+                    }\n+                    return t4;\n+                }\n \n-                        // If we have more than 4 spaces, the indent is 1\n-                        // (the rest is just indented code block)\n-                        if (indentAfterMarker > 4) {\n-                            indentAfterMarker = 1;\n-                        }\n+                function _temp2$2(arg_0) {\n+                    return /* @__PURE__ */ jsxRuntime.jsx(Argument, {\n+                        arg: arg_0\n+                    }, arg_0.name);\n+                }\n \n-                        // \"  -  test\"\n-                        //  ^^^^^ - calculating total length of this thing\n-                        const indent = initial + indentAfterMarker;\n+                function _temp$5(arg) {\n+                    return /* @__PURE__ */ jsxRuntime.jsx(Argument, {\n+                        arg\n+                    }, arg.name);\n+                }\n \n-                        // Run subparser & write tokens\n-                        token = state.push('list_item_open', 'li', 1);\n-                        token.markup = String.fromCharCode(markerCharCode);\n-                        const itemLines = [nextLine, 0];\n-                        token.map = itemLines;\n-                        if (isOrdered) {\n-                            token.info = state.src.slice(start, posAfterMarker - 1);\n-                        }\n+                function Directives(t0) {\n+                    var _a, _b, _c;\n+                    const $ = reactCompilerRuntime.c(6);\n+                    const {\n+                        field\n+                    } = t0;\n+                    let t1;\n+                    if ($[0] !== ((_a = field.astNode) == null ? void 0 : _a.directives)) {\n+                        t1 = ((_b = field.astNode) == null ? void 0 : _b.directives) || [];\n+                        $[0] = (_c = field.astNode) == null ? void 0 : _c.directives;\n+                        $[1] = t1;\n+                    } else {\n+                        t1 = $[1];\n+                    }\n+                    const directives = t1;\n+                    if (!directives || directives.length === 0) {\n+                        return null;\n+                    }\n+                    let t2;\n+                    if ($[2] !== directives) {\n+                        t2 = directives.map(_temp3$2);\n+                        $[2] = directives;\n+                        $[3] = t2;\n+                    } else {\n+                        t2 = $[3];\n+                    }\n+                    let t3;\n+                    if ($[4] !== t2) {\n+                        t3 = /* @__PURE__ */ jsxRuntime.jsx(ExplorerSection, {\n+                            title: \"Directives\",\n+                            children: t2\n+                        });\n+                        $[4] = t2;\n+                        $[5] = t3;\n+                    } else {\n+                        t3 = $[5];\n+                    }\n+                    return t3;\n+                }\n \n-                        // change current state, then restore it after parser subcall\n-                        const oldTight = state.tight;\n-                        const oldTShift = state.tShift[nextLine];\n-                        const oldSCount = state.sCount[nextLine];\n+                function _temp3$2(directive) {\n+                    return /* @__PURE__ */ jsxRuntime.jsx(\"div\", {\n+                        children: /* @__PURE__ */ jsxRuntime.jsx(Directive, {\n+                            directive\n+                        })\n+                    }, directive.name.value);\n+                }\n \n-                        //  - example list\n-                        // ^ listIndent position will be here\n-                        //   ^ blkIndent position will be here\n-                        //\n-                        const oldListIndent = state.listIndent;\n-                        state.listIndent = state.blkIndent;\n-                        state.blkIndent = indent;\n-                        state.tight = true;\n-                        state.tShift[nextLine] = contentStart - state.bMarks[nextLine];\n-                        state.sCount[nextLine] = offset;\n-                        if (contentStart >= max && state.isEmpty(nextLine + 1)) {\n-                            // workaround for this case\n-                            // (list item is empty, list terminates before \"foo\"):\n-                            // ~~~~~~~~\n-                            //   -\n-                            //\n-                            //     foo\n-                            // ~~~~~~~~\n-                            state.line = Math.min(state.line + 2, endLine);\n+                function SchemaDocumentation(props) {\n+                    var _a, _b, _c, _d;\n+                    const $ = reactCompilerRuntime.c(39);\n+                    let t0;\n+                    if ($[0] !== props.schema) {\n+                        t0 = props.schema.getQueryType();\n+                        $[0] = props.schema;\n+                        $[1] = t0;\n+                    } else {\n+                        t0 = $[1];\n+                    }\n+                    const queryType = t0;\n+                    let t1;\n+                    if ($[2] !== props.schema) {\n+                        t1 = (_b = (_a = props.schema).getMutationType) == null ? void 0 : _b.call(_a);\n+                        $[2] = props.schema;\n+                        $[3] = t1;\n+                    } else {\n+                        t1 = $[3];\n+                    }\n+                    const mutationType = t1;\n+                    let t2;\n+                    if ($[4] !== props.schema) {\n+                        t2 = (_d = (_c = props.schema).getSubscriptionType) == null ? void 0 : _d.call(_c);\n+                        $[4] = props.schema;\n+                        $[5] = t2;\n+                    } else {\n+                        t2 = $[5];\n+                    }\n+                    const subscriptionType = t2;\n+                    let T0;\n+                    let t3;\n+                    let t4;\n+                    let t5;\n+                    let t6;\n+                    if ($[6] !== mutationType || $[7] !== props.schema || $[8] !== queryType || $[9] !== subscriptionType) {\n+                        const typeMap = props.schema.getTypeMap();\n+                        const t72 = queryType == null ? void 0 : queryType.name;\n+                        const t82 = mutationType == null ? void 0 : mutationType.name;\n+                        const t9 = subscriptionType == null ? void 0 : subscriptionType.name;\n+                        let t10;\n+                        if ($[15] !== t72 || $[16] !== t82 || $[17] !== t9) {\n+                            t10 = [t72, t82, t9];\n+                            $[15] = t72;\n+                            $[16] = t82;\n+                            $[17] = t9;\n+                            $[18] = t10;\n                         } else {\n-                            state.md.block.tokenize(state, nextLine, endLine, true);\n-                        }\n-\n-                        // If any of list item is tight, mark list as tight\n-                        if (!state.tight || prevEmptyEnd) {\n-                            tight = false;\n-                        }\n-                        // Item become loose if finish with empty line,\n-                        // but we should filter last element, because it means list finish\n-                        prevEmptyEnd = state.line - nextLine > 1 && state.isEmpty(state.line - 1);\n-                        state.blkIndent = state.listIndent;\n-                        state.listIndent = oldListIndent;\n-                        state.tShift[nextLine] = oldTShift;\n-                        state.sCount[nextLine] = oldSCount;\n-                        state.tight = oldTight;\n-                        token = state.push('list_item_close', 'li', -1);\n-                        token.markup = String.fromCharCode(markerCharCode);\n-                        nextLine = state.line;\n-                        itemLines[1] = nextLine;\n-                        if (nextLine >= endLine) {\n-                            break;\n-                        }\n-\n-                        //\n-                        // Try to check if list is terminated or continued.\n-                        //\n-                        if (state.sCount[nextLine] < state.blkIndent) {\n-                            break;\n+                            t10 = $[18];\n                         }\n-\n-                        // if it's indented more than 3 spaces, it should be a code block\n-                        if (state.sCount[nextLine] - state.blkIndent >= 4) {\n-                            break;\n+                        const ignoreTypesInAllSchema = t10;\n+                        const t11 = props.schema.description || \"A GraphQL schema provides a root type for each kind of operation.\";\n+                        if ($[19] !== t11) {\n+                            t5 = /* @__PURE__ */ jsxRuntime.jsx(MarkdownContent, {\n+                                type: \"description\",\n+                                children: t11\n+                            });\n+                            $[19] = t11;\n+                            $[20] = t5;\n+                        } else {\n+                            t5 = $[20];\n                         }\n-\n-                        // fail if terminating block found\n-                        let terminate = false;\n-                        for (let i = 0, l = terminatorRules.length; i < l; i++) {\n-                            if (terminatorRules[i](state, nextLine, endLine, true)) {\n-                                terminate = true;\n-                                break;\n-                            }\n+                        let t12;\n+                        if ($[21] !== queryType) {\n+                            t12 = queryType ? /* @__PURE__ */ jsxRuntime.jsxs(\"div\", {\n+                                children: [ /* @__PURE__ */ jsxRuntime.jsx(\"span\", {\n+                                    className: \"graphiql-doc-explorer-root-type\",\n+                                    children: \"query\"\n+                                }), \": \", /* @__PURE__ */ jsxRuntime.jsx(TypeLink, {\n+                                    type: queryType\n+                                })]\n+                            }) : null;\n+                            $[21] = queryType;\n+                            $[22] = t12;\n+                        } else {\n+                            t12 = $[22];\n                         }\n-                        if (terminate) {\n-                            break;\n+                        let t13;\n+                        if ($[23] !== mutationType) {\n+                            t13 = mutationType && /* @__PURE__ */ jsxRuntime.jsxs(\"div\", {\n+                                children: [ /* @__PURE__ */ jsxRuntime.jsx(\"span\", {\n+                                    className: \"graphiql-doc-explorer-root-type\",\n+                                    children: \"mutation\"\n+                                }), \": \", /* @__PURE__ */ jsxRuntime.jsx(TypeLink, {\n+                                    type: mutationType\n+                                })]\n+                            });\n+                            $[23] = mutationType;\n+                            $[24] = t13;\n+                        } else {\n+                            t13 = $[24];\n                         }\n-\n-                        // fail if list has another type\n-                        if (isOrdered) {\n-                            posAfterMarker = skipOrderedListMarker(state, nextLine);\n-                            if (posAfterMarker < 0) {\n-                                break;\n-                            }\n-                            start = state.bMarks[nextLine] + state.tShift[nextLine];\n+                        let t14;\n+                        if ($[25] !== subscriptionType) {\n+                            t14 = subscriptionType && /* @__PURE__ */ jsxRuntime.jsxs(\"div\", {\n+                                children: [ /* @__PURE__ */ jsxRuntime.jsx(\"span\", {\n+                                    className: \"graphiql-doc-explorer-root-type\",\n+                                    children: \"subscription\"\n+                                }), \": \", /* @__PURE__ */ jsxRuntime.jsx(TypeLink, {\n+                                    type: subscriptionType\n+                                })]\n+                            });\n+                            $[25] = subscriptionType;\n+                            $[26] = t14;\n                         } else {\n-                            posAfterMarker = skipBulletListMarker(state, nextLine);\n-                            if (posAfterMarker < 0) {\n-                                break;\n-                            }\n+                            t14 = $[26];\n                         }\n-                        if (markerCharCode !== state.src.charCodeAt(posAfterMarker - 1)) {\n-                            break;\n+                        if ($[27] !== t12 || $[28] !== t13 || $[29] !== t14) {\n+                            t6 = /* @__PURE__ */ jsxRuntime.jsxs(ExplorerSection, {\n+                                title: \"Root Types\",\n+                                children: [t12, t13, t14]\n+                            });\n+                            $[27] = t12;\n+                            $[28] = t13;\n+                            $[29] = t14;\n+                            $[30] = t6;\n+                        } else {\n+                            t6 = $[30];\n                         }\n-                    }\n-\n-                    // Finalize list\n-                    if (isOrdered) {\n-                        token = state.push('ordered_list_close', 'ol', -1);\n+                        T0 = ExplorerSection;\n+                        t3 = \"All Schema Types\";\n+                        t4 = typeMap && /* @__PURE__ */ jsxRuntime.jsx(\"div\", {\n+                            children: Object.values(typeMap).map(type => {\n+                                if (ignoreTypesInAllSchema.includes(type.name) || type.name.startsWith(\"__\")) {\n+                                    return null;\n+                                }\n+                                return /* @__PURE__ */ jsxRuntime.jsx(\"div\", {\n+                                    children: /* @__PURE__ */ jsxRuntime.jsx(TypeLink, {\n+                                        type\n+                                    })\n+                                }, type.name);\n+                            })\n+                        });\n+                        $[6] = mutationType;\n+                        $[7] = props.schema;\n+                        $[8] = queryType;\n+                        $[9] = subscriptionType;\n+                        $[10] = T0;\n+                        $[11] = t3;\n+                        $[12] = t4;\n+                        $[13] = t5;\n+                        $[14] = t6;\n                     } else {\n-                        token = state.push('bullet_list_close', 'ul', -1);\n+                        T0 = $[10];\n+                        t3 = $[11];\n+                        t4 = $[12];\n+                        t5 = $[13];\n+                        t6 = $[14];\n+                    }\n+                    let t7;\n+                    if ($[31] !== T0 || $[32] !== t3 || $[33] !== t4) {\n+                        t7 = /* @__PURE__ */ jsxRuntime.jsx(T0, {\n+                            title: t3,\n+                            children: t4\n+                        });\n+                        $[31] = T0;\n+                        $[32] = t3;\n+                        $[33] = t4;\n+                        $[34] = t7;\n+                    } else {\n+                        t7 = $[34];\n                     }\n-                    token.markup = String.fromCharCode(markerCharCode);\n-                    listLines[1] = nextLine;\n-                    state.line = nextLine;\n-                    state.parentType = oldParentType;\n-\n-                    // mark paragraphs tight if needed\n-                    if (tight) {\n-                        markTightParagraphs(state, listTokIdx);\n+                    let t8;\n+                    if ($[35] !== t5 || $[36] !== t6 || $[37] !== t7) {\n+                        t8 = /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, {\n+                            children: [t5, t6, t7]\n+                        });\n+                        $[35] = t5;\n+                        $[36] = t6;\n+                        $[37] = t7;\n+                        $[38] = t8;\n+                    } else {\n+                        t8 = $[38];\n                     }\n-                    return true;\n+                    return t8;\n                 }\n \n-                function reference(state, startLine, _endLine, silent) {\n-                    let pos = state.bMarks[startLine] + state.tShift[startLine];\n-                    let max = state.eMarks[startLine];\n-                    let nextLine = startLine + 1;\n-\n-                    // if it's indented more than 3 spaces, it should be a code block\n-                    if (state.sCount[startLine] - state.blkIndent >= 4) {\n-                        return false;\n-                    }\n-                    if (state.src.charCodeAt(pos) !== 0x5B /* [ */ ) {\n-                        return false;\n-                    }\n-\n-                    function getNextLine(nextLine) {\n-                        const endLine = state.lineMax;\n-                        if (nextLine >= endLine || state.isEmpty(nextLine)) {\n-                            // empty line or end of input\n-                            return null;\n-                        }\n-                        let isContinuation = false;\n-\n-                        // this would be a code block normally, but after paragraph\n-                        // it's considered a lazy continuation regardless of what's there\n-                        if (state.sCount[nextLine] - state.blkIndent > 3) {\n-                            isContinuation = true;\n+                function debounce(duration, fn) {\n+                    let timeout;\n+                    return function(...args) {\n+                        if (timeout) {\n+                            window.clearTimeout(timeout);\n                         }\n+                        timeout = window.setTimeout(() => {\n+                            timeout = null;\n+                            fn(...args);\n+                        }, duration);\n+                    };\n+                }\n \n-                        // quirk for blockquotes, this line should already be checked by that rule\n-                        if (state.sCount[nextLine] < 0) {\n-                            isContinuation = true;\n-                        }\n-                        if (!isContinuation) {\n-                            const terminatorRules = state.md.block.ruler.getRules('reference');\n-                            const oldParentType = state.parentType;\n-                            state.parentType = 'reference';\n+                function Search() {\n+                    \"use no memo\";\n \n-                            // Some tags can terminate paragraph without empty line.\n-                            let terminate = false;\n-                            for (let i = 0, l = terminatorRules.length; i < l; i++) {\n-                                if (terminatorRules[i](state, nextLine, endLine, true)) {\n-                                    terminate = true;\n-                                    break;\n-                                }\n-                            }\n-                            state.parentType = oldParentType;\n-                            if (terminate) {\n-                                // terminated by another block\n-                                return null;\n+                    const {\n+                        explorerNavStack,\n+                        push\n+                    } = useExplorerContext({\n+                        nonNull: true,\n+                        caller: Search\n+                    });\n+                    const inputRef = React.useRef(null);\n+                    const getSearchResults = useSearchResults();\n+                    const [searchValue, setSearchValue] = React.useState(\"\");\n+                    const [results, setResults] = React.useState(getSearchResults(searchValue));\n+                    const debouncedGetSearchResults = React.useMemo(() => debounce(200, search => {\n+                        setResults(getSearchResults(search));\n+                    }), [getSearchResults]);\n+                    React.useEffect(() => {\n+                        debouncedGetSearchResults(searchValue);\n+                    }, [debouncedGetSearchResults, searchValue]);\n+                    React.useEffect(() => {\n+                        function handleKeyDown(event) {\n+                            var _a;\n+                            if (event.metaKey && event.key === \"k\") {\n+                                (_a = inputRef.current) == null ? void 0 : _a.focus();\n                             }\n                         }\n-                        const pos = state.bMarks[nextLine] + state.tShift[nextLine];\n-                        const max = state.eMarks[nextLine];\n+                        window.addEventListener(\"keydown\", handleKeyDown);\n+                        return () => window.removeEventListener(\"keydown\", handleKeyDown);\n+                    }, []);\n+                    const navItem = explorerNavStack.at(-1);\n+                    const onSelect = React.useCallback(def => {\n+                        push(\"field\" in def ? {\n+                            name: def.field.name,\n+                            def: def.field\n+                        } : {\n+                            name: def.type.name,\n+                            def: def.type\n+                        });\n+                    }, [push]);\n+                    const isFocused = React.useRef(false);\n+                    const handleFocus = React.useCallback(e => {\n+                        isFocused.current = e.type === \"focus\";\n+                    }, []);\n+                    const shouldSearchBoxAppear = explorerNavStack.length === 1 || graphql.isObjectType(navItem.def) || graphql.isInterfaceType(navItem.def) || graphql.isInputObjectType(navItem.def);\n+                    if (!shouldSearchBoxAppear) {\n+                        return null;\n+                    }\n+                    return /* @__PURE__ */ jsxRuntime.jsxs(react.Combobox, {\n+                        as: \"div\",\n+                        className: \"graphiql-doc-explorer-search\",\n+                        onChange: onSelect,\n+                        \"data-state\": isFocused ? void 0 : \"idle\",\n+                        \"aria-label\": `Search ${navItem.name}...`,\n+                        children: [ /* @__PURE__ */ jsxRuntime.jsxs(\"div\", {\n+                            className: \"graphiql-doc-explorer-search-input\",\n+                            onClick: () => {\n+                                var _a;\n+                                (_a = inputRef.current) == null ? void 0 : _a.focus();\n+                            },\n+                            children: [ /* @__PURE__ */ jsxRuntime.jsx(MagnifyingGlassIcon, {}), /* @__PURE__ */ jsxRuntime.jsx(react.Combobox.Input, {\n+                                autoComplete: \"off\",\n+                                onFocus: handleFocus,\n+                                onBlur: handleFocus,\n+                                onChange: event_0 => setSearchValue(event_0.target.value),\n+                                placeholder: `${isMacOs ? \"\u2318\" : \"Ctrl\"} K`,\n+                                ref: inputRef,\n+                                value: searchValue,\n+                                \"data-cy\": \"doc-explorer-input\"\n+                            })]\n+                        }), isFocused.current && /* @__PURE__ */ jsxRuntime.jsxs(react.Combobox.Options, {\n+                            \"data-cy\": \"doc-explorer-list\",\n+                            children: [results.within.length + results.types.length + results.fields.length === 0 ? /* @__PURE__ */ jsxRuntime.jsx(\"li\", {\n+                                className: \"graphiql-doc-explorer-search-empty\",\n+                                children: \"No results found\"\n+                            }) : results.within.map((result, i) => /* @__PURE__ */ jsxRuntime.jsx(react.Combobox.Option, {\n+                                value: result,\n+                                \"data-cy\": \"doc-explorer-option\",\n+                                children: /* @__PURE__ */ jsxRuntime.jsx(Field$1, {\n+                                    field: result.field,\n+                                    argument: result.argument\n+                                })\n+                            }, `within-${i}`)), results.within.length > 0 && results.types.length + results.fields.length > 0 ? /* @__PURE__ */ jsxRuntime.jsx(\"div\", {\n+                                className: \"graphiql-doc-explorer-search-divider\",\n+                                children: \"Other results\"\n+                            }) : null, results.types.map((result_0, i_0) => /* @__PURE__ */ jsxRuntime.jsx(react.Combobox.Option, {\n+                                value: result_0,\n+                                \"data-cy\": \"doc-explorer-option\",\n+                                children: /* @__PURE__ */ jsxRuntime.jsx(Type, {\n+                                    type: result_0.type\n+                                })\n+                            }, `type-${i_0}`)), results.fields.map((result_1, i_1) => /* @__PURE__ */ jsxRuntime.jsxs(react.Combobox.Option, {\n+                                value: result_1,\n+                                \"data-cy\": \"doc-explorer-option\",\n+                                children: [ /* @__PURE__ */ jsxRuntime.jsx(Type, {\n+                                    type: result_1.type\n+                                }), \".\", /* @__PURE__ */ jsxRuntime.jsx(Field$1, {\n+                                    field: result_1.field,\n+                                    argument: result_1.argument\n+                                })]\n+                            }, `field-${i_1}`))]\n+                        })]\n+                    });\n+                }\n+                const _useSearchResults = useSearchResults;\n \n-                        // max + 1 explicitly includes the newline\n-                        return state.src.slice(pos, max + 1);\n+                function useSearchResults(caller) {\n+                    const $ = reactCompilerRuntime.c(9);\n+                    const t0 = caller || _useSearchResults;\n+                    let t1;\n+                    if ($[0] !== t0) {\n+                        t1 = {\n+                            nonNull: true,\n+                            caller: t0\n+                        };\n+                        $[0] = t0;\n+                        $[1] = t1;\n+                    } else {\n+                        t1 = $[1];\n                     }\n-                    let str = state.src.slice(pos, max + 1);\n-                    max = str.length;\n-                    let labelEnd = -1;\n-                    for (pos = 1; pos < max; pos++) {\n-                        const ch = str.charCodeAt(pos);\n-                        if (ch === 0x5B /* [ */ ) {\n-                            return false;\n-                        } else if (ch === 0x5D /* ] */ ) {\n-                            labelEnd = pos;\n-                            break;\n-                        } else if (ch === 0x0A /* \\n */ ) {\n-                            const lineContent = getNextLine(nextLine);\n-                            if (lineContent !== null) {\n-                                str += lineContent;\n-                                max = str.length;\n-                                nextLine++;\n+                    const {\n+                        explorerNavStack\n+                    } = useExplorerContext(t1);\n+                    const t2 = caller || _useSearchResults;\n+                    let t3;\n+                    if ($[2] !== t2) {\n+                        t3 = {\n+                            nonNull: true,\n+                            caller: t2\n+                        };\n+                        $[2] = t2;\n+                        $[3] = t3;\n+                    } else {\n+                        t3 = $[3];\n+                    }\n+                    const {\n+                        schema\n+                    } = useSchemaContext(t3);\n+                    let t4;\n+                    if ($[4] !== explorerNavStack) {\n+                        t4 = explorerNavStack.at(-1);\n+                        $[4] = explorerNavStack;\n+                        $[5] = t4;\n+                    } else {\n+                        t4 = $[5];\n+                    }\n+                    const navItem = t4;\n+                    let t5;\n+                    if ($[6] !== navItem || $[7] !== schema) {\n+                        t5 = searchValue => {\n+                            const matches = {\n+                                within: [],\n+                                types: [],\n+                                fields: []\n+                            };\n+                            if (!schema) {\n+                                return matches;\n                             }\n-                        } else if (ch === 0x5C /* \\ */ ) {\n-                            pos++;\n-                            if (pos < max && str.charCodeAt(pos) === 0x0A) {\n-                                const lineContent = getNextLine(nextLine);\n-                                if (lineContent !== null) {\n-                                    str += lineContent;\n-                                    max = str.length;\n-                                    nextLine++;\n+                            const withinType = navItem.def;\n+                            const typeMap = schema.getTypeMap();\n+                            let typeNames = Object.keys(typeMap);\n+                            if (withinType) {\n+                                typeNames = typeNames.filter(n => n !== withinType.name);\n+                                typeNames.unshift(withinType.name);\n+                            }\n+                            for (const typeName of typeNames) {\n+                                if (matches.within.length + matches.types.length + matches.fields.length >= 100) {\n+                                    break;\n+                                }\n+                                const type = typeMap[typeName];\n+                                if (withinType !== type && isMatch(typeName, searchValue)) {\n+                                    matches.types.push({\n+                                        type\n+                                    });\n+                                }\n+                                if (!graphql.isObjectType(type) && !graphql.isInterfaceType(type) && !graphql.isInputObjectType(type)) {\n+                                    continue;\n+                                }\n+                                const fields = type.getFields();\n+                                for (const fieldName in fields) {\n+                                    const field = fields[fieldName];\n+                                    let matchingArgs;\n+                                    if (!isMatch(fieldName, searchValue)) {\n+                                        if (\"args\" in field) {\n+                                            matchingArgs = field.args.filter(arg => isMatch(arg.name, searchValue));\n+                                            if (matchingArgs.length === 0) {\n+                                                continue;\n+                                            }\n+                                        } else {\n+                                            continue;\n+                                        }\n+                                    }\n+                                    matches[withinType === type ? \"within\" : \"fields\"].push(...(matchingArgs ? matchingArgs.map(argument => ({\n+                                        type,\n+                                        field,\n+                                        argument\n+                                    })) : [{\n+                                        type,\n+                                        field\n+                                    }]));\n                                 }\n                             }\n-                        }\n+                            return matches;\n+                        };\n+                        $[6] = navItem;\n+                        $[7] = schema;\n+                        $[8] = t5;\n+                    } else {\n+                        t5 = $[8];\n                     }\n-                    if (labelEnd < 0 || str.charCodeAt(labelEnd + 1) !== 0x3A /* : */ ) {\n-                        return false;\n+                    return t5;\n+                }\n+\n+                function isMatch(sourceText, searchValue) {\n+                    try {\n+                        const escaped = searchValue.replaceAll(/[^_0-9A-Za-z]/g, ch => \"\\\\\" + ch);\n+                        return sourceText.search(new RegExp(escaped, \"i\")) !== -1;\n+                    } catch {\n+                        return sourceText.toLowerCase().includes(searchValue.toLowerCase());\n                     }\n+                }\n \n-                    // [label]:   destination   'title'\n-                    //         ^^^ skip optional whitespace here\n-                    for (pos = labelEnd + 2; pos < max; pos++) {\n-                        const ch = str.charCodeAt(pos);\n-                        if (ch === 0x0A) {\n-                            const lineContent = getNextLine(nextLine);\n-                            if (lineContent !== null) {\n-                                str += lineContent;\n-                                max = str.length;\n-                                nextLine++;\n-                            }\n-                        } else if (isSpace(ch));\n-                        else {\n-                            break;\n-                        }\n+                function Type(props) {\n+                    const $ = reactCompilerRuntime.c(2);\n+                    let t0;\n+                    if ($[0] !== props.type.name) {\n+                        t0 = /* @__PURE__ */ jsxRuntime.jsx(\"span\", {\n+                            className: \"graphiql-doc-explorer-search-type\",\n+                            children: props.type.name\n+                        });\n+                        $[0] = props.type.name;\n+                        $[1] = t0;\n+                    } else {\n+                        t0 = $[1];\n                     }\n+                    return t0;\n+                }\n \n-                    // [label]:   destination   'title'\n-                    //            ^^^^^^^^^^^ parse this\n-                    const destRes = state.md.helpers.parseLinkDestination(str, pos, max);\n-                    if (!destRes.ok) {\n-                        return false;\n+                function Field$1(t0) {\n+                    const $ = reactCompilerRuntime.c(7);\n+                    const {\n+                        field,\n+                        argument\n+                    } = t0;\n+                    let t1;\n+                    if ($[0] !== field.name) {\n+                        t1 = /* @__PURE__ */ jsxRuntime.jsx(\"span\", {\n+                            className: \"graphiql-doc-explorer-search-field\",\n+                            children: field.name\n+                        });\n+                        $[0] = field.name;\n+                        $[1] = t1;\n+                    } else {\n+                        t1 = $[1];\n                     }\n-                    const href = state.md.normalizeLink(destRes.str);\n-                    if (!state.md.validateLink(href)) {\n-                        return false;\n+                    let t2;\n+                    if ($[2] !== argument) {\n+                        t2 = argument ? /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, {\n+                            children: [\"(\", /* @__PURE__ */ jsxRuntime.jsx(\"span\", {\n+                                className: \"graphiql-doc-explorer-search-argument\",\n+                                children: argument.name\n+                            }), \":\", \" \", renderType(argument.type, _temp$4), \")\"]\n+                        }) : null;\n+                        $[2] = argument;\n+                        $[3] = t2;\n+                    } else {\n+                        t2 = $[3];\n                     }\n-                    pos = destRes.pos;\n+                    let t3;\n+                    if ($[4] !== t1 || $[5] !== t2) {\n+                        t3 = /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, {\n+                            children: [t1, t2]\n+                        });\n+                        $[4] = t1;\n+                        $[5] = t2;\n+                        $[6] = t3;\n+                    } else {\n+                        t3 = $[6];\n+                    }\n+                    return t3;\n+                }\n \n-                    // save cursor state, we could require to rollback later\n-                    const destEndPos = pos;\n-                    const destEndLineNo = nextLine;\n+                function _temp$4(namedType) {\n+                    return /* @__PURE__ */ jsxRuntime.jsx(Type, {\n+                        type: namedType\n+                    });\n+                }\n \n-                    // [label]:   destination   'title'\n-                    //                       ^^^ skipping those spaces\n-                    const start = pos;\n-                    for (; pos < max; pos++) {\n-                        const ch = str.charCodeAt(pos);\n-                        if (ch === 0x0A) {\n-                            const lineContent = getNextLine(nextLine);\n-                            if (lineContent !== null) {\n-                                str += lineContent;\n-                                max = str.length;\n-                                nextLine++;\n-                            }\n-                        } else if (isSpace(ch));\n-                        else {\n-                            break;\n-                        }\n+                function FieldLink(props) {\n+                    const $ = reactCompilerRuntime.c(7);\n+                    let t0;\n+                    if ($[0] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t0 = {\n+                            nonNull: true\n+                        };\n+                        $[0] = t0;\n+                    } else {\n+                        t0 = $[0];\n                     }\n-\n-                    // [label]:   destination   'title'\n-                    //                          ^^^^^^^ parse this\n-                    let titleRes = state.md.helpers.parseLinkTitle(str, pos, max);\n-                    while (titleRes.can_continue) {\n-                        const lineContent = getNextLine(nextLine);\n-                        if (lineContent === null) break;\n-                        str += lineContent;\n-                        pos = max;\n-                        max = str.length;\n-                        nextLine++;\n-                        titleRes = state.md.helpers.parseLinkTitle(str, pos, max, titleRes);\n+                    const {\n+                        push\n+                    } = useExplorerContext(t0);\n+                    let t1;\n+                    if ($[1] !== props.field || $[2] !== push) {\n+                        t1 = event => {\n+                            event.preventDefault();\n+                            push({\n+                                name: props.field.name,\n+                                def: props.field\n+                            });\n+                        };\n+                        $[1] = props.field;\n+                        $[2] = push;\n+                        $[3] = t1;\n+                    } else {\n+                        t1 = $[3];\n                     }\n-                    let title;\n-                    if (pos < max && start !== pos && titleRes.ok) {\n-                        title = titleRes.str;\n-                        pos = titleRes.pos;\n+                    let t2;\n+                    if ($[4] !== props.field.name || $[5] !== t1) {\n+                        t2 = /* @__PURE__ */ jsxRuntime.jsx(\"a\", {\n+                            className: \"graphiql-doc-explorer-field-name\",\n+                            onClick: t1,\n+                            href: \"#\",\n+                            children: props.field.name\n+                        });\n+                        $[4] = props.field.name;\n+                        $[5] = t1;\n+                        $[6] = t2;\n                     } else {\n-                        title = '';\n-                        pos = destEndPos;\n-                        nextLine = destEndLineNo;\n+                        t2 = $[6];\n                     }\n+                    return t2;\n+                }\n \n-                    // skip trailing spaces until the rest of the line\n-                    while (pos < max) {\n-                        const ch = str.charCodeAt(pos);\n-                        if (!isSpace(ch)) {\n-                            break;\n-                        }\n-                        pos++;\n+                function TypeDocumentation(props) {\n+                    const $ = reactCompilerRuntime.c(2);\n+                    let t0;\n+                    if ($[0] !== props.type) {\n+                        t0 = graphql.isNamedType(props.type) ? /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, {\n+                            children: [props.type.description ? /* @__PURE__ */ jsxRuntime.jsx(MarkdownContent, {\n+                                type: \"description\",\n+                                children: props.type.description\n+                            }) : null, /* @__PURE__ */ jsxRuntime.jsx(ImplementsInterfaces, {\n+                                type: props.type\n+                            }), /* @__PURE__ */ jsxRuntime.jsx(Fields, {\n+                                type: props.type\n+                            }), /* @__PURE__ */ jsxRuntime.jsx(EnumValues, {\n+                                type: props.type\n+                            }), /* @__PURE__ */ jsxRuntime.jsx(PossibleTypes, {\n+                                type: props.type\n+                            })]\n+                        }) : null;\n+                        $[0] = props.type;\n+                        $[1] = t0;\n+                    } else {\n+                        t0 = $[1];\n                     }\n-                    if (pos < max && str.charCodeAt(pos) !== 0x0A) {\n-                        if (title) {\n-                            // garbage at the end of the line after title,\n-                            // but it could still be a valid reference if we roll back\n-                            title = '';\n-                            pos = destEndPos;\n-                            nextLine = destEndLineNo;\n-                            while (pos < max) {\n-                                const ch = str.charCodeAt(pos);\n-                                if (!isSpace(ch)) {\n-                                    break;\n-                                }\n-                                pos++;\n-                            }\n-                        }\n+                    return t0;\n+                }\n+\n+                function ImplementsInterfaces(t0) {\n+                    const $ = reactCompilerRuntime.c(5);\n+                    const {\n+                        type\n+                    } = t0;\n+                    if (!graphql.isObjectType(type)) {\n+                        return null;\n                     }\n-                    if (pos < max && str.charCodeAt(pos) !== 0x0A) {\n-                        // garbage at the end of the line\n-                        return false;\n+                    let t1;\n+                    if ($[0] !== type) {\n+                        t1 = type.getInterfaces();\n+                        $[0] = type;\n+                        $[1] = t1;\n+                    } else {\n+                        t1 = $[1];\n                     }\n-                    const label = normalizeReference(str.slice(1, labelEnd));\n-                    if (!label) {\n-                        // CommonMark 0.20 disallows empty labels\n-                        return false;\n+                    const interfaces = t1;\n+                    let t2;\n+                    if ($[2] !== interfaces.length || $[3] !== type) {\n+                        t2 = interfaces.length > 0 ? /* @__PURE__ */ jsxRuntime.jsx(ExplorerSection, {\n+                            title: \"Implements\",\n+                            children: type.getInterfaces().map(_temp$3)\n+                        }) : null;\n+                        $[2] = interfaces.length;\n+                        $[3] = type;\n+                        $[4] = t2;\n+                    } else {\n+                        t2 = $[4];\n                     }\n+                    return t2;\n+                }\n \n-                    // Reference can not terminate anything. This check is for safety only.\n-                    /* istanbul ignore if */\n-                    if (silent) {\n-                        return true;\n+                function _temp$3(implementedInterface) {\n+                    return /* @__PURE__ */ jsxRuntime.jsx(\"div\", {\n+                        children: /* @__PURE__ */ jsxRuntime.jsx(TypeLink, {\n+                            type: implementedInterface\n+                        })\n+                    }, implementedInterface.name);\n+                }\n+\n+                function Fields(t0) {\n+                    const $ = reactCompilerRuntime.c(12);\n+                    const {\n+                        type\n+                    } = t0;\n+                    const [showDeprecated, setShowDeprecated] = React.useState(false);\n+                    let t1;\n+                    if ($[0] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t1 = () => {\n+                            setShowDeprecated(true);\n+                        };\n+                        $[0] = t1;\n+                    } else {\n+                        t1 = $[0];\n                     }\n-                    if (typeof state.env.references === 'undefined') {\n-                        state.env.references = {};\n+                    const handleShowDeprecated = t1;\n+                    if (!graphql.isObjectType(type) && !graphql.isInterfaceType(type) && !graphql.isInputObjectType(type)) {\n+                        return null;\n                     }\n-                    if (typeof state.env.references[label] === 'undefined') {\n-                        state.env.references[label] = {\n-                            title,\n-                            href\n-                        };\n+                    let deprecatedFields;\n+                    let fields;\n+                    let t2;\n+                    if ($[1] !== type) {\n+                        const fieldMap = type.getFields();\n+                        fields = [];\n+                        deprecatedFields = [];\n+                        for (const field of Object.keys(fieldMap).map(name => fieldMap[name])) {\n+                            if (field.deprecationReason) {\n+                                deprecatedFields.push(field);\n+                            } else {\n+                                fields.push(field);\n+                            }\n+                        }\n+                        t2 = fields.length > 0 ? /* @__PURE__ */ jsxRuntime.jsx(ExplorerSection, {\n+                            title: \"Fields\",\n+                            children: fields.map(_temp2$1)\n+                        }) : null;\n+                        $[1] = type;\n+                        $[2] = deprecatedFields;\n+                        $[3] = fields;\n+                        $[4] = t2;\n+                    } else {\n+                        deprecatedFields = $[2];\n+                        fields = $[3];\n+                        t2 = $[4];\n+                    }\n+                    let t3;\n+                    if ($[5] !== deprecatedFields || $[6] !== fields.length || $[7] !== showDeprecated) {\n+                        t3 = deprecatedFields.length > 0 ? showDeprecated || fields.length === 0 ? /* @__PURE__ */ jsxRuntime.jsx(ExplorerSection, {\n+                            title: \"Deprecated Fields\",\n+                            children: deprecatedFields.map(_temp3$1)\n+                        }) : /* @__PURE__ */ jsxRuntime.jsx(Button$1, {\n+                            type: \"button\",\n+                            onClick: handleShowDeprecated,\n+                            children: \"Show Deprecated Fields\"\n+                        }) : null;\n+                        $[5] = deprecatedFields;\n+                        $[6] = fields.length;\n+                        $[7] = showDeprecated;\n+                        $[8] = t3;\n+                    } else {\n+                        t3 = $[8];\n                     }\n-                    state.line = nextLine;\n-                    return true;\n+                    let t4;\n+                    if ($[9] !== t2 || $[10] !== t3) {\n+                        t4 = /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, {\n+                            children: [t2, t3]\n+                        });\n+                        $[9] = t2;\n+                        $[10] = t3;\n+                        $[11] = t4;\n+                    } else {\n+                        t4 = $[11];\n+                    }\n+                    return t4;\n                 }\n \n-                // List of valid html blocks names, according to commonmark spec\n-                // https://spec.commonmark.org/0.30/#html-blocks\n-\n-                var block_names = ['address', 'article', 'aside', 'base', 'basefont', 'blockquote', 'body', 'caption', 'center', 'col', 'colgroup', 'dd', 'details', 'dialog', 'dir', 'div', 'dl', 'dt', 'fieldset', 'figcaption', 'figure', 'footer', 'form', 'frame', 'frameset', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'head', 'header', 'hr', 'html', 'iframe', 'legend', 'li', 'link', 'main', 'menu', 'menuitem', 'nav', 'noframes', 'ol', 'optgroup', 'option', 'p', 'param', 'search', 'section', 'summary', 'table', 'tbody', 'td', 'tfoot', 'th', 'thead', 'title', 'tr', 'track', 'ul'];\n-\n-                // Regexps to match html elements\n-\n-                const attr_name = '[a-zA-Z_:][a-zA-Z0-9:._-]*';\n-                const unquoted = '[^\"\\'=<>`\\\\x00-\\\\x20]+';\n-                const single_quoted = \"'[^']*'\";\n-                const double_quoted = '\"[^\"]*\"';\n-                const attr_value = '(?:' + unquoted + '|' + single_quoted + '|' + double_quoted + ')';\n-                const attribute = '(?:\\\\s+' + attr_name + '(?:\\\\s*=\\\\s*' + attr_value + ')?)';\n-                const open_tag = '<[A-Za-z][A-Za-z0-9\\\\-]*' + attribute + '*\\\\s*\\\\/?>';\n-                const close_tag = '<\\\\/[A-Za-z][A-Za-z0-9\\\\-]*\\\\s*>';\n-                const comment = '<!---?>|<!--(?:[^-]|-[^-]|--[^>])*-->';\n-                const processing = '<[?][\\\\s\\\\S]*?[?]>';\n-                const declaration = '<![A-Za-z][^>]*>';\n-                const cdata = '<!\\\\[CDATA\\\\[[\\\\s\\\\S]*?\\\\]\\\\]>';\n-                const HTML_TAG_RE = new RegExp('^(?:' + open_tag + '|' + close_tag + '|' + comment + '|' + processing + '|' + declaration + '|' + cdata + ')');\n-                const HTML_OPEN_CLOSE_TAG_RE = new RegExp('^(?:' + open_tag + '|' + close_tag + ')');\n-\n-                // HTML block\n-\n-                // An array of opening and corresponding closing sequences for html tags,\n-                // last argument defines whether it can terminate a paragraph or not\n-                //\n-                const HTML_SEQUENCES = [\n-                    [/^<(script|pre|style|textarea)(?=(\\s|>|$))/i, /<\\/(script|pre|style|textarea)>/i, true],\n-                    [/^<!--/, /-->/, true],\n-                    [/^<\\?/, /\\?>/, true],\n-                    [/^<![A-Z]/, />/, true],\n-                    [/^<!\\[CDATA\\[/, /\\]\\]>/, true],\n-                    [new RegExp('^</?(' + block_names.join('|') + ')(?=(\\\\s|/?>|$))', 'i'), /^$/, true],\n-                    [new RegExp(HTML_OPEN_CLOSE_TAG_RE.source + '\\\\s*$'), /^$/, false]\n-                ];\n+                function _temp3$1(field_1) {\n+                    return /* @__PURE__ */ jsxRuntime.jsx(Field, {\n+                        field: field_1\n+                    }, field_1.name);\n+                }\n \n-                function html_block(state, startLine, endLine, silent) {\n-                    let pos = state.bMarks[startLine] + state.tShift[startLine];\n-                    let max = state.eMarks[startLine];\n+                function _temp2$1(field_0) {\n+                    return /* @__PURE__ */ jsxRuntime.jsx(Field, {\n+                        field: field_0\n+                    }, field_0.name);\n+                }\n \n-                    // if it's indented more than 3 spaces, it should be a code block\n-                    if (state.sCount[startLine] - state.blkIndent >= 4) {\n-                        return false;\n+                function Field(t0) {\n+                    const $ = reactCompilerRuntime.c(22);\n+                    const {\n+                        field\n+                    } = t0;\n+                    let t1;\n+                    let t2;\n+                    let t3;\n+                    if ($[0] !== field) {\n+                        const args = \"args\" in field ? field.args.filter(_temp4$1) : [];\n+                        t3 = \"graphiql-doc-explorer-item\";\n+                        t1 = /* @__PURE__ */ jsxRuntime.jsx(FieldLink, {\n+                            field\n+                        });\n+                        t2 = args.length > 0 ? /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, {\n+                            children: [\"(\", /* @__PURE__ */ jsxRuntime.jsx(\"span\", {\n+                                children: args.map(arg_0 => args.length === 1 ? /* @__PURE__ */ jsxRuntime.jsx(Argument, {\n+                                    arg: arg_0,\n+                                    inline: true\n+                                }, arg_0.name) : /* @__PURE__ */ jsxRuntime.jsx(\"div\", {\n+                                    className: \"graphiql-doc-explorer-argument-multiple\",\n+                                    children: /* @__PURE__ */ jsxRuntime.jsx(Argument, {\n+                                        arg: arg_0,\n+                                        inline: true\n+                                    })\n+                                }, arg_0.name))\n+                            }), \")\"]\n+                        }) : null;\n+                        $[0] = field;\n+                        $[1] = t1;\n+                        $[2] = t2;\n+                        $[3] = t3;\n+                    } else {\n+                        t1 = $[1];\n+                        t2 = $[2];\n+                        t3 = $[3];\n+                    }\n+                    let t4;\n+                    if ($[4] !== field.type) {\n+                        t4 = /* @__PURE__ */ jsxRuntime.jsx(TypeLink, {\n+                            type: field.type\n+                        });\n+                        $[4] = field.type;\n+                        $[5] = t4;\n+                    } else {\n+                        t4 = $[5];\n                     }\n-                    if (!state.md.options.html) {\n-                        return false;\n+                    let t5;\n+                    if ($[6] !== field) {\n+                        t5 = /* @__PURE__ */ jsxRuntime.jsx(DefaultValue, {\n+                            field\n+                        });\n+                        $[6] = field;\n+                        $[7] = t5;\n+                    } else {\n+                        t5 = $[7];\n                     }\n-                    if (state.src.charCodeAt(pos) !== 0x3C /* < */ ) {\n-                        return false;\n+                    let t6;\n+                    if ($[8] !== t1 || $[9] !== t2 || $[10] !== t4 || $[11] !== t5) {\n+                        t6 = /* @__PURE__ */ jsxRuntime.jsxs(\"div\", {\n+                            children: [t1, t2, \": \", t4, t5]\n+                        });\n+                        $[8] = t1;\n+                        $[9] = t2;\n+                        $[10] = t4;\n+                        $[11] = t5;\n+                        $[12] = t6;\n+                    } else {\n+                        t6 = $[12];\n                     }\n-                    let lineText = state.src.slice(pos, max);\n-                    let i = 0;\n-                    for (; i < HTML_SEQUENCES.length; i++) {\n-                        if (HTML_SEQUENCES[i][0].test(lineText)) {\n-                            break;\n-                        }\n+                    let t7;\n+                    if ($[13] !== field.description) {\n+                        t7 = field.description ? /* @__PURE__ */ jsxRuntime.jsx(MarkdownContent, {\n+                            type: \"description\",\n+                            onlyShowFirstChild: true,\n+                            children: field.description\n+                        }) : null;\n+                        $[13] = field.description;\n+                        $[14] = t7;\n+                    } else {\n+                        t7 = $[14];\n                     }\n-                    if (i === HTML_SEQUENCES.length) {\n-                        return false;\n+                    let t8;\n+                    if ($[15] !== field.deprecationReason) {\n+                        t8 = /* @__PURE__ */ jsxRuntime.jsx(DeprecationReason, {\n+                            children: field.deprecationReason\n+                        });\n+                        $[15] = field.deprecationReason;\n+                        $[16] = t8;\n+                    } else {\n+                        t8 = $[16];\n                     }\n-                    if (silent) {\n-                        // true if this sequence can be a terminator, false otherwise\n-                        return HTML_SEQUENCES[i][2];\n+                    let t9;\n+                    if ($[17] !== t3 || $[18] !== t6 || $[19] !== t7 || $[20] !== t8) {\n+                        t9 = /* @__PURE__ */ jsxRuntime.jsxs(\"div\", {\n+                            className: t3,\n+                            children: [t6, t7, t8]\n+                        });\n+                        $[17] = t3;\n+                        $[18] = t6;\n+                        $[19] = t7;\n+                        $[20] = t8;\n+                        $[21] = t9;\n+                    } else {\n+                        t9 = $[21];\n                     }\n-                    let nextLine = startLine + 1;\n+                    return t9;\n+                }\n \n-                    // If we are here - we detected HTML block.\n-                    // Let's roll down till block end.\n-                    if (!HTML_SEQUENCES[i][1].test(lineText)) {\n-                        for (; nextLine < endLine; nextLine++) {\n-                            if (state.sCount[nextLine] < state.blkIndent) {\n-                                break;\n-                            }\n-                            pos = state.bMarks[nextLine] + state.tShift[nextLine];\n-                            max = state.eMarks[nextLine];\n-                            lineText = state.src.slice(pos, max);\n-                            if (HTML_SEQUENCES[i][1].test(lineText)) {\n-                                if (lineText.length !== 0) {\n-                                    nextLine++;\n-                                }\n-                                break;\n+                function _temp4$1(arg) {\n+                    return !arg.deprecationReason;\n+                }\n+\n+                function EnumValues(t0) {\n+                    const $ = reactCompilerRuntime.c(12);\n+                    const {\n+                        type\n+                    } = t0;\n+                    const [showDeprecated, setShowDeprecated] = React.useState(false);\n+                    let t1;\n+                    if ($[0] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t1 = () => {\n+                            setShowDeprecated(true);\n+                        };\n+                        $[0] = t1;\n+                    } else {\n+                        t1 = $[0];\n+                    }\n+                    const handleShowDeprecated = t1;\n+                    if (!graphql.isEnumType(type)) {\n+                        return null;\n+                    }\n+                    let deprecatedValues;\n+                    let t2;\n+                    let values;\n+                    if ($[1] !== type) {\n+                        values = [];\n+                        deprecatedValues = [];\n+                        for (const value of type.getValues()) {\n+                            if (value.deprecationReason) {\n+                                deprecatedValues.push(value);\n+                            } else {\n+                                values.push(value);\n                             }\n                         }\n+                        t2 = values.length > 0 ? /* @__PURE__ */ jsxRuntime.jsx(ExplorerSection, {\n+                            title: \"Enum Values\",\n+                            children: values.map(_temp5)\n+                        }) : null;\n+                        $[1] = type;\n+                        $[2] = deprecatedValues;\n+                        $[3] = t2;\n+                        $[4] = values;\n+                    } else {\n+                        deprecatedValues = $[2];\n+                        t2 = $[3];\n+                        values = $[4];\n+                    }\n+                    let t3;\n+                    if ($[5] !== deprecatedValues || $[6] !== showDeprecated || $[7] !== values.length) {\n+                        t3 = deprecatedValues.length > 0 ? showDeprecated || values.length === 0 ? /* @__PURE__ */ jsxRuntime.jsx(ExplorerSection, {\n+                            title: \"Deprecated Enum Values\",\n+                            children: deprecatedValues.map(_temp6)\n+                        }) : /* @__PURE__ */ jsxRuntime.jsx(Button$1, {\n+                            type: \"button\",\n+                            onClick: handleShowDeprecated,\n+                            children: \"Show Deprecated Values\"\n+                        }) : null;\n+                        $[5] = deprecatedValues;\n+                        $[6] = showDeprecated;\n+                        $[7] = values.length;\n+                        $[8] = t3;\n+                    } else {\n+                        t3 = $[8];\n                     }\n-                    state.line = nextLine;\n-                    const token = state.push('html_block', '', 0);\n-                    token.map = [startLine, nextLine];\n-                    token.content = state.getLines(startLine, nextLine, state.blkIndent, true);\n-                    return true;\n+                    let t4;\n+                    if ($[9] !== t2 || $[10] !== t3) {\n+                        t4 = /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, {\n+                            children: [t2, t3]\n+                        });\n+                        $[9] = t2;\n+                        $[10] = t3;\n+                        $[11] = t4;\n+                    } else {\n+                        t4 = $[11];\n+                    }\n+                    return t4;\n                 }\n \n-                // heading (#, ##, ...)\n+                function _temp6(value_1) {\n+                    return /* @__PURE__ */ jsxRuntime.jsx(EnumValue, {\n+                        value: value_1\n+                    }, value_1.name);\n+                }\n \n-                function heading(state, startLine, endLine, silent) {\n-                    let pos = state.bMarks[startLine] + state.tShift[startLine];\n-                    let max = state.eMarks[startLine];\n+                function _temp5(value_0) {\n+                    return /* @__PURE__ */ jsxRuntime.jsx(EnumValue, {\n+                        value: value_0\n+                    }, value_0.name);\n+                }\n \n-                    // if it's indented more than 3 spaces, it should be a code block\n-                    if (state.sCount[startLine] - state.blkIndent >= 4) {\n-                        return false;\n+                function EnumValue(t0) {\n+                    const $ = reactCompilerRuntime.c(10);\n+                    const {\n+                        value\n+                    } = t0;\n+                    let t1;\n+                    if ($[0] !== value.name) {\n+                        t1 = /* @__PURE__ */ jsxRuntime.jsx(\"div\", {\n+                            className: \"graphiql-doc-explorer-enum-value\",\n+                            children: value.name\n+                        });\n+                        $[0] = value.name;\n+                        $[1] = t1;\n+                    } else {\n+                        t1 = $[1];\n                     }\n-                    let ch = state.src.charCodeAt(pos);\n-                    if (ch !== 0x23 /* # */ || pos >= max) {\n-                        return false;\n+                    let t2;\n+                    if ($[2] !== value.description) {\n+                        t2 = value.description ? /* @__PURE__ */ jsxRuntime.jsx(MarkdownContent, {\n+                            type: \"description\",\n+                            children: value.description\n+                        }) : null;\n+                        $[2] = value.description;\n+                        $[3] = t2;\n+                    } else {\n+                        t2 = $[3];\n+                    }\n+                    let t3;\n+                    if ($[4] !== value.deprecationReason) {\n+                        t3 = value.deprecationReason ? /* @__PURE__ */ jsxRuntime.jsx(MarkdownContent, {\n+                            type: \"deprecation\",\n+                            children: value.deprecationReason\n+                        }) : null;\n+                        $[4] = value.deprecationReason;\n+                        $[5] = t3;\n+                    } else {\n+                        t3 = $[5];\n                     }\n+                    let t4;\n+                    if ($[6] !== t1 || $[7] !== t2 || $[8] !== t3) {\n+                        t4 = /* @__PURE__ */ jsxRuntime.jsxs(\"div\", {\n+                            className: \"graphiql-doc-explorer-item\",\n+                            children: [t1, t2, t3]\n+                        });\n+                        $[6] = t1;\n+                        $[7] = t2;\n+                        $[8] = t3;\n+                        $[9] = t4;\n+                    } else {\n+                        t4 = $[9];\n+                    }\n+                    return t4;\n+                }\n \n-                    // count heading level\n-                    let level = 1;\n-                    ch = state.src.charCodeAt(++pos);\n-                    while (ch === 0x23 /* # */ && pos < max && level <= 6) {\n-                        level++;\n-                        ch = state.src.charCodeAt(++pos);\n+                function PossibleTypes(t0) {\n+                    const $ = reactCompilerRuntime.c(7);\n+                    const {\n+                        type\n+                    } = t0;\n+                    let t1;\n+                    if ($[0] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t1 = {\n+                            nonNull: true\n+                        };\n+                        $[0] = t1;\n+                    } else {\n+                        t1 = $[0];\n                     }\n-                    if (level > 6 || pos < max && !isSpace(ch)) {\n-                        return false;\n+                    const {\n+                        schema\n+                    } = useSchemaContext(t1);\n+                    if (!schema || !graphql.isAbstractType(type)) {\n+                        return null;\n                     }\n-                    if (silent) {\n-                        return true;\n+                    const t2 = graphql.isInterfaceType(type) ? \"Implementations\" : \"Possible Types\";\n+                    let t3;\n+                    if ($[1] !== schema || $[2] !== type) {\n+                        t3 = schema.getPossibleTypes(type).map(_temp7);\n+                        $[1] = schema;\n+                        $[2] = type;\n+                        $[3] = t3;\n+                    } else {\n+                        t3 = $[3];\n                     }\n-\n-                    // Let's cut tails like '    ###  ' from the end of string\n-\n-                    max = state.skipSpacesBack(max, pos);\n-                    const tmp = state.skipCharsBack(max, 0x23, pos); // #\n-                    if (tmp > pos && isSpace(state.src.charCodeAt(tmp - 1))) {\n-                        max = tmp;\n+                    let t4;\n+                    if ($[4] !== t2 || $[5] !== t3) {\n+                        t4 = /* @__PURE__ */ jsxRuntime.jsx(ExplorerSection, {\n+                            title: t2,\n+                            children: t3\n+                        });\n+                        $[4] = t2;\n+                        $[5] = t3;\n+                        $[6] = t4;\n+                    } else {\n+                        t4 = $[6];\n                     }\n-                    state.line = startLine + 1;\n-                    const token_o = state.push('heading_open', 'h' + String(level), 1);\n-                    token_o.markup = '########'.slice(0, level);\n-                    token_o.map = [startLine, state.line];\n-                    const token_i = state.push('inline', '', 0);\n-                    token_i.content = state.src.slice(pos, max).trim();\n-                    token_i.map = [startLine, state.line];\n-                    token_i.children = [];\n-                    const token_c = state.push('heading_close', 'h' + String(level), -1);\n-                    token_c.markup = '########'.slice(0, level);\n-                    return true;\n+                    return t4;\n                 }\n \n-                // lheading (---, ===)\n-\n-                function lheading(state, startLine, endLine /*, silent */ ) {\n-                    const terminatorRules = state.md.block.ruler.getRules('paragraph');\n+                function _temp7(possibleType) {\n+                    return /* @__PURE__ */ jsxRuntime.jsx(\"div\", {\n+                        children: /* @__PURE__ */ jsxRuntime.jsx(TypeLink, {\n+                            type: possibleType\n+                        })\n+                    }, possibleType.name);\n+                }\n \n-                    // if it's indented more than 3 spaces, it should be a code block\n-                    if (state.sCount[startLine] - state.blkIndent >= 4) {\n-                        return false;\n+                function DocExplorer() {\n+                    const $ = reactCompilerRuntime.c(40);\n+                    let t0;\n+                    if ($[0] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t0 = {\n+                            nonNull: true,\n+                            caller: DocExplorer\n+                        };\n+                        $[0] = t0;\n+                    } else {\n+                        t0 = $[0];\n                     }\n-                    const oldParentType = state.parentType;\n-                    state.parentType = 'paragraph'; // use paragraph to match terminatorRules\n-\n-                    // jump line-by-line until empty one or EOF\n-                    let level = 0;\n-                    let marker;\n-                    let nextLine = startLine + 1;\n-                    for (; nextLine < endLine && !state.isEmpty(nextLine); nextLine++) {\n-                        // this would be a code block normally, but after paragraph\n-                        // it's considered a lazy continuation regardless of what's there\n-                        if (state.sCount[nextLine] - state.blkIndent > 3) {\n-                            continue;\n-                        }\n-\n-                        //\n-                        // Check for underline in setext header\n-                        //\n-                        if (state.sCount[nextLine] >= state.blkIndent) {\n-                            let pos = state.bMarks[nextLine] + state.tShift[nextLine];\n-                            const max = state.eMarks[nextLine];\n-                            if (pos < max) {\n-                                marker = state.src.charCodeAt(pos);\n-                                if (marker === 0x2D /* - */ || marker === 0x3D /* = */ ) {\n-                                    pos = state.skipChars(pos, marker);\n-                                    pos = state.skipSpaces(pos);\n-                                    if (pos >= max) {\n-                                        level = marker === 0x3D /* = */ ? 1 : 2;\n-                                        break;\n+                    const {\n+                        fetchError,\n+                        isFetching,\n+                        schema,\n+                        validationErrors\n+                    } = useSchemaContext(t0);\n+                    let t1;\n+                    if ($[1] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t1 = {\n+                            nonNull: true,\n+                            caller: DocExplorer\n+                        };\n+                        $[1] = t1;\n+                    } else {\n+                        t1 = $[1];\n+                    }\n+                    const {\n+                        explorerNavStack,\n+                        pop\n+                    } = useExplorerContext(t1);\n+                    let content;\n+                    let navItem;\n+                    if ($[2] !== explorerNavStack || $[3] !== fetchError || $[4] !== isFetching || $[5] !== schema || $[6] !== validationErrors) {\n+                        navItem = explorerNavStack.at(-1);\n+                        content = null;\n+                        if (fetchError) {\n+                            let t22;\n+                            if ($[9] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                                t22 = /* @__PURE__ */ jsxRuntime.jsx(\"div\", {\n+                                    className: \"graphiql-doc-explorer-error\",\n+                                    children: \"Error fetching schema\"\n+                                });\n+                                $[9] = t22;\n+                            } else {\n+                                t22 = $[9];\n+                            }\n+                            content = t22;\n+                        } else {\n+                            if (validationErrors.length > 0) {\n+                                const t22 = validationErrors[0];\n+                                let t32;\n+                                if ($[10] !== t22.message) {\n+                                    t32 = /* @__PURE__ */ jsxRuntime.jsxs(\"div\", {\n+                                        className: \"graphiql-doc-explorer-error\",\n+                                        children: [\"Schema is invalid: \", t22.message]\n+                                    });\n+                                    $[10] = t22.message;\n+                                    $[11] = t32;\n+                                } else {\n+                                    t32 = $[11];\n+                                }\n+                                content = t32;\n+                            } else {\n+                                if (isFetching) {\n+                                    let t22;\n+                                    if ($[12] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                                        t22 = /* @__PURE__ */ jsxRuntime.jsx(Spinner, {});\n+                                        $[12] = t22;\n+                                    } else {\n+                                        t22 = $[12];\n+                                    }\n+                                    content = t22;\n+                                } else {\n+                                    if (!schema) {\n+                                        let t22;\n+                                        if ($[13] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                                            t22 = /* @__PURE__ */ jsxRuntime.jsx(\"div\", {\n+                                                className: \"graphiql-doc-explorer-error\",\n+                                                children: \"No GraphQL schema available\"\n+                                            });\n+                                            $[13] = t22;\n+                                        } else {\n+                                            t22 = $[13];\n+                                        }\n+                                        content = t22;\n+                                    } else {\n+                                        if (explorerNavStack.length === 1) {\n+                                            let t22;\n+                                            if ($[14] !== schema) {\n+                                                t22 = /* @__PURE__ */ jsxRuntime.jsx(SchemaDocumentation, {\n+                                                    schema\n+                                                });\n+                                                $[14] = schema;\n+                                                $[15] = t22;\n+                                            } else {\n+                                                t22 = $[15];\n+                                            }\n+                                            content = t22;\n+                                        } else {\n+                                            if (graphql.isType(navItem.def)) {\n+                                                let t22;\n+                                                if ($[16] !== navItem.def) {\n+                                                    t22 = /* @__PURE__ */ jsxRuntime.jsx(TypeDocumentation, {\n+                                                        type: navItem.def\n+                                                    });\n+                                                    $[16] = navItem.def;\n+                                                    $[17] = t22;\n+                                                } else {\n+                                                    t22 = $[17];\n+                                                }\n+                                                content = t22;\n+                                            } else {\n+                                                if (navItem.def) {\n+                                                    let t22;\n+                                                    if ($[18] !== navItem.def) {\n+                                                        t22 = /* @__PURE__ */ jsxRuntime.jsx(FieldDocumentation, {\n+                                                            field: navItem.def\n+                                                        });\n+                                                        $[18] = navItem.def;\n+                                                        $[19] = t22;\n+                                                    } else {\n+                                                        t22 = $[19];\n+                                                    }\n+                                                    content = t22;\n+                                                }\n+                                            }\n+                                        }\n                                     }\n                                 }\n                             }\n                         }\n-\n-                        // quirk for blockquotes, this line should already be checked by that rule\n-                        if (state.sCount[nextLine] < 0) {\n-                            continue;\n-                        }\n-\n-                        // Some tags can terminate paragraph without empty line.\n-                        let terminate = false;\n-                        for (let i = 0, l = terminatorRules.length; i < l; i++) {\n-                            if (terminatorRules[i](state, nextLine, endLine, true)) {\n-                                terminate = true;\n-                                break;\n-                            }\n-                        }\n-                        if (terminate) {\n-                            break;\n+                        $[2] = explorerNavStack;\n+                        $[3] = fetchError;\n+                        $[4] = isFetching;\n+                        $[5] = schema;\n+                        $[6] = validationErrors;\n+                        $[7] = content;\n+                        $[8] = navItem;\n+                    } else {\n+                        content = $[7];\n+                        navItem = $[8];\n+                    }\n+                    let prevName;\n+                    if (explorerNavStack.length > 1) {\n+                        let t22;\n+                        if ($[20] !== explorerNavStack) {\n+                            t22 = explorerNavStack.at(-2);\n+                            $[20] = explorerNavStack;\n+                            $[21] = t22;\n+                        } else {\n+                            t22 = $[21];\n                         }\n+                        prevName = t22.name;\n                     }\n-                    if (!level) {\n-                        // Didn't find valid underline\n-                        return false;\n+                    let t2;\n+                    if ($[22] !== pop || $[23] !== prevName) {\n+                        t2 = prevName && /* @__PURE__ */ jsxRuntime.jsxs(\"a\", {\n+                            href: \"#\",\n+                            className: \"graphiql-doc-explorer-back\",\n+                            onClick: event => {\n+                                event.preventDefault();\n+                                pop();\n+                            },\n+                            \"aria-label\": `Go back to ${prevName}`,\n+                            children: [ /* @__PURE__ */ jsxRuntime.jsx(ChevronLeftIcon, {}), prevName]\n+                        });\n+                        $[22] = pop;\n+                        $[23] = prevName;\n+                        $[24] = t2;\n+                    } else {\n+                        t2 = $[24];\n                     }\n-                    const content = state.getLines(startLine, nextLine, state.blkIndent, false).trim();\n-                    state.line = nextLine + 1;\n-                    const token_o = state.push('heading_open', 'h' + String(level), 1);\n-                    token_o.markup = String.fromCharCode(marker);\n-                    token_o.map = [startLine, state.line];\n-                    const token_i = state.push('inline', '', 0);\n-                    token_i.content = content;\n-                    token_i.map = [startLine, state.line - 1];\n-                    token_i.children = [];\n-                    const token_c = state.push('heading_close', 'h' + String(level), -1);\n-                    token_c.markup = String.fromCharCode(marker);\n-                    state.parentType = oldParentType;\n-                    return true;\n+                    let t3;\n+                    if ($[25] !== navItem.name) {\n+                        t3 = /* @__PURE__ */ jsxRuntime.jsx(\"div\", {\n+                            className: \"graphiql-doc-explorer-title\",\n+                            children: navItem.name\n+                        });\n+                        $[25] = navItem.name;\n+                        $[26] = t3;\n+                    } else {\n+                        t3 = $[26];\n+                    }\n+                    let t4;\n+                    if ($[27] !== t2 || $[28] !== t3) {\n+                        t4 = /* @__PURE__ */ jsxRuntime.jsxs(\"div\", {\n+                            className: \"graphiql-doc-explorer-header-content\",\n+                            children: [t2, t3]\n+                        });\n+                        $[27] = t2;\n+                        $[28] = t3;\n+                        $[29] = t4;\n+                    } else {\n+                        t4 = $[29];\n+                    }\n+                    let t5;\n+                    if ($[30] !== navItem.name) {\n+                        t5 = /* @__PURE__ */ jsxRuntime.jsx(Search, {}, navItem.name);\n+                        $[30] = navItem.name;\n+                        $[31] = t5;\n+                    } else {\n+                        t5 = $[31];\n+                    }\n+                    let t6;\n+                    if ($[32] !== t4 || $[33] !== t5) {\n+                        t6 = /* @__PURE__ */ jsxRuntime.jsxs(\"div\", {\n+                            className: \"graphiql-doc-explorer-header\",\n+                            children: [t4, t5]\n+                        });\n+                        $[32] = t4;\n+                        $[33] = t5;\n+                        $[34] = t6;\n+                    } else {\n+                        t6 = $[34];\n+                    }\n+                    let t7;\n+                    if ($[35] !== content) {\n+                        t7 = /* @__PURE__ */ jsxRuntime.jsx(\"div\", {\n+                            className: \"graphiql-doc-explorer-content\",\n+                            children: content\n+                        });\n+                        $[35] = content;\n+                        $[36] = t7;\n+                    } else {\n+                        t7 = $[36];\n+                    }\n+                    let t8;\n+                    if ($[37] !== t6 || $[38] !== t7) {\n+                        t8 = /* @__PURE__ */ jsxRuntime.jsxs(\"section\", {\n+                            className: \"graphiql-doc-explorer\",\n+                            \"aria-label\": \"Documentation Explorer\",\n+                            children: [t6, t7]\n+                        });\n+                        $[37] = t6;\n+                        $[38] = t7;\n+                        $[39] = t8;\n+                    } else {\n+                        t8 = $[39];\n+                    }\n+                    return t8;\n                 }\n-\n-                // Paragraph\n-\n-                function paragraph(state, startLine, endLine) {\n-                    const terminatorRules = state.md.block.ruler.getRules('paragraph');\n-                    const oldParentType = state.parentType;\n-                    let nextLine = startLine + 1;\n-                    state.parentType = 'paragraph';\n-\n-                    // jump line-by-line until empty one or EOF\n-                    for (; nextLine < endLine && !state.isEmpty(nextLine); nextLine++) {\n-                        // this would be a code block normally, but after paragraph\n-                        // it's considered a lazy continuation regardless of what's there\n-                        if (state.sCount[nextLine] - state.blkIndent > 3) {\n-                            continue;\n-                        }\n-\n-                        // quirk for blockquotes, this line should already be checked by that rule\n-                        if (state.sCount[nextLine] < 0) {\n-                            continue;\n+                const DOC_EXPLORER_PLUGIN = {\n+                    title: \"Documentation Explorer\",\n+                    icon: function Icon() {\n+                        const pluginContext = usePluginContext();\n+                        return (pluginContext == null ? void 0 : pluginContext.visiblePlugin) === DOC_EXPLORER_PLUGIN ? /* @__PURE__ */ jsxRuntime.jsx(DocsFilledIcon, {}) : /* @__PURE__ */ jsxRuntime.jsx(DocsIcon, {});\n+                    },\n+                    content: DocExplorer\n+                };\n+                const HISTORY_PLUGIN = {\n+                    title: \"History\",\n+                    icon: HistoryIcon,\n+                    content: History\n+                };\n+                const PluginContext = createNullableContext(\"PluginContext\");\n+\n+                function PluginContextProvider(props) {\n+                    const $ = reactCompilerRuntime.c(27);\n+                    const storage = useStorageContext();\n+                    const explorerContext = useExplorerContext();\n+                    const historyContext = useHistoryContext();\n+                    const hasExplorerContext = Boolean(explorerContext);\n+                    const hasHistoryContext = Boolean(historyContext);\n+                    let t0;\n+                    let pluginList;\n+                    if ($[0] !== hasExplorerContext || $[1] !== hasHistoryContext || $[2] !== props.plugins) {\n+                        pluginList = [];\n+                        const pluginTitles = {};\n+                        if (hasExplorerContext) {\n+                            pluginList.push(DOC_EXPLORER_PLUGIN);\n+                            pluginTitles[DOC_EXPLORER_PLUGIN.title] = true;\n+                        }\n+                        if (hasHistoryContext) {\n+                            pluginList.push(HISTORY_PLUGIN);\n+                            pluginTitles[HISTORY_PLUGIN.title] = true;\n+                        }\n+                        let t12;\n+                        if ($[4] !== props.plugins) {\n+                            t12 = props.plugins || [];\n+                            $[4] = props.plugins;\n+                            $[5] = t12;\n+                        } else {\n+                            t12 = $[5];\n                         }\n-\n-                        // Some tags can terminate paragraph without empty line.\n-                        let terminate = false;\n-                        for (let i = 0, l = terminatorRules.length; i < l; i++) {\n-                            if (terminatorRules[i](state, nextLine, endLine, true)) {\n-                                terminate = true;\n-                                break;\n+                        for (const plugin of t12) {\n+                            if (typeof plugin.title !== \"string\" || !plugin.title) {\n+                                throw new Error(\"All GraphiQL plugins must have a unique title\");\n+                            }\n+                            if (pluginTitles[plugin.title]) {\n+                                throw new Error(`All GraphiQL plugins must have a unique title, found two plugins with the title '${plugin.title}'`);\n+                            } else {\n+                                pluginList.push(plugin);\n+                                pluginTitles[plugin.title] = true;\n                             }\n                         }\n-                        if (terminate) {\n-                            break;\n-                        }\n+                        $[0] = hasExplorerContext;\n+                        $[1] = hasHistoryContext;\n+                        $[2] = props.plugins;\n+                        $[3] = pluginList;\n+                    } else {\n+                        pluginList = $[3];\n                     }\n-                    const content = state.getLines(startLine, nextLine, state.blkIndent, false).trim();\n-                    state.line = nextLine;\n-                    const token_o = state.push('paragraph_open', 'p', 1);\n-                    token_o.map = [startLine, state.line];\n-                    const token_i = state.push('inline', '', 0);\n-                    token_i.content = content;\n-                    token_i.map = [startLine, state.line];\n-                    token_i.children = [];\n-                    state.push('paragraph_close', 'p', -1);\n-                    state.parentType = oldParentType;\n-                    return true;\n-                }\n-\n-                /** internal\n-                 * class ParserBlock\n-                 *\n-                 * Block-level tokenizer.\n-                 **/\n-\n-                const _rules$1 = [\n-                    // First 2 params - rule name & source. Secondary array - list of rules,\n-                    // which can be terminated by this one.\n-                    ['table', table, ['paragraph', 'reference']],\n-                    ['code', code],\n-                    ['fence', fence, ['paragraph', 'reference', 'blockquote', 'list']],\n-                    ['blockquote', blockquote, ['paragraph', 'reference', 'blockquote', 'list']],\n-                    ['hr', hr, ['paragraph', 'reference', 'blockquote', 'list']],\n-                    ['list', list, ['paragraph', 'reference', 'blockquote']],\n-                    ['reference', reference],\n-                    ['html_block', html_block, ['paragraph', 'reference', 'blockquote']],\n-                    ['heading', heading, ['paragraph', 'reference', 'blockquote']],\n-                    ['lheading', lheading],\n-                    ['paragraph', paragraph]\n-                ];\n-\n-                /**\n-                 * new ParserBlock()\n-                 **/\n-                function ParserBlock() {\n-                    /**\n-                     * ParserBlock#ruler -> Ruler\n-                     *\n-                     * [[Ruler]] instance. Keep configuration of block rules.\n-                     **/\n-                    this.ruler = new Ruler();\n-                    for (let i = 0; i < _rules$1.length; i++) {\n-                        this.ruler.push(_rules$1[i][0], _rules$1[i][1], {\n-                            alt: (_rules$1[i][2] || []).slice()\n+                    t0 = pluginList;\n+                    const plugins = t0;\n+                    let t1;\n+                    if ($[6] !== plugins || $[7] !== props.visiblePlugin || $[8] !== storage) {\n+                        t1 = () => {\n+                            const storedValue = storage == null ? void 0 : storage.get(STORAGE_KEY$4);\n+                            const pluginForStoredValue = plugins.find(plugin_0 => plugin_0.title === storedValue);\n+                            if (pluginForStoredValue) {\n+                                return pluginForStoredValue;\n+                            }\n+                            if (storedValue) {\n+                                storage == null ? void 0 : storage.set(STORAGE_KEY$4, \"\");\n+                            }\n+                            if (!props.visiblePlugin) {\n+                                return null;\n+                            }\n+                            return plugins.find(plugin_1 => (typeof props.visiblePlugin === \"string\" ? plugin_1.title : plugin_1) === props.visiblePlugin) || null;\n+                        };\n+                        $[6] = plugins;\n+                        $[7] = props.visiblePlugin;\n+                        $[8] = storage;\n+                        $[9] = t1;\n+                    } else {\n+                        t1 = $[9];\n+                    }\n+                    const [visiblePlugin, internalSetVisiblePlugin] = React.useState(t1);\n+                    const {\n+                        onTogglePluginVisibility,\n+                        children\n+                    } = props;\n+                    let t2;\n+                    if ($[10] !== onTogglePluginVisibility || $[11] !== plugins) {\n+                        t2 = plugin_2 => {\n+                            const newVisiblePlugin = plugin_2 ? plugins.find(p => (typeof plugin_2 === \"string\" ? p.title : p) === plugin_2) || null : null;\n+                            internalSetVisiblePlugin(current => {\n+                                if (newVisiblePlugin === current) {\n+                                    return current;\n+                                }\n+                                onTogglePluginVisibility == null ? void 0 : onTogglePluginVisibility(newVisiblePlugin);\n+                                return newVisiblePlugin;\n+                            });\n+                        };\n+                        $[10] = onTogglePluginVisibility;\n+                        $[11] = plugins;\n+                        $[12] = t2;\n+                    } else {\n+                        t2 = $[12];\n+                    }\n+                    const setVisiblePlugin = t2;\n+                    let t3;\n+                    if ($[13] !== props.visiblePlugin || $[14] !== setVisiblePlugin) {\n+                        t3 = () => {\n+                            if (props.visiblePlugin) {\n+                                setVisiblePlugin(props.visiblePlugin);\n+                            }\n+                        };\n+                        $[13] = props.visiblePlugin;\n+                        $[14] = setVisiblePlugin;\n+                        $[15] = t3;\n+                    } else {\n+                        t3 = $[15];\n+                    }\n+                    let t4;\n+                    if ($[16] !== plugins || $[17] !== props.visiblePlugin || $[18] !== setVisiblePlugin) {\n+                        t4 = [plugins, props.visiblePlugin, setVisiblePlugin];\n+                        $[16] = plugins;\n+                        $[17] = props.visiblePlugin;\n+                        $[18] = setVisiblePlugin;\n+                        $[19] = t4;\n+                    } else {\n+                        t4 = $[19];\n+                    }\n+                    React.useEffect(t3, t4);\n+                    let t5;\n+                    if ($[20] !== plugins || $[21] !== setVisiblePlugin || $[22] !== visiblePlugin) {\n+                        t5 = {\n+                            plugins,\n+                            setVisiblePlugin,\n+                            visiblePlugin\n+                        };\n+                        $[20] = plugins;\n+                        $[21] = setVisiblePlugin;\n+                        $[22] = visiblePlugin;\n+                        $[23] = t5;\n+                    } else {\n+                        t5 = $[23];\n+                    }\n+                    const value = t5;\n+                    let t6;\n+                    if ($[24] !== children || $[25] !== value) {\n+                        t6 = /* @__PURE__ */ jsxRuntime.jsx(PluginContext.Provider, {\n+                            value,\n+                            children\n                         });\n+                        $[24] = children;\n+                        $[25] = value;\n+                        $[26] = t6;\n+                    } else {\n+                        t6 = $[26];\n                     }\n+                    return t6;\n                 }\n+                const usePluginContext = createContextHook(PluginContext);\n+                const STORAGE_KEY$4 = \"visiblePlugin\";\n \n-                // Generate tokens for input range\n-                //\n-                ParserBlock.prototype.tokenize = function(state, startLine, endLine) {\n-                    const rules = this.ruler.getRules('');\n-                    const len = rules.length;\n-                    const maxNesting = state.md.options.maxNesting;\n-                    let line = startLine;\n-                    let hasEmptyLines = false;\n-                    while (line < endLine) {\n-                        state.line = line = state.skipEmptyLines(line);\n-                        if (line >= endLine) {\n-                            break;\n-                        }\n-\n-                        // Termination condition for nested calls.\n-                        // Nested calls currently used for blockquotes & lists\n-                        if (state.sCount[line] < state.blkIndent) {\n-                            break;\n-                        }\n-\n-                        // If nesting level exceeded - skip tail to the end. That's not ordinary\n-                        // situation and we should not care about content.\n-                        if (state.level >= maxNesting) {\n-                            state.line = endLine;\n-                            break;\n-                        }\n-\n-                        // Try all possible rules.\n-                        // On success, rule should:\n-                        //\n-                        // - update `state.line`\n-                        // - update `state.tokens`\n-                        // - return true\n-                        const prevLine = state.line;\n-                        let ok = false;\n-                        for (let i = 0; i < len; i++) {\n-                            ok = rules[i](state, line, endLine, false);\n-                            if (ok) {\n-                                if (prevLine >= state.line) {\n-                                    throw new Error(\"block rule didn't increment state.line\");\n+                function onHasCompletion(_cm, data, schema, explorer, plugin, callback) {\n+                    void importCodeMirror([], {\n+                        useCommonAddons: false\n+                    }).then(CodeMirror => {\n+                        let information;\n+                        let fieldName;\n+                        let typeNamePill;\n+                        let typeNamePrefix;\n+                        let typeName;\n+                        let typeNameSuffix;\n+                        let description;\n+                        let deprecation;\n+                        let deprecationReason;\n+                        CodeMirror.on(data, \"select\",\n+                            // @ts-expect-error\n+                            (ctx, el) => {\n+                                if (!information) {\n+                                    const hintsUl = el.parentNode;\n+                                    information = document.createElement(\"div\");\n+                                    information.className = \"CodeMirror-hint-information\";\n+                                    hintsUl.append(information);\n+                                    const header = document.createElement(\"header\");\n+                                    header.className = \"CodeMirror-hint-information-header\";\n+                                    information.append(header);\n+                                    fieldName = document.createElement(\"span\");\n+                                    fieldName.className = \"CodeMirror-hint-information-field-name\";\n+                                    header.append(fieldName);\n+                                    typeNamePill = document.createElement(\"span\");\n+                                    typeNamePill.className = \"CodeMirror-hint-information-type-name-pill\";\n+                                    header.append(typeNamePill);\n+                                    typeNamePrefix = document.createElement(\"span\");\n+                                    typeNamePill.append(typeNamePrefix);\n+                                    typeName = document.createElement(\"a\");\n+                                    typeName.className = \"CodeMirror-hint-information-type-name\";\n+                                    typeName.href = \"javascript:void 0\";\n+                                    typeName.addEventListener(\"click\", onClickHintInformation);\n+                                    typeNamePill.append(typeName);\n+                                    typeNameSuffix = document.createElement(\"span\");\n+                                    typeNamePill.append(typeNameSuffix);\n+                                    description = document.createElement(\"div\");\n+                                    description.className = \"CodeMirror-hint-information-description\";\n+                                    information.append(description);\n+                                    deprecation = document.createElement(\"div\");\n+                                    deprecation.className = \"CodeMirror-hint-information-deprecation\";\n+                                    information.append(deprecation);\n+                                    const deprecationLabel = document.createElement(\"span\");\n+                                    deprecationLabel.className = \"CodeMirror-hint-information-deprecation-label\";\n+                                    deprecationLabel.textContent = \"Deprecated\";\n+                                    deprecation.append(deprecationLabel);\n+                                    deprecationReason = document.createElement(\"div\");\n+                                    deprecationReason.className = \"CodeMirror-hint-information-deprecation-reason\";\n+                                    deprecation.append(deprecationReason);\n+                                    const defaultInformationPadding = parseInt(window.getComputedStyle(information).paddingBottom.replace(/px$/, \"\"), 10) || 0;\n+                                    const defaultInformationMaxHeight = parseInt(window.getComputedStyle(information).maxHeight.replace(/px$/, \"\"), 10) || 0;\n+                                    const handleScroll = () => {\n+                                        if (information) {\n+                                            information.style.paddingTop = hintsUl.scrollTop + defaultInformationPadding + \"px\";\n+                                            information.style.maxHeight = hintsUl.scrollTop + defaultInformationMaxHeight + \"px\";\n+                                        }\n+                                    };\n+                                    hintsUl.addEventListener(\"scroll\", handleScroll);\n+                                    let onRemoveFn;\n+                                    hintsUl.addEventListener(\"DOMNodeRemoved\", onRemoveFn = event => {\n+                                        if (event.target !== hintsUl) {\n+                                            return;\n+                                        }\n+                                        hintsUl.removeEventListener(\"scroll\", handleScroll);\n+                                        hintsUl.removeEventListener(\"DOMNodeRemoved\", onRemoveFn);\n+                                        if (information) {\n+                                            information.removeEventListener(\"click\", onClickHintInformation);\n+                                        }\n+                                        information = null;\n+                                        fieldName = null;\n+                                        typeNamePill = null;\n+                                        typeNamePrefix = null;\n+                                        typeName = null;\n+                                        typeNameSuffix = null;\n+                                        description = null;\n+                                        deprecation = null;\n+                                        deprecationReason = null;\n+                                        onRemoveFn = null;\n+                                    });\n                                 }\n-                                break;\n-                            }\n-                        }\n-\n-                        // this can only happen if user disables paragraph rule\n-                        if (!ok) throw new Error('none of the block rules matched');\n-\n-                        // set state.tight if we had an empty line before current tag\n-                        // i.e. latest empty line should not count\n-                        state.tight = !hasEmptyLines;\n+                                if (fieldName) {\n+                                    fieldName.textContent = ctx.text;\n+                                }\n+                                if (typeNamePill && typeNamePrefix && typeName && typeNameSuffix) {\n+                                    if (ctx.type) {\n+                                        typeNamePill.style.display = \"inline\";\n+                                        const renderType2 = type => {\n+                                            if (graphql.isNonNullType(type)) {\n+                                                typeNameSuffix.textContent = \"!\" + typeNameSuffix.textContent;\n+                                                renderType2(type.ofType);\n+                                            } else if (graphql.isListType(type)) {\n+                                                typeNamePrefix.textContent += \"[\";\n+                                                typeNameSuffix.textContent = \"]\" + typeNameSuffix.textContent;\n+                                                renderType2(type.ofType);\n+                                            } else {\n+                                                typeName.textContent = type.name;\n+                                            }\n+                                        };\n+                                        typeNamePrefix.textContent = \"\";\n+                                        typeNameSuffix.textContent = \"\";\n+                                        renderType2(ctx.type);\n+                                    } else {\n+                                        typeNamePrefix.textContent = \"\";\n+                                        typeName.textContent = \"\";\n+                                        typeNameSuffix.textContent = \"\";\n+                                        typeNamePill.style.display = \"none\";\n+                                    }\n+                                }\n+                                if (description) {\n+                                    if (ctx.description) {\n+                                        description.style.display = \"block\";\n+                                        description.innerHTML = markdown.render(ctx.description);\n+                                    } else {\n+                                        description.style.display = \"none\";\n+                                        description.innerHTML = \"\";\n+                                    }\n+                                }\n+                                if (deprecation && deprecationReason) {\n+                                    if (ctx.deprecationReason) {\n+                                        deprecation.style.display = \"block\";\n+                                        deprecationReason.innerHTML = markdown.render(ctx.deprecationReason);\n+                                    } else {\n+                                        deprecation.style.display = \"none\";\n+                                        deprecationReason.innerHTML = \"\";\n+                                    }\n+                                }\n+                            });\n+                    });\n \n-                        // paragraph might \"eat\" one newline after it in nested lists\n-                        if (state.isEmpty(state.line - 1)) {\n-                            hasEmptyLines = true;\n+                    function onClickHintInformation(event) {\n+                        if (!schema || !explorer || !plugin || !(event.currentTarget instanceof HTMLElement)) {\n+                            return;\n                         }\n-                        line = state.line;\n-                        if (line < endLine && state.isEmpty(line)) {\n-                            hasEmptyLines = true;\n-                            line++;\n-                            state.line = line;\n+                        const typeName = event.currentTarget.textContent || \"\";\n+                        const type = schema.getType(typeName);\n+                        if (type) {\n+                            plugin.setVisiblePlugin(DOC_EXPLORER_PLUGIN);\n+                            explorer.push({\n+                                name: type.name,\n+                                def: type\n+                            });\n+                            callback == null ? void 0 : callback(type);\n                         }\n                     }\n-                };\n+                }\n \n-                /**\n-                 * ParserBlock.parse(str, md, env, outTokens)\n-                 *\n-                 * Process input string and push block tokens into `outTokens`\n-                 **/\n-                ParserBlock.prototype.parse = function(src, md, env, outTokens) {\n-                    if (!src) {\n-                        return;\n+                function useSynchronizeValue(editor, value) {\n+                    const $ = reactCompilerRuntime.c(4);\n+                    let t0;\n+                    let t1;\n+                    if ($[0] !== editor || $[1] !== value) {\n+                        t0 = () => {\n+                            if (editor && typeof value === \"string\" && value !== editor.getValue()) {\n+                                editor.setValue(value);\n+                            }\n+                        };\n+                        t1 = [editor, value];\n+                        $[0] = editor;\n+                        $[1] = value;\n+                        $[2] = t0;\n+                        $[3] = t1;\n+                    } else {\n+                        t0 = $[2];\n+                        t1 = $[3];\n                     }\n-                    const state = new this.State(src, md, env, outTokens);\n-                    this.tokenize(state, state.line, state.lineMax);\n-                };\n-                ParserBlock.prototype.State = StateBlock;\n-\n-                // Inline parser state\n-\n-                function StateInline(src, md, env, outTokens) {\n-                    this.src = src;\n-                    this.env = env;\n-                    this.md = md;\n-                    this.tokens = outTokens;\n-                    this.tokens_meta = Array(outTokens.length);\n-                    this.pos = 0;\n-                    this.posMax = this.src.length;\n-                    this.level = 0;\n-                    this.pending = '';\n-                    this.pendingLevel = 0;\n-\n-                    // Stores { start: end } pairs. Useful for backtrack\n-                    // optimization of pairs parse (emphasis, strikes).\n-                    this.cache = {};\n-\n-                    // List of emphasis-like delimiters for current tag\n-                    this.delimiters = [];\n-\n-                    // Stack of delimiter lists for upper level tags\n-                    this._prev_delimiters = [];\n+                    React.useEffect(t0, t1);\n+                }\n \n-                    // backtick length => last seen position\n-                    this.backticks = {};\n-                    this.backticksScanned = false;\n+                function useSynchronizeOption(editor, option, value) {\n+                    const $ = reactCompilerRuntime.c(5);\n+                    let t0;\n+                    let t1;\n+                    if ($[0] !== editor || $[1] !== option || $[2] !== value) {\n+                        t0 = () => {\n+                            if (editor) {\n+                                editor.setOption(option, value);\n+                            }\n+                        };\n+                        t1 = [editor, option, value];\n+                        $[0] = editor;\n+                        $[1] = option;\n+                        $[2] = value;\n+                        $[3] = t0;\n+                        $[4] = t1;\n+                    } else {\n+                        t0 = $[3];\n+                        t1 = $[4];\n+                    }\n+                    React.useEffect(t0, t1);\n+                }\n \n-                    // Counter used to disable inline linkify-it execution\n-                    // inside <a> and markdown links\n-                    this.linkLevel = 0;\n+                function useChangeHandler(editor, callback, storageKey, tabProperty, caller) {\n+                    const $ = reactCompilerRuntime.c(10);\n+                    let t0;\n+                    if ($[0] !== caller) {\n+                        t0 = {\n+                            nonNull: true,\n+                            caller\n+                        };\n+                        $[0] = caller;\n+                        $[1] = t0;\n+                    } else {\n+                        t0 = $[1];\n+                    }\n+                    const {\n+                        updateActiveTabValues\n+                    } = useEditorContext(t0);\n+                    const storage = useStorageContext();\n+                    let t1;\n+                    let t2;\n+                    if ($[2] !== callback || $[3] !== editor || $[4] !== storage || $[5] !== storageKey || $[6] !== tabProperty || $[7] !== updateActiveTabValues) {\n+                        t1 = () => {\n+                            if (!editor) {\n+                                return;\n+                            }\n+                            const store = debounce(500, value => {\n+                                if (!storage || storageKey === null) {\n+                                    return;\n+                                }\n+                                storage.set(storageKey, value);\n+                            });\n+                            const updateTab = debounce(100, value_0 => {\n+                                updateActiveTabValues({\n+                                    [tabProperty]: value_0\n+                                });\n+                            });\n+                            const handleChange = (editorInstance, changeObj) => {\n+                                if (!changeObj) {\n+                                    return;\n+                                }\n+                                const newValue = editorInstance.getValue();\n+                                store(newValue);\n+                                updateTab(newValue);\n+                                callback == null ? void 0 : callback(newValue);\n+                            };\n+                            editor.on(\"change\", handleChange);\n+                            return () => editor.off(\"change\", handleChange);\n+                        };\n+                        t2 = [callback, editor, storage, storageKey, tabProperty, updateActiveTabValues];\n+                        $[2] = callback;\n+                        $[3] = editor;\n+                        $[4] = storage;\n+                        $[5] = storageKey;\n+                        $[6] = tabProperty;\n+                        $[7] = updateActiveTabValues;\n+                        $[8] = t1;\n+                        $[9] = t2;\n+                    } else {\n+                        t1 = $[8];\n+                        t2 = $[9];\n+                    }\n+                    React.useEffect(t1, t2);\n                 }\n \n-                // Flush pending text\n-                //\n-                StateInline.prototype.pushPending = function() {\n-                    const token = new Token('text', '', 0);\n-                    token.content = this.pending;\n-                    token.level = this.pendingLevel;\n-                    this.tokens.push(token);\n-                    this.pending = '';\n-                    return token;\n-                };\n+                function useCompletion(editor, callback, caller) {\n+                    const $ = reactCompilerRuntime.c(9);\n+                    let t0;\n+                    if ($[0] !== caller) {\n+                        t0 = {\n+                            nonNull: true,\n+                            caller\n+                        };\n+                        $[0] = caller;\n+                        $[1] = t0;\n+                    } else {\n+                        t0 = $[1];\n+                    }\n+                    const {\n+                        schema\n+                    } = useSchemaContext(t0);\n+                    const explorer = useExplorerContext();\n+                    const plugin = usePluginContext();\n+                    let t1;\n+                    let t2;\n+                    if ($[2] !== callback || $[3] !== editor || $[4] !== explorer || $[5] !== plugin || $[6] !== schema) {\n+                        t1 = () => {\n+                            if (!editor) {\n+                                return;\n+                            }\n+                            const handleCompletion = (instance, changeObj) => {\n+                                onHasCompletion(instance, changeObj, schema, explorer, plugin, type => {\n+                                    callback == null ? void 0 : callback({\n+                                        kind: \"Type\",\n+                                        type,\n+                                        schema: schema || void 0\n+                                    });\n+                                });\n+                            };\n+                            editor.on(\"hasCompletion\", handleCompletion);\n+                            return () => editor.off(\"hasCompletion\", handleCompletion);\n+                        };\n+                        t2 = [callback, editor, explorer, plugin, schema];\n+                        $[2] = callback;\n+                        $[3] = editor;\n+                        $[4] = explorer;\n+                        $[5] = plugin;\n+                        $[6] = schema;\n+                        $[7] = t1;\n+                        $[8] = t2;\n+                    } else {\n+                        t1 = $[7];\n+                        t2 = $[8];\n+                    }\n+                    React.useEffect(t1, t2);\n+                }\n \n-                // Push new token to \"stream\".\n-                // If pending text exists - flush it as text token\n-                //\n-                StateInline.prototype.push = function(type, tag, nesting) {\n-                    if (this.pending) {\n-                        this.pushPending();\n+                function useKeyMap(editor, keys, callback) {\n+                    const $ = reactCompilerRuntime.c(5);\n+                    let t0;\n+                    let t1;\n+                    if ($[0] !== callback || $[1] !== editor || $[2] !== keys) {\n+                        t0 = () => {\n+                            if (!editor) {\n+                                return;\n+                            }\n+                            for (const key of keys) {\n+                                editor.removeKeyMap(key);\n+                            }\n+                            if (callback) {\n+                                const keyMap = {};\n+                                for (const key_0 of keys) {\n+                                    keyMap[key_0] = () => callback();\n+                                }\n+                                editor.addKeyMap(keyMap);\n+                            }\n+                        };\n+                        t1 = [editor, keys, callback];\n+                        $[0] = callback;\n+                        $[1] = editor;\n+                        $[2] = keys;\n+                        $[3] = t0;\n+                        $[4] = t1;\n+                    } else {\n+                        t0 = $[3];\n+                        t1 = $[4];\n                     }\n-                    const token = new Token(type, tag, nesting);\n-                    let token_meta = null;\n-                    if (nesting < 0) {\n-                        // closing tag\n-                        this.level--;\n-                        this.delimiters = this._prev_delimiters.pop();\n+                    React.useEffect(t0, t1);\n+                }\n+                const _useCopyQuery = useCopyQuery;\n+                const _useMergeQuery = useMergeQuery;\n+                const _usePrettifyEditors = usePrettifyEditors;\n+                const _useAutoCompleteLeafs = useAutoCompleteLeafs;\n+\n+                function useCopyQuery(t0) {\n+                    const $ = reactCompilerRuntime.c(7);\n+                    let t1;\n+                    if ($[0] !== t0) {\n+                        t1 = t0 === void 0 ? {} : t0;\n+                        $[0] = t0;\n+                        $[1] = t1;\n+                    } else {\n+                        t1 = $[1];\n                     }\n-                    token.level = this.level;\n-                    if (nesting > 0) {\n-                        // opening tag\n-                        this.level++;\n-                        this._prev_delimiters.push(this.delimiters);\n-                        this.delimiters = [];\n-                        token_meta = {\n-                            delimiters: this.delimiters\n+                    const {\n+                        caller,\n+                        onCopyQuery\n+                    } = t1;\n+                    const t2 = caller || _useCopyQuery;\n+                    let t3;\n+                    if ($[2] !== t2) {\n+                        t3 = {\n+                            nonNull: true,\n+                            caller: t2\n                         };\n+                        $[2] = t2;\n+                        $[3] = t3;\n+                    } else {\n+                        t3 = $[3];\n                     }\n-                    this.pendingLevel = this.level;\n-                    this.tokens.push(token);\n-                    this.tokens_meta.push(token_meta);\n-                    return token;\n-                };\n-\n-                // Scan a sequence of emphasis-like markers, and determine whether\n-                // it can start an emphasis sequence or end an emphasis sequence.\n-                //\n-                //  - start - position to scan from (it should point at a valid marker);\n-                //  - canSplitWord - determine if these markers can be found inside a word\n-                //\n-                StateInline.prototype.scanDelims = function(start, canSplitWord) {\n-                    const max = this.posMax;\n-                    const marker = this.src.charCodeAt(start);\n-\n-                    // treat beginning of the line as a whitespace\n-                    const lastChar = start > 0 ? this.src.charCodeAt(start - 1) : 0x20;\n-                    let pos = start;\n-                    while (pos < max && this.src.charCodeAt(pos) === marker) {\n-                        pos++;\n+                    const {\n+                        queryEditor\n+                    } = useEditorContext(t3);\n+                    let t4;\n+                    if ($[4] !== onCopyQuery || $[5] !== queryEditor) {\n+                        t4 = () => {\n+                            if (!queryEditor) {\n+                                return;\n+                            }\n+                            const query = queryEditor.getValue();\n+                            copyToClipboard(query);\n+                            onCopyQuery == null ? void 0 : onCopyQuery(query);\n+                        };\n+                        $[4] = onCopyQuery;\n+                        $[5] = queryEditor;\n+                        $[6] = t4;\n+                    } else {\n+                        t4 = $[6];\n                     }\n-                    const count = pos - start;\n-\n-                    // treat end of the line as a whitespace\n-                    const nextChar = pos < max ? this.src.charCodeAt(pos) : 0x20;\n-                    const isLastPunctChar = isMdAsciiPunct(lastChar) || isPunctChar(String.fromCharCode(lastChar));\n-                    const isNextPunctChar = isMdAsciiPunct(nextChar) || isPunctChar(String.fromCharCode(nextChar));\n-                    const isLastWhiteSpace = isWhiteSpace(lastChar);\n-                    const isNextWhiteSpace = isWhiteSpace(nextChar);\n-                    const left_flanking = !isNextWhiteSpace && (!isNextPunctChar || isLastWhiteSpace || isLastPunctChar);\n-                    const right_flanking = !isLastWhiteSpace && (!isLastPunctChar || isNextWhiteSpace || isNextPunctChar);\n-                    const can_open = left_flanking && (canSplitWord || !right_flanking || isLastPunctChar);\n-                    const can_close = right_flanking && (canSplitWord || !left_flanking || isNextPunctChar);\n-                    return {\n-                        can_open,\n-                        can_close,\n-                        length: count\n-                    };\n-                };\n-\n-                // re-export Token class to use in block rules\n-                StateInline.prototype.Token = Token;\n-\n-                // Skip text characters for text token, place those to pending buffer\n-                // and increment current pos\n-\n-                // Rule to skip pure text\n-                // '{}$%@~+=:' reserved for extentions\n-\n-                // !, \", #, $, %, &, ', (, ), *, +, ,, -, ., /, :, ;, <, =, >, ?, @, [, \\, ], ^, _, `, {, |, }, or ~\n+                    return t4;\n+                }\n \n-                // !!!! Don't confuse with \"Markdown ASCII Punctuation\" chars\n-                // http://spec.commonmark.org/0.15/#ascii-punctuation-character\n-                function isTerminatorChar(ch) {\n-                    switch (ch) {\n-                        case 0x0A /* \\n */ :\n-                        case 0x21 /* ! */ :\n-                        case 0x23 /* # */ :\n-                        case 0x24 /* $ */ :\n-                        case 0x25 /* % */ :\n-                        case 0x26 /* & */ :\n-                        case 0x2A /* * */ :\n-                        case 0x2B /* + */ :\n-                        case 0x2D /* - */ :\n-                        case 0x3A /* : */ :\n-                        case 0x3C /* < */ :\n-                        case 0x3D /* = */ :\n-                        case 0x3E /* > */ :\n-                        case 0x40 /* @ */ :\n-                        case 0x5B /* [ */ :\n-                        case 0x5C /* \\ */ :\n-                        case 0x5D /* ] */ :\n-                        case 0x5E /* ^ */ :\n-                        case 0x5F /* _ */ :\n-                        case 0x60 /* ` */ :\n-                        case 0x7B /* { */ :\n-                        case 0x7D /* } */ :\n-                        case 0x7E /* ~ */ :\n-                            return true;\n-                        default:\n-                            return false;\n+                function useMergeQuery(t0) {\n+                    const $ = reactCompilerRuntime.c(8);\n+                    let t1;\n+                    if ($[0] !== t0) {\n+                        t1 = t0 === void 0 ? {} : t0;\n+                        $[0] = t0;\n+                        $[1] = t1;\n+                    } else {\n+                        t1 = $[1];\n+                    }\n+                    const {\n+                        caller\n+                    } = t1;\n+                    const t2 = caller || _useMergeQuery;\n+                    let t3;\n+                    if ($[2] !== t2) {\n+                        t3 = {\n+                            nonNull: true,\n+                            caller: t2\n+                        };\n+                        $[2] = t2;\n+                        $[3] = t3;\n+                    } else {\n+                        t3 = $[3];\n+                    }\n+                    const {\n+                        queryEditor\n+                    } = useEditorContext(t3);\n+                    let t4;\n+                    if ($[4] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t4 = {\n+                            nonNull: true,\n+                            caller: _useMergeQuery\n+                        };\n+                        $[4] = t4;\n+                    } else {\n+                        t4 = $[4];\n+                    }\n+                    const {\n+                        schema\n+                    } = useSchemaContext(t4);\n+                    let t5;\n+                    if ($[5] !== queryEditor || $[6] !== schema) {\n+                        t5 = () => {\n+                            const documentAST = queryEditor == null ? void 0 : queryEditor.documentAST;\n+                            const query = queryEditor == null ? void 0 : queryEditor.getValue();\n+                            if (!documentAST || !query) {\n+                                return;\n+                            }\n+                            queryEditor.setValue(graphql.print(toolkit.mergeAst(documentAST, schema)));\n+                        };\n+                        $[5] = queryEditor;\n+                        $[6] = schema;\n+                        $[7] = t5;\n+                    } else {\n+                        t5 = $[7];\n                     }\n+                    return t5;\n                 }\n \n-                function text(state, silent) {\n-                    let pos = state.pos;\n-                    while (pos < state.posMax && !isTerminatorChar(state.src.charCodeAt(pos))) {\n-                        pos++;\n+                function usePrettifyEditors(t0) {\n+                    const $ = reactCompilerRuntime.c(8);\n+                    let t1;\n+                    if ($[0] !== t0) {\n+                        t1 = t0 === void 0 ? {} : t0;\n+                        $[0] = t0;\n+                        $[1] = t1;\n+                    } else {\n+                        t1 = $[1];\n                     }\n-                    if (pos === state.pos) {\n-                        return false;\n+                    const {\n+                        caller\n+                    } = t1;\n+                    const t2 = caller || _usePrettifyEditors;\n+                    let t3;\n+                    if ($[2] !== t2) {\n+                        t3 = {\n+                            nonNull: true,\n+                            caller: t2\n+                        };\n+                        $[2] = t2;\n+                        $[3] = t3;\n+                    } else {\n+                        t3 = $[3];\n                     }\n-                    if (!silent) {\n-                        state.pending += state.src.slice(state.pos, pos);\n+                    const {\n+                        queryEditor,\n+                        headerEditor,\n+                        variableEditor\n+                    } = useEditorContext(t3);\n+                    let t4;\n+                    if ($[4] !== headerEditor || $[5] !== queryEditor || $[6] !== variableEditor) {\n+                        t4 = () => {\n+                            if (variableEditor) {\n+                                const variableEditorContent = variableEditor.getValue();\n+                                try {\n+                                    const prettifiedVariableEditorContent = JSON.stringify(JSON.parse(variableEditorContent), null, 2);\n+                                    if (prettifiedVariableEditorContent !== variableEditorContent) {\n+                                        variableEditor.setValue(prettifiedVariableEditorContent);\n+                                    }\n+                                } catch {}\n+                            }\n+                            if (headerEditor) {\n+                                const headerEditorContent = headerEditor.getValue();\n+                                try {\n+                                    const prettifiedHeaderEditorContent = JSON.stringify(JSON.parse(headerEditorContent), null, 2);\n+                                    if (prettifiedHeaderEditorContent !== headerEditorContent) {\n+                                        headerEditor.setValue(prettifiedHeaderEditorContent);\n+                                    }\n+                                } catch {}\n+                            }\n+                            if (queryEditor) {\n+                                const editorContent = queryEditor.getValue();\n+                                const prettifiedEditorContent = graphql.print(graphql.parse(editorContent));\n+                                if (prettifiedEditorContent !== editorContent) {\n+                                    queryEditor.setValue(prettifiedEditorContent);\n+                                }\n+                            }\n+                        };\n+                        $[4] = headerEditor;\n+                        $[5] = queryEditor;\n+                        $[6] = variableEditor;\n+                        $[7] = t4;\n+                    } else {\n+                        t4 = $[7];\n                     }\n-                    state.pos = pos;\n-                    return true;\n+                    return t4;\n                 }\n \n-                // Alternative implementation, for memory.\n-                //\n-                // It costs 10% of performance, but allows extend terminators list, if place it\n-                // to `ParserInline` property. Probably, will switch to it sometime, such\n-                // flexibility required.\n-\n-                /*\n-                var TERMINATOR_RE = /[\\n!#$%&*+\\-:<=>@[\\\\\\]^_`{}~]/;\n-\n-                module.exports = function text(state, silent) {\n-                  var pos = state.pos,\n-                      idx = state.src.slice(pos).search(TERMINATOR_RE);\n-\n-                  // first char is terminator -> empty text\n-                  if (idx === 0) { return false; }\n+                function useAutoCompleteLeafs(t0) {\n+                    const $ = reactCompilerRuntime.c(10);\n+                    let t1;\n+                    if ($[0] !== t0) {\n+                        t1 = t0 === void 0 ? {} : t0;\n+                        $[0] = t0;\n+                        $[1] = t1;\n+                    } else {\n+                        t1 = $[1];\n+                    }\n+                    const {\n+                        getDefaultFieldNames,\n+                        caller\n+                    } = t1;\n+                    const t2 = caller || _useAutoCompleteLeafs;\n+                    let t3;\n+                    if ($[2] !== t2) {\n+                        t3 = {\n+                            nonNull: true,\n+                            caller: t2\n+                        };\n+                        $[2] = t2;\n+                        $[3] = t3;\n+                    } else {\n+                        t3 = $[3];\n+                    }\n+                    const {\n+                        schema\n+                    } = useSchemaContext(t3);\n+                    const t4 = caller || _useAutoCompleteLeafs;\n+                    let t5;\n+                    if ($[4] !== t4) {\n+                        t5 = {\n+                            nonNull: true,\n+                            caller: t4\n+                        };\n+                        $[4] = t4;\n+                        $[5] = t5;\n+                    } else {\n+                        t5 = $[5];\n+                    }\n+                    const {\n+                        queryEditor\n+                    } = useEditorContext(t5);\n+                    let t6;\n+                    if ($[6] !== getDefaultFieldNames || $[7] !== queryEditor || $[8] !== schema) {\n+                        t6 = () => {\n+                            if (!queryEditor) {\n+                                return;\n+                            }\n+                            const query = queryEditor.getValue();\n+                            const {\n+                                insertions,\n+                                result\n+                            } = toolkit.fillLeafs(schema, query, getDefaultFieldNames);\n+                            if (insertions && insertions.length > 0) {\n+                                queryEditor.operation(() => {\n+                                    const cursor = queryEditor.getCursor();\n+                                    const cursorIndex = queryEditor.indexFromPos(cursor);\n+                                    queryEditor.setValue(result || \"\");\n+                                    let added;\n+                                    added = 0;\n+                                    const markers = insertions.map(t7 => {\n+                                        const {\n+                                            index,\n+                                            string\n+                                        } = t7;\n+                                        added = added + string.length;\n+                                        return queryEditor.markText(queryEditor.posFromIndex(index + added), queryEditor.posFromIndex(index + added), {\n+                                            className: \"auto-inserted-leaf\",\n+                                            clearOnEnter: true,\n+                                            title: \"Automatically added leaf fields\"\n+                                        });\n+                                    });\n+                                    setTimeout(() => {\n+                                        for (const marker of markers) {\n+                                            marker.clear();\n+                                        }\n+                                    }, 7e3);\n+                                    let newCursorIndex = cursorIndex;\n+                                    for (const {\n+                                            index: index_0,\n+                                            string: string_0\n+                                        }\n+                                        of insertions) {\n+                                        if (index_0 < cursorIndex) {\n+                                            newCursorIndex = newCursorIndex + string_0.length;\n+                                        }\n+                                    }\n+                                    queryEditor.setCursor(queryEditor.posFromIndex(newCursorIndex));\n+                                });\n+                            }\n+                            return result;\n+                        };\n+                        $[6] = getDefaultFieldNames;\n+                        $[7] = queryEditor;\n+                        $[8] = schema;\n+                        $[9] = t6;\n+                    } else {\n+                        t6 = $[9];\n+                    }\n+                    return t6;\n+                }\n+                const useEditorState = editor => {\n+                    \"use no memo\";\n \n-                  // no terminator -> text till end of string\n-                  if (idx < 0) {\n-                    if (!silent) { state.pending += state.src.slice(pos); }\n-                    state.pos = state.src.length;\n-                    return true;\n-                  }\n+                    var _ref2;\n+                    const context = useEditorContext({\n+                        nonNull: true\n+                    });\n+                    const editorInstance = context[`${editor}Editor`];\n+                    let valueString = \"\";\n+                    const editorValue = (_ref2 = editorInstance == null ? void 0 : editorInstance.getValue()) !== null && _ref2 !== void 0 ? _ref2 : false;\n+                    if (editorValue && editorValue.length > 0) {\n+                        valueString = editorValue;\n+                    }\n+                    const handleEditorValue = React.useCallback(value => editorInstance == null ? void 0 : editorInstance.setValue(value), [editorInstance]);\n+                    return React.useMemo(() => [valueString, handleEditorValue], [valueString, handleEditorValue]);\n+                };\n+                const useOperationsEditorState = () => {\n+                    return useEditorState(\"query\");\n+                };\n+                const useVariablesEditorState = () => {\n+                    return useEditorState(\"variable\");\n+                };\n+                const useHeadersEditorState = () => {\n+                    return useEditorState(\"header\");\n+                };\n+\n+                function useOptimisticState(t0) {\n+                    const $ = reactCompilerRuntime.c(12);\n+                    const [upstreamState, upstreamSetState] = t0;\n+                    let t1;\n+                    if ($[0] !== upstreamState) {\n+                        t1 = {\n+                            pending: null,\n+                            last: upstreamState\n+                        };\n+                        $[0] = upstreamState;\n+                        $[1] = t1;\n+                    } else {\n+                        t1 = $[1];\n+                    }\n+                    const lastStateRef = React.useRef(t1);\n+                    const [state, setOperationsText] = React.useState(upstreamState);\n+                    let t2;\n+                    let t3;\n+                    if ($[2] !== state || $[3] !== upstreamSetState || $[4] !== upstreamState) {\n+                        t2 = () => {\n+                            if (lastStateRef.current.last === upstreamState);\n+                            else {\n+                                lastStateRef.current.last = upstreamState;\n+                                if (lastStateRef.current.pending === null) {\n+                                    setOperationsText(upstreamState);\n+                                } else {\n+                                    if (lastStateRef.current.pending === upstreamState) {\n+                                        lastStateRef.current.pending = null;\n+                                        if (upstreamState !== state) {\n+                                            lastStateRef.current.pending = state;\n+                                            upstreamSetState(state);\n+                                        }\n+                                    } else {\n+                                        lastStateRef.current.pending = null;\n+                                        setOperationsText(upstreamState);\n+                                    }\n+                                }\n+                            }\n+                        };\n+                        t3 = [upstreamState, state, upstreamSetState];\n+                        $[2] = state;\n+                        $[3] = upstreamSetState;\n+                        $[4] = upstreamState;\n+                        $[5] = t2;\n+                        $[6] = t3;\n+                    } else {\n+                        t2 = $[5];\n+                        t3 = $[6];\n+                    }\n+                    React.useEffect(t2, t3);\n+                    let t4;\n+                    if ($[7] !== upstreamSetState) {\n+                        t4 = newState => {\n+                            setOperationsText(newState);\n+                            if (lastStateRef.current.pending === null && lastStateRef.current.last !== newState) {\n+                                lastStateRef.current.pending = newState;\n+                                upstreamSetState(newState);\n+                            }\n+                        };\n+                        $[7] = upstreamSetState;\n+                        $[8] = t4;\n+                    } else {\n+                        t4 = $[8];\n+                    }\n+                    const setState = t4;\n+                    let t5;\n+                    if ($[9] !== setState || $[10] !== state) {\n+                        t5 = [state, setState];\n+                        $[9] = setState;\n+                        $[10] = state;\n+                        $[11] = t5;\n+                    } else {\n+                        t5 = $[11];\n+                    }\n+                    return t5;\n+                }\n \n-                  if (!silent) { state.pending += state.src.slice(pos, pos + idx); }\n+                function importCodeMirrorImports$3() {\n+                    return importCodeMirror([ // @ts-expect-error\n+                        Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror/mode/javascript/javascript.js */ \"../../../node_modules/codemirror/mode/javascript/javascript.js\")))\n+                    ]);\n+                }\n+                const _useHeaderEditor = useHeaderEditor;\n \n-                  state.pos += idx;\n+                function useHeaderEditor(t0, caller) {\n+                    const $ = reactCompilerRuntime.c(17);\n+                    let t1;\n+                    if ($[0] !== t0) {\n+                        t1 = t0 === void 0 ? {} : t0;\n+                        $[0] = t0;\n+                        $[1] = t1;\n+                    } else {\n+                        t1 = $[1];\n+                    }\n+                    const {\n+                        editorTheme: t2,\n+                        keyMap: t3,\n+                        onEdit,\n+                        readOnly: t4\n+                    } = t1;\n+                    const editorTheme = t2 === void 0 ? DEFAULT_EDITOR_THEME : t2;\n+                    const keyMap = t3 === void 0 ? DEFAULT_KEY_MAP : t3;\n+                    const readOnly = t4 === void 0 ? false : t4;\n+                    const t5 = caller || _useHeaderEditor;\n+                    let t6;\n+                    if ($[2] !== t5) {\n+                        t6 = {\n+                            nonNull: true,\n+                            caller: t5\n+                        };\n+                        $[2] = t5;\n+                        $[3] = t6;\n+                    } else {\n+                        t6 = $[3];\n+                    }\n+                    const {\n+                        initialHeaders,\n+                        headerEditor,\n+                        setHeaderEditor,\n+                        shouldPersistHeaders\n+                    } = useEditorContext(t6);\n+                    const executionContext = useExecutionContext();\n+                    const t7 = caller || _useHeaderEditor;\n+                    let t8;\n+                    if ($[4] !== t7) {\n+                        t8 = {\n+                            caller: t7\n+                        };\n+                        $[4] = t7;\n+                        $[5] = t8;\n+                    } else {\n+                        t8 = $[5];\n+                    }\n+                    const merge = useMergeQuery(t8);\n+                    const t9 = caller || _useHeaderEditor;\n+                    let t10;\n+                    if ($[6] !== t9) {\n+                        t10 = {\n+                            caller: t9\n+                        };\n+                        $[6] = t9;\n+                        $[7] = t10;\n+                    } else {\n+                        t10 = $[7];\n+                    }\n+                    const prettify = usePrettifyEditors(t10);\n+                    const ref = React.useRef(null);\n+                    let t11;\n+                    let t12;\n+                    if ($[8] !== editorTheme || $[9] !== initialHeaders || $[10] !== readOnly || $[11] !== setHeaderEditor) {\n+                        t11 = () => {\n+                            let isActive;\n+                            isActive = true;\n+                            importCodeMirrorImports$3().then(CodeMirror => {\n+                                if (!isActive) {\n+                                    return;\n+                                }\n+                                const container = ref.current;\n+                                if (!container) {\n+                                    return;\n+                                }\n+                                const newEditor = CodeMirror(container, {\n+                                    value: initialHeaders,\n+                                    lineNumbers: true,\n+                                    tabSize: 2,\n+                                    mode: {\n+                                        name: \"javascript\",\n+                                        json: true\n+                                    },\n+                                    theme: editorTheme,\n+                                    autoCloseBrackets: true,\n+                                    matchBrackets: true,\n+                                    showCursorWhenSelecting: true,\n+                                    readOnly: readOnly ? \"nocursor\" : false,\n+                                    foldGutter: true,\n+                                    gutters: [\"CodeMirror-linenumbers\", \"CodeMirror-foldgutter\"],\n+                                    extraKeys: commonKeys\n+                                });\n+                                newEditor.addKeyMap({\n+                                    \"Cmd-Space\"() {\n+                                        newEditor.showHint({\n+                                            completeSingle: false,\n+                                            container\n+                                        });\n+                                    },\n+                                    \"Ctrl-Space\"() {\n+                                        newEditor.showHint({\n+                                            completeSingle: false,\n+                                            container\n+                                        });\n+                                    },\n+                                    \"Alt-Space\"() {\n+                                        newEditor.showHint({\n+                                            completeSingle: false,\n+                                            container\n+                                        });\n+                                    },\n+                                    \"Shift-Space\"() {\n+                                        newEditor.showHint({\n+                                            completeSingle: false,\n+                                            container\n+                                        });\n+                                    }\n+                                });\n+                                newEditor.on(\"keyup\", _temp$2);\n+                                setHeaderEditor(newEditor);\n+                            });\n+                            return () => {\n+                                isActive = false;\n+                            };\n+                        };\n+                        t12 = [editorTheme, initialHeaders, readOnly, setHeaderEditor];\n+                        $[8] = editorTheme;\n+                        $[9] = initialHeaders;\n+                        $[10] = readOnly;\n+                        $[11] = setHeaderEditor;\n+                        $[12] = t11;\n+                        $[13] = t12;\n+                    } else {\n+                        t11 = $[12];\n+                        t12 = $[13];\n+                    }\n+                    React.useEffect(t11, t12);\n+                    useSynchronizeOption(headerEditor, \"keyMap\", keyMap);\n+                    useChangeHandler(headerEditor, onEdit, shouldPersistHeaders ? STORAGE_KEY$3 : null, \"headers\", _useHeaderEditor);\n+                    let t13;\n+                    if ($[14] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t13 = [\"Cmd-Enter\", \"Ctrl-Enter\"];\n+                        $[14] = t13;\n+                    } else {\n+                        t13 = $[14];\n+                    }\n+                    useKeyMap(headerEditor, t13, executionContext == null ? void 0 : executionContext.run);\n+                    let t14;\n+                    if ($[15] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t14 = [\"Shift-Ctrl-P\"];\n+                        $[15] = t14;\n+                    } else {\n+                        t14 = $[15];\n+                    }\n+                    useKeyMap(headerEditor, t14, prettify);\n+                    let t15;\n+                    if ($[16] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t15 = [\"Shift-Ctrl-M\"];\n+                        $[16] = t15;\n+                    } else {\n+                        t15 = $[16];\n+                    }\n+                    useKeyMap(headerEditor, t15, merge);\n+                    return ref;\n+                }\n \n-                  return true;\n-                }; */\n+                function _temp$2(editorInstance, event) {\n+                    const {\n+                        code,\n+                        key,\n+                        shiftKey\n+                    } = event;\n+                    const isLetter = code.startsWith(\"Key\");\n+                    const isNumber = !shiftKey && code.startsWith(\"Digit\");\n+                    if (isLetter || isNumber || key === \"_\" || key === '\"') {\n+                        editorInstance.execCommand(\"autocomplete\");\n+                    }\n+                }\n+                const STORAGE_KEY$3 = \"headers\";\n+                const invalidCharacters = Array.from({\n+                    length: 11\n+                }, (_, i) => {\n+                    return String.fromCharCode(8192 + i);\n+                }).concat([\"\\u2028\", \"\\u2029\", \"\u202f\", \"\u00a0\"]);\n+                const sanitizeRegex = new RegExp(\"[\" + invalidCharacters.join(\"\") + \"]\", \"g\");\n \n-                // Process links like https://example.org/\n+                function normalizeWhitespace(line) {\n+                    return line.replace(sanitizeRegex, \" \");\n+                }\n \n-                // RFC3986: scheme = ALPHA *( ALPHA / DIGIT / \"+\" / \"-\" / \".\" )\n-                const SCHEME_RE = /(?:^|[^a-z0-9.+-])([a-z][a-z0-9.+-]*)$/i;\n+                function importCodeMirrorImports$2() {\n+                    return importCodeMirror([Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror/addon/comment/comment.js */ \"../../../node_modules/codemirror/addon/comment/comment.js\"))), Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror/addon/search/search.js */ \"../../../node_modules/codemirror/addon/search/search.js\"))), Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror-graphql/esm/hint.js */ \"../../codemirror-graphql/esm/hint.js\"))), Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror-graphql/esm/lint.js */ \"../../codemirror-graphql/esm/lint.js\"))), Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror-graphql/esm/info.js */ \"../../codemirror-graphql/esm/info.js\"))), Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror-graphql/esm/jump.js */ \"../../codemirror-graphql/esm/jump.js\"))), Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror-graphql/esm/mode.js */ \"../../codemirror-graphql/esm/mode.js\")))]);\n+                }\n+                const _useQueryEditor = useQueryEditor;\n \n-                function linkify(state, silent) {\n-                    if (!state.md.options.linkify) return false;\n-                    if (state.linkLevel > 0) return false;\n-                    const pos = state.pos;\n-                    const max = state.posMax;\n-                    if (pos + 3 > max) return false;\n-                    if (state.src.charCodeAt(pos) !== 0x3A /* : */ ) return false;\n-                    if (state.src.charCodeAt(pos + 1) !== 0x2F /* / */ ) return false;\n-                    if (state.src.charCodeAt(pos + 2) !== 0x2F /* / */ ) return false;\n-                    const match = state.pending.match(SCHEME_RE);\n-                    if (!match) return false;\n-                    const proto = match[1];\n-                    const link = state.md.linkify.matchAtStart(state.src.slice(pos - proto.length));\n-                    if (!link) return false;\n-                    let url = link.url;\n+                function updateVariableEditor(variableEditor, operationFacts) {\n+                    variableEditor.state.lint.linterOptions.variableToType = operationFacts == null ? void 0 : operationFacts.variableToType;\n+                    variableEditor.options.lint.variableToType = operationFacts == null ? void 0 : operationFacts.variableToType;\n+                    variableEditor.options.hintOptions.variableToType = operationFacts == null ? void 0 : operationFacts.variableToType;\n+                }\n \n-                    // invalid link, but still detected by linkify somehow;\n-                    // need to check to prevent infinite loop below\n-                    if (url.length <= proto.length) return false;\n+                function updateEditorSchema(editor, schema) {\n+                    editor.state.lint.linterOptions.schema = schema;\n+                    editor.options.lint.schema = schema;\n+                    editor.options.hintOptions.schema = schema;\n+                    editor.options.info.schema = schema;\n+                    editor.options.jump.schema = schema;\n+                }\n \n-                    // disallow '*' at the end of the link (conflicts with emphasis)\n-                    url = url.replace(/\\*+$/, '');\n-                    const fullUrl = state.md.normalizeLink(url);\n-                    if (!state.md.validateLink(fullUrl)) return false;\n-                    if (!silent) {\n-                        state.pending = state.pending.slice(0, -proto.length);\n-                        const token_o = state.push('link_open', 'a', 1);\n-                        token_o.attrs = [\n-                            ['href', fullUrl]\n-                        ];\n-                        token_o.markup = 'linkify';\n-                        token_o.info = 'auto';\n-                        const token_t = state.push('text', '', 0);\n-                        token_t.content = state.md.normalizeLinkText(url);\n-                        const token_c = state.push('link_close', 'a', -1);\n-                        token_c.markup = 'linkify';\n-                        token_c.info = 'auto';\n-                    }\n-                    state.pos += url.length - proto.length;\n-                    return true;\n+                function updateEditorValidationRules(editor, validationRules) {\n+                    editor.state.lint.linterOptions.validationRules = validationRules;\n+                    editor.options.lint.validationRules = validationRules;\n                 }\n \n-                // Proceess '\\n'\n+                function updateEditorExternalFragments(editor, externalFragmentList) {\n+                    editor.state.lint.linterOptions.externalFragments = externalFragmentList;\n+                    editor.options.lint.externalFragments = externalFragmentList;\n+                    editor.options.hintOptions.externalFragments = externalFragmentList;\n+                }\n \n-                function newline(state, silent) {\n-                    let pos = state.pos;\n-                    if (state.src.charCodeAt(pos) !== 0x0A /* \\n */ ) {\n-                        return false;\n+                function useQueryEditor(t0, caller) {\n+                    const $ = reactCompilerRuntime.c(41);\n+                    let t1;\n+                    if ($[0] !== t0) {\n+                        t1 = t0 === void 0 ? {} : t0;\n+                        $[0] = t0;\n+                        $[1] = t1;\n+                    } else {\n+                        t1 = $[1];\n                     }\n-                    const pmax = state.pending.length - 1;\n-                    const max = state.posMax;\n-\n-                    // '  \\n' -> hardbreak\n-                    // Lookup in pending chars is bad practice! Don't copy to other rules!\n-                    // Pending string is stored in concat mode, indexed lookups will cause\n-                    // convertion to flat mode.\n-                    if (!silent) {\n-                        if (pmax >= 0 && state.pending.charCodeAt(pmax) === 0x20) {\n-                            if (pmax >= 1 && state.pending.charCodeAt(pmax - 1) === 0x20) {\n-                                // Find whitespaces tail of pending chars.\n-                                let ws = pmax - 1;\n-                                while (ws >= 1 && state.pending.charCodeAt(ws - 1) === 0x20) ws--;\n-                                state.pending = state.pending.slice(0, ws);\n-                                state.push('hardbreak', 'br', 0);\n-                            } else {\n-                                state.pending = state.pending.slice(0, -1);\n-                                state.push('softbreak', 'br', 0);\n+                    const {\n+                        editorTheme: t2,\n+                        keyMap: t3,\n+                        onClickReference,\n+                        onCopyQuery,\n+                        onEdit,\n+                        readOnly: t4\n+                    } = t1;\n+                    const editorTheme = t2 === void 0 ? DEFAULT_EDITOR_THEME : t2;\n+                    const keyMap = t3 === void 0 ? DEFAULT_KEY_MAP : t3;\n+                    const readOnly = t4 === void 0 ? false : t4;\n+                    const t5 = caller || _useQueryEditor;\n+                    let t6;\n+                    if ($[2] !== t5) {\n+                        t6 = {\n+                            nonNull: true,\n+                            caller: t5\n+                        };\n+                        $[2] = t5;\n+                        $[3] = t6;\n+                    } else {\n+                        t6 = $[3];\n+                    }\n+                    const {\n+                        schema\n+                    } = useSchemaContext(t6);\n+                    const t7 = caller || _useQueryEditor;\n+                    let t8;\n+                    if ($[4] !== t7) {\n+                        t8 = {\n+                            nonNull: true,\n+                            caller: t7\n+                        };\n+                        $[4] = t7;\n+                        $[5] = t8;\n+                    } else {\n+                        t8 = $[5];\n+                    }\n+                    const {\n+                        externalFragments,\n+                        initialQuery,\n+                        queryEditor,\n+                        setOperationName,\n+                        setQueryEditor,\n+                        validationRules,\n+                        variableEditor,\n+                        updateActiveTabValues\n+                    } = useEditorContext(t8);\n+                    const executionContext = useExecutionContext();\n+                    const storage = useStorageContext();\n+                    const explorer = useExplorerContext();\n+                    const plugin = usePluginContext();\n+                    const t9 = caller || _useQueryEditor;\n+                    let t10;\n+                    if ($[6] !== onCopyQuery || $[7] !== t9) {\n+                        t10 = {\n+                            caller: t9,\n+                            onCopyQuery\n+                        };\n+                        $[6] = onCopyQuery;\n+                        $[7] = t9;\n+                        $[8] = t10;\n+                    } else {\n+                        t10 = $[8];\n+                    }\n+                    const copy = useCopyQuery(t10);\n+                    const t11 = caller || _useQueryEditor;\n+                    let t12;\n+                    if ($[9] !== t11) {\n+                        t12 = {\n+                            caller: t11\n+                        };\n+                        $[9] = t11;\n+                        $[10] = t12;\n+                    } else {\n+                        t12 = $[10];\n+                    }\n+                    const merge = useMergeQuery(t12);\n+                    const t13 = caller || _useQueryEditor;\n+                    let t14;\n+                    if ($[11] !== t13) {\n+                        t14 = {\n+                            caller: t13\n+                        };\n+                        $[11] = t13;\n+                        $[12] = t14;\n+                    } else {\n+                        t14 = $[12];\n+                    }\n+                    const prettify = usePrettifyEditors(t14);\n+                    const ref = React.useRef(null);\n+                    const codeMirrorRef = React.useRef();\n+                    const onClickReferenceRef = React.useRef(_temp$1);\n+                    let t15;\n+                    let t16;\n+                    if ($[13] !== explorer || $[14] !== onClickReference || $[15] !== plugin) {\n+                        t15 = () => {\n+                            onClickReferenceRef.current = reference => {\n+                                if (!explorer || !plugin) {\n+                                    return;\n+                                }\n+                                plugin.setVisiblePlugin(DOC_EXPLORER_PLUGIN);\n+                                bb47: switch (reference.kind) {\n+                                    case \"Type\": {\n+                                        explorer.push({\n+                                            name: reference.type.name,\n+                                            def: reference.type\n+                                        });\n+                                        break bb47;\n+                                    }\n+                                    case \"Field\": {\n+                                        explorer.push({\n+                                            name: reference.field.name,\n+                                            def: reference.field\n+                                        });\n+                                        break bb47;\n+                                    }\n+                                    case \"Argument\": {\n+                                        if (reference.field) {\n+                                            explorer.push({\n+                                                name: reference.field.name,\n+                                                def: reference.field\n+                                            });\n+                                        }\n+                                        break bb47;\n+                                    }\n+                                    case \"EnumValue\": {\n+                                        if (reference.type) {\n+                                            explorer.push({\n+                                                name: reference.type.name,\n+                                                def: reference.type\n+                                            });\n+                                        }\n+                                    }\n+                                }\n+                                onClickReference == null ? void 0 : onClickReference(reference);\n+                            };\n+                        };\n+                        t16 = [explorer, onClickReference, plugin];\n+                        $[13] = explorer;\n+                        $[14] = onClickReference;\n+                        $[15] = plugin;\n+                        $[16] = t15;\n+                        $[17] = t16;\n+                    } else {\n+                        t15 = $[16];\n+                        t16 = $[17];\n+                    }\n+                    React.useEffect(t15, t16);\n+                    let t17;\n+                    let t18;\n+                    if ($[18] !== editorTheme || $[19] !== initialQuery || $[20] !== readOnly || $[21] !== setQueryEditor) {\n+                        t17 = () => {\n+                            let isActive;\n+                            isActive = true;\n+                            importCodeMirrorImports$2().then(CodeMirror => {\n+                                if (!isActive) {\n+                                    return;\n+                                }\n+                                codeMirrorRef.current = CodeMirror;\n+                                const container = ref.current;\n+                                if (!container) {\n+                                    return;\n+                                }\n+                                const newEditor = CodeMirror(container, {\n+                                    value: initialQuery,\n+                                    lineNumbers: true,\n+                                    tabSize: 2,\n+                                    foldGutter: true,\n+                                    mode: \"graphql\",\n+                                    theme: editorTheme,\n+                                    autoCloseBrackets: true,\n+                                    matchBrackets: true,\n+                                    showCursorWhenSelecting: true,\n+                                    readOnly: readOnly ? \"nocursor\" : false,\n+                                    lint: {\n+                                        schema: void 0,\n+                                        validationRules: null,\n+                                        externalFragments: void 0\n+                                    },\n+                                    hintOptions: {\n+                                        schema: void 0,\n+                                        closeOnUnfocus: false,\n+                                        completeSingle: false,\n+                                        container,\n+                                        externalFragments: void 0,\n+                                        autocompleteOptions: {\n+                                            mode: graphqlLanguageService.GraphQLDocumentMode.EXECUTABLE\n+                                        }\n+                                    },\n+                                    info: {\n+                                        schema: void 0,\n+                                        renderDescription: _temp2,\n+                                        onClick(reference_0) {\n+                                            onClickReferenceRef.current(reference_0);\n+                                        }\n+                                    },\n+                                    jump: {\n+                                        schema: void 0,\n+                                        onClick(reference_1) {\n+                                            onClickReferenceRef.current(reference_1);\n+                                        }\n+                                    },\n+                                    gutters: [\"CodeMirror-linenumbers\", \"CodeMirror-foldgutter\"],\n+                                    extraKeys: {\n+                                        ...commonKeys,\n+                                        \"Cmd-S\"() {},\n+                                        \"Ctrl-S\"() {}\n+                                    }\n+                                });\n+                                newEditor.addKeyMap({\n+                                    \"Cmd-Space\"() {\n+                                        newEditor.showHint({\n+                                            completeSingle: true,\n+                                            container\n+                                        });\n+                                    },\n+                                    \"Ctrl-Space\"() {\n+                                        newEditor.showHint({\n+                                            completeSingle: true,\n+                                            container\n+                                        });\n+                                    },\n+                                    \"Alt-Space\"() {\n+                                        newEditor.showHint({\n+                                            completeSingle: true,\n+                                            container\n+                                        });\n+                                    },\n+                                    \"Shift-Space\"() {\n+                                        newEditor.showHint({\n+                                            completeSingle: true,\n+                                            container\n+                                        });\n+                                    },\n+                                    \"Shift-Alt-Space\"() {\n+                                        newEditor.showHint({\n+                                            completeSingle: true,\n+                                            container\n+                                        });\n+                                    }\n+                                });\n+                                newEditor.on(\"keyup\", _temp3);\n+                                let showingHints;\n+                                showingHints = false;\n+                                newEditor.on(\"startCompletion\", () => {\n+                                    showingHints = true;\n+                                });\n+                                newEditor.on(\"endCompletion\", () => {\n+                                    showingHints = false;\n+                                });\n+                                newEditor.on(\"keydown\", (editorInstance_0, event_0) => {\n+                                    if (event_0.key === \"Escape\" && showingHints) {\n+                                        event_0.stopPropagation();\n+                                    }\n+                                });\n+                                newEditor.on(\"beforeChange\", _temp4);\n+                                newEditor.documentAST = null;\n+                                newEditor.operationName = null;\n+                                newEditor.operations = null;\n+                                newEditor.variableToType = null;\n+                                setQueryEditor(newEditor);\n+                            });\n+                            return () => {\n+                                isActive = false;\n+                            };\n+                        };\n+                        t18 = [editorTheme, initialQuery, readOnly, setQueryEditor];\n+                        $[18] = editorTheme;\n+                        $[19] = initialQuery;\n+                        $[20] = readOnly;\n+                        $[21] = setQueryEditor;\n+                        $[22] = t17;\n+                        $[23] = t18;\n+                    } else {\n+                        t17 = $[22];\n+                        t18 = $[23];\n+                    }\n+                    React.useEffect(t17, t18);\n+                    useSynchronizeOption(queryEditor, \"keyMap\", keyMap);\n+                    let t19;\n+                    let t20;\n+                    if ($[24] !== onEdit || $[25] !== queryEditor || $[26] !== schema || $[27] !== setOperationName || $[28] !== storage || $[29] !== updateActiveTabValues || $[30] !== variableEditor) {\n+                        t19 = () => {\n+                            if (!queryEditor) {\n+                                return;\n+                            }\n+                            const getAndUpdateOperationFacts = function getAndUpdateOperationFacts2(editorInstance_2) {\n+                                var _editorInstance_2$ope, _editorInstance_2$ope2, _ref3, _ref4;\n+                                var _a;\n+                                const operationFacts = graphqlLanguageService.getOperationFacts(schema, editorInstance_2.getValue());\n+                                const operationName = toolkit.getSelectedOperationName((_editorInstance_2$ope = editorInstance_2.operations) !== null && _editorInstance_2$ope !== void 0 ? _editorInstance_2$ope : void 0, (_editorInstance_2$ope2 = editorInstance_2.operationName) !== null && _editorInstance_2$ope2 !== void 0 ? _editorInstance_2$ope2 : void 0, operationFacts == null ? void 0 : operationFacts.operations);\n+                                editorInstance_2.documentAST = (_ref3 = operationFacts == null ? void 0 : operationFacts.documentAST) !== null && _ref3 !== void 0 ? _ref3 : null;\n+                                editorInstance_2.operationName = operationName !== null && operationName !== void 0 ? operationName : null;\n+                                editorInstance_2.operations = (_ref4 = operationFacts == null ? void 0 : operationFacts.operations) !== null && _ref4 !== void 0 ? _ref4 : null;\n+                                if (variableEditor) {\n+                                    updateVariableEditor(variableEditor, operationFacts);\n+                                    (_a = codeMirrorRef.current) == null ? void 0 : _a.signal(variableEditor, \"change\", variableEditor);\n+                                }\n+                                return operationFacts ? {\n+                                    ...operationFacts,\n+                                    operationName\n+                                } : null;\n+                            };\n+                            const handleChange = debounce(100, editorInstance_3 => {\n+                                var _ref5;\n+                                const query = editorInstance_3.getValue();\n+                                storage == null ? void 0 : storage.set(STORAGE_KEY_QUERY, query);\n+                                const currentOperationName = editorInstance_3.operationName;\n+                                const operationFacts_0 = getAndUpdateOperationFacts(editorInstance_3);\n+                                if ((operationFacts_0 == null ? void 0 : operationFacts_0.operationName) !== void 0) {\n+                                    storage == null ? void 0 : storage.set(STORAGE_KEY_OPERATION_NAME, operationFacts_0.operationName);\n+                                }\n+                                onEdit == null ? void 0 : onEdit(query, operationFacts_0 == null ? void 0 : operationFacts_0.documentAST);\n+                                if ((operationFacts_0 == null ? void 0 : operationFacts_0.operationName) && currentOperationName !== operationFacts_0.operationName) {\n+                                    setOperationName(operationFacts_0.operationName);\n+                                }\n+                                updateActiveTabValues({\n+                                    query,\n+                                    operationName: (_ref5 = operationFacts_0 == null ? void 0 : operationFacts_0.operationName) !== null && _ref5 !== void 0 ? _ref5 : null\n+                                });\n+                            });\n+                            getAndUpdateOperationFacts(queryEditor);\n+                            queryEditor.on(\"change\", handleChange);\n+                            return () => queryEditor.off(\"change\", handleChange);\n+                        };\n+                        t20 = [onEdit, queryEditor, schema, setOperationName, storage, variableEditor, updateActiveTabValues];\n+                        $[24] = onEdit;\n+                        $[25] = queryEditor;\n+                        $[26] = schema;\n+                        $[27] = setOperationName;\n+                        $[28] = storage;\n+                        $[29] = updateActiveTabValues;\n+                        $[30] = variableEditor;\n+                        $[31] = t19;\n+                        $[32] = t20;\n+                    } else {\n+                        t19 = $[31];\n+                        t20 = $[32];\n+                    }\n+                    React.useEffect(t19, t20);\n+                    useSynchronizeSchema(queryEditor, schema !== null && schema !== void 0 ? schema : null, codeMirrorRef);\n+                    useSynchronizeValidationRules(queryEditor, validationRules !== null && validationRules !== void 0 ? validationRules : null, codeMirrorRef);\n+                    useSynchronizeExternalFragments(queryEditor, externalFragments, codeMirrorRef);\n+                    useCompletion(queryEditor, onClickReference || null, _useQueryEditor);\n+                    const run = executionContext == null ? void 0 : executionContext.run;\n+                    let t21;\n+                    if ($[33] !== queryEditor || $[34] !== run || $[35] !== setOperationName) {\n+                        t21 = () => {\n+                            var _a;\n+                            if (!run || !queryEditor || !queryEditor.operations || !queryEditor.hasFocus()) {\n+                                run == null ? void 0 : run();\n+                                return;\n                             }\n-                        } else {\n-                            state.push('softbreak', 'br', 0);\n-                        }\n+                            const cursorIndex = queryEditor.indexFromPos(queryEditor.getCursor());\n+                            let operationName_0;\n+                            for (const operation of queryEditor.operations) {\n+                                if (operation.loc && operation.loc.start <= cursorIndex && operation.loc.end >= cursorIndex) {\n+                                    operationName_0 = (_a = operation.name) == null ? void 0 : _a.value;\n+                                }\n+                            }\n+                            if (operationName_0 && operationName_0 !== queryEditor.operationName) {\n+                                setOperationName(operationName_0);\n+                            }\n+                            run();\n+                        };\n+                        $[33] = queryEditor;\n+                        $[34] = run;\n+                        $[35] = setOperationName;\n+                        $[36] = t21;\n+                    } else {\n+                        t21 = $[36];\n                     }\n-                    pos++;\n-\n-                    // skip heading spaces for next line\n-                    while (pos < max && isSpace(state.src.charCodeAt(pos))) {\n-                        pos++;\n+                    const runAtCursor = t21;\n+                    let t22;\n+                    if ($[37] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t22 = [\"Cmd-Enter\", \"Ctrl-Enter\"];\n+                        $[37] = t22;\n+                    } else {\n+                        t22 = $[37];\n                     }\n-                    state.pos = pos;\n-                    return true;\n-                }\n-\n-                // Process escaped chars and hardbreaks\n-\n-                const ESCAPED = [];\n-                for (let i = 0; i < 256; i++) {\n-                    ESCAPED.push(0);\n-                }\n-                '\\\\!\"#$%&\\'()*+,./:;<=>?@[]^_`{|}~-'.split('').forEach(function(ch) {\n-                    ESCAPED[ch.charCodeAt(0)] = 1;\n-                });\n-\n-                function escape(state, silent) {\n-                    let pos = state.pos;\n-                    const max = state.posMax;\n-                    if (state.src.charCodeAt(pos) !== 0x5C /* \\ */ ) return false;\n-                    pos++;\n-\n-                    // '\\' at the end of the inline block\n-                    if (pos >= max) return false;\n-                    let ch1 = state.src.charCodeAt(pos);\n-                    if (ch1 === 0x0A) {\n-                        if (!silent) {\n-                            state.push('hardbreak', 'br', 0);\n-                        }\n-                        pos++;\n-                        // skip leading whitespaces from next line\n-                        while (pos < max) {\n-                            ch1 = state.src.charCodeAt(pos);\n-                            if (!isSpace(ch1)) break;\n-                            pos++;\n-                        }\n-                        state.pos = pos;\n-                        return true;\n+                    useKeyMap(queryEditor, t22, runAtCursor);\n+                    let t23;\n+                    if ($[38] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t23 = [\"Shift-Ctrl-C\"];\n+                        $[38] = t23;\n+                    } else {\n+                        t23 = $[38];\n                     }\n-                    let escapedStr = state.src[pos];\n-                    if (ch1 >= 0xD800 && ch1 <= 0xDBFF && pos + 1 < max) {\n-                        const ch2 = state.src.charCodeAt(pos + 1);\n-                        if (ch2 >= 0xDC00 && ch2 <= 0xDFFF) {\n-                            escapedStr += state.src[pos + 1];\n-                            pos++;\n-                        }\n+                    useKeyMap(queryEditor, t23, copy);\n+                    let t24;\n+                    if ($[39] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t24 = [\"Shift-Ctrl-P\", \"Shift-Ctrl-F\"];\n+                        $[39] = t24;\n+                    } else {\n+                        t24 = $[39];\n                     }\n-                    const origStr = '\\\\' + escapedStr;\n-                    if (!silent) {\n-                        const token = state.push('text_special', '', 0);\n-                        if (ch1 < 256 && ESCAPED[ch1] !== 0) {\n-                            token.content = escapedStr;\n-                        } else {\n-                            token.content = origStr;\n-                        }\n-                        token.markup = origStr;\n-                        token.info = 'escape';\n+                    useKeyMap(queryEditor, t24, prettify);\n+                    let t25;\n+                    if ($[40] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t25 = [\"Shift-Ctrl-M\"];\n+                        $[40] = t25;\n+                    } else {\n+                        t25 = $[40];\n                     }\n-                    state.pos = pos + 1;\n-                    return true;\n+                    useKeyMap(queryEditor, t25, merge);\n+                    return ref;\n                 }\n \n-                // Parse backticks\n-\n-                function backtick(state, silent) {\n-                    let pos = state.pos;\n-                    const ch = state.src.charCodeAt(pos);\n-                    if (ch !== 0x60 /* ` */ ) {\n-                        return false;\n+                function _temp4(editorInstance_1, change) {\n+                    var _a;\n+                    if (change.origin === \"paste\") {\n+                        const text_0 = change.text.map(normalizeWhitespace);\n+                        (_a = change.update) == null ? void 0 : _a.call(change, change.from, change.to, text_0);\n                     }\n-                    const start = pos;\n-                    pos++;\n-                    const max = state.posMax;\n+                }\n \n-                    // scan marker length\n-                    while (pos < max && state.src.charCodeAt(pos) === 0x60 /* ` */ ) {\n-                        pos++;\n-                    }\n-                    const marker = state.src.slice(start, pos);\n-                    const openerLength = marker.length;\n-                    if (state.backticksScanned && (state.backticks[openerLength] || 0) <= start) {\n-                        if (!silent) state.pending += marker;\n-                        state.pos += openerLength;\n-                        return true;\n+                function _temp3(editorInstance, event) {\n+                    if (AUTO_COMPLETE_AFTER_KEY.test(event.key)) {\n+                        editorInstance.execCommand(\"autocomplete\");\n                     }\n-                    let matchEnd = pos;\n-                    let matchStart;\n+                }\n \n-                    // Nothing found in the cache, scan until the end of the line (or until marker is found)\n-                    while ((matchStart = state.src.indexOf('`', matchEnd)) !== -1) {\n-                        matchEnd = matchStart + 1;\n+                function _temp2(text) {\n+                    return markdown.render(text);\n+                }\n \n-                        // scan marker length\n-                        while (matchEnd < max && state.src.charCodeAt(matchEnd) === 0x60 /* ` */ ) {\n-                            matchEnd++;\n-                        }\n-                        const closerLength = matchEnd - matchStart;\n-                        if (closerLength === openerLength) {\n-                            // Found matching closer length.\n-                            if (!silent) {\n-                                const token = state.push('code_inline', 'code', 0);\n-                                token.markup = marker;\n-                                token.content = state.src.slice(pos, matchStart).replace(/\\n/g, ' ').replace(/^ (.+) $/, '$1');\n-                            }\n-                            state.pos = matchEnd;\n-                            return true;\n-                        }\n+                function _temp$1() {}\n \n-                        // Some different length found, put it in cache as upper limit of where closer can be found\n-                        state.backticks[closerLength] = matchStart;\n+                function useSynchronizeSchema(editor, schema, codeMirrorRef) {\n+                    const $ = reactCompilerRuntime.c(5);\n+                    let t0;\n+                    let t1;\n+                    if ($[0] !== codeMirrorRef || $[1] !== editor || $[2] !== schema) {\n+                        t0 = () => {\n+                            if (!editor) {\n+                                return;\n+                            }\n+                            const didChange = editor.options.lint.schema !== schema;\n+                            updateEditorSchema(editor, schema);\n+                            if (didChange && codeMirrorRef.current) {\n+                                codeMirrorRef.current.signal(editor, \"change\", editor);\n+                            }\n+                        };\n+                        t1 = [editor, schema, codeMirrorRef];\n+                        $[0] = codeMirrorRef;\n+                        $[1] = editor;\n+                        $[2] = schema;\n+                        $[3] = t0;\n+                        $[4] = t1;\n+                    } else {\n+                        t0 = $[3];\n+                        t1 = $[4];\n                     }\n-\n-                    // Scanned through the end, didn't find anything\n-                    state.backticksScanned = true;\n-                    if (!silent) state.pending += marker;\n-                    state.pos += openerLength;\n-                    return true;\n+                    React.useEffect(t0, t1);\n                 }\n \n-                // ~~strike through~~\n-                //\n-\n-                // Insert each marker as a separate text token, and add it to delimiter list\n-                //\n-                function strikethrough_tokenize(state, silent) {\n-                    const start = state.pos;\n-                    const marker = state.src.charCodeAt(start);\n-                    if (silent) {\n-                        return false;\n-                    }\n-                    if (marker !== 0x7E /* ~ */ ) {\n-                        return false;\n+                function useSynchronizeValidationRules(editor, validationRules, codeMirrorRef) {\n+                    const $ = reactCompilerRuntime.c(5);\n+                    let t0;\n+                    let t1;\n+                    if ($[0] !== codeMirrorRef || $[1] !== editor || $[2] !== validationRules) {\n+                        t0 = () => {\n+                            if (!editor) {\n+                                return;\n+                            }\n+                            const didChange = editor.options.lint.validationRules !== validationRules;\n+                            updateEditorValidationRules(editor, validationRules);\n+                            if (didChange && codeMirrorRef.current) {\n+                                codeMirrorRef.current.signal(editor, \"change\", editor);\n+                            }\n+                        };\n+                        t1 = [editor, validationRules, codeMirrorRef];\n+                        $[0] = codeMirrorRef;\n+                        $[1] = editor;\n+                        $[2] = validationRules;\n+                        $[3] = t0;\n+                        $[4] = t1;\n+                    } else {\n+                        t0 = $[3];\n+                        t1 = $[4];\n                     }\n-                    const scanned = state.scanDelims(state.pos, true);\n-                    let len = scanned.length;\n-                    const ch = String.fromCharCode(marker);\n-                    if (len < 2) {\n-                        return false;\n+                    React.useEffect(t0, t1);\n+                }\n+\n+                function useSynchronizeExternalFragments(editor, externalFragments, codeMirrorRef) {\n+                    const $ = reactCompilerRuntime.c(9);\n+                    let t0;\n+                    if ($[0] !== externalFragments) {\n+                        t0 = externalFragments.values();\n+                        $[0] = externalFragments;\n+                        $[1] = t0;\n+                    } else {\n+                        t0 = $[1];\n                     }\n-                    let token;\n-                    if (len % 2) {\n-                        token = state.push('text', '', 0);\n-                        token.content = ch;\n-                        len--;\n+                    let t1;\n+                    if ($[2] !== t0) {\n+                        t1 = [...t0];\n+                        $[2] = t0;\n+                        $[3] = t1;\n+                    } else {\n+                        t1 = $[3];\n                     }\n-                    for (let i = 0; i < len; i += 2) {\n-                        token = state.push('text', '', 0);\n-                        token.content = ch + ch;\n-                        state.delimiters.push({\n-                            marker,\n-                            length: 0,\n-                            // disable \"rule of 3\" length checks meant for emphasis\n-                            token: state.tokens.length - 1,\n-                            end: -1,\n-                            open: scanned.can_open,\n-                            close: scanned.can_close\n-                        });\n+                    const externalFragmentList = t1;\n+                    let t2;\n+                    let t3;\n+                    if ($[4] !== codeMirrorRef || $[5] !== editor || $[6] !== externalFragmentList) {\n+                        t2 = () => {\n+                            if (!editor) {\n+                                return;\n+                            }\n+                            const didChange = editor.options.lint.externalFragments !== externalFragmentList;\n+                            updateEditorExternalFragments(editor, externalFragmentList);\n+                            if (didChange && codeMirrorRef.current) {\n+                                codeMirrorRef.current.signal(editor, \"change\", editor);\n+                            }\n+                        };\n+                        t3 = [editor, externalFragmentList, codeMirrorRef];\n+                        $[4] = codeMirrorRef;\n+                        $[5] = editor;\n+                        $[6] = externalFragmentList;\n+                        $[7] = t2;\n+                        $[8] = t3;\n+                    } else {\n+                        t2 = $[7];\n+                        t3 = $[8];\n                     }\n-                    state.pos += scanned.length;\n-                    return true;\n+                    React.useEffect(t2, t3);\n                 }\n-\n-                function postProcess$1(state, delimiters) {\n-                    let token;\n-                    const loneMarkers = [];\n-                    const max = delimiters.length;\n-                    for (let i = 0; i < max; i++) {\n-                        const startDelim = delimiters[i];\n-                        if (startDelim.marker !== 0x7E /* ~ */ ) {\n-                            continue;\n-                        }\n-                        if (startDelim.end === -1) {\n-                            continue;\n+                const AUTO_COMPLETE_AFTER_KEY = /^[a-zA-Z0-9_@(]$/;\n+                const STORAGE_KEY_QUERY = \"query\";\n+                const STORAGE_KEY_OPERATION_NAME = \"operationName\";\n+\n+                function getDefaultTabState({\n+                    defaultQuery,\n+                    defaultHeaders,\n+                    headers,\n+                    defaultTabs,\n+                    query,\n+                    variables,\n+                    storage,\n+                    shouldPersistHeaders\n+                }) {\n+                    const storedState = storage == null ? void 0 : storage.get(STORAGE_KEY$2);\n+                    try {\n+                        if (!storedState) {\n+                            throw new Error(\"Storage for tabs is empty\");\n                         }\n-                        const endDelim = delimiters[startDelim.end];\n-                        token = state.tokens[startDelim.token];\n-                        token.type = 's_open';\n-                        token.tag = 's';\n-                        token.nesting = 1;\n-                        token.markup = '~~';\n-                        token.content = '';\n-                        token = state.tokens[endDelim.token];\n-                        token.type = 's_close';\n-                        token.tag = 's';\n-                        token.nesting = -1;\n-                        token.markup = '~~';\n-                        token.content = '';\n-                        if (state.tokens[endDelim.token - 1].type === 'text' && state.tokens[endDelim.token - 1].content === '~') {\n-                            loneMarkers.push(endDelim.token - 1);\n+                        const parsed = JSON.parse(storedState);\n+                        const headersForHash = shouldPersistHeaders ? headers : void 0;\n+                        if (isTabsState(parsed)) {\n+                            const expectedHash = hashFromTabContents({\n+                                query,\n+                                variables,\n+                                headers: headersForHash\n+                            });\n+                            let matchingTabIndex = -1;\n+                            for (let index = 0; index < parsed.tabs.length; index++) {\n+                                const tab = parsed.tabs[index];\n+                                tab.hash = hashFromTabContents({\n+                                    query: tab.query,\n+                                    variables: tab.variables,\n+                                    headers: tab.headers\n+                                });\n+                                if (tab.hash === expectedHash) {\n+                                    matchingTabIndex = index;\n+                                }\n+                            }\n+                            if (matchingTabIndex >= 0) {\n+                                parsed.activeTabIndex = matchingTabIndex;\n+                            } else {\n+                                const operationName = query ? fuzzyExtractOperationName(query) : null;\n+                                parsed.tabs.push({\n+                                    id: guid(),\n+                                    hash: expectedHash,\n+                                    title: operationName || DEFAULT_TITLE,\n+                                    query,\n+                                    variables,\n+                                    headers,\n+                                    operationName,\n+                                    response: null\n+                                });\n+                                parsed.activeTabIndex = parsed.tabs.length - 1;\n+                            }\n+                            return parsed;\n                         }\n+                        throw new Error(\"Storage for tabs is invalid\");\n+                    } catch {\n+                        return {\n+                            activeTabIndex: 0,\n+                            tabs: (defaultTabs || [{\n+                                query: query !== null && query !== void 0 ? query : defaultQuery,\n+                                variables,\n+                                headers: headers !== null && headers !== void 0 ? headers : defaultHeaders\n+                            }]).map(createTab)\n+                        };\n                     }\n+                }\n \n-                    // If a marker sequence has an odd number of characters, it's splitted\n-                    // like this: `~~~~~` -> `~` + `~~` + `~~`, leaving one marker at the\n-                    // start of the sequence.\n-                    //\n-                    // So, we have to move all those markers after subsequent s_close tags.\n-                    //\n-                    while (loneMarkers.length) {\n-                        const i = loneMarkers.pop();\n-                        let j = i + 1;\n-                        while (j < state.tokens.length && state.tokens[j].type === 's_close') {\n-                            j++;\n-                        }\n-                        j--;\n-                        if (i !== j) {\n-                            token = state.tokens[j];\n-                            state.tokens[j] = state.tokens[i];\n-                            state.tokens[i] = token;\n-                        }\n-                    }\n+                function isTabsState(obj) {\n+                    return obj && typeof obj === \"object\" && !Array.isArray(obj) && hasNumberKey(obj, \"activeTabIndex\") && \"tabs\" in obj && Array.isArray(obj.tabs) && obj.tabs.every(isTabState);\n                 }\n \n-                // Walk through delimiter list and replace text tokens with tags\n-                //\n-                function strikethrough_postProcess(state) {\n-                    const tokens_meta = state.tokens_meta;\n-                    const max = state.tokens_meta.length;\n-                    postProcess$1(state, state.delimiters);\n-                    for (let curr = 0; curr < max; curr++) {\n-                        if (tokens_meta[curr] && tokens_meta[curr].delimiters) {\n-                            postProcess$1(state, tokens_meta[curr].delimiters);\n-                        }\n-                    }\n+                function isTabState(obj) {\n+                    return obj && typeof obj === \"object\" && !Array.isArray(obj) && hasStringKey(obj, \"id\") && hasStringKey(obj, \"title\") && hasStringOrNullKey(obj, \"query\") && hasStringOrNullKey(obj, \"variables\") && hasStringOrNullKey(obj, \"headers\") && hasStringOrNullKey(obj, \"operationName\") && hasStringOrNullKey(obj, \"response\");\n                 }\n-                var r_strikethrough = {\n-                    tokenize: strikethrough_tokenize,\n-                    postProcess: strikethrough_postProcess\n-                };\n \n-                // Process *this* and _that_\n-                //\n+                function hasNumberKey(obj, key) {\n+                    return key in obj && typeof obj[key] === \"number\";\n+                }\n \n-                // Insert each marker as a separate text token, and add it to delimiter list\n-                //\n-                function emphasis_tokenize(state, silent) {\n-                    const start = state.pos;\n-                    const marker = state.src.charCodeAt(start);\n-                    if (silent) {\n-                        return false;\n-                    }\n-                    if (marker !== 0x5F /* _ */ && marker !== 0x2A /* * */ ) {\n-                        return false;\n-                    }\n-                    const scanned = state.scanDelims(state.pos, marker === 0x2A);\n-                    for (let i = 0; i < scanned.length; i++) {\n-                        const token = state.push('text', '', 0);\n-                        token.content = String.fromCharCode(marker);\n-                        state.delimiters.push({\n-                            // Char code of the starting marker (number).\n-                            //\n-                            marker,\n-                            // Total length of these series of delimiters.\n-                            //\n-                            length: scanned.length,\n-                            // A position of the token this delimiter corresponds to.\n-                            //\n-                            token: state.tokens.length - 1,\n-                            // If this delimiter is matched as a valid opener, `end` will be\n-                            // equal to its position, otherwise it's `-1`.\n-                            //\n-                            end: -1,\n-                            // Boolean flags that determine if this delimiter could open or close\n-                            // an emphasis.\n-                            //\n-                            open: scanned.can_open,\n-                            close: scanned.can_close\n-                        });\n-                    }\n-                    state.pos += scanned.length;\n-                    return true;\n+                function hasStringKey(obj, key) {\n+                    return key in obj && typeof obj[key] === \"string\";\n                 }\n \n-                function postProcess(state, delimiters) {\n-                    const max = delimiters.length;\n-                    for (let i = max - 1; i >= 0; i--) {\n-                        const startDelim = delimiters[i];\n-                        if (startDelim.marker !== 0x5F /* _ */ && startDelim.marker !== 0x2A /* * */ ) {\n-                            continue;\n-                        }\n+                function hasStringOrNullKey(obj, key) {\n+                    return key in obj && (typeof obj[key] === \"string\" || obj[key] === null);\n+                }\n \n-                        // Process only opening markers\n-                        if (startDelim.end === -1) {\n-                            continue;\n-                        }\n-                        const endDelim = delimiters[startDelim.end];\n+                function useSynchronizeActiveTabValues({\n+                    queryEditor,\n+                    variableEditor,\n+                    headerEditor,\n+                    responseEditor\n+                }) {\n+                    return React.useCallback(state => {\n+                        var _ref6, _ref7, _ref8, _ref9, _ref10;\n+                        const query = (_ref6 = queryEditor == null ? void 0 : queryEditor.getValue()) !== null && _ref6 !== void 0 ? _ref6 : null;\n+                        const variables = (_ref7 = variableEditor == null ? void 0 : variableEditor.getValue()) !== null && _ref7 !== void 0 ? _ref7 : null;\n+                        const headers = (_ref8 = headerEditor == null ? void 0 : headerEditor.getValue()) !== null && _ref8 !== void 0 ? _ref8 : null;\n+                        const operationName = (_ref9 = queryEditor == null ? void 0 : queryEditor.operationName) !== null && _ref9 !== void 0 ? _ref9 : null;\n+                        const response = (_ref10 = responseEditor == null ? void 0 : responseEditor.getValue()) !== null && _ref10 !== void 0 ? _ref10 : null;\n+                        return setPropertiesInActiveTab(state, {\n+                            query,\n+                            variables,\n+                            headers,\n+                            response,\n+                            operationName\n+                        });\n+                    }, [queryEditor, variableEditor, headerEditor, responseEditor]);\n+                }\n \n-                        // If the previous delimiter has the same marker and is adjacent to this one,\n-                        // merge those into one strong delimiter.\n-                        //\n-                        // `<em><em>whatever</em></em>` -> `<strong>whatever</strong>`\n-                        //\n-                        const isStrong = i > 0 && delimiters[i - 1].end === startDelim.end + 1 &&\n-                            // check that first two markers match and adjacent\n-                            delimiters[i - 1].marker === startDelim.marker && delimiters[i - 1].token === startDelim.token - 1 &&\n-                            // check that last two markers are adjacent (we can safely assume they match)\n-                            delimiters[startDelim.end + 1].token === endDelim.token + 1;\n-                        const ch = String.fromCharCode(startDelim.marker);\n-                        const token_o = state.tokens[startDelim.token];\n-                        token_o.type = isStrong ? 'strong_open' : 'em_open';\n-                        token_o.tag = isStrong ? 'strong' : 'em';\n-                        token_o.nesting = 1;\n-                        token_o.markup = isStrong ? ch + ch : ch;\n-                        token_o.content = '';\n-                        const token_c = state.tokens[endDelim.token];\n-                        token_c.type = isStrong ? 'strong_close' : 'em_close';\n-                        token_c.tag = isStrong ? 'strong' : 'em';\n-                        token_c.nesting = -1;\n-                        token_c.markup = isStrong ? ch + ch : ch;\n-                        token_c.content = '';\n-                        if (isStrong) {\n-                            state.tokens[delimiters[i - 1].token].content = '';\n-                            state.tokens[delimiters[startDelim.end + 1].token].content = '';\n-                            i--;\n-                        }\n-                    }\n+                function serializeTabState(tabState, shouldPersistHeaders = false) {\n+                    return JSON.stringify(tabState, (key, value) => key === \"hash\" || key === \"response\" || !shouldPersistHeaders && key === \"headers\" ? null : value);\n                 }\n \n-                // Walk through delimiter list and replace text tokens with tags\n-                //\n-                function emphasis_post_process(state) {\n-                    const tokens_meta = state.tokens_meta;\n-                    const max = state.tokens_meta.length;\n-                    postProcess(state, state.delimiters);\n-                    for (let curr = 0; curr < max; curr++) {\n-                        if (tokens_meta[curr] && tokens_meta[curr].delimiters) {\n-                            postProcess(state, tokens_meta[curr].delimiters);\n-                        }\n-                    }\n+                function useStoreTabs({\n+                    storage,\n+                    shouldPersistHeaders\n+                }) {\n+                    const store = React.useMemo(() => debounce(500, value => {\n+                        storage == null ? void 0 : storage.set(STORAGE_KEY$2, value);\n+                    }), [storage]);\n+                    return React.useCallback(currentState => {\n+                        store(serializeTabState(currentState, shouldPersistHeaders));\n+                    }, [shouldPersistHeaders, store]);\n                 }\n-                var r_emphasis = {\n-                    tokenize: emphasis_tokenize,\n-                    postProcess: emphasis_post_process\n-                };\n \n-                // Process [link](<to> \"stuff\")\n+                function useSetEditorValues({\n+                    queryEditor,\n+                    variableEditor,\n+                    headerEditor,\n+                    responseEditor,\n+                    defaultHeaders\n+                }) {\n+                    return React.useCallback(({\n+                        query,\n+                        variables,\n+                        headers,\n+                        response\n+                    }) => {\n+                        var _ref11;\n+                        queryEditor == null ? void 0 : queryEditor.setValue(query !== null && query !== void 0 ? query : \"\");\n+                        variableEditor == null ? void 0 : variableEditor.setValue(variables !== null && variables !== void 0 ? variables : \"\");\n+                        headerEditor == null ? void 0 : headerEditor.setValue((_ref11 = headers !== null && headers !== void 0 ? headers : defaultHeaders) !== null && _ref11 !== void 0 ? _ref11 : \"\");\n+                        responseEditor == null ? void 0 : responseEditor.setValue(response !== null && response !== void 0 ? response : \"\");\n+                    }, [headerEditor, queryEditor, responseEditor, variableEditor, defaultHeaders]);\n+                }\n \n-                function link(state, silent) {\n-                    let code, label, res, ref;\n-                    let href = '';\n-                    let title = '';\n-                    let start = state.pos;\n-                    let parseReference = true;\n-                    if (state.src.charCodeAt(state.pos) !== 0x5B /* [ */ ) {\n-                        return false;\n-                    }\n-                    const oldPos = state.pos;\n-                    const max = state.posMax;\n-                    const labelStart = state.pos + 1;\n-                    const labelEnd = state.md.helpers.parseLinkLabel(state, state.pos, true);\n+                function createTab({\n+                    query = null,\n+                    variables = null,\n+                    headers = null\n+                } = {}) {\n+                    return {\n+                        id: guid(),\n+                        hash: hashFromTabContents({\n+                            query,\n+                            variables,\n+                            headers\n+                        }),\n+                        title: query && fuzzyExtractOperationName(query) || DEFAULT_TITLE,\n+                        query,\n+                        variables,\n+                        headers,\n+                        operationName: null,\n+                        response: null\n+                    };\n+                }\n \n-                    // parser failed to find ']', so it's not a valid link\n-                    if (labelEnd < 0) {\n-                        return false;\n-                    }\n-                    let pos = labelEnd + 1;\n-                    if (pos < max && state.src.charCodeAt(pos) === 0x28 /* ( */ ) {\n-                        //\n-                        // Inline link\n-                        //\n+                function setPropertiesInActiveTab(state, partialTab) {\n+                    return {\n+                        ...state,\n+                        tabs: state.tabs.map((tab, index) => {\n+                            if (index !== state.activeTabIndex) {\n+                                return tab;\n+                            }\n+                            const newTab = {\n+                                ...tab,\n+                                ...partialTab\n+                            };\n+                            return {\n+                                ...newTab,\n+                                hash: hashFromTabContents(newTab),\n+                                title: newTab.operationName || (newTab.query ? fuzzyExtractOperationName(newTab.query) : void 0) || DEFAULT_TITLE\n+                            };\n+                        })\n+                    };\n+                }\n \n-                        // might have found a valid shortcut link, disable reference parsing\n-                        parseReference = false;\n+                function guid() {\n+                    const s4 = () => {\n+                        return Math.floor((1 + Math.random()) * 65536).toString(16).slice(1);\n+                    };\n+                    return `${s4()}${s4()}-${s4()}-${s4()}-${s4()}-${s4()}${s4()}${s4()}`;\n+                }\n \n-                        // [link](  <href>  \"title\"  )\n-                        //        ^^ skipping these spaces\n-                        pos++;\n-                        for (; pos < max; pos++) {\n-                            code = state.src.charCodeAt(pos);\n-                            if (!isSpace(code) && code !== 0x0A) {\n-                                break;\n-                            }\n-                        }\n-                        if (pos >= max) {\n-                            return false;\n-                        }\n+                function hashFromTabContents(args) {\n+                    var _args$query, _args$variables, _args$headers;\n+                    return [(_args$query = args.query) !== null && _args$query !== void 0 ? _args$query : \"\", (_args$variables = args.variables) !== null && _args$variables !== void 0 ? _args$variables : \"\", (_args$headers = args.headers) !== null && _args$headers !== void 0 ? _args$headers : \"\"].join(\"|\");\n+                }\n \n-                        // [link](  <href>  \"title\"  )\n-                        //          ^^^^^^ parsing link destination\n-                        start = pos;\n-                        res = state.md.helpers.parseLinkDestination(state.src, pos, state.posMax);\n-                        if (res.ok) {\n-                            href = state.md.normalizeLink(res.str);\n-                            if (state.md.validateLink(href)) {\n-                                pos = res.pos;\n-                            } else {\n-                                href = '';\n-                            }\n+                function fuzzyExtractOperationName(str) {\n+                    var _ref12;\n+                    const regex = /^(?!#).*(query|subscription|mutation)\\s+([a-zA-Z0-9_]+)/m;\n+                    const match = regex.exec(str);\n+                    return (_ref12 = match == null ? void 0 : match[2]) !== null && _ref12 !== void 0 ? _ref12 : null;\n+                }\n \n-                            // [link](  <href>  \"title\"  )\n-                            //                ^^ skipping these spaces\n-                            start = pos;\n-                            for (; pos < max; pos++) {\n-                                code = state.src.charCodeAt(pos);\n-                                if (!isSpace(code) && code !== 0x0A) {\n-                                    break;\n-                                }\n-                            }\n+                function clearHeadersFromTabs(storage) {\n+                    const persistedTabs = storage == null ? void 0 : storage.get(STORAGE_KEY$2);\n+                    if (persistedTabs) {\n+                        const parsedTabs = JSON.parse(persistedTabs);\n+                        storage == null ? void 0 : storage.set(STORAGE_KEY$2, JSON.stringify(parsedTabs, (key, value) => key === \"headers\" ? null : value));\n+                    }\n+                }\n+                const DEFAULT_TITLE = \"<untitled>\";\n+                const STORAGE_KEY$2 = \"tabState\";\n \n-                            // [link](  <href>  \"title\"  )\n-                            //                  ^^^^^^^ parsing link title\n-                            res = state.md.helpers.parseLinkTitle(state.src, pos, state.posMax);\n-                            if (pos < max && start !== pos && res.ok) {\n-                                title = res.str;\n-                                pos = res.pos;\n+                function importCodeMirrorImports$1() {\n+                    return importCodeMirror([Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror-graphql/esm/variables/hint.js */ \"../../codemirror-graphql/esm/variables/hint.js\"))), Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror-graphql/esm/variables/lint.js */ \"../../codemirror-graphql/esm/variables/lint.js\"))), Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror-graphql/esm/variables/mode.js */ \"../../codemirror-graphql/esm/variables/mode.js\")))]);\n+                }\n+                const _useVariableEditor = useVariableEditor;\n \n-                                // [link](  <href>  \"title\"  )\n-                                //                         ^^ skipping these spaces\n-                                for (; pos < max; pos++) {\n-                                    code = state.src.charCodeAt(pos);\n-                                    if (!isSpace(code) && code !== 0x0A) {\n-                                        break;\n-                                    }\n+                function useVariableEditor(t0, caller) {\n+                    const $ = reactCompilerRuntime.c(17);\n+                    let t1;\n+                    if ($[0] !== t0) {\n+                        t1 = t0 === void 0 ? {} : t0;\n+                        $[0] = t0;\n+                        $[1] = t1;\n+                    } else {\n+                        t1 = $[1];\n+                    }\n+                    const {\n+                        editorTheme: t2,\n+                        keyMap: t3,\n+                        onClickReference,\n+                        onEdit,\n+                        readOnly: t4\n+                    } = t1;\n+                    const editorTheme = t2 === void 0 ? DEFAULT_EDITOR_THEME : t2;\n+                    const keyMap = t3 === void 0 ? DEFAULT_KEY_MAP : t3;\n+                    const readOnly = t4 === void 0 ? false : t4;\n+                    const t5 = caller || _useVariableEditor;\n+                    let t6;\n+                    if ($[2] !== t5) {\n+                        t6 = {\n+                            nonNull: true,\n+                            caller: t5\n+                        };\n+                        $[2] = t5;\n+                        $[3] = t6;\n+                    } else {\n+                        t6 = $[3];\n+                    }\n+                    const {\n+                        initialVariables,\n+                        variableEditor,\n+                        setVariableEditor\n+                    } = useEditorContext(t6);\n+                    const executionContext = useExecutionContext();\n+                    const t7 = caller || _useVariableEditor;\n+                    let t8;\n+                    if ($[4] !== t7) {\n+                        t8 = {\n+                            caller: t7\n+                        };\n+                        $[4] = t7;\n+                        $[5] = t8;\n+                    } else {\n+                        t8 = $[5];\n+                    }\n+                    const merge = useMergeQuery(t8);\n+                    const t9 = caller || _useVariableEditor;\n+                    let t10;\n+                    if ($[6] !== t9) {\n+                        t10 = {\n+                            caller: t9\n+                        };\n+                        $[6] = t9;\n+                        $[7] = t10;\n+                    } else {\n+                        t10 = $[7];\n+                    }\n+                    const prettify = usePrettifyEditors(t10);\n+                    const ref = React.useRef(null);\n+                    const codeMirrorRef = React.useRef();\n+                    let t11;\n+                    let t12;\n+                    if ($[8] !== editorTheme || $[9] !== initialVariables || $[10] !== readOnly || $[11] !== setVariableEditor) {\n+                        t11 = () => {\n+                            let isActive;\n+                            isActive = true;\n+                            importCodeMirrorImports$1().then(CodeMirror => {\n+                                if (!isActive) {\n+                                    return;\n                                 }\n-                            }\n-                        }\n-                        if (pos >= max || state.src.charCodeAt(pos) !== 0x29 /* ) */ ) {\n-                            // parsing a valid shortcut link failed, fallback to reference\n-                            parseReference = true;\n-                        }\n-                        pos++;\n+                                codeMirrorRef.current = CodeMirror;\n+                                const container = ref.current;\n+                                if (!container) {\n+                                    return;\n+                                }\n+                                const newEditor = CodeMirror(container, {\n+                                    value: initialVariables,\n+                                    lineNumbers: true,\n+                                    tabSize: 2,\n+                                    mode: \"graphql-variables\",\n+                                    theme: editorTheme,\n+                                    autoCloseBrackets: true,\n+                                    matchBrackets: true,\n+                                    showCursorWhenSelecting: true,\n+                                    readOnly: readOnly ? \"nocursor\" : false,\n+                                    foldGutter: true,\n+                                    lint: {\n+                                        variableToType: void 0\n+                                    },\n+                                    hintOptions: {\n+                                        closeOnUnfocus: false,\n+                                        completeSingle: false,\n+                                        container,\n+                                        variableToType: void 0\n+                                    },\n+                                    gutters: [\"CodeMirror-linenumbers\", \"CodeMirror-foldgutter\"],\n+                                    extraKeys: commonKeys\n+                                });\n+                                newEditor.addKeyMap({\n+                                    \"Cmd-Space\"() {\n+                                        newEditor.showHint({\n+                                            completeSingle: false,\n+                                            container\n+                                        });\n+                                    },\n+                                    \"Ctrl-Space\"() {\n+                                        newEditor.showHint({\n+                                            completeSingle: false,\n+                                            container\n+                                        });\n+                                    },\n+                                    \"Alt-Space\"() {\n+                                        newEditor.showHint({\n+                                            completeSingle: false,\n+                                            container\n+                                        });\n+                                    },\n+                                    \"Shift-Space\"() {\n+                                        newEditor.showHint({\n+                                            completeSingle: false,\n+                                            container\n+                                        });\n+                                    }\n+                                });\n+                                newEditor.on(\"keyup\", _temp);\n+                                setVariableEditor(newEditor);\n+                            });\n+                            return () => {\n+                                isActive = false;\n+                            };\n+                        };\n+                        t12 = [editorTheme, initialVariables, readOnly, setVariableEditor];\n+                        $[8] = editorTheme;\n+                        $[9] = initialVariables;\n+                        $[10] = readOnly;\n+                        $[11] = setVariableEditor;\n+                        $[12] = t11;\n+                        $[13] = t12;\n+                    } else {\n+                        t11 = $[12];\n+                        t12 = $[13];\n                     }\n-                    if (parseReference) {\n-                        //\n-                        // Link reference\n-                        //\n-                        if (typeof state.env.references === 'undefined') {\n-                            return false;\n-                        }\n-                        if (pos < max && state.src.charCodeAt(pos) === 0x5B /* [ */ ) {\n-                            start = pos + 1;\n-                            pos = state.md.helpers.parseLinkLabel(state, pos);\n-                            if (pos >= 0) {\n-                                label = state.src.slice(start, pos++);\n-                            } else {\n-                                pos = labelEnd + 1;\n-                            }\n-                        } else {\n-                            pos = labelEnd + 1;\n-                        }\n-\n-                        // covers label === '' and label === undefined\n-                        // (collapsed reference link and shortcut reference link respectively)\n-                        if (!label) {\n-                            label = state.src.slice(labelStart, labelEnd);\n-                        }\n-                        ref = state.env.references[normalizeReference(label)];\n-                        if (!ref) {\n-                            state.pos = oldPos;\n-                            return false;\n-                        }\n-                        href = ref.href;\n-                        title = ref.title;\n+                    React.useEffect(t11, t12);\n+                    useSynchronizeOption(variableEditor, \"keyMap\", keyMap);\n+                    useChangeHandler(variableEditor, onEdit, STORAGE_KEY$1, \"variables\", _useVariableEditor);\n+                    useCompletion(variableEditor, onClickReference || null, _useVariableEditor);\n+                    let t13;\n+                    if ($[14] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t13 = [\"Cmd-Enter\", \"Ctrl-Enter\"];\n+                        $[14] = t13;\n+                    } else {\n+                        t13 = $[14];\n                     }\n-\n-                    //\n-                    // We found the end of the link, and know for a fact it's a valid link;\n-                    // so all that's left to do is to call tokenizer.\n-                    //\n-                    if (!silent) {\n-                        state.pos = labelStart;\n-                        state.posMax = labelEnd;\n-                        const token_o = state.push('link_open', 'a', 1);\n-                        const attrs = [\n-                            ['href', href]\n-                        ];\n-                        token_o.attrs = attrs;\n-                        if (title) {\n-                            attrs.push(['title', title]);\n-                        }\n-                        state.linkLevel++;\n-                        state.md.inline.tokenize(state);\n-                        state.linkLevel--;\n-                        state.push('link_close', 'a', -1);\n+                    useKeyMap(variableEditor, t13, executionContext == null ? void 0 : executionContext.run);\n+                    let t14;\n+                    if ($[15] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t14 = [\"Shift-Ctrl-P\"];\n+                        $[15] = t14;\n+                    } else {\n+                        t14 = $[15];\n                     }\n-                    state.pos = pos;\n-                    state.posMax = max;\n-                    return true;\n+                    useKeyMap(variableEditor, t14, prettify);\n+                    let t15;\n+                    if ($[16] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t15 = [\"Shift-Ctrl-M\"];\n+                        $[16] = t15;\n+                    } else {\n+                        t15 = $[16];\n+                    }\n+                    useKeyMap(variableEditor, t15, merge);\n+                    return ref;\n                 }\n \n-                // Process ![image](<src> \"title\")\n-\n-                function image(state, silent) {\n-                    let code, content, label, pos, ref, res, title, start;\n-                    let href = '';\n-                    const oldPos = state.pos;\n-                    const max = state.posMax;\n-                    if (state.src.charCodeAt(state.pos) !== 0x21 /* ! */ ) {\n-                        return false;\n+                function _temp(editorInstance, event) {\n+                    const {\n+                        code,\n+                        key,\n+                        shiftKey\n+                    } = event;\n+                    const isLetter = code.startsWith(\"Key\");\n+                    const isNumber = !shiftKey && code.startsWith(\"Digit\");\n+                    if (isLetter || isNumber || key === \"_\" || key === '\"') {\n+                        editorInstance.execCommand(\"autocomplete\");\n+                    }\n+                }\n+                const STORAGE_KEY$1 = \"variables\";\n+                const EditorContext = createNullableContext(\"EditorContext\");\n+\n+                function EditorContextProvider(props) {\n+                    const $ = reactCompilerRuntime.c(89);\n+                    const storage = useStorageContext();\n+                    const [headerEditor, setHeaderEditor] = React.useState(null);\n+                    const [queryEditor, setQueryEditor] = React.useState(null);\n+                    const [responseEditor, setResponseEditor] = React.useState(null);\n+                    const [variableEditor, setVariableEditor] = React.useState(null);\n+                    let t0;\n+                    if ($[0] !== props.shouldPersistHeaders || $[1] !== storage) {\n+                        t0 = () => {\n+                            const isStored = (storage == null ? void 0 : storage.get(PERSIST_HEADERS_STORAGE_KEY)) !== null;\n+                            return props.shouldPersistHeaders !== false && isStored ? (storage == null ? void 0 : storage.get(PERSIST_HEADERS_STORAGE_KEY)) === \"true\" : Boolean(props.shouldPersistHeaders);\n+                        };\n+                        $[0] = props.shouldPersistHeaders;\n+                        $[1] = storage;\n+                        $[2] = t0;\n+                    } else {\n+                        t0 = $[2];\n                     }\n-                    if (state.src.charCodeAt(state.pos + 1) !== 0x5B /* [ */ ) {\n-                        return false;\n+                    const [shouldPersistHeaders, setShouldPersistHeadersInternal] = React.useState(t0);\n+                    useSynchronizeValue(headerEditor, props.headers);\n+                    useSynchronizeValue(queryEditor, props.query);\n+                    useSynchronizeValue(responseEditor, props.response);\n+                    useSynchronizeValue(variableEditor, props.variables);\n+                    let t1;\n+                    if ($[3] !== shouldPersistHeaders || $[4] !== storage) {\n+                        t1 = {\n+                            storage,\n+                            shouldPersistHeaders\n+                        };\n+                        $[3] = shouldPersistHeaders;\n+                        $[4] = storage;\n+                        $[5] = t1;\n+                    } else {\n+                        t1 = $[5];\n                     }\n-                    const labelStart = state.pos + 2;\n-                    const labelEnd = state.md.helpers.parseLinkLabel(state, state.pos + 1, false);\n-\n-                    // parser failed to find ']', so it's not a valid link\n-                    if (labelEnd < 0) {\n-                        return false;\n+                    const storeTabs = useStoreTabs(t1);\n+                    let t2;\n+                    if ($[6] !== props.defaultHeaders || $[7] !== props.defaultQuery || $[8] !== props.defaultTabs || $[9] !== props.headers || $[10] !== props.query || $[11] !== props.response || $[12] !== props.variables || $[13] !== shouldPersistHeaders || $[14] !== storage || $[15] !== storeTabs) {\n+                        t2 = () => {\n+                            var _ref13, _props$query, _ref14, _props$variables, _ref15, _props$headers, _props$response, _ref16, _ref17;\n+                            const query = (_ref13 = (_props$query = props.query) !== null && _props$query !== void 0 ? _props$query : storage == null ? void 0 : storage.get(STORAGE_KEY_QUERY)) !== null && _ref13 !== void 0 ? _ref13 : null;\n+                            const variables = (_ref14 = (_props$variables = props.variables) !== null && _props$variables !== void 0 ? _props$variables : storage == null ? void 0 : storage.get(STORAGE_KEY$1)) !== null && _ref14 !== void 0 ? _ref14 : null;\n+                            const headers = (_ref15 = (_props$headers = props.headers) !== null && _props$headers !== void 0 ? _props$headers : storage == null ? void 0 : storage.get(STORAGE_KEY$3)) !== null && _ref15 !== void 0 ? _ref15 : null;\n+                            const response = (_props$response = props.response) !== null && _props$response !== void 0 ? _props$response : \"\";\n+                            const tabState = getDefaultTabState({\n+                                query,\n+                                variables,\n+                                headers,\n+                                defaultTabs: props.defaultTabs,\n+                                defaultQuery: props.defaultQuery || DEFAULT_QUERY,\n+                                defaultHeaders: props.defaultHeaders,\n+                                storage,\n+                                shouldPersistHeaders\n+                            });\n+                            storeTabs(tabState);\n+                            return {\n+                                query: (_ref16 = query !== null && query !== void 0 ? query : tabState.activeTabIndex === 0 ? tabState.tabs[0].query : null) !== null && _ref16 !== void 0 ? _ref16 : \"\",\n+                                variables: variables !== null && variables !== void 0 ? variables : \"\",\n+                                headers: (_ref17 = headers !== null && headers !== void 0 ? headers : props.defaultHeaders) !== null && _ref17 !== void 0 ? _ref17 : \"\",\n+                                response,\n+                                tabState\n+                            };\n+                        };\n+                        $[6] = props.defaultHeaders;\n+                        $[7] = props.defaultQuery;\n+                        $[8] = props.defaultTabs;\n+                        $[9] = props.headers;\n+                        $[10] = props.query;\n+                        $[11] = props.response;\n+                        $[12] = props.variables;\n+                        $[13] = shouldPersistHeaders;\n+                        $[14] = storage;\n+                        $[15] = storeTabs;\n+                        $[16] = t2;\n+                    } else {\n+                        t2 = $[16];\n                     }\n-                    pos = labelEnd + 1;\n-                    if (pos < max && state.src.charCodeAt(pos) === 0x28 /* ( */ ) {\n-                        //\n-                        // Inline link\n-                        //\n-\n-                        // [link](  <href>  \"title\"  )\n-                        //        ^^ skipping these spaces\n-                        pos++;\n-                        for (; pos < max; pos++) {\n-                            code = state.src.charCodeAt(pos);\n-                            if (!isSpace(code) && code !== 0x0A) {\n-                                break;\n-                            }\n-                        }\n-                        if (pos >= max) {\n-                            return false;\n-                        }\n-\n-                        // [link](  <href>  \"title\"  )\n-                        //          ^^^^^^ parsing link destination\n-                        start = pos;\n-                        res = state.md.helpers.parseLinkDestination(state.src, pos, state.posMax);\n-                        if (res.ok) {\n-                            href = state.md.normalizeLink(res.str);\n-                            if (state.md.validateLink(href)) {\n-                                pos = res.pos;\n+                    const [initialState] = React.useState(t2);\n+                    const [tabState_0, setTabState] = React.useState(initialState.tabState);\n+                    let t3;\n+                    if ($[17] !== headerEditor || $[18] !== storage || $[19] !== tabState_0) {\n+                        t3 = persist => {\n+                            if (persist) {\n+                                var _ref18;\n+                                storage == null ? void 0 : storage.set(STORAGE_KEY$3, (_ref18 = headerEditor == null ? void 0 : headerEditor.getValue()) !== null && _ref18 !== void 0 ? _ref18 : \"\");\n+                                const serializedTabs = serializeTabState(tabState_0, true);\n+                                storage == null ? void 0 : storage.set(STORAGE_KEY$2, serializedTabs);\n                             } else {\n-                                href = '';\n+                                storage == null ? void 0 : storage.set(STORAGE_KEY$3, \"\");\n+                                clearHeadersFromTabs(storage);\n                             }\n-                        }\n-\n-                        // [link](  <href>  \"title\"  )\n-                        //                ^^ skipping these spaces\n-                        start = pos;\n-                        for (; pos < max; pos++) {\n-                            code = state.src.charCodeAt(pos);\n-                            if (!isSpace(code) && code !== 0x0A) {\n-                                break;\n+                            setShouldPersistHeadersInternal(persist);\n+                            storage == null ? void 0 : storage.set(PERSIST_HEADERS_STORAGE_KEY, persist.toString());\n+                        };\n+                        $[17] = headerEditor;\n+                        $[18] = storage;\n+                        $[19] = tabState_0;\n+                        $[20] = t3;\n+                    } else {\n+                        t3 = $[20];\n+                    }\n+                    const setShouldPersistHeaders = t3;\n+                    const lastShouldPersistHeadersProp = React.useRef();\n+                    let t4;\n+                    let t5;\n+                    if ($[21] !== props.shouldPersistHeaders || $[22] !== setShouldPersistHeaders) {\n+                        t4 = () => {\n+                            const propValue = Boolean(props.shouldPersistHeaders);\n+                            if ((lastShouldPersistHeadersProp == null ? void 0 : lastShouldPersistHeadersProp.current) !== propValue) {\n+                                setShouldPersistHeaders(propValue);\n+                                lastShouldPersistHeadersProp.current = propValue;\n+                            }\n+                        };\n+                        t5 = [props.shouldPersistHeaders, setShouldPersistHeaders];\n+                        $[21] = props.shouldPersistHeaders;\n+                        $[22] = setShouldPersistHeaders;\n+                        $[23] = t4;\n+                        $[24] = t5;\n+                    } else {\n+                        t4 = $[23];\n+                        t5 = $[24];\n+                    }\n+                    React.useEffect(t4, t5);\n+                    let t6;\n+                    if ($[25] !== headerEditor || $[26] !== queryEditor || $[27] !== responseEditor || $[28] !== variableEditor) {\n+                        t6 = {\n+                            queryEditor,\n+                            variableEditor,\n+                            headerEditor,\n+                            responseEditor\n+                        };\n+                        $[25] = headerEditor;\n+                        $[26] = queryEditor;\n+                        $[27] = responseEditor;\n+                        $[28] = variableEditor;\n+                        $[29] = t6;\n+                    } else {\n+                        t6 = $[29];\n+                    }\n+                    const synchronizeActiveTabValues = useSynchronizeActiveTabValues(t6);\n+                    const {\n+                        onTabChange,\n+                        defaultHeaders,\n+                        defaultQuery,\n+                        children\n+                    } = props;\n+                    let t7;\n+                    if ($[30] !== defaultHeaders || $[31] !== headerEditor || $[32] !== queryEditor || $[33] !== responseEditor || $[34] !== variableEditor) {\n+                        t7 = {\n+                            queryEditor,\n+                            variableEditor,\n+                            headerEditor,\n+                            responseEditor,\n+                            defaultHeaders\n+                        };\n+                        $[30] = defaultHeaders;\n+                        $[31] = headerEditor;\n+                        $[32] = queryEditor;\n+                        $[33] = responseEditor;\n+                        $[34] = variableEditor;\n+                        $[35] = t7;\n+                    } else {\n+                        t7 = $[35];\n+                    }\n+                    const setEditorValues = useSetEditorValues(t7);\n+                    let t8;\n+                    if ($[36] !== defaultHeaders || $[37] !== defaultQuery || $[38] !== onTabChange || $[39] !== setEditorValues || $[40] !== storeTabs || $[41] !== synchronizeActiveTabValues) {\n+                        t8 = () => {\n+                            setTabState(current => {\n+                                const updatedValues = synchronizeActiveTabValues(current);\n+                                const updated = {\n+                                    tabs: [...updatedValues.tabs, createTab({\n+                                        headers: defaultHeaders,\n+                                        query: defaultQuery !== null && defaultQuery !== void 0 ? defaultQuery : DEFAULT_QUERY\n+                                    })],\n+                                    activeTabIndex: updatedValues.tabs.length\n+                                };\n+                                storeTabs(updated);\n+                                setEditorValues(updated.tabs[updated.activeTabIndex]);\n+                                onTabChange == null ? void 0 : onTabChange(updated);\n+                                return updated;\n+                            });\n+                        };\n+                        $[36] = defaultHeaders;\n+                        $[37] = defaultQuery;\n+                        $[38] = onTabChange;\n+                        $[39] = setEditorValues;\n+                        $[40] = storeTabs;\n+                        $[41] = synchronizeActiveTabValues;\n+                        $[42] = t8;\n+                    } else {\n+                        t8 = $[42];\n+                    }\n+                    const addTab = t8;\n+                    let t9;\n+                    if ($[43] !== onTabChange || $[44] !== setEditorValues || $[45] !== storeTabs) {\n+                        t9 = index => {\n+                            setTabState(current_0 => {\n+                                const updated_0 = {\n+                                    ...current_0,\n+                                    activeTabIndex: index\n+                                };\n+                                storeTabs(updated_0);\n+                                setEditorValues(updated_0.tabs[updated_0.activeTabIndex]);\n+                                onTabChange == null ? void 0 : onTabChange(updated_0);\n+                                return updated_0;\n+                            });\n+                        };\n+                        $[43] = onTabChange;\n+                        $[44] = setEditorValues;\n+                        $[45] = storeTabs;\n+                        $[46] = t9;\n+                    } else {\n+                        t9 = $[46];\n+                    }\n+                    const changeTab = t9;\n+                    let t10;\n+                    if ($[47] !== onTabChange || $[48] !== setEditorValues || $[49] !== storeTabs) {\n+                        t10 = newOrder => {\n+                            setTabState(current_1 => {\n+                                const activeTab = current_1.tabs[current_1.activeTabIndex];\n+                                const updated_1 = {\n+                                    tabs: newOrder,\n+                                    activeTabIndex: newOrder.indexOf(activeTab)\n+                                };\n+                                storeTabs(updated_1);\n+                                setEditorValues(updated_1.tabs[updated_1.activeTabIndex]);\n+                                onTabChange == null ? void 0 : onTabChange(updated_1);\n+                                return updated_1;\n+                            });\n+                        };\n+                        $[47] = onTabChange;\n+                        $[48] = setEditorValues;\n+                        $[49] = storeTabs;\n+                        $[50] = t10;\n+                    } else {\n+                        t10 = $[50];\n+                    }\n+                    const moveTab = t10;\n+                    let t11;\n+                    if ($[51] !== onTabChange || $[52] !== setEditorValues || $[53] !== storeTabs) {\n+                        t11 = index_0 => {\n+                            setTabState(current_2 => {\n+                                const updated_2 = {\n+                                    tabs: current_2.tabs.filter((_tab, i) => index_0 !== i),\n+                                    activeTabIndex: Math.max(current_2.activeTabIndex - 1, 0)\n+                                };\n+                                storeTabs(updated_2);\n+                                setEditorValues(updated_2.tabs[updated_2.activeTabIndex]);\n+                                onTabChange == null ? void 0 : onTabChange(updated_2);\n+                                return updated_2;\n+                            });\n+                        };\n+                        $[51] = onTabChange;\n+                        $[52] = setEditorValues;\n+                        $[53] = storeTabs;\n+                        $[54] = t11;\n+                    } else {\n+                        t11 = $[54];\n+                    }\n+                    const closeTab = t11;\n+                    let t12;\n+                    if ($[55] !== onTabChange || $[56] !== storeTabs) {\n+                        t12 = partialTab => {\n+                            setTabState(current_3 => {\n+                                const updated_3 = setPropertiesInActiveTab(current_3, partialTab);\n+                                storeTabs(updated_3);\n+                                onTabChange == null ? void 0 : onTabChange(updated_3);\n+                                return updated_3;\n+                            });\n+                        };\n+                        $[55] = onTabChange;\n+                        $[56] = storeTabs;\n+                        $[57] = t12;\n+                    } else {\n+                        t12 = $[57];\n+                    }\n+                    const updateActiveTabValues = t12;\n+                    const {\n+                        onEditOperationName\n+                    } = props;\n+                    let t13;\n+                    if ($[58] !== onEditOperationName || $[59] !== queryEditor || $[60] !== updateActiveTabValues) {\n+                        t13 = operationName => {\n+                            if (!queryEditor) {\n+                                return;\n                             }\n-                        }\n-\n-                        // [link](  <href>  \"title\"  )\n-                        //                  ^^^^^^^ parsing link title\n-                        res = state.md.helpers.parseLinkTitle(state.src, pos, state.posMax);\n-                        if (pos < max && start !== pos && res.ok) {\n-                            title = res.str;\n-                            pos = res.pos;\n-\n-                            // [link](  <href>  \"title\"  )\n-                            //                         ^^ skipping these spaces\n-                            for (; pos < max; pos++) {\n-                                code = state.src.charCodeAt(pos);\n-                                if (!isSpace(code) && code !== 0x0A) {\n-                                    break;\n-                                }\n+                            updateQueryEditor(queryEditor, operationName);\n+                            updateActiveTabValues({\n+                                operationName\n+                            });\n+                            onEditOperationName == null ? void 0 : onEditOperationName(operationName);\n+                        };\n+                        $[58] = onEditOperationName;\n+                        $[59] = queryEditor;\n+                        $[60] = updateActiveTabValues;\n+                        $[61] = t13;\n+                    } else {\n+                        t13 = $[61];\n+                    }\n+                    const setOperationName = t13;\n+                    let t14;\n+                    let map;\n+                    if ($[62] !== props.externalFragments) {\n+                        map = /* @__PURE__ */ new Map();\n+                        if (Array.isArray(props.externalFragments)) {\n+                            for (const fragment of props.externalFragments) {\n+                                map.set(fragment.name.value, fragment);\n                             }\n                         } else {\n-                            title = '';\n-                        }\n-                        if (pos >= max || state.src.charCodeAt(pos) !== 0x29 /* ) */ ) {\n-                            state.pos = oldPos;\n-                            return false;\n-                        }\n-                        pos++;\n-                    } else {\n-                        //\n-                        // Link reference\n-                        //\n-                        if (typeof state.env.references === 'undefined') {\n-                            return false;\n-                        }\n-                        if (pos < max && state.src.charCodeAt(pos) === 0x5B /* [ */ ) {\n-                            start = pos + 1;\n-                            pos = state.md.helpers.parseLinkLabel(state, pos);\n-                            if (pos >= 0) {\n-                                label = state.src.slice(start, pos++);\n+                            if (typeof props.externalFragments === \"string\") {\n+                                graphql.visit(graphql.parse(props.externalFragments, {}), {\n+                                    FragmentDefinition(fragment_0) {\n+                                        map.set(fragment_0.name.value, fragment_0);\n+                                    }\n+                                });\n                             } else {\n-                                pos = labelEnd + 1;\n+                                if (props.externalFragments) {\n+                                    throw new Error(\"The `externalFragments` prop must either be a string that contains the fragment definitions in SDL or a list of FragmentDefinitionNode objects.\");\n+                                }\n                             }\n-                        } else {\n-                            pos = labelEnd + 1;\n-                        }\n-\n-                        // covers label === '' and label === undefined\n-                        // (collapsed reference link and shortcut reference link respectively)\n-                        if (!label) {\n-                            label = state.src.slice(labelStart, labelEnd);\n-                        }\n-                        ref = state.env.references[normalizeReference(label)];\n-                        if (!ref) {\n-                            state.pos = oldPos;\n-                            return false;\n                         }\n-                        href = ref.href;\n-                        title = ref.title;\n+                        $[62] = props.externalFragments;\n+                        $[63] = map;\n+                    } else {\n+                        map = $[63];\n                     }\n-\n-                    //\n-                    // We found the end of the link, and know for a fact it's a valid link;\n-                    // so all that's left to do is to call tokenizer.\n-                    //\n-                    if (!silent) {\n-                        content = state.src.slice(labelStart, labelEnd);\n-                        const tokens = [];\n-                        state.md.inline.parse(content, state.md, state.env, tokens);\n-                        const token = state.push('image', 'img', 0);\n-                        const attrs = [\n-                            ['src', href],\n-                            ['alt', '']\n-                        ];\n-                        token.attrs = attrs;\n-                        token.children = tokens;\n-                        token.content = content;\n-                        if (title) {\n-                            attrs.push(['title', title]);\n-                        }\n+                    t14 = map;\n+                    const externalFragments = t14;\n+                    let t15;\n+                    if ($[64] !== props.validationRules) {\n+                        t15 = props.validationRules || [];\n+                        $[64] = props.validationRules;\n+                        $[65] = t15;\n+                    } else {\n+                        t15 = $[65];\n                     }\n-                    state.pos = pos;\n-                    state.posMax = max;\n-                    return true;\n+                    const validationRules = t15;\n+                    let t16;\n+                    if ($[66] !== addTab || $[67] !== changeTab || $[68] !== closeTab || $[69] !== externalFragments || $[70] !== headerEditor || $[71] !== initialState.headers || $[72] !== initialState.query || $[73] !== initialState.response || $[74] !== initialState.variables || $[75] !== moveTab || $[76] !== queryEditor || $[77] !== responseEditor || $[78] !== setOperationName || $[79] !== setShouldPersistHeaders || $[80] !== shouldPersistHeaders || $[81] !== tabState_0 || $[82] !== updateActiveTabValues || $[83] !== validationRules || $[84] !== variableEditor) {\n+                        t16 = {\n+                            ...tabState_0,\n+                            addTab,\n+                            changeTab,\n+                            moveTab,\n+                            closeTab,\n+                            updateActiveTabValues,\n+                            headerEditor,\n+                            queryEditor,\n+                            responseEditor,\n+                            variableEditor,\n+                            setHeaderEditor,\n+                            setQueryEditor,\n+                            setResponseEditor,\n+                            setVariableEditor,\n+                            setOperationName,\n+                            initialQuery: initialState.query,\n+                            initialVariables: initialState.variables,\n+                            initialHeaders: initialState.headers,\n+                            initialResponse: initialState.response,\n+                            externalFragments,\n+                            validationRules,\n+                            shouldPersistHeaders,\n+                            setShouldPersistHeaders\n+                        };\n+                        $[66] = addTab;\n+                        $[67] = changeTab;\n+                        $[68] = closeTab;\n+                        $[69] = externalFragments;\n+                        $[70] = headerEditor;\n+                        $[71] = initialState.headers;\n+                        $[72] = initialState.query;\n+                        $[73] = initialState.response;\n+                        $[74] = initialState.variables;\n+                        $[75] = moveTab;\n+                        $[76] = queryEditor;\n+                        $[77] = responseEditor;\n+                        $[78] = setOperationName;\n+                        $[79] = setShouldPersistHeaders;\n+                        $[80] = shouldPersistHeaders;\n+                        $[81] = tabState_0;\n+                        $[82] = updateActiveTabValues;\n+                        $[83] = validationRules;\n+                        $[84] = variableEditor;\n+                        $[85] = t16;\n+                    } else {\n+                        t16 = $[85];\n+                    }\n+                    const value = t16;\n+                    let t17;\n+                    if ($[86] !== children || $[87] !== value) {\n+                        t17 = /* @__PURE__ */ jsxRuntime.jsx(EditorContext.Provider, {\n+                            value,\n+                            children\n+                        });\n+                        $[86] = children;\n+                        $[87] = value;\n+                        $[88] = t17;\n+                    } else {\n+                        t17 = $[88];\n+                    }\n+                    return t17;\n                 }\n \n-                // Process autolinks '<protocol:...>'\n+                function updateQueryEditor(queryEditor, operationName) {\n+                    queryEditor.operationName = operationName;\n+                }\n+                const useEditorContext = createContextHook(EditorContext);\n+                const PERSIST_HEADERS_STORAGE_KEY = \"shouldPersistHeaders\";\n+                const DEFAULT_QUERY = `# Welcome to GraphiQL\n+#\n+# GraphiQL is an in-browser tool for writing, validating, and\n+# testing GraphQL queries.\n+#\n+# Type queries into this side of the screen, and you will see intelligent\n+# typeaheads aware of the current GraphQL type schema and live syntax and\n+# validation errors highlighted within the text.\n+#\n+# GraphQL queries typically start with a \"{\" character. Lines that start\n+# with a # are ignored.\n+#\n+# An example GraphQL query might look like:\n+#\n+#     {\n+#       field(arg: \"value\") {\n+#         subField\n+#       }\n+#     }\n+#\n+# Keyboard shortcuts:\n+#\n+#   Prettify query:  Shift-Ctrl-P (or press the prettify button)\n+#\n+#  Merge fragments:  Shift-Ctrl-M (or press the merge button)\n+#\n+#        Run Query:  Ctrl-Enter (or press the play button)\n+#\n+#    Auto Complete:  Ctrl-Space (or just start typing)\n+#\n \n-                /* eslint max-len:0 */\n-                const EMAIL_RE = /^([a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*)$/;\n-                /* eslint-disable-next-line no-control-regex */\n-                const AUTOLINK_RE = /^([a-zA-Z][a-zA-Z0-9+.-]{1,31}):([^<>\\x00-\\x20]*)$/;\n+`;\n \n-                function autolink(state, silent) {\n-                    let pos = state.pos;\n-                    if (state.src.charCodeAt(pos) !== 0x3C /* < */ ) {\n-                        return false;\n+                function HeaderEditor(t0) {\n+                    const $ = reactCompilerRuntime.c(13);\n+                    let hookArgs;\n+                    let isHidden;\n+                    if ($[0] !== t0) {\n+                        ({\n+                            isHidden,\n+                            ...hookArgs\n+                        } = t0);\n+                        $[0] = t0;\n+                        $[1] = hookArgs;\n+                        $[2] = isHidden;\n+                    } else {\n+                        hookArgs = $[1];\n+                        isHidden = $[2];\n                     }\n-                    const start = state.pos;\n-                    const max = state.posMax;\n-                    for (;;) {\n-                        if (++pos >= max) return false;\n-                        const ch = state.src.charCodeAt(pos);\n-                        if (ch === 0x3C /* < */ ) return false;\n-                        if (ch === 0x3E /* > */ ) break;\n+                    let t1;\n+                    if ($[3] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t1 = {\n+                            nonNull: true,\n+                            caller: HeaderEditor\n+                        };\n+                        $[3] = t1;\n+                    } else {\n+                        t1 = $[3];\n                     }\n-                    const url = state.src.slice(start + 1, pos);\n-                    if (AUTOLINK_RE.test(url)) {\n-                        const fullUrl = state.md.normalizeLink(url);\n-                        if (!state.md.validateLink(fullUrl)) {\n-                            return false;\n-                        }\n-                        if (!silent) {\n-                            const token_o = state.push('link_open', 'a', 1);\n-                            token_o.attrs = [\n-                                ['href', fullUrl]\n-                            ];\n-                            token_o.markup = 'autolink';\n-                            token_o.info = 'auto';\n-                            const token_t = state.push('text', '', 0);\n-                            token_t.content = state.md.normalizeLinkText(url);\n-                            const token_c = state.push('link_close', 'a', -1);\n-                            token_c.markup = 'autolink';\n-                            token_c.info = 'auto';\n-                        }\n-                        state.pos += url.length + 2;\n-                        return true;\n+                    const {\n+                        headerEditor\n+                    } = useEditorContext(t1);\n+                    const ref = useHeaderEditor(hookArgs, HeaderEditor);\n+                    let t2;\n+                    let t3;\n+                    if ($[4] !== headerEditor || $[5] !== isHidden) {\n+                        t2 = () => {\n+                            if (!isHidden) {\n+                                headerEditor == null ? void 0 : headerEditor.refresh();\n+                            }\n+                        };\n+                        t3 = [headerEditor, isHidden];\n+                        $[4] = headerEditor;\n+                        $[5] = isHidden;\n+                        $[6] = t2;\n+                        $[7] = t3;\n+                    } else {\n+                        t2 = $[6];\n+                        t3 = $[7];\n                     }\n-                    if (EMAIL_RE.test(url)) {\n-                        const fullUrl = state.md.normalizeLink('mailto:' + url);\n-                        if (!state.md.validateLink(fullUrl)) {\n-                            return false;\n-                        }\n-                        if (!silent) {\n-                            const token_o = state.push('link_open', 'a', 1);\n-                            token_o.attrs = [\n-                                ['href', fullUrl]\n-                            ];\n-                            token_o.markup = 'autolink';\n-                            token_o.info = 'auto';\n-                            const token_t = state.push('text', '', 0);\n-                            token_t.content = state.md.normalizeLinkText(url);\n-                            const token_c = state.push('link_close', 'a', -1);\n-                            token_c.markup = 'autolink';\n-                            token_c.info = 'auto';\n-                        }\n-                        state.pos += url.length + 2;\n-                        return true;\n+                    React.useEffect(t2, t3);\n+                    const t4 = isHidden && \"hidden\";\n+                    let t5;\n+                    if ($[8] !== t4) {\n+                        t5 = clsx.clsx(\"graphiql-editor\", t4);\n+                        $[8] = t4;\n+                        $[9] = t5;\n+                    } else {\n+                        t5 = $[9];\n                     }\n-                    return false;\n+                    let t6;\n+                    if ($[10] !== ref || $[11] !== t5) {\n+                        t6 = /* @__PURE__ */ jsxRuntime.jsx(\"div\", {\n+                            className: t5,\n+                            ref\n+                        });\n+                        $[10] = ref;\n+                        $[11] = t5;\n+                        $[12] = t6;\n+                    } else {\n+                        t6 = $[12];\n+                    }\n+                    return t6;\n                 }\n \n-                // Process html tags\n+                function ImagePreview(props) {\n+                    var _a;\n+                    const $ = reactCompilerRuntime.c(14);\n+                    let t0;\n+                    if ($[0] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t0 = {\n+                            width: null,\n+                            height: null\n+                        };\n+                        $[0] = t0;\n+                    } else {\n+                        t0 = $[0];\n+                    }\n+                    const [dimensions, setDimensions] = React.useState(t0);\n+                    const [mime, setMime] = React.useState(null);\n+                    const ref = React.useRef(null);\n+                    const src = (_a = tokenToURL(props.token)) == null ? void 0 : _a.href;\n+                    let t1;\n+                    let t2;\n+                    if ($[1] !== src) {\n+                        t1 = () => {\n+                            if (!ref.current) {\n+                                return;\n+                            }\n+                            if (!src) {\n+                                setDimensions({\n+                                    width: null,\n+                                    height: null\n+                                });\n+                                setMime(null);\n+                                return;\n+                            }\n+                            fetch(src, {\n+                                method: \"HEAD\"\n+                            }).then(response => {\n+                                setMime(response.headers.get(\"Content-Type\"));\n+                            }).catch(() => {\n+                                setMime(null);\n+                            });\n+                        };\n+                        t2 = [src];\n+                        $[1] = src;\n+                        $[2] = t1;\n+                        $[3] = t2;\n+                    } else {\n+                        t1 = $[2];\n+                        t2 = $[3];\n+                    }\n+                    React.useEffect(t1, t2);\n+                    let t3;\n+                    if ($[4] !== dimensions.height || $[5] !== dimensions.width || $[6] !== mime) {\n+                        t3 = dimensions.width !== null && dimensions.height !== null ? /* @__PURE__ */ jsxRuntime.jsxs(\"div\", {\n+                            children: [dimensions.width, \"x\", dimensions.height, mime === null ? null : \" \" + mime]\n+                        }) : null;\n+                        $[4] = dimensions.height;\n+                        $[5] = dimensions.width;\n+                        $[6] = mime;\n+                        $[7] = t3;\n+                    } else {\n+                        t3 = $[7];\n+                    }\n+                    const dims = t3;\n+                    let t4;\n+                    if ($[8] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t4 = () => {\n+                            var _ref19, _ref20;\n+                            var _a2, _b;\n+                            setDimensions({\n+                                width: (_ref19 = (_a2 = ref.current) == null ? void 0 : _a2.naturalWidth) !== null && _ref19 !== void 0 ? _ref19 : null,\n+                                height: (_ref20 = (_b = ref.current) == null ? void 0 : _b.naturalHeight) !== null && _ref20 !== void 0 ? _ref20 : null\n+                            });\n+                        };\n+                        $[8] = t4;\n+                    } else {\n+                        t4 = $[8];\n+                    }\n+                    let t5;\n+                    if ($[9] !== src) {\n+                        t5 = /* @__PURE__ */ jsxRuntime.jsx(\"img\", {\n+                            onLoad: t4,\n+                            ref,\n+                            src\n+                        });\n+                        $[9] = src;\n+                        $[10] = t5;\n+                    } else {\n+                        t5 = $[10];\n+                    }\n+                    let t6;\n+                    if ($[11] !== dims || $[12] !== t5) {\n+                        t6 = /* @__PURE__ */ jsxRuntime.jsxs(\"div\", {\n+                            children: [t5, dims]\n+                        });\n+                        $[11] = dims;\n+                        $[12] = t5;\n+                        $[13] = t6;\n+                    } else {\n+                        t6 = $[13];\n+                    }\n+                    return t6;\n+                }\n+                ImagePreview.shouldRender = function shouldRender(token) {\n+                    const url = tokenToURL(token);\n+                    return url ? isImageURL(url) : false;\n+                };\n \n-                function isLinkOpen(str) {\n-                    return /^<a[>\\s]/i.test(str);\n+                function tokenToURL(token) {\n+                    if (token.type !== \"string\") {\n+                        return;\n+                    }\n+                    const value = token.string.slice(1).slice(0, -1).trim();\n+                    try {\n+                        const {\n+                            location\n+                        } = window;\n+                        return new URL(value, location.protocol + \"//\" + location.host);\n+                    } catch {\n+                        return;\n+                    }\n                 }\n \n-                function isLinkClose(str) {\n-                    return /^<\\/a\\s*>/i.test(str);\n+                function isImageURL(url) {\n+                    return /\\.(bmp|gif|jpe?g|png|svg|webp)$/.test(url.pathname);\n                 }\n \n-                function isLetter(ch) {\n-                    /* eslint no-bitwise:0 */\n-                    const lc = ch | 0x20; // to lower case\n-                    return lc >= 0x61 /* a */ && lc <= 0x7a /* z */ ;\n+                function QueryEditor(props) {\n+                    const $ = reactCompilerRuntime.c(2);\n+                    const ref = useQueryEditor(props, QueryEditor);\n+                    let t0;\n+                    if ($[0] !== ref) {\n+                        t0 = /* @__PURE__ */ jsxRuntime.jsx(\"div\", {\n+                            className: \"graphiql-editor\",\n+                            ref\n+                        });\n+                        $[0] = ref;\n+                        $[1] = t0;\n+                    } else {\n+                        t0 = $[1];\n+                    }\n+                    return t0;\n                 }\n \n-                function html_inline(state, silent) {\n-                    if (!state.md.options.html) {\n-                        return false;\n+                function importCodeMirrorImports() {\n+                    return importCodeMirror([Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror/addon/fold/foldgutter.js */ \"../../../node_modules/codemirror/addon/fold/foldgutter.js\"))), Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror/addon/fold/brace-fold.js */ \"../../../node_modules/codemirror/addon/fold/brace-fold.js\"))), Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror/addon/dialog/dialog.js */ \"../../../node_modules/codemirror/addon/dialog/dialog.js\"))), Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror/addon/search/search.js */ \"../../../node_modules/codemirror/addon/search/search.js\"))), Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror/addon/search/searchcursor.js */ \"../../../node_modules/codemirror/addon/search/searchcursor.js\"))), Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror/addon/search/jump-to-line.js */ \"../../../node_modules/codemirror/addon/search/jump-to-line.js\"))), // @ts-expect-error\n+                        Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror/keymap/sublime.js */ \"../../../node_modules/codemirror/keymap/sublime.js\"))), Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror-graphql/esm/results/mode.js */ \"../../codemirror-graphql/esm/results/mode.js\"))), Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! codemirror-graphql/esm/utils/info-addon.js */ \"../../codemirror-graphql/esm/utils/info-addon.js\")))\n+                    ], {\n+                        useCommonAddons: false\n+                    });\n+                }\n+                const _useResponseEditor = useResponseEditor;\n+\n+                function useResponseEditor(t0, caller) {\n+                    const $ = reactCompilerRuntime.c(19);\n+                    let t1;\n+                    if ($[0] !== t0) {\n+                        t1 = t0 === void 0 ? {} : t0;\n+                        $[0] = t0;\n+                        $[1] = t1;\n+                    } else {\n+                        t1 = $[1];\n                     }\n+                    const {\n+                        responseTooltip,\n+                        editorTheme: t2,\n+                        keyMap: t3\n+                    } = t1;\n+                    const editorTheme = t2 === void 0 ? DEFAULT_EDITOR_THEME : t2;\n+                    const keyMap = t3 === void 0 ? DEFAULT_KEY_MAP : t3;\n+                    const t4 = caller || _useResponseEditor;\n+                    let t5;\n+                    if ($[2] !== t4) {\n+                        t5 = {\n+                            nonNull: true,\n+                            caller: t4\n+                        };\n+                        $[2] = t4;\n+                        $[3] = t5;\n+                    } else {\n+                        t5 = $[3];\n+                    }\n+                    const {\n+                        fetchError,\n+                        validationErrors\n+                    } = useSchemaContext(t5);\n+                    const t6 = caller || _useResponseEditor;\n+                    let t7;\n+                    if ($[4] !== t6) {\n+                        t7 = {\n+                            nonNull: true,\n+                            caller: t6\n+                        };\n+                        $[4] = t6;\n+                        $[5] = t7;\n+                    } else {\n+                        t7 = $[5];\n+                    }\n+                    const {\n+                        initialResponse,\n+                        responseEditor,\n+                        setResponseEditor\n+                    } = useEditorContext(t7);\n+                    const ref = React.useRef(null);\n+                    const responseTooltipRef = React.useRef(responseTooltip);\n+                    let t8;\n+                    let t9;\n+                    if ($[6] !== responseTooltip) {\n+                        t8 = () => {\n+                            responseTooltipRef.current = responseTooltip;\n+                        };\n+                        t9 = [responseTooltip];\n+                        $[6] = responseTooltip;\n+                        $[7] = t8;\n+                        $[8] = t9;\n+                    } else {\n+                        t8 = $[7];\n+                        t9 = $[8];\n+                    }\n+                    React.useEffect(t8, t9);\n+                    let t10;\n+                    let t11;\n+                    if ($[9] !== editorTheme || $[10] !== initialResponse || $[11] !== setResponseEditor) {\n+                        t10 = () => {\n+                            let isActive;\n+                            isActive = true;\n+                            importCodeMirrorImports().then(CodeMirror => {\n+                                if (!isActive) {\n+                                    return;\n+                                }\n+                                const tooltipDiv = document.createElement(\"div\");\n+                                CodeMirror.registerHelper(\"info\", \"graphql-results\", (token, _options, _cm, pos) => {\n+                                    const infoElements = [];\n+                                    const ResponseTooltipComponent = responseTooltipRef.current;\n+                                    if (ResponseTooltipComponent) {\n+                                        infoElements.push( /* @__PURE__ */ jsxRuntime.jsx(ResponseTooltipComponent, {\n+                                            pos,\n+                                            token\n+                                        }));\n+                                    }\n+                                    if (ImagePreview.shouldRender(token)) {\n+                                        infoElements.push( /* @__PURE__ */ jsxRuntime.jsx(ImagePreview, {\n+                                            token\n+                                        }, \"image-preview\"));\n+                                    }\n+                                    if (!infoElements.length) {\n+                                        ReactDOM.unmountComponentAtNode(tooltipDiv);\n+                                        return null;\n+                                    }\n+                                    ReactDOM.render(infoElements, tooltipDiv);\n+                                    return tooltipDiv;\n+                                });\n+                                const container = ref.current;\n+                                if (!container) {\n+                                    return;\n+                                }\n+                                const newEditor = CodeMirror(container, {\n+                                    value: initialResponse,\n+                                    lineWrapping: true,\n+                                    readOnly: true,\n+                                    theme: editorTheme,\n+                                    mode: \"graphql-results\",\n+                                    foldGutter: true,\n+                                    gutters: [\"CodeMirror-foldgutter\"],\n+                                    info: true,\n+                                    extraKeys: commonKeys\n+                                });\n+                                setResponseEditor(newEditor);\n+                            });\n+                            return () => {\n+                                isActive = false;\n+                            };\n+                        };\n+                        t11 = [editorTheme, initialResponse, setResponseEditor];\n+                        $[9] = editorTheme;\n+                        $[10] = initialResponse;\n+                        $[11] = setResponseEditor;\n+                        $[12] = t10;\n+                        $[13] = t11;\n+                    } else {\n+                        t10 = $[12];\n+                        t11 = $[13];\n+                    }\n+                    React.useEffect(t10, t11);\n+                    useSynchronizeOption(responseEditor, \"keyMap\", keyMap);\n+                    let t12;\n+                    let t13;\n+                    if ($[14] !== fetchError || $[15] !== responseEditor || $[16] !== validationErrors) {\n+                        t12 = () => {\n+                            if (fetchError) {\n+                                responseEditor == null ? void 0 : responseEditor.setValue(fetchError);\n+                            }\n+                            if (validationErrors.length > 0) {\n+                                responseEditor == null ? void 0 : responseEditor.setValue(toolkit.formatError(validationErrors));\n+                            }\n+                        };\n+                        t13 = [responseEditor, fetchError, validationErrors];\n+                        $[14] = fetchError;\n+                        $[15] = responseEditor;\n+                        $[16] = validationErrors;\n+                        $[17] = t12;\n+                        $[18] = t13;\n+                    } else {\n+                        t12 = $[17];\n+                        t13 = $[18];\n+                    }\n+                    React.useEffect(t12, t13);\n+                    return ref;\n+                }\n \n-                    // Check start\n-                    const max = state.posMax;\n-                    const pos = state.pos;\n-                    if (state.src.charCodeAt(pos) !== 0x3C /* < */ || pos + 2 >= max) {\n-                        return false;\n+                function ResponseEditor(props) {\n+                    const $ = reactCompilerRuntime.c(2);\n+                    const ref = useResponseEditor(props, ResponseEditor);\n+                    let t0;\n+                    if ($[0] !== ref) {\n+                        t0 = /* @__PURE__ */ jsxRuntime.jsx(\"section\", {\n+                            className: \"result-window\",\n+                            \"aria-label\": \"Result Window\",\n+                            \"aria-live\": \"polite\",\n+                            \"aria-atomic\": \"true\",\n+                            ref\n+                        });\n+                        $[0] = ref;\n+                        $[1] = t0;\n+                    } else {\n+                        t0 = $[1];\n                     }\n+                    return t0;\n+                }\n \n-                    // Quick fail on second char\n-                    const ch = state.src.charCodeAt(pos + 1);\n-                    if (ch !== 0x21 /* ! */ && ch !== 0x3F /* ? */ && ch !== 0x2F /* / */ && !isLetter(ch)) {\n-                        return false;\n+                function VariableEditor(t0) {\n+                    const $ = reactCompilerRuntime.c(13);\n+                    let hookArgs;\n+                    let isHidden;\n+                    if ($[0] !== t0) {\n+                        ({\n+                            isHidden,\n+                            ...hookArgs\n+                        } = t0);\n+                        $[0] = t0;\n+                        $[1] = hookArgs;\n+                        $[2] = isHidden;\n+                    } else {\n+                        hookArgs = $[1];\n+                        isHidden = $[2];\n                     }\n-                    const match = state.src.slice(pos).match(HTML_TAG_RE);\n-                    if (!match) {\n-                        return false;\n+                    let t1;\n+                    if ($[3] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t1 = {\n+                            nonNull: true,\n+                            caller: VariableEditor\n+                        };\n+                        $[3] = t1;\n+                    } else {\n+                        t1 = $[3];\n                     }\n-                    if (!silent) {\n-                        const token = state.push('html_inline', '', 0);\n-                        token.content = match[0];\n-                        if (isLinkOpen(token.content)) state.linkLevel++;\n-                        if (isLinkClose(token.content)) state.linkLevel--;\n+                    const {\n+                        variableEditor\n+                    } = useEditorContext(t1);\n+                    const ref = useVariableEditor(hookArgs, VariableEditor);\n+                    let t2;\n+                    let t3;\n+                    if ($[4] !== isHidden || $[5] !== variableEditor) {\n+                        t2 = () => {\n+                            if (variableEditor && !isHidden) {\n+                                variableEditor.refresh();\n+                            }\n+                        };\n+                        t3 = [variableEditor, isHidden];\n+                        $[4] = isHidden;\n+                        $[5] = variableEditor;\n+                        $[6] = t2;\n+                        $[7] = t3;\n+                    } else {\n+                        t2 = $[6];\n+                        t3 = $[7];\n                     }\n-                    state.pos += match[0].length;\n-                    return true;\n+                    React.useEffect(t2, t3);\n+                    const t4 = isHidden && \"hidden\";\n+                    let t5;\n+                    if ($[8] !== t4) {\n+                        t5 = clsx.clsx(\"graphiql-editor\", t4);\n+                        $[8] = t4;\n+                        $[9] = t5;\n+                    } else {\n+                        t5 = $[9];\n+                    }\n+                    let t6;\n+                    if ($[10] !== ref || $[11] !== t5) {\n+                        t6 = /* @__PURE__ */ jsxRuntime.jsx(\"div\", {\n+                            className: t5,\n+                            ref\n+                        });\n+                        $[10] = ref;\n+                        $[11] = t5;\n+                        $[12] = t6;\n+                    } else {\n+                        t6 = $[12];\n+                    }\n+                    return t6;\n                 }\n \n-                // Process html entity - &#123;, &#xAF;, &quot;, ...\n-\n-                const DIGITAL_RE = /^&#((?:x[a-f0-9]{1,6}|[0-9]{1,7}));/i;\n-                const NAMED_RE = /^&([a-z][a-z0-9]{1,31});/i;\n+                function GraphiQLProvider(t0) {\n+                    const $ = reactCompilerRuntime.c(39);\n+                    const {\n+                        children,\n+                        dangerouslyAssumeSchemaIsValid,\n+                        defaultQuery,\n+                        defaultHeaders,\n+                        defaultTabs,\n+                        externalFragments,\n+                        fetcher,\n+                        getDefaultFieldNames,\n+                        headers,\n+                        inputValueDeprecation,\n+                        introspectionQueryName,\n+                        maxHistoryLength,\n+                        onEditOperationName,\n+                        onSchemaChange,\n+                        onTabChange,\n+                        onTogglePluginVisibility,\n+                        operationName,\n+                        plugins,\n+                        query,\n+                        response,\n+                        schema,\n+                        schemaDescription,\n+                        shouldPersistHeaders,\n+                        storage,\n+                        validationRules,\n+                        variables,\n+                        visiblePlugin\n+                    } = t0;\n+                    let t1;\n+                    if ($[0] !== children || $[1] !== onTogglePluginVisibility || $[2] !== plugins || $[3] !== visiblePlugin) {\n+                        t1 = /* @__PURE__ */ jsxRuntime.jsx(ExplorerContextProvider, {\n+                            children: /* @__PURE__ */ jsxRuntime.jsx(PluginContextProvider, {\n+                                onTogglePluginVisibility,\n+                                plugins,\n+                                visiblePlugin,\n+                                children\n+                            })\n+                        });\n+                        $[0] = children;\n+                        $[1] = onTogglePluginVisibility;\n+                        $[2] = plugins;\n+                        $[3] = visiblePlugin;\n+                        $[4] = t1;\n+                    } else {\n+                        t1 = $[4];\n+                    }\n+                    let t2;\n+                    if ($[5] !== fetcher || $[6] !== getDefaultFieldNames || $[7] !== operationName || $[8] !== t1) {\n+                        t2 = /* @__PURE__ */ jsxRuntime.jsx(ExecutionContextProvider, {\n+                            getDefaultFieldNames,\n+                            fetcher,\n+                            operationName,\n+                            children: t1\n+                        });\n+                        $[5] = fetcher;\n+                        $[6] = getDefaultFieldNames;\n+                        $[7] = operationName;\n+                        $[8] = t1;\n+                        $[9] = t2;\n+                    } else {\n+                        t2 = $[9];\n+                    }\n+                    let t3;\n+                    if ($[10] !== dangerouslyAssumeSchemaIsValid || $[11] !== fetcher || $[12] !== inputValueDeprecation || $[13] !== introspectionQueryName || $[14] !== onSchemaChange || $[15] !== schema || $[16] !== schemaDescription || $[17] !== t2) {\n+                        t3 = /* @__PURE__ */ jsxRuntime.jsx(SchemaContextProvider, {\n+                            dangerouslyAssumeSchemaIsValid,\n+                            fetcher,\n+                            inputValueDeprecation,\n+                            introspectionQueryName,\n+                            onSchemaChange,\n+                            schema,\n+                            schemaDescription,\n+                            children: t2\n+                        });\n+                        $[10] = dangerouslyAssumeSchemaIsValid;\n+                        $[11] = fetcher;\n+                        $[12] = inputValueDeprecation;\n+                        $[13] = introspectionQueryName;\n+                        $[14] = onSchemaChange;\n+                        $[15] = schema;\n+                        $[16] = schemaDescription;\n+                        $[17] = t2;\n+                        $[18] = t3;\n+                    } else {\n+                        t3 = $[18];\n+                    }\n+                    let t4;\n+                    if ($[19] !== defaultHeaders || $[20] !== defaultQuery || $[21] !== defaultTabs || $[22] !== externalFragments || $[23] !== headers || $[24] !== onEditOperationName || $[25] !== onTabChange || $[26] !== query || $[27] !== response || $[28] !== shouldPersistHeaders || $[29] !== t3 || $[30] !== validationRules || $[31] !== variables) {\n+                        t4 = /* @__PURE__ */ jsxRuntime.jsx(EditorContextProvider, {\n+                            defaultQuery,\n+                            defaultHeaders,\n+                            defaultTabs,\n+                            externalFragments,\n+                            headers,\n+                            onEditOperationName,\n+                            onTabChange,\n+                            query,\n+                            response,\n+                            shouldPersistHeaders,\n+                            validationRules,\n+                            variables,\n+                            children: t3\n+                        });\n+                        $[19] = defaultHeaders;\n+                        $[20] = defaultQuery;\n+                        $[21] = defaultTabs;\n+                        $[22] = externalFragments;\n+                        $[23] = headers;\n+                        $[24] = onEditOperationName;\n+                        $[25] = onTabChange;\n+                        $[26] = query;\n+                        $[27] = response;\n+                        $[28] = shouldPersistHeaders;\n+                        $[29] = t3;\n+                        $[30] = validationRules;\n+                        $[31] = variables;\n+                        $[32] = t4;\n+                    } else {\n+                        t4 = $[32];\n+                    }\n+                    let t5;\n+                    if ($[33] !== maxHistoryLength || $[34] !== t4) {\n+                        t5 = /* @__PURE__ */ jsxRuntime.jsx(HistoryContextProvider, {\n+                            maxHistoryLength,\n+                            children: t4\n+                        });\n+                        $[33] = maxHistoryLength;\n+                        $[34] = t4;\n+                        $[35] = t5;\n+                    } else {\n+                        t5 = $[35];\n+                    }\n+                    let t6;\n+                    if ($[36] !== storage || $[37] !== t5) {\n+                        t6 = /* @__PURE__ */ jsxRuntime.jsx(StorageContextProvider, {\n+                            storage,\n+                            children: t5\n+                        });\n+                        $[36] = storage;\n+                        $[37] = t5;\n+                        $[38] = t6;\n+                    } else {\n+                        t6 = $[38];\n+                    }\n+                    return t6;\n+                }\n \n-                function entity(state, silent) {\n-                    const pos = state.pos;\n-                    const max = state.posMax;\n-                    if (state.src.charCodeAt(pos) !== 0x26 /* & */ ) return false;\n-                    if (pos + 1 >= max) return false;\n-                    const ch = state.src.charCodeAt(pos + 1);\n-                    if (ch === 0x23 /* # */ ) {\n-                        const match = state.src.slice(pos).match(DIGITAL_RE);\n-                        if (match) {\n-                            if (!silent) {\n-                                const code = match[1][0].toLowerCase() === 'x' ? parseInt(match[1].slice(1), 16) : parseInt(match[1], 10);\n-                                const token = state.push('text_special', '', 0);\n-                                token.content = isValidEntityCode(code) ? fromCodePoint(code) : fromCodePoint(0xFFFD);\n-                                token.markup = match[0];\n-                                token.info = 'entity';\n+                function useTheme(t0) {\n+                    const $ = reactCompilerRuntime.c(11);\n+                    const defaultTheme = t0 === void 0 ? null : t0;\n+                    const storageContext = useStorageContext();\n+                    let t1;\n+                    if ($[0] !== defaultTheme || $[1] !== storageContext) {\n+                        t1 = () => {\n+                            if (!storageContext) {\n+                                return null;\n                             }\n-                            state.pos += match[0].length;\n-                            return true;\n-                        }\n-                    } else {\n-                        const match = state.src.slice(pos).match(NAMED_RE);\n-                        if (match) {\n-                            const decoded = entities.decodeHTML(match[0]);\n-                            if (decoded !== match[0]) {\n-                                if (!silent) {\n-                                    const token = state.push('text_special', '', 0);\n-                                    token.content = decoded;\n-                                    token.markup = match[0];\n-                                    token.info = 'entity';\n+                            const stored = storageContext.get(STORAGE_KEY);\n+                            switch (stored) {\n+                                case \"light\": {\n+                                    return \"light\";\n+                                }\n+                                case \"dark\": {\n+                                    return \"dark\";\n+                                }\n+                                default: {\n+                                    if (typeof stored === \"string\") {\n+                                        storageContext.set(STORAGE_KEY, \"\");\n+                                    }\n+                                    return defaultTheme;\n                                 }\n-                                state.pos += match[0].length;\n-                                return true;\n                             }\n-                        }\n+                        };\n+                        $[0] = defaultTheme;\n+                        $[1] = storageContext;\n+                        $[2] = t1;\n+                    } else {\n+                        t1 = $[2];\n                     }\n-                    return false;\n+                    const [theme, setThemeInternal] = React.useState(t1);\n+                    let t2;\n+                    let t3;\n+                    if ($[3] !== theme) {\n+                        t2 = () => {\n+                            if (typeof window === \"undefined\") {\n+                                return;\n+                            }\n+                            document.body.classList.remove(\"graphiql-light\", \"graphiql-dark\");\n+                            if (theme) {\n+                                document.body.classList.add(`graphiql-${theme}`);\n+                            }\n+                        };\n+                        t3 = [theme];\n+                        $[3] = theme;\n+                        $[4] = t2;\n+                        $[5] = t3;\n+                    } else {\n+                        t2 = $[4];\n+                        t3 = $[5];\n+                    }\n+                    React.useLayoutEffect(t2, t3);\n+                    let t4;\n+                    if ($[6] !== storageContext) {\n+                        t4 = newTheme => {\n+                            storageContext == null ? void 0 : storageContext.set(STORAGE_KEY, newTheme || \"\");\n+                            setThemeInternal(newTheme);\n+                        };\n+                        $[6] = storageContext;\n+                        $[7] = t4;\n+                    } else {\n+                        t4 = $[7];\n+                    }\n+                    const setTheme = t4;\n+                    let t5;\n+                    if ($[8] !== setTheme || $[9] !== theme) {\n+                        t5 = {\n+                            theme,\n+                            setTheme\n+                        };\n+                        $[8] = setTheme;\n+                        $[9] = theme;\n+                        $[10] = t5;\n+                    } else {\n+                        t5 = $[10];\n+                    }\n+                    return t5;\n                 }\n+                const STORAGE_KEY = \"theme\";\n \n-                // For each opening emphasis-like marker find a matching closing one\n-                //\n-\n-                function processDelimiters(delimiters) {\n-                    const openersBottom = {};\n-                    const max = delimiters.length;\n-                    if (!max) return;\n-\n-                    // headerIdx is the first delimiter of the current (where closer is) delimiter run\n-                    let headerIdx = 0;\n-                    let lastTokenIdx = -2; // needs any value lower than -1\n-                    const jumps = [];\n-                    for (let closerIdx = 0; closerIdx < max; closerIdx++) {\n-                        const closer = delimiters[closerIdx];\n-                        jumps.push(0);\n-\n-                        // markers belong to same delimiter run if:\n-                        //  - they have adjacent tokens\n-                        //  - AND markers are the same\n-                        //\n-                        if (delimiters[headerIdx].marker !== closer.marker || lastTokenIdx !== closer.token - 1) {\n-                            headerIdx = closerIdx;\n-                        }\n-                        lastTokenIdx = closer.token;\n-\n-                        // Length is only used for emphasis-specific \"rule of 3\",\n-                        // if it's not defined (in strikethrough or 3rd party plugins),\n-                        // we can default it to 0 to disable those checks.\n-                        //\n-                        closer.length = closer.length || 0;\n-                        if (!closer.close) continue;\n-\n-                        // Previously calculated lower bounds (previous fails)\n-                        // for each marker, each delimiter length modulo 3,\n-                        // and for whether this closer can be an opener;\n-                        // https://github.com/commonmark/cmark/commit/34250e12ccebdc6372b8b49c44fab57c72443460\n-                        /* eslint-disable-next-line no-prototype-builtins */\n-                        if (!openersBottom.hasOwnProperty(closer.marker)) {\n-                            openersBottom[closer.marker] = [-1, -1, -1, -1, -1, -1];\n-                        }\n-                        const minOpenerIdx = openersBottom[closer.marker][(closer.open ? 3 : 0) + closer.length % 3];\n-                        let openerIdx = headerIdx - jumps[headerIdx] - 1;\n-                        let newMinOpenerIdx = openerIdx;\n-                        for (; openerIdx > minOpenerIdx; openerIdx -= jumps[openerIdx] + 1) {\n-                            const opener = delimiters[openerIdx];\n-                            if (opener.marker !== closer.marker) continue;\n-                            if (opener.open && opener.end < 0) {\n-                                let isOddMatch = false;\n-\n-                                // from spec:\n-                                //\n-                                // If one of the delimiters can both open and close emphasis, then the\n-                                // sum of the lengths of the delimiter runs containing the opening and\n-                                // closing delimiters must not be a multiple of 3 unless both lengths\n-                                // are multiples of 3.\n-                                //\n-                                if (opener.close || closer.open) {\n-                                    if ((opener.length + closer.length) % 3 === 0) {\n-                                        if (opener.length % 3 !== 0 || closer.length % 3 !== 0) {\n-                                            isOddMatch = true;\n-                                        }\n+                function useDragResize(t0) {\n+                    const $ = reactCompilerRuntime.c(31);\n+                    const {\n+                        defaultSizeRelation: t1,\n+                        direction,\n+                        initiallyHidden,\n+                        onHiddenElementChange,\n+                        sizeThresholdFirst: t2,\n+                        sizeThresholdSecond: t3,\n+                        storageKey\n+                    } = t0;\n+                    const defaultSizeRelation = t1 === void 0 ? DEFAULT_FLEX : t1;\n+                    const sizeThresholdFirst = t2 === void 0 ? 100 : t2;\n+                    const sizeThresholdSecond = t3 === void 0 ? 100 : t3;\n+                    const storage = useStorageContext();\n+                    let t4;\n+                    if ($[0] !== storage || $[1] !== storageKey) {\n+                        t4 = debounce(500, value => {\n+                            if (storageKey) {\n+                                storage == null ? void 0 : storage.set(storageKey, value);\n+                            }\n+                        });\n+                        $[0] = storage;\n+                        $[1] = storageKey;\n+                        $[2] = t4;\n+                    } else {\n+                        t4 = $[2];\n+                    }\n+                    const store = t4;\n+                    let t5;\n+                    if ($[3] !== initiallyHidden || $[4] !== storage || $[5] !== storageKey) {\n+                        t5 = () => {\n+                            const storedValue = storageKey && (storage == null ? void 0 : storage.get(storageKey));\n+                            if (storedValue === HIDE_FIRST || initiallyHidden === \"first\") {\n+                                return \"first\";\n+                            }\n+                            if (storedValue === HIDE_SECOND || initiallyHidden === \"second\") {\n+                                return \"second\";\n+                            }\n+                            return null;\n+                        };\n+                        $[3] = initiallyHidden;\n+                        $[4] = storage;\n+                        $[5] = storageKey;\n+                        $[6] = t5;\n+                    } else {\n+                        t5 = $[6];\n+                    }\n+                    const [hiddenElement, setHiddenElement] = React.useState(t5);\n+                    let t6;\n+                    if ($[7] !== hiddenElement || $[8] !== onHiddenElementChange) {\n+                        t6 = element => {\n+                            if (element !== hiddenElement) {\n+                                setHiddenElement(element);\n+                                onHiddenElementChange == null ? void 0 : onHiddenElementChange(element);\n+                            }\n+                        };\n+                        $[7] = hiddenElement;\n+                        $[8] = onHiddenElementChange;\n+                        $[9] = t6;\n+                    } else {\n+                        t6 = $[9];\n+                    }\n+                    const setHiddenElementWithCallback = t6;\n+                    const firstRef = React.useRef(null);\n+                    const dragBarRef = React.useRef(null);\n+                    const secondRef = React.useRef(null);\n+                    const defaultFlexRef = React.useRef(`${defaultSizeRelation}`);\n+                    let t7;\n+                    if ($[10] !== storage || $[11] !== storageKey) {\n+                        t7 = () => {\n+                            const storedValue_0 = storageKey && (storage == null ? void 0 : storage.get(storageKey)) || defaultFlexRef.current;\n+                            if (firstRef.current) {\n+                                firstRef.current.style.display = \"flex\";\n+                                firstRef.current.style.flex = storedValue_0 === HIDE_FIRST || storedValue_0 === HIDE_SECOND ? defaultFlexRef.current : storedValue_0;\n+                            }\n+                            if (secondRef.current) {\n+                                secondRef.current.style.display = \"flex\";\n+                                secondRef.current.style.flex = \"1\";\n+                            }\n+                            if (dragBarRef.current) {\n+                                dragBarRef.current.style.display = \"flex\";\n+                            }\n+                        };\n+                        $[10] = storage;\n+                        $[11] = storageKey;\n+                        $[12] = t7;\n+                    } else {\n+                        t7 = $[12];\n+                    }\n+                    let t8;\n+                    if ($[13] !== direction || $[14] !== storage || $[15] !== storageKey) {\n+                        t8 = [direction, storage, storageKey];\n+                        $[13] = direction;\n+                        $[14] = storage;\n+                        $[15] = storageKey;\n+                        $[16] = t8;\n+                    } else {\n+                        t8 = $[16];\n+                    }\n+                    React.useLayoutEffect(t7, t8);\n+                    let t10;\n+                    let t9;\n+                    if ($[17] !== hiddenElement || $[18] !== storage || $[19] !== storageKey) {\n+                        t9 = () => {\n+                            const hide = resizableElement => {\n+                                const element_0 = resizableElement === \"first\" ? firstRef.current : secondRef.current;\n+                                if (!element_0) {\n+                                    return;\n+                                }\n+                                element_0.style.left = \"-1000px\";\n+                                element_0.style.position = \"absolute\";\n+                                element_0.style.opacity = \"0\";\n+                                element_0.style.height = \"500px\";\n+                                element_0.style.width = \"500px\";\n+                                if (firstRef.current) {\n+                                    const flex = parseFloat(firstRef.current.style.flex);\n+                                    if (!Number.isFinite(flex) || flex < 1) {\n+                                        firstRef.current.style.flex = \"1\";\n                                     }\n                                 }\n-                                if (!isOddMatch) {\n-                                    // If previous delimiter cannot be an opener, we can safely skip\n-                                    // the entire sequence in future checks. This is required to make\n-                                    // sure algorithm has linear complexity (see *_*_*_*_*_... case).\n-                                    //\n-                                    const lastJump = openerIdx > 0 && !delimiters[openerIdx - 1].open ? jumps[openerIdx - 1] + 1 : 0;\n-                                    jumps[closerIdx] = closerIdx - openerIdx + lastJump;\n-                                    jumps[openerIdx] = lastJump;\n-                                    closer.open = false;\n-                                    opener.end = closerIdx;\n-                                    opener.close = false;\n-                                    newMinOpenerIdx = -1;\n-                                    // treat next token as start of run,\n-                                    // it optimizes skips in **<...>**a**<...>** pathological case\n-                                    lastTokenIdx = -2;\n-                                    break;\n+                            };\n+                            const show = resizableElement_0 => {\n+                                const element_1 = resizableElement_0 === \"first\" ? firstRef.current : secondRef.current;\n+                                if (!element_1) {\n+                                    return;\n+                                }\n+                                element_1.style.width = \"\";\n+                                element_1.style.height = \"\";\n+                                element_1.style.opacity = \"\";\n+                                element_1.style.position = \"\";\n+                                element_1.style.left = \"\";\n+                                if (storage && storageKey) {\n+                                    const storedValue_1 = storage.get(storageKey);\n+                                    if (firstRef.current && storedValue_1 !== HIDE_FIRST && storedValue_1 !== HIDE_SECOND) {\n+                                        firstRef.current.style.flex = storedValue_1 || defaultFlexRef.current;\n+                                    }\n                                 }\n+                            };\n+                            if (hiddenElement === \"first\") {\n+                                hide(\"first\");\n+                            } else {\n+                                show(\"first\");\n                             }\n-                        }\n-                        if (newMinOpenerIdx !== -1) {\n-                            // If match for this delimiter run failed, we want to set lower bound for\n-                            // future lookups. This is required to make sure algorithm has linear\n-                            // complexity.\n-                            //\n-                            // See details here:\n-                            // https://github.com/commonmark/cmark/issues/178#issuecomment-270417442\n-                            //\n-                            openersBottom[closer.marker][(closer.open ? 3 : 0) + (closer.length || 0) % 3] = newMinOpenerIdx;\n-                        }\n+                            if (hiddenElement === \"second\") {\n+                                hide(\"second\");\n+                            } else {\n+                                show(\"second\");\n+                            }\n+                        };\n+                        t10 = [hiddenElement, storage, storageKey];\n+                        $[17] = hiddenElement;\n+                        $[18] = storage;\n+                        $[19] = storageKey;\n+                        $[20] = t10;\n+                        $[21] = t9;\n+                    } else {\n+                        t10 = $[20];\n+                        t9 = $[21];\n                     }\n-                }\n+                    React.useLayoutEffect(t9, t10);\n+                    let t11;\n+                    let t12;\n+                    if ($[22] !== direction || $[23] !== setHiddenElementWithCallback || $[24] !== sizeThresholdFirst || $[25] !== sizeThresholdSecond || $[26] !== store) {\n+                        t11 = () => {\n+                            if (!dragBarRef.current || !firstRef.current || !secondRef.current) {\n+                                return;\n+                            }\n+                            const dragBarContainer = dragBarRef.current;\n+                            const firstContainer = firstRef.current;\n+                            const wrapper = firstContainer.parentElement;\n+                            const eventProperty = direction === \"horizontal\" ? \"clientX\" : \"clientY\";\n+                            const rectProperty = direction === \"horizontal\" ? \"left\" : \"top\";\n+                            const adjacentRectProperty = direction === \"horizontal\" ? \"right\" : \"bottom\";\n+                            const sizeProperty = direction === \"horizontal\" ? \"clientWidth\" : \"clientHeight\";\n+                            const handleMouseDown = function handleMouseDown2(downEvent) {\n+                                downEvent.preventDefault();\n+                                const offset = downEvent[eventProperty] - dragBarContainer.getBoundingClientRect()[rectProperty];\n+                                const handleMouseMove = function handleMouseMove2(moveEvent) {\n+                                    if (moveEvent.buttons === 0) {\n+                                        return handleMouseUp();\n+                                    }\n+                                    const firstSize = moveEvent[eventProperty] - wrapper.getBoundingClientRect()[rectProperty] - offset;\n+                                    const secondSize = wrapper.getBoundingClientRect()[adjacentRectProperty] - moveEvent[eventProperty] + offset - dragBarContainer[sizeProperty];\n+                                    if (firstSize < sizeThresholdFirst) {\n+                                        setHiddenElementWithCallback(\"first\");\n+                                        store(HIDE_FIRST);\n+                                    } else {\n+                                        if (secondSize < sizeThresholdSecond) {\n+                                            setHiddenElementWithCallback(\"second\");\n+                                            store(HIDE_SECOND);\n+                                        } else {\n+                                            setHiddenElementWithCallback(null);\n+                                            const newFlex = `${firstSize / secondSize}`;\n+                                            firstContainer.style.flex = newFlex;\n+                                            store(newFlex);\n+                                        }\n+                                    }\n+                                };\n \n-                function link_pairs(state) {\n-                    const tokens_meta = state.tokens_meta;\n-                    const max = state.tokens_meta.length;\n-                    processDelimiters(state.delimiters);\n-                    for (let curr = 0; curr < max; curr++) {\n-                        if (tokens_meta[curr] && tokens_meta[curr].delimiters) {\n-                            processDelimiters(tokens_meta[curr].delimiters);\n-                        }\n+                                function handleMouseUp() {\n+                                    document.removeEventListener(\"mousemove\", handleMouseMove);\n+                                    document.removeEventListener(\"mouseup\", handleMouseUp);\n+                                }\n+                                document.addEventListener(\"mousemove\", handleMouseMove);\n+                                document.addEventListener(\"mouseup\", handleMouseUp);\n+                            };\n+                            dragBarContainer.addEventListener(\"mousedown\", handleMouseDown);\n+                            const reset = function reset2() {\n+                                if (firstRef.current) {\n+                                    firstRef.current.style.flex = defaultFlexRef.current;\n+                                }\n+                                store(defaultFlexRef.current);\n+                                setHiddenElementWithCallback(null);\n+                            };\n+                            dragBarContainer.addEventListener(\"dblclick\", reset);\n+                            return () => {\n+                                dragBarContainer.removeEventListener(\"mousedown\", handleMouseDown);\n+                                dragBarContainer.removeEventListener(\"dblclick\", reset);\n+                            };\n+                        };\n+                        t12 = [direction, setHiddenElementWithCallback, sizeThresholdFirst, sizeThresholdSecond, store];\n+                        $[22] = direction;\n+                        $[23] = setHiddenElementWithCallback;\n+                        $[24] = sizeThresholdFirst;\n+                        $[25] = sizeThresholdSecond;\n+                        $[26] = store;\n+                        $[27] = t11;\n+                        $[28] = t12;\n+                    } else {\n+                        t11 = $[27];\n+                        t12 = $[28];\n                     }\n+                    React.useEffect(t11, t12);\n+                    let t13;\n+                    if ($[29] !== hiddenElement) {\n+                        t13 = {\n+                            dragBarRef,\n+                            hiddenElement,\n+                            firstRef,\n+                            setHiddenElement,\n+                            secondRef\n+                        };\n+                        $[29] = hiddenElement;\n+                        $[30] = t13;\n+                    } else {\n+                        t13 = $[30];\n+                    }\n+                    return t13;\n                 }\n-\n-                // Clean up tokens after emphasis and strikethrough postprocessing:\n-                // merge adjacent text nodes into one and re-calculate all token levels\n-                //\n-                // This is necessary because initially emphasis delimiter markers (*, _, ~)\n-                // are treated as their own separate text tokens. Then emphasis rule either\n-                // leaves them as text (needed to merge with adjacent text) or turns them\n-                // into opening/closing tags (which messes up levels inside).\n-                //\n-\n-                function fragments_join(state) {\n-                    let curr, last;\n-                    let level = 0;\n-                    const tokens = state.tokens;\n-                    const max = state.tokens.length;\n-                    for (curr = last = 0; curr < max; curr++) {\n-                        // re-calculate levels after emphasis/strikethrough turns some text nodes\n-                        // into opening/closing tags\n-                        if (tokens[curr].nesting < 0) level--; // closing tag\n-                        tokens[curr].level = level;\n-                        if (tokens[curr].nesting > 0) level++; // opening tag\n-\n-                        if (tokens[curr].type === 'text' && curr + 1 < max && tokens[curr + 1].type === 'text') {\n-                            // collapse two adjacent text nodes\n-                            tokens[curr + 1].content = tokens[curr].content + tokens[curr + 1].content;\n-                        } else {\n-                            if (curr !== last) {\n-                                tokens[last] = tokens[curr];\n+                const DEFAULT_FLEX = 1;\n+                const HIDE_FIRST = \"hide-first\";\n+                const HIDE_SECOND = \"hide-second\";\n+                const ToolbarButton = React.forwardRef((t0, ref) => {\n+                    const $ = reactCompilerRuntime.c(19);\n+                    let label;\n+                    let onClick;\n+                    let props;\n+                    if ($[0] !== t0) {\n+                        ({\n+                            label,\n+                            onClick,\n+                            ...props\n+                        } = t0);\n+                        $[0] = t0;\n+                        $[1] = label;\n+                        $[2] = onClick;\n+                        $[3] = props;\n+                    } else {\n+                        label = $[1];\n+                        onClick = $[2];\n+                        props = $[3];\n+                    }\n+                    const [error, setError] = React.useState(null);\n+                    let t1;\n+                    if ($[4] !== onClick) {\n+                        t1 = event => {\n+                            try {\n+                                if (onClick) {\n+                                    onClick(event);\n+                                }\n+                                setError(null);\n+                            } catch (t22) {\n+                                const err = t22;\n+                                setError(err instanceof Error ? err : new Error(`Toolbar button click failed: ${err}`));\n                             }\n-                            last++;\n-                        }\n+                        };\n+                        $[4] = onClick;\n+                        $[5] = t1;\n+                    } else {\n+                        t1 = $[5];\n                     }\n-                    if (curr !== last) {\n-                        tokens.length = last;\n+                    const handleClick = t1;\n+                    const t2 = error && \"error\";\n+                    let t3;\n+                    if ($[6] !== props.className || $[7] !== t2) {\n+                        t3 = clsx.clsx(\"graphiql-toolbar-button\", t2, props.className);\n+                        $[6] = props.className;\n+                        $[7] = t2;\n+                        $[8] = t3;\n+                    } else {\n+                        t3 = $[8];\n                     }\n-                }\n-\n-                /** internal\n-                 * class ParserInline\n-                 *\n-                 * Tokenizes paragraph content.\n-                 **/\n-\n-                // Parser rules\n-\n-                const _rules = [\n-                    ['text', text],\n-                    ['linkify', linkify],\n-                    ['newline', newline],\n-                    ['escape', escape],\n-                    ['backticks', backtick],\n-                    ['strikethrough', r_strikethrough.tokenize],\n-                    ['emphasis', r_emphasis.tokenize],\n-                    ['link', link],\n-                    ['image', image],\n-                    ['autolink', autolink],\n-                    ['html_inline', html_inline],\n-                    ['entity', entity]\n-                ];\n-\n-                // `rule2` ruleset was created specifically for emphasis/strikethrough\n-                // post-processing and may be changed in the future.\n-                //\n-                // Don't use this for anything except pairs (plugins working with `balance_pairs`).\n-                //\n-                const _rules2 = [\n-                    ['balance_pairs', link_pairs],\n-                    ['strikethrough', r_strikethrough.postProcess],\n-                    ['emphasis', r_emphasis.postProcess],\n-                    // rules for pairs separate '**' into its own text tokens, which may be left unused,\n-                    // rule below merges unused segments back with the rest of the text\n-                    ['fragments_join', fragments_join]\n-                ];\n-\n-                /**\n-                 * new ParserInline()\n-                 **/\n-                function ParserInline() {\n-                    /**\n-                     * ParserInline#ruler -> Ruler\n-                     *\n-                     * [[Ruler]] instance. Keep configuration of inline rules.\n-                     **/\n-                    this.ruler = new Ruler();\n-                    for (let i = 0; i < _rules.length; i++) {\n-                        this.ruler.push(_rules[i][0], _rules[i][1]);\n+                    const t4 = error ? error.message : label;\n+                    const t5 = error ? \"true\" : props[\"aria-invalid\"];\n+                    let t6;\n+                    if ($[9] !== handleClick || $[10] !== props || $[11] !== ref || $[12] !== t3 || $[13] !== t4 || $[14] !== t5) {\n+                        t6 = /* @__PURE__ */ jsxRuntime.jsx(UnStyledButton, {\n+                            ...props,\n+                            ref,\n+                            type: \"button\",\n+                            className: t3,\n+                            onClick: handleClick,\n+                            \"aria-label\": t4,\n+                            \"aria-invalid\": t5\n+                        });\n+                        $[9] = handleClick;\n+                        $[10] = props;\n+                        $[11] = ref;\n+                        $[12] = t3;\n+                        $[13] = t4;\n+                        $[14] = t5;\n+                        $[15] = t6;\n+                    } else {\n+                        t6 = $[15];\n                     }\n-\n-                    /**\n-                     * ParserInline#ruler2 -> Ruler\n-                     *\n-                     * [[Ruler]] instance. Second ruler used for post-processing\n-                     * (e.g. in emphasis-like rules).\n-                     **/\n-                    this.ruler2 = new Ruler();\n-                    for (let i = 0; i < _rules2.length; i++) {\n-                        this.ruler2.push(_rules2[i][0], _rules2[i][1]);\n+                    let t7;\n+                    if ($[16] !== label || $[17] !== t6) {\n+                        t7 = /* @__PURE__ */ jsxRuntime.jsx(Tooltip, {\n+                            label,\n+                            children: t6\n+                        });\n+                        $[16] = label;\n+                        $[17] = t6;\n+                        $[18] = t7;\n+                    } else {\n+                        t7 = $[18];\n                     }\n-                }\n+                    return t7;\n+                });\n+                ToolbarButton.displayName = \"ToolbarButton\";\n \n-                // Skip single token by running all rules in validation mode;\n-                // returns `true` if any rule reported success\n-                //\n-                ParserInline.prototype.skipToken = function(state) {\n-                    const pos = state.pos;\n-                    const rules = this.ruler.getRules('');\n-                    const len = rules.length;\n-                    const maxNesting = state.md.options.maxNesting;\n-                    const cache = state.cache;\n-                    if (typeof cache[pos] !== 'undefined') {\n-                        state.pos = cache[pos];\n-                        return;\n+                function ExecuteButton() {\n+                    const $ = reactCompilerRuntime.c(19);\n+                    let t0;\n+                    if ($[0] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t0 = {\n+                            nonNull: true,\n+                            caller: ExecuteButton\n+                        };\n+                        $[0] = t0;\n+                    } else {\n+                        t0 = $[0];\n                     }\n-                    let ok = false;\n-                    if (state.level < maxNesting) {\n-                        for (let i = 0; i < len; i++) {\n-                            // Increment state.level and decrement it later to limit recursion.\n-                            // It's harmless to do here, because no tokens are created. But ideally,\n-                            // we'd need a separate private state variable for this purpose.\n-                            //\n-                            state.level++;\n-                            ok = rules[i](state, true);\n-                            state.level--;\n-                            if (ok) {\n-                                if (pos >= state.pos) {\n-                                    throw new Error(\"inline rule didn't increment state.pos\");\n-                                }\n-                                break;\n-                            }\n-                        }\n+                    const {\n+                        queryEditor,\n+                        setOperationName\n+                    } = useEditorContext(t0);\n+                    let t1;\n+                    if ($[1] === Symbol.for(\"react.memo_cache_sentinel\")) {\n+                        t1 = {\n+                            nonNull: true,\n+                            caller: ExecuteButton\n+                        };\n+                        $[1] = t1;\n                     } else {\n-                        // Too much nesting, just skip until the end of the paragraph.\n-                        //\n-                        // NOTE: this will cause links to behave incorrectly in the following case,\n-                        //       when an amount of `[` is exactly equal to `maxNesting + 1`:\n-                        //\n-                        //       [[[[[[[[[[[[[[[[[[[[[foo]()\n-                        //\n-                        // TODO: remove this workaround when CM standard will allow nested links\n-                        //       (we can replace it by preventing links from being parsed in\n-                        //       validation mode)\n-                        //\n-                        state.pos = state.posMax;\n+                        t1 = $[1];\n                     }\n-                    if (!ok) {\n-                        state.pos++;\n+                    const {\n+                        isFetching,\n+                        isSubscribed,\n+                        operationName,\n+                        run,\n+                        stop\n+                    } = useExecutionContext(t1);\n+                    let t2;\n+                    if ($[2] !== (queryEditor == null ? void 0 : queryEditor.operations)) {\n+                        t2 = (queryEditor == null ? void 0 : queryEditor.operations) || [];\n+                        $[2] = queryEditor == null ? void 0 : queryEditor.operations;\n+                        $[3] = t2;\n+                    } else {\n+                        t2 = $[3];\n                     }\n-                    cache[pos] = state.pos;\n-                };\n-\n-                // Generate tokens for input range\n-                //\n-                ParserInline.prototype.tokenize = function(state) {\n-                    const rules = this.ruler.getRules('');\n-                    const len = rules.length;\n-                    const end = state.posMax;\n-                    const maxNesting = state.md.options.maxNesting;\n-                    while (state.pos < end) {\n-                        // Try all possible rules.\n-                        // On success, rule should:\n-                        //\n-                        // - update `state.pos`\n-                        // - update `state.tokens`\n-                        // - return true\n-                        const prevPos = state.pos;\n-                        let ok = false;\n-                        if (state.level < maxNesting) {\n-                            for (let i = 0; i < len; i++) {\n-                                ok = rules[i](state, false);\n-                                if (ok) {\n-                                    if (prevPos >= state.pos) {\n-                                        throw new Error(\"inline rule didn't increment state.pos\");\n+                    const operations = t2;\n+                    const hasOptions = operations.length > 1 && typeof operationName !== \"string\";\n+                    const isRunning = isFetching || isSubscribed;\n+                    const label = `${isRunning ? \"Stop\" : \"Execute\"} query (Ctrl-Enter)`;\n+                    let t3;\n+                    if ($[4] !== isRunning) {\n+                        t3 = isRunning ? /* @__PURE__ */ jsxRuntime.jsx(StopIcon, {}) : /* @__PURE__ */ jsxRuntime.jsx(PlayIcon, {});\n+                        $[4] = isRunning;\n+                        $[5] = t3;\n+                    } else {\n+                        t3 = $[5];\n+                    }\n+                    let t4;\n+                    if ($[6] !== label || $[7] !== t3) {\n+                        t4 = {\n+                            type: \"button\",\n+                            className: \"graphiql-execute-button\",\n+                            children: t3,\n+                            \"aria-label\": label\n+                        };\n+                        $[6] = label;\n+                        $[7] = t3;\n+                        $[8] = t4;\n+                    } else {\n+                        t4 = $[8];\n+                    }\n+                    const buttonProps = t4;\n+                    let t5;\n+                    if ($[9] !== buttonProps || $[10] !== hasOptions || $[11] !== isRunning || $[12] !== label || $[13] !== operations || $[14] !== queryEditor || $[15] !== run || $[16] !== setOperationName || $[17] !== stop) {\n+                        t5 = hasOptions && !isRunning ? /* @__PURE__ */ jsxRuntime.jsxs(DropdownMenu, {\n+                            children: [ /* @__PURE__ */ jsxRuntime.jsx(Tooltip, {\n+                                label,\n+                                children: /* @__PURE__ */ jsxRuntime.jsx(DropdownMenu.Button, {\n+                                    ...buttonProps\n+                                })\n+                            }), /* @__PURE__ */ jsxRuntime.jsx(DropdownMenu.Content, {\n+                                children: operations.map((operation, i) => {\n+                                    const opName = operation.name ? operation.name.value : `<Unnamed ${operation.operation}>`;\n+                                    return /* @__PURE__ */ jsxRuntime.jsx(DropdownMenu.Item, {\n+                                        onSelect: () => {\n+                                            var _a;\n+                                            const selectedOperationName = (_a = operation.name) == null ? void 0 : _a.value;\n+                                            if (queryEditor && selectedOperationName && selectedOperationName !== queryEditor.operationName) {\n+                                                setOperationName(selectedOperationName);\n+                                            }\n+                                            run();\n+                                        },\n+                                        children: opName\n+                                    }, `${opName}-${i}`);\n+                                })\n+                            })]\n+                        }) : /* @__PURE__ */ jsxRuntime.jsx(Tooltip, {\n+                            label,\n+                            children: /* @__PURE__ */ jsxRuntime.jsx(\"button\", {\n+                                ...buttonProps,\n+                                onClick: () => {\n+                                    if (isRunning) {\n+                                        stop();\n+                                    } else {\n+                                        run();\n                                     }\n-                                    break;\n                                 }\n-                            }\n-                        }\n-                        if (ok) {\n-                            if (state.pos >= end) {\n-                                break;\n-                            }\n-                            continue;\n-                        }\n-                        state.pending += state.src[state.pos++];\n+                            })\n+                        });\n+                        $[9] = buttonProps;\n+                        $[10] = hasOptions;\n+                        $[11] = isRunning;\n+                        $[12] = label;\n+                        $[13] = operations;\n+                        $[14] = queryEditor;\n+                        $[15] = run;\n+                        $[16] = setOperationName;\n+                        $[17] = stop;\n+                        $[18] = t5;\n+                    } else {\n+                        t5 = $[18];\n                     }\n-                    if (state.pending) {\n-                        state.pushPending();\n+                    return t5;\n+                }\n+                const ToolbarMenuRoot = t0 => {\n+                    const $ = reactCompilerRuntime.c(20);\n+                    let button;\n+                    let children;\n+                    let label;\n+                    let props;\n+                    if ($[0] !== t0) {\n+                        ({\n+                            button,\n+                            children,\n+                            label,\n+                            ...props\n+                        } = t0);\n+                        $[0] = t0;\n+                        $[1] = button;\n+                        $[2] = children;\n+                        $[3] = label;\n+                        $[4] = props;\n+                    } else {\n+                        button = $[1];\n+                        children = $[2];\n+                        label = $[3];\n+                        props = $[4];\n+                    }\n+                    let t1;\n+                    if ($[5] !== props.className) {\n+                        t1 = clsx.clsx(\"graphiql-un-styled graphiql-toolbar-menu\", props.className);\n+                        $[5] = props.className;\n+                        $[6] = t1;\n+                    } else {\n+                        t1 = $[6];\n                     }\n-                };\n-\n-                /**\n-                 * ParserInline.parse(str, md, env, outTokens)\n-                 *\n-                 * Process input string and push inline tokens into `outTokens`\n-                 **/\n-                ParserInline.prototype.parse = function(str, md, env, outTokens) {\n-                    const state = new this.State(str, md, env, outTokens);\n-                    this.tokenize(state);\n-                    const rules = this.ruler2.getRules('');\n-                    const len = rules.length;\n-                    for (let i = 0; i < len; i++) {\n-                        rules[i](state);\n+                    let t2;\n+                    if ($[7] !== button || $[8] !== label || $[9] !== t1) {\n+                        t2 = /* @__PURE__ */ jsxRuntime.jsx(DropdownMenu.Button, {\n+                            className: t1,\n+                            \"aria-label\": label,\n+                            children: button\n+                        });\n+                        $[7] = button;\n+                        $[8] = label;\n+                        $[9] = t1;\n+                        $[10] = t2;\n+                    } else {\n+                        t2 = $[10];\n+                    }\n+                    let t3;\n+                    if ($[11] !== label || $[12] !== t2) {\n+                        t3 = /* @__PURE__ */ jsxRuntime.jsx(Tooltip, {\n+                            label,\n+                            children: t2\n+                        });\n+                        $[11] = label;\n+                        $[12] = t2;\n+                        $[13] = t3;\n+                    } else {\n+                        t3 = $[13];\n+                    }\n+                    let t4;\n+                    if ($[14] !== children) {\n+                        t4 = /* @__PURE__ */ jsxRuntime.jsx(DropdownMenu.Content, {\n+                            children\n+                        });\n+                        $[14] = children;\n+                        $[15] = t4;\n+                    } else {\n+                        t4 = $[15];\n+                    }\n+                    let t5;\n+                    if ($[16] !== props || $[17] !== t3 || $[18] !== t4) {\n+                        t5 = /* @__PURE__ */ jsxRuntime.jsxs(DropdownMenu, {\n+                            ...props,\n+                            children: [t3, t4]\n+                        });\n+                        $[16] = props;\n+                        $[17] = t3;\n+                        $[18] = t4;\n+                        $[19] = t5;\n+                    } else {\n+                        t5 = $[19];\n                     }\n+                    return t5;\n                 };\n-                ParserInline.prototype.State = StateInline;\n+                const ToolbarMenu = createComponentGroup(ToolbarMenuRoot, {\n+                    Item: DropdownMenu.Item\n+                });\n+                exports.Argument = Argument;\n+                exports.ArgumentIcon = ArgumentIcon;\n+                exports.Button = Button$1;\n+                exports.ButtonGroup = ButtonGroup;\n+                exports.ChevronDownIcon = ChevronDownIcon;\n+                exports.ChevronLeftIcon = ChevronLeftIcon;\n+                exports.ChevronUpIcon = ChevronUpIcon;\n+                exports.CloseIcon = CloseIcon;\n+                exports.CopyIcon = CopyIcon;\n+                exports.DOC_EXPLORER_PLUGIN = DOC_EXPLORER_PLUGIN;\n+                exports.DefaultValue = DefaultValue;\n+                exports.DeprecatedArgumentIcon = DeprecatedArgumentIcon;\n+                exports.DeprecatedEnumValueIcon = DeprecatedEnumValueIcon;\n+                exports.DeprecatedFieldIcon = DeprecatedFieldIcon;\n+                exports.DeprecationReason = DeprecationReason;\n+                exports.Dialog = Dialog;\n+                exports.DialogRoot = DialogRoot;\n+                exports.Directive = Directive;\n+                exports.DirectiveIcon = DirectiveIcon;\n+                exports.DocExplorer = DocExplorer;\n+                exports.DocsFilledIcon = DocsFilledIcon;\n+                exports.DocsIcon = DocsIcon;\n+                exports.DropdownMenu = DropdownMenu;\n+                exports.EditorContext = EditorContext;\n+                exports.EditorContextProvider = EditorContextProvider;\n+                exports.EnumValueIcon = EnumValueIcon;\n+                exports.ExecuteButton = ExecuteButton;\n+                exports.ExecutionContext = ExecutionContext;\n+                exports.ExecutionContextProvider = ExecutionContextProvider;\n+                exports.ExplorerContext = ExplorerContext;\n+                exports.ExplorerContextProvider = ExplorerContextProvider;\n+                exports.ExplorerSection = ExplorerSection;\n+                exports.FieldDocumentation = FieldDocumentation;\n+                exports.FieldIcon = FieldIcon;\n+                exports.FieldLink = FieldLink;\n+                exports.GraphiQLProvider = GraphiQLProvider;\n+                exports.HISTORY_PLUGIN = HISTORY_PLUGIN;\n+                exports.HeaderEditor = HeaderEditor;\n+                exports.History = History;\n+                exports.HistoryContext = HistoryContext;\n+                exports.HistoryContextProvider = HistoryContextProvider;\n+                exports.HistoryIcon = HistoryIcon;\n+                exports.ImagePreview = ImagePreview;\n+                exports.ImplementsIcon = ImplementsIcon;\n+                exports.KeyboardShortcutIcon = KeyboardShortcutIcon;\n+                exports.MagnifyingGlassIcon = MagnifyingGlassIcon;\n+                exports.MarkdownContent = MarkdownContent;\n+                exports.MergeIcon = MergeIcon;\n+                exports.PenIcon = PenIcon;\n+                exports.PlayIcon = PlayIcon;\n+                exports.PluginContext = PluginContext;\n+                exports.PluginContextProvider = PluginContextProvider;\n+                exports.PlusIcon = PlusIcon;\n+                exports.PrettifyIcon = PrettifyIcon;\n+                exports.QueryEditor = QueryEditor;\n+                exports.ReloadIcon = ReloadIcon;\n+                exports.ResponseEditor = ResponseEditor;\n+                exports.RootTypeIcon = RootTypeIcon;\n+                exports.SchemaContext = SchemaContext;\n+                exports.SchemaContextProvider = SchemaContextProvider;\n+                exports.SchemaDocumentation = SchemaDocumentation;\n+                exports.Search = Search;\n+                exports.SettingsIcon = SettingsIcon;\n+                exports.Spinner = Spinner;\n+                exports.StarFilledIcon = StarFilledIcon;\n+                exports.StarIcon = StarIcon;\n+                exports.StopIcon = StopIcon;\n+                exports.StorageContext = StorageContext;\n+                exports.StorageContextProvider = StorageContextProvider;\n+                exports.Tab = Tab;\n+                exports.Tabs = Tabs;\n+                exports.ToolbarButton = ToolbarButton;\n+                exports.ToolbarMenu = ToolbarMenu;\n+                exports.Tooltip = Tooltip;\n+                exports.TooltipRoot = TooltipRoot;\n+                exports.TrashIcon = TrashIcon;\n+                exports.TypeDocumentation = TypeDocumentation;\n+                exports.TypeIcon = TypeIcon;\n+                exports.TypeLink = TypeLink;\n+                exports.UnStyledButton = UnStyledButton;\n+                exports.VariableEditor = VariableEditor;\n+                exports.isMacOs = isMacOs;\n+                exports.useAutoCompleteLeafs = useAutoCompleteLeafs;\n+                exports.useCopyQuery = useCopyQuery;\n+                exports.useDragResize = useDragResize;\n+                exports.useEditorContext = useEditorContext;\n+                exports.useEditorState = useEditorState;\n+                exports.useExecutionContext = useExecutionContext;\n+                exports.useExplorerContext = useExplorerContext;\n+                exports.useHeaderEditor = useHeaderEditor;\n+                exports.useHeadersEditorState = useHeadersEditorState;\n+                exports.useHistoryContext = useHistoryContext;\n+                exports.useMergeQuery = useMergeQuery;\n+                exports.useOperationsEditorState = useOperationsEditorState;\n+                exports.useOptimisticState = useOptimisticState;\n+                exports.usePluginContext = usePluginContext;\n+                exports.usePrettifyEditors = usePrettifyEditors;\n+                exports.useQueryEditor = useQueryEditor;\n+                exports.useResponseEditor = useResponseEditor;\n+                exports.useSchemaContext = useSchemaContext;\n+                exports.useStorageContext = useStorageContext;\n+                exports.useTheme = useTheme;\n+                exports.useVariableEditor = useVariableEditor;\n+                exports.useVariablesEditorState = useVariablesEditorState;\n \n-                // markdown-it default options\n+                /***/\n+            }),\n \n-                var cfg_default = {\n-                    options: {\n-                        // Enable HTML tags in source\n-                        html: false,\n-                        // Use '/' to close single tags (<br />)\n-                        xhtmlOut: false,\n-                        // Convert '\\n' in paragraphs into <br>\n-                        breaks: false,\n-                        // CSS language prefix for fenced blocks\n-                        langPrefix: 'language-',\n-                        // autoconvert URL-like texts to links\n-                        linkify: false,\n-                        // Enable some language-neutral replacements + quotes beautification\n-                        typographer: false,\n-                        // Double + single quotes replacement pairs, when typographer enabled,\n-                        // and smartquotes on. Could be either a String or an Array.\n-                        //\n-                        // For example, you can use '\u00ab\u00bb\u201e\u201c' for Russian, '\u201e\u201c\u201a\u2018' for German,\n-                        // and ['\u00ab\\xA0', '\\xA0\u00bb', '\u2039\\xA0', '\\xA0\u203a'] for French (including nbsp).\n-                        quotes: '\\u201c\\u201d\\u2018\\u2019',\n-                        /* \u201c\u201d\u2018\u2019 */\n+        /***/\n+        \"../../graphiql-toolkit/dist/esm/async-helpers/index.js\":\n+            /*!**************************************************************!*\\\n+              !*** ../../graphiql-toolkit/dist/esm/async-helpers/index.js ***!\n+              \\**************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                        // Highlighter function. Should return escaped HTML,\n-                        // or '' if the source string is not changed and should be escaped externaly.\n-                        // If result starts with <pre... internal wrapper is skipped.\n-                        //\n-                        // function (/*str, lang*/) { return ''; }\n-                        //\n-                        highlight: null,\n-                        // Internal protection, recursion limit\n-                        maxNesting: 100\n-                    },\n-                    components: {\n-                        core: {},\n-                        block: {},\n-                        inline: {}\n-                    }\n-                };\n+                \"use strict\";\n \n-                // \"Zero\" preset, with nothing enabled. Useful for manual configuring of simple\n-                // modes. For example, to parse bold/italic only.\n \n-                var cfg_zero = {\n-                    options: {\n-                        // Enable HTML tags in source\n-                        html: false,\n-                        // Use '/' to close single tags (<br />)\n-                        xhtmlOut: false,\n-                        // Convert '\\n' in paragraphs into <br>\n-                        breaks: false,\n-                        // CSS language prefix for fenced blocks\n-                        langPrefix: 'language-',\n-                        // autoconvert URL-like texts to links\n-                        linkify: false,\n-                        // Enable some language-neutral replacements + quotes beautification\n-                        typographer: false,\n-                        // Double + single quotes replacement pairs, when typographer enabled,\n-                        // and smartquotes on. Could be either a String or an Array.\n-                        //\n-                        // For example, you can use '\u00ab\u00bb\u201e\u201c' for Russian, '\u201e\u201c\u201a\u2018' for German,\n-                        // and ['\u00ab\\xA0', '\\xA0\u00bb', '\u2039\\xA0', '\\xA0\u203a'] for French (including nbsp).\n-                        quotes: '\\u201c\\u201d\\u2018\\u2019',\n-                        /* \u201c\u201d\u2018\u2019 */\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.fetcherReturnToPromise = fetcherReturnToPromise;\n+                exports.isAsyncIterable = isAsyncIterable;\n+                exports.isObservable = isObservable;\n+                exports.isPromise = isPromise;\n+                __webpack_require__( /*! ../chunk-LMOQIXV4.js */ \"../../graphiql-toolkit/dist/esm/chunk-LMOQIXV4.js\");\n \n-                        // Highlighter function. Should return escaped HTML,\n-                        // or '' if the source string is not changed and should be escaped externaly.\n-                        // If result starts with <pre... internal wrapper is skipped.\n-                        //\n-                        // function (/*str, lang*/) { return ''; }\n-                        //\n-                        highlight: null,\n-                        // Internal protection, recursion limit\n-                        maxNesting: 20\n-                    },\n-                    components: {\n-                        core: {\n-                            rules: ['normalize', 'block', 'inline', 'text_join']\n-                        },\n-                        block: {\n-                            rules: ['paragraph']\n-                        },\n-                        inline: {\n-                            rules: ['text'],\n-                            rules2: ['balance_pairs', 'fragments_join']\n-                        }\n-                    }\n-                };\n+                function isPromise(value) {\n+                    return typeof value == \"object\" && value !== null && typeof value.then == \"function\";\n+                }\n \n-                // Commonmark default options\n+                function observableToPromise(observable) {\n+                    return new Promise((resolve, reject) => {\n+                        const subscription = observable.subscribe({\n+                            next(v) {\n+                                resolve(v), subscription.unsubscribe();\n+                            },\n+                            error: reject,\n+                            complete() {\n+                                reject(new Error(\"no value resolved\"));\n+                            }\n+                        });\n+                    });\n+                }\n \n-                var cfg_commonmark = {\n-                    options: {\n-                        // Enable HTML tags in source\n-                        html: true,\n-                        // Use '/' to close single tags (<br />)\n-                        xhtmlOut: true,\n-                        // Convert '\\n' in paragraphs into <br>\n-                        breaks: false,\n-                        // CSS language prefix for fenced blocks\n-                        langPrefix: 'language-',\n-                        // autoconvert URL-like texts to links\n-                        linkify: false,\n-                        // Enable some language-neutral replacements + quotes beautification\n-                        typographer: false,\n-                        // Double + single quotes replacement pairs, when typographer enabled,\n-                        // and smartquotes on. Could be either a String or an Array.\n-                        //\n-                        // For example, you can use '\u00ab\u00bb\u201e\u201c' for Russian, '\u201e\u201c\u201a\u2018' for German,\n-                        // and ['\u00ab\\xA0', '\\xA0\u00bb', '\u2039\\xA0', '\\xA0\u203a'] for French (including nbsp).\n-                        quotes: '\\u201c\\u201d\\u2018\\u2019',\n-                        /* \u201c\u201d\u2018\u2019 */\n+                function isObservable(value) {\n+                    return typeof value == \"object\" && value !== null && \"subscribe\" in value && typeof value.subscribe == \"function\";\n+                }\n \n-                        // Highlighter function. Should return escaped HTML,\n-                        // or '' if the source string is not changed and should be escaped externaly.\n-                        // If result starts with <pre... internal wrapper is skipped.\n-                        //\n-                        // function (/*str, lang*/) { return ''; }\n-                        //\n-                        highlight: null,\n-                        // Internal protection, recursion limit\n-                        maxNesting: 20\n+                function isAsyncIterable(input) {\n+                    return typeof input == \"object\" && input !== null && (\n+                        // Some browsers still don't have Symbol.asyncIterator implemented (iOS Safari)\n+                        // That means every custom AsyncIterable must be built using a AsyncGeneratorFunction (async function * () {})\n+                        input[Symbol.toStringTag] === \"AsyncGenerator\" || Symbol.asyncIterator in input);\n+                }\n+                async function asyncIterableToPromise(input) {\n+                    var _a;\n+                    const iteratorReturn = (_a = (\"return\" in input ? input : input[Symbol.asyncIterator]()).return) == null ? void 0 : _a.bind(input),\n+                        result = await (\"next\" in input ? input : input[Symbol.asyncIterator]()).next.bind(input)();\n+                    return iteratorReturn == null || iteratorReturn(), result.value;\n+                }\n+                async function fetcherReturnToPromise(fetcherResult) {\n+                    const result = await fetcherResult;\n+                    return isAsyncIterable(result) ? asyncIterableToPromise(result) : isObservable(result) ? observableToPromise(result) : result;\n+                }\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../graphiql-toolkit/dist/esm/chunk-LMOQIXV4.js\":\n+            /*!*********************************************************!*\\\n+              !*** ../../graphiql-toolkit/dist/esm/chunk-LMOQIXV4.js ***!\n+              \\*********************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.__spreadValues = exports.__spreadProps = exports.__forAwait = exports.__await = exports.__asyncGenerator = void 0;\n+                var __defProp = Object.defineProperty,\n+                    __defProps = Object.defineProperties;\n+                var __getOwnPropDescs = Object.getOwnPropertyDescriptors;\n+                var __getOwnPropSymbols = Object.getOwnPropertySymbols;\n+                var __hasOwnProp = Object.prototype.hasOwnProperty,\n+                    __propIsEnum = Object.prototype.propertyIsEnumerable;\n+                var __knownSymbol = (name, symbol) => (symbol = Symbol[name]) ? symbol : Symbol.for(\"Symbol.\" + name);\n+                var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, {\n+                        enumerable: !0,\n+                        configurable: !0,\n+                        writable: !0,\n+                        value\n+                    }) : obj[key] = value,\n+                    __spreadValues = (a, b) => {\n+                        for (var prop in b || (b = {})) __hasOwnProp.call(b, prop) && __defNormalProp(a, prop, b[prop]);\n+                        if (__getOwnPropSymbols)\n+                            for (var prop of __getOwnPropSymbols(b)) __propIsEnum.call(b, prop) && __defNormalProp(a, prop, b[prop]);\n+                        return a;\n                     },\n-                    components: {\n-                        core: {\n-                            rules: ['normalize', 'block', 'inline', 'text_join']\n-                        },\n-                        block: {\n-                            rules: ['blockquote', 'code', 'fence', 'heading', 'hr', 'html_block', 'lheading', 'list', 'reference', 'paragraph']\n-                        },\n-                        inline: {\n-                            rules: ['autolink', 'backticks', 'emphasis', 'entity', 'escape', 'html_inline', 'image', 'link', 'newline', 'text'],\n-                            rules2: ['balance_pairs', 'emphasis', 'fragments_join']\n-                        }\n-                    }\n-                };\n+                    __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));\n+                exports.__spreadProps = __spreadProps;\n+                exports.__spreadValues = __spreadValues;\n+                var __await = function(promise, isYieldStar) {\n+                        this[0] = promise, this[1] = isYieldStar;\n+                    },\n+                    __asyncGenerator = (__this, __arguments, generator) => {\n+                        var resume = (k, v, yes, no) => {\n+                                try {\n+                                    var x = generator[k](v),\n+                                        isAwait = (v = x.value) instanceof __await,\n+                                        done = x.done;\n+                                    Promise.resolve(isAwait ? v[0] : v).then(y => isAwait ? resume(k === \"return\" ? k : \"next\", v[1] ? {\n+                                        done: y.done,\n+                                        value: y.value\n+                                    } : y, yes, no) : yes({\n+                                        value: y,\n+                                        done\n+                                    })).catch(e => resume(\"throw\", e, yes, no));\n+                                } catch (e) {\n+                                    no(e);\n+                                }\n+                            },\n+                            method = k => it[k] = x => new Promise((yes, no) => resume(k, x, yes, no)),\n+                            it = {};\n+                        return generator = generator.apply(__this, __arguments), it[__knownSymbol(\"asyncIterator\")] = () => it, method(\"next\"), method(\"throw\"), method(\"return\"), it;\n+                    };\n+                exports.__asyncGenerator = __asyncGenerator;\n+                exports.__await = __await;\n+                var __forAwait = (obj, it, method) => (it = obj[__knownSymbol(\"asyncIterator\")]) ? it.call(obj) : (obj = obj[__knownSymbol(\"iterator\")](), it = {}, method = (key, fn) => (fn = obj[key]) && (it[key] = arg => new Promise((yes, no, done) => (arg = fn.call(obj, arg), done = arg.done, Promise.resolve(arg.value).then(value => yes({\n+                    value,\n+                    done\n+                }), no)))), method(\"next\"), method(\"return\"), it);\n+                exports.__forAwait = __forAwait;\n \n-                // Main parser class\n+                /***/\n+            }),\n \n-                const config = {\n-                    default: cfg_default,\n-                    zero: cfg_zero,\n-                    commonmark: cfg_commonmark\n-                };\n+        /***/\n+        \"../../graphiql-toolkit/dist/esm/create-fetcher/createFetcher.js\":\n+            /*!***********************************************************************!*\\\n+              !*** ../../graphiql-toolkit/dist/esm/create-fetcher/createFetcher.js ***!\n+              \\***********************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                //\n-                // This validator can prohibit more than really needed to prevent XSS. It's a\n-                // tradeoff to keep code simple and to be secure by default.\n-                //\n-                // If you need different setup - override validator method as you wish. Or\n-                // replace it with dummy function and use external sanitizer.\n-                //\n+                \"use strict\";\n \n-                const BAD_PROTO_RE = /^(vbscript|javascript|file|data):/;\n-                const GOOD_DATA_RE = /^data:image\\/(gif|png|jpeg|webp);/;\n \n-                function validateLink(url) {\n-                    // url should be normalized at this point, and existing entities are decoded\n-                    const str = url.trim().toLowerCase();\n-                    return BAD_PROTO_RE.test(str) ? GOOD_DATA_RE.test(str) : true;\n-                }\n-                const RECODE_HOSTNAME_FOR = ['http:', 'https:', 'mailto:'];\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.createGraphiQLFetcher = createGraphiQLFetcher;\n+                __webpack_require__( /*! ../chunk-LMOQIXV4.js */ \"../../graphiql-toolkit/dist/esm/chunk-LMOQIXV4.js\");\n+                var _lib = __webpack_require__( /*! ./lib */ \"../../graphiql-toolkit/dist/esm/create-fetcher/lib.js\");\n \n-                function normalizeLink(url) {\n-                    const parsed = mdurl__namespace.parse(url, true);\n-                    if (parsed.hostname) {\n-                        // Encode hostnames in urls like:\n-                        // `http://host/`, `https://host/`, `mailto:user@host`, `//host/`\n-                        //\n-                        // We don't encode unknown schemas, because it's likely that we encode\n-                        // something we shouldn't (e.g. `skype:name` treated as `skype:host`)\n-                        //\n-                        if (!parsed.protocol || RECODE_HOSTNAME_FOR.indexOf(parsed.protocol) >= 0) {\n-                            try {\n-                                parsed.hostname = punycode.toASCII(parsed.hostname);\n-                            } catch (er) {\n-                                /**/ }\n+                function createGraphiQLFetcher(options) {\n+                    const httpFetch = options.fetch || typeof window != \"undefined\" && window.fetch;\n+                    if (!httpFetch) throw new Error(\"No valid fetcher implementation available\");\n+                    options.enableIncrementalDelivery = options.enableIncrementalDelivery !== !1;\n+                    const simpleFetcher = (0, _lib.createSimpleFetcher)(options, httpFetch),\n+                        httpFetcher = options.enableIncrementalDelivery ? (0, _lib.createMultipartFetcher)(options, httpFetch) : simpleFetcher;\n+                    return async (graphQLParams, fetcherOpts) => {\n+                        if (graphQLParams.operationName === \"IntrospectionQuery\") return (options.schemaFetcher || simpleFetcher)(graphQLParams, fetcherOpts);\n+                        if (fetcherOpts != null && fetcherOpts.documentAST ? (0, _lib.isSubscriptionWithName)(fetcherOpts.documentAST, graphQLParams.operationName || void 0) : !1) {\n+                            const wsFetcher = await (0, _lib.getWsFetcher)(options, fetcherOpts);\n+                            if (!wsFetcher) throw new Error(`Your GraphiQL createFetcher is not properly configured for websocket subscriptions yet. ${options.subscriptionUrl ? `Provided URL ${options.subscriptionUrl} failed` : \"Please provide subscriptionUrl, wsClient or legacyClient option first.\"}`);\n+                            return wsFetcher(graphQLParams);\n                         }\n-                    }\n-                    return mdurl__namespace.encode(mdurl__namespace.format(parsed));\n+                        return httpFetcher(graphQLParams, fetcherOpts);\n+                    };\n                 }\n \n-                function normalizeLinkText(url) {\n-                    const parsed = mdurl__namespace.parse(url, true);\n-                    if (parsed.hostname) {\n-                        // Encode hostnames in urls like:\n-                        // `http://host/`, `https://host/`, `mailto:user@host`, `//host/`\n-                        //\n-                        // We don't encode unknown schemas, because it's likely that we encode\n-                        // something we shouldn't (e.g. `skype:name` treated as `skype:host`)\n-                        //\n-                        if (!parsed.protocol || RECODE_HOSTNAME_FOR.indexOf(parsed.protocol) >= 0) {\n-                            try {\n-                                parsed.hostname = punycode.toUnicode(parsed.hostname);\n-                            } catch (er) {\n-                                /**/ }\n-                        }\n-                    }\n+                /***/\n+            }),\n \n-                    // add '%' to exclude list because of https://github.com/markdown-it/markdown-it/issues/720\n-                    return mdurl__namespace.decode(mdurl__namespace.format(parsed), mdurl__namespace.decode.defaultChars + '%');\n-                }\n+        /***/\n+        \"../../graphiql-toolkit/dist/esm/create-fetcher/index.js\":\n+            /*!***************************************************************!*\\\n+              !*** ../../graphiql-toolkit/dist/esm/create-fetcher/index.js ***!\n+              \\***************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                /**\n-                 * class MarkdownIt\n-                 *\n-                 * Main parser/renderer class.\n-                 *\n-                 * ##### Usage\n-                 *\n-                 * ```javascript\n-                 * // node.js, \"classic\" way:\n-                 * var MarkdownIt = require('markdown-it'),\n-                 *     md = new MarkdownIt();\n-                 * var result = md.render('# markdown-it rulezz!');\n-                 *\n-                 * // node.js, the same, but with sugar:\n-                 * var md = require('markdown-it')();\n-                 * var result = md.render('# markdown-it rulezz!');\n-                 *\n-                 * // browser without AMD, added to \"window\" on script load\n-                 * // Note, there are no dash.\n-                 * var md = window.markdownit();\n-                 * var result = md.render('# markdown-it rulezz!');\n-                 * ```\n-                 *\n-                 * Single line rendering, without paragraph wrap:\n-                 *\n-                 * ```javascript\n-                 * var md = require('markdown-it')();\n-                 * var result = md.renderInline('__markdown-it__ rulezz!');\n-                 * ```\n-                 **/\n+                \"use strict\";\n \n-                /**\n-                 * new MarkdownIt([presetName, options])\n-                 * - presetName (String): optional, `commonmark` / `zero`\n-                 * - options (Object)\n-                 *\n-                 * Creates parser instanse with given config. Can be called without `new`.\n-                 *\n-                 * ##### presetName\n-                 *\n-                 * MarkdownIt provides named presets as a convenience to quickly\n-                 * enable/disable active syntax rules and options for common use cases.\n-                 *\n-                 * - [\"commonmark\"](https://github.com/markdown-it/markdown-it/blob/master/lib/presets/commonmark.mjs) -\n-                 *   configures parser to strict [CommonMark](http://commonmark.org/) mode.\n-                 * - [default](https://github.com/markdown-it/markdown-it/blob/master/lib/presets/default.mjs) -\n-                 *   similar to GFM, used when no preset name given. Enables all available rules,\n-                 *   but still without html, typographer & autolinker.\n-                 * - [\"zero\"](https://github.com/markdown-it/markdown-it/blob/master/lib/presets/zero.mjs) -\n-                 *   all rules disabled. Useful to quickly setup your config via `.enable()`.\n-                 *   For example, when you need only `bold` and `italic` markup and nothing else.\n-                 *\n-                 * ##### options:\n-                 *\n-                 * - __html__ - `false`. Set `true` to enable HTML tags in source. Be careful!\n-                 *   That's not safe! You may need external sanitizer to protect output from XSS.\n-                 *   It's better to extend features via plugins, instead of enabling HTML.\n-                 * - __xhtmlOut__ - `false`. Set `true` to add '/' when closing single tags\n-                 *   (`<br />`). This is needed only for full CommonMark compatibility. In real\n-                 *   world you will need HTML output.\n-                 * - __breaks__ - `false`. Set `true` to convert `\\n` in paragraphs into `<br>`.\n-                 * - __langPrefix__ - `language-`. CSS language class prefix for fenced blocks.\n-                 *   Can be useful for external highlighters.\n-                 * - __linkify__ - `false`. Set `true` to autoconvert URL-like text to links.\n-                 * - __typographer__  - `false`. Set `true` to enable [some language-neutral\n-                 *   replacement](https://github.com/markdown-it/markdown-it/blob/master/lib/rules_core/replacements.mjs) +\n-                 *   quotes beautification (smartquotes).\n-                 * - __quotes__ - `\u201c\u201d\u2018\u2019`, String or Array. Double + single quotes replacement\n-                 *   pairs, when typographer enabled and smartquotes on. For example, you can\n-                 *   use `'\u00ab\u00bb\u201e\u201c'` for Russian, `'\u201e\u201c\u201a\u2018'` for German, and\n-                 *   `['\u00ab\\xA0', '\\xA0\u00bb', '\u2039\\xA0', '\\xA0\u203a']` for French (including nbsp).\n-                 * - __highlight__ - `null`. Highlighter function for fenced code blocks.\n-                 *   Highlighter `function (str, lang)` should return escaped HTML. It can also\n-                 *   return empty string if the source was not changed and should be escaped\n-                 *   externaly. If result starts with <pre... internal wrapper is skipped.\n-                 *\n-                 * ##### Example\n-                 *\n-                 * ```javascript\n-                 * // commonmark mode\n-                 * var md = require('markdown-it')('commonmark');\n-                 *\n-                 * // default mode\n-                 * var md = require('markdown-it')();\n-                 *\n-                 * // enable everything\n-                 * var md = require('markdown-it')({\n-                 *   html: true,\n-                 *   linkify: true,\n-                 *   typographer: true\n-                 * });\n-                 * ```\n-                 *\n-                 * ##### Syntax highlighting\n-                 *\n-                 * ```js\n-                 * var hljs = require('highlight.js') // https://highlightjs.org/\n-                 *\n-                 * var md = require('markdown-it')({\n-                 *   highlight: function (str, lang) {\n-                 *     if (lang && hljs.getLanguage(lang)) {\n-                 *       try {\n-                 *         return hljs.highlight(str, { language: lang, ignoreIllegals: true }).value;\n-                 *       } catch (__) {}\n-                 *     }\n-                 *\n-                 *     return ''; // use external default escaping\n-                 *   }\n-                 * });\n-                 * ```\n-                 *\n-                 * Or with full wrapper override (if you need assign class to `<pre>` or `<code>`):\n-                 *\n-                 * ```javascript\n-                 * var hljs = require('highlight.js') // https://highlightjs.org/\n-                 *\n-                 * // Actual default values\n-                 * var md = require('markdown-it')({\n-                 *   highlight: function (str, lang) {\n-                 *     if (lang && hljs.getLanguage(lang)) {\n-                 *       try {\n-                 *         return '<pre><code class=\"hljs\">' +\n-                 *                hljs.highlight(str, { language: lang, ignoreIllegals: true }).value +\n-                 *                '</code></pre>';\n-                 *       } catch (__) {}\n-                 *     }\n-                 *\n-                 *     return '<pre><code class=\"hljs\">' + md.utils.escapeHtml(str) + '</code></pre>';\n-                 *   }\n-                 * });\n-                 * ```\n-                 *\n-                 **/\n-                function MarkdownIt(presetName, options) {\n-                    if (!(this instanceof MarkdownIt)) {\n-                        return new MarkdownIt(presetName, options);\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                var _exportNames = {\n+                    createGraphiQLFetcher: true\n+                };\n+                Object.defineProperty(exports, \"createGraphiQLFetcher\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _createFetcher.createGraphiQLFetcher;\n                     }\n-                    if (!options) {\n-                        if (!isString(presetName)) {\n-                            options = presetName || {};\n-                            presetName = 'default';\n+                }));\n+                __webpack_require__( /*! ../chunk-LMOQIXV4.js */ \"../../graphiql-toolkit/dist/esm/chunk-LMOQIXV4.js\");\n+                var _types = __webpack_require__( /*! ./types */ \"../../graphiql-toolkit/dist/esm/create-fetcher/types.js\");\n+                Object.keys(_types).forEach(function(key) {\n+                    if (key === \"default\" || key === \"__esModule\") return;\n+                    if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;\n+                    if (key in exports && exports[key] === _types[key]) return;\n+                    Object.defineProperty(exports, key, {\n+                        enumerable: true,\n+                        get: function() {\n+                            return _types[key];\n                         }\n-                    }\n+                    });\n+                });\n+                var _createFetcher = __webpack_require__( /*! ./createFetcher */ \"../../graphiql-toolkit/dist/esm/create-fetcher/createFetcher.js\");\n \n-                    /**\n-                     * MarkdownIt#inline -> ParserInline\n-                     *\n-                     * Instance of [[ParserInline]]. You may need it to add new rules when\n-                     * writing plugins. For simple rules control use [[MarkdownIt.disable]] and\n-                     * [[MarkdownIt.enable]].\n-                     **/\n-                    this.inline = new ParserInline();\n+                /***/\n+            }),\n \n-                    /**\n-                     * MarkdownIt#block -> ParserBlock\n-                     *\n-                     * Instance of [[ParserBlock]]. You may need it to add new rules when\n-                     * writing plugins. For simple rules control use [[MarkdownIt.disable]] and\n-                     * [[MarkdownIt.enable]].\n-                     **/\n-                    this.block = new ParserBlock();\n+        /***/\n+        \"../../graphiql-toolkit/dist/esm/create-fetcher/lib.js\":\n+            /*!*************************************************************!*\\\n+              !*** ../../graphiql-toolkit/dist/esm/create-fetcher/lib.js ***!\n+              \\*************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                    /**\n-                     * MarkdownIt#core -> Core\n-                     *\n-                     * Instance of [[Core]] chain executor. You may need it to add new rules when\n-                     * writing plugins. For simple rules control use [[MarkdownIt.disable]] and\n-                     * [[MarkdownIt.enable]].\n-                     **/\n-                    this.core = new Core();\n+                \"use strict\";\n \n-                    /**\n-                     * MarkdownIt#renderer -> Renderer\n-                     *\n-                     * Instance of [[Renderer]]. Use it to modify output look. Or to add rendering\n-                     * rules for new token types, generated by plugins.\n-                     *\n-                     * ##### Example\n-                     *\n-                     * ```javascript\n-                     * var md = require('markdown-it')();\n-                     *\n-                     * function myToken(tokens, idx, options, env, self) {\n-                     *   //...\n-                     *   return result;\n-                     * };\n-                     *\n-                     * md.renderer.rules['my_token'] = myToken\n-                     * ```\n-                     *\n-                     * See [[Renderer]] docs and [source code](https://github.com/markdown-it/markdown-it/blob/master/lib/renderer.mjs).\n-                     **/\n-                    this.renderer = new Renderer();\n \n-                    /**\n-                     * MarkdownIt#linkify -> LinkifyIt\n-                     *\n-                     * [linkify-it](https://github.com/markdown-it/linkify-it) instance.\n-                     * Used by [linkify](https://github.com/markdown-it/markdown-it/blob/master/lib/rules_core/linkify.mjs)\n-                     * rule.\n-                     **/\n-                    this.linkify = new LinkifyIt();\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.createWebsocketsFetcherFromClient = exports.createSimpleFetcher = exports.createMultipartFetcher = exports.createLegacyWebsocketsFetcher = void 0;\n+                exports.createWebsocketsFetcherFromUrl = createWebsocketsFetcherFromUrl;\n+                exports.getWsFetcher = getWsFetcher;\n+                exports.isSubscriptionWithName = void 0;\n+                var _chunkLMOQIXV = __webpack_require__( /*! ../chunk-LMOQIXV4.js */ \"../../graphiql-toolkit/dist/esm/chunk-LMOQIXV4.js\");\n+                var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n+                var _meros = __webpack_require__( /*! meros */ \"../../../node_modules/meros/browser/index.js\");\n+                var _pushPullAsyncIterableIterator = __webpack_require__( /*! @n1ru4l/push-pull-async-iterable-iterator */ \"../../../node_modules/@n1ru4l/push-pull-async-iterable-iterator/index.js\");\n \n-                    /**\n-                     * MarkdownIt#validateLink(url) -> Boolean\n-                     *\n-                     * Link validation function. CommonMark allows too much in links. By default\n-                     * we disable `javascript:`, `vbscript:`, `file:` schemas, and almost all `data:...` schemas\n-                     * except some embedded image types.\n-                     *\n-                     * You can change this behaviour:\n-                     *\n-                     * ```javascript\n-                     * var md = require('markdown-it')();\n-                     * // enable everything\n-                     * md.validateLink = function () { return true; }\n-                     * ```\n-                     **/\n-                    this.validateLink = validateLink;\n+                function _getRequireWildcardCache(e) {\n+                    if (\"function\" != typeof WeakMap) return null;\n+                    var r = new WeakMap(),\n+                        t = new WeakMap();\n+                    return (_getRequireWildcardCache = function(e) {\n+                        return e ? t : r;\n+                    })(e);\n+                }\n+\n+                function _interopRequireWildcard(e, r) {\n+                    if (!r && e && e.__esModule) return e;\n+                    if (null === e || \"object\" != typeof e && \"function\" != typeof e) return {\n+                        default: e\n+                    };\n+                    var t = _getRequireWildcardCache(r);\n+                    if (t && t.has(e)) return t.get(e);\n+                    var n = {\n+                            __proto__: null\n+                        },\n+                        a = Object.defineProperty && Object.getOwnPropertyDescriptor;\n+                    for (var u in e)\n+                        if (\"default\" !== u && Object.prototype.hasOwnProperty.call(e, u)) {\n+                            var i = a ? Object.getOwnPropertyDescriptor(e, u) : null;\n+                            i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u];\n+                        } return n.default = e, t && t.set(e, n), n;\n+                }\n+                const errorHasCode = err => typeof err == \"object\" && err !== null && \"code\" in err,\n+                    isSubscriptionWithName = (document, name) => {\n+                        let isSubscription = !1;\n+                        return (0, _graphql.visit)(document, {\n+                            OperationDefinition(node) {\n+                                var _a;\n+                                name === ((_a = node.name) == null ? void 0 : _a.value) && node.operation === \"subscription\" && (isSubscription = !0);\n+                            }\n+                        }), isSubscription;\n+                    },\n+                    createSimpleFetcher = (options, httpFetch) => async (graphQLParams, fetcherOpts) => (await httpFetch(options.url, {\n+                        method: \"POST\",\n+                        body: JSON.stringify(graphQLParams),\n+                        headers: (0, _chunkLMOQIXV.__spreadValues)((0, _chunkLMOQIXV.__spreadValues)({\n+                            \"content-type\": \"application/json\"\n+                        }, options.headers), fetcherOpts == null ? void 0 : fetcherOpts.headers)\n+                    })).json();\n+                exports.createSimpleFetcher = createSimpleFetcher;\n+                exports.isSubscriptionWithName = isSubscriptionWithName;\n+                async function createWebsocketsFetcherFromUrl(url, connectionParams) {\n+                    let wsClient;\n+                    try {\n+                        const {\n+                            createClient\n+                        } = await Promise.resolve().then(() => _interopRequireWildcard(__webpack_require__( /*! graphql-ws */ \"../../../node_modules/graphql-ws/lib/index.js\")));\n+                        return wsClient = createClient({\n+                            url,\n+                            connectionParams\n+                        }), createWebsocketsFetcherFromClient(wsClient);\n+                    } catch (err) {\n+                        if (errorHasCode(err) && err.code === \"MODULE_NOT_FOUND\") throw new Error(\"You need to install the 'graphql-ws' package to use websockets when passing a 'subscriptionUrl'\");\n+                        console.error(`Error creating websocket client for ${url}`, err);\n+                    }\n+                }\n+                const createWebsocketsFetcherFromClient = wsClient => graphQLParams => (0, _pushPullAsyncIterableIterator.makeAsyncIterableIteratorFromSink)(sink => wsClient.subscribe(graphQLParams, (0, _chunkLMOQIXV.__spreadProps)((0, _chunkLMOQIXV.__spreadValues)({}, sink), {\n+                        error(err) {\n+                            err instanceof CloseEvent ? sink.error(new Error(`Socket closed with event ${err.code} ${err.reason || \"\"}`.trim())) : sink.error(err);\n+                        }\n+                    }))),\n+                    createLegacyWebsocketsFetcher = legacyWsClient => graphQLParams => {\n+                        const observable = legacyWsClient.request(graphQLParams);\n+                        return (0, _pushPullAsyncIterableIterator.makeAsyncIterableIteratorFromSink)(\n+                            // @ts-ignore\n+                            sink => observable.subscribe(sink).unsubscribe);\n+                    },\n+                    createMultipartFetcher = (options, httpFetch) => function(graphQLParams, fetcherOpts) {\n+                        return (0, _chunkLMOQIXV.__asyncGenerator)(this, null, function*() {\n+                            const response = yield new _chunkLMOQIXV.__await(httpFetch(options.url, {\n+                                method: \"POST\",\n+                                body: JSON.stringify(graphQLParams),\n+                                headers: (0, _chunkLMOQIXV.__spreadValues)((0, _chunkLMOQIXV.__spreadValues)({\n+                                    \"content-type\": \"application/json\",\n+                                    accept: \"application/json, multipart/mixed\"\n+                                }, options.headers), fetcherOpts == null ? void 0 : fetcherOpts.headers)\n+                            }).then(r => (0, _meros.meros)(r, {\n+                                multiple: !0\n+                            })));\n+                            if (!(0, _pushPullAsyncIterableIterator.isAsyncIterable)(response)) return yield response.json();\n+                            try {\n+                                for (var iter = (0, _chunkLMOQIXV.__forAwait)(response), more, temp, error; more = !(temp = yield new _chunkLMOQIXV.__await(iter.next())).done; more = !1) {\n+                                    const chunk = temp.value;\n+                                    if (chunk.some(part => !part.json)) {\n+                                        const message = chunk.map(part => `Headers::\n+${part.headers}\n+\n+Body::\n+${part.body}`);\n+                                        throw new Error(`Expected multipart chunks to be of json type. got:\n+${message}`);\n+                                    }\n+                                    yield chunk.map(part => part.body);\n+                                }\n+                            } catch (temp) {\n+                                error = [temp];\n+                            } finally {\n+                                try {\n+                                    more && (temp = iter.return) && (yield new _chunkLMOQIXV.__await(temp.call(iter)));\n+                                } finally {\n+                                    if (error) throw error[0];\n+                                }\n+                            }\n+                        });\n+                    };\n+                exports.createMultipartFetcher = createMultipartFetcher;\n+                exports.createLegacyWebsocketsFetcher = createLegacyWebsocketsFetcher;\n+                exports.createWebsocketsFetcherFromClient = createWebsocketsFetcherFromClient;\n+                async function getWsFetcher(options, fetcherOpts) {\n+                    if (options.wsClient) return createWebsocketsFetcherFromClient(options.wsClient);\n+                    if (options.subscriptionUrl) return createWebsocketsFetcherFromUrl(options.subscriptionUrl, (0, _chunkLMOQIXV.__spreadValues)((0, _chunkLMOQIXV.__spreadValues)({}, options.wsConnectionParams), fetcherOpts == null ? void 0 : fetcherOpts.headers));\n+                    const legacyWebsocketsClient = options.legacyClient || options.legacyWsClient;\n+                    if (legacyWebsocketsClient) return createLegacyWebsocketsFetcher(legacyWebsocketsClient);\n+                }\n \n-                    /**\n-                     * MarkdownIt#normalizeLink(url) -> String\n-                     *\n-                     * Function used to encode link url to a machine-readable format,\n-                     * which includes url-encoding, punycode, etc.\n-                     **/\n-                    this.normalizeLink = normalizeLink;\n+                /***/\n+            }),\n \n-                    /**\n-                     * MarkdownIt#normalizeLinkText(url) -> String\n-                     *\n-                     * Function used to decode link url to a human-readable format`\n-                     **/\n-                    this.normalizeLinkText = normalizeLinkText;\n+        /***/\n+        \"../../graphiql-toolkit/dist/esm/create-fetcher/types.js\":\n+            /*!***************************************************************!*\\\n+              !*** ../../graphiql-toolkit/dist/esm/create-fetcher/types.js ***!\n+              \\***************************************************************/\n+            /***/\n+            (function() {\n \n-                    // Expose utils & helpers for easy acces from plugins\n+                \"use strict\";\n \n-                    /**\n-                     * MarkdownIt#utils -> utils\n-                     *\n-                     * Assorted utility functions, useful to write plugins. See details\n-                     * [here](https://github.com/markdown-it/markdown-it/blob/master/lib/common/utils.mjs).\n-                     **/\n-                    this.utils = utils;\n \n-                    /**\n-                     * MarkdownIt#helpers -> helpers\n-                     *\n-                     * Link components parser functions, useful to write plugins. See details\n-                     * [here](https://github.com/markdown-it/markdown-it/blob/master/lib/helpers).\n-                     **/\n-                    this.helpers = assign({}, helpers);\n-                    this.options = {};\n-                    this.configure(presetName);\n-                    if (options) {\n-                        this.set(options);\n-                    }\n-                }\n+                /***/\n+            }),\n \n-                /** chainable\n-                 * MarkdownIt.set(options)\n-                 *\n-                 * Set parser options (in the same format as in constructor). Probably, you\n-                 * will never need it, but you can change options after constructor call.\n-                 *\n-                 * ##### Example\n-                 *\n-                 * ```javascript\n-                 * var md = require('markdown-it')()\n-                 *             .set({ html: true, breaks: true })\n-                 *             .set({ typographer, true });\n-                 * ```\n-                 *\n-                 * __Note:__ To achieve the best possible performance, don't modify a\n-                 * `markdown-it` instance options on the fly. If you need multiple configurations\n-                 * it's best to create multiple instances and initialize each with separate\n-                 * config.\n-                 **/\n-                MarkdownIt.prototype.set = function(options) {\n-                    assign(this.options, options);\n-                    return this;\n-                };\n+        /***/\n+        \"../../graphiql-toolkit/dist/esm/format/index.js\":\n+            /*!*******************************************************!*\\\n+              !*** ../../graphiql-toolkit/dist/esm/format/index.js ***!\n+              \\*******************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                /** chainable, internal\n-                 * MarkdownIt.configure(presets)\n-                 *\n-                 * Batch load of all options and compenent settings. This is internal method,\n-                 * and you probably will not need it. But if you will - see available presets\n-                 * and data structure [here](https://github.com/markdown-it/markdown-it/tree/master/lib/presets)\n-                 *\n-                 * We strongly recommend to use presets instead of direct config loads. That\n-                 * will give better compatibility with next versions.\n-                 **/\n-                MarkdownIt.prototype.configure = function(presets) {\n-                    const self = this;\n-                    if (isString(presets)) {\n-                        const presetName = presets;\n-                        presets = config[presetName];\n-                        if (!presets) {\n-                            throw new Error('Wrong `markdown-it` preset \"' + presetName + '\", check name');\n-                        }\n-                    }\n-                    if (!presets) {\n-                        throw new Error('Wrong `markdown-it` preset, can\\'t be empty');\n-                    }\n-                    if (presets.options) {\n-                        self.set(presets.options);\n-                    }\n-                    if (presets.components) {\n-                        Object.keys(presets.components).forEach(function(name) {\n-                            if (presets.components[name].rules) {\n-                                self[name].ruler.enableOnly(presets.components[name].rules);\n-                            }\n-                            if (presets.components[name].rules2) {\n-                                self[name].ruler2.enableOnly(presets.components[name].rules2);\n-                            }\n-                        });\n-                    }\n-                    return this;\n-                };\n+                \"use strict\";\n \n-                /** chainable\n-                 * MarkdownIt.enable(list, ignoreInvalid)\n-                 * - list (String|Array): rule name or list of rule names to enable\n-                 * - ignoreInvalid (Boolean): set `true` to ignore errors when rule not found.\n-                 *\n-                 * Enable list or rules. It will automatically find appropriate components,\n-                 * containing rules with given names. If rule not found, and `ignoreInvalid`\n-                 * not set - throws exception.\n-                 *\n-                 * ##### Example\n-                 *\n-                 * ```javascript\n-                 * var md = require('markdown-it')()\n-                 *             .enable(['sub', 'sup'])\n-                 *             .disable('smartquotes');\n-                 * ```\n-                 **/\n-                MarkdownIt.prototype.enable = function(list, ignoreInvalid) {\n-                    let result = [];\n-                    if (!Array.isArray(list)) {\n-                        list = [list];\n-                    }\n-                    ['core', 'block', 'inline'].forEach(function(chain) {\n-                        result = result.concat(this[chain].ruler.enable(list, true));\n-                    }, this);\n-                    result = result.concat(this.inline.ruler2.enable(list, true));\n-                    const missed = list.filter(function(name) {\n-                        return result.indexOf(name) < 0;\n-                    });\n-                    if (missed.length && !ignoreInvalid) {\n-                        throw new Error('MarkdownIt. Failed to enable unknown rule(s): ' + missed);\n-                    }\n-                    return this;\n-                };\n \n-                /** chainable\n-                 * MarkdownIt.disable(list, ignoreInvalid)\n-                 * - list (String|Array): rule name or list of rule names to disable.\n-                 * - ignoreInvalid (Boolean): set `true` to ignore errors when rule not found.\n-                 *\n-                 * The same as [[MarkdownIt.enable]], but turn specified rules off.\n-                 **/\n-                MarkdownIt.prototype.disable = function(list, ignoreInvalid) {\n-                    let result = [];\n-                    if (!Array.isArray(list)) {\n-                        list = [list];\n-                    }\n-                    ['core', 'block', 'inline'].forEach(function(chain) {\n-                        result = result.concat(this[chain].ruler.disable(list, true));\n-                    }, this);\n-                    result = result.concat(this.inline.ruler2.disable(list, true));\n-                    const missed = list.filter(function(name) {\n-                        return result.indexOf(name) < 0;\n-                    });\n-                    if (missed.length && !ignoreInvalid) {\n-                        throw new Error('MarkdownIt. Failed to disable unknown rule(s): ' + missed);\n-                    }\n-                    return this;\n-                };\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.formatError = formatError;\n+                exports.formatResult = formatResult;\n+                var _chunkLMOQIXV = __webpack_require__( /*! ../chunk-LMOQIXV4.js */ \"../../graphiql-toolkit/dist/esm/chunk-LMOQIXV4.js\");\n \n-                /** chainable\n-                 * MarkdownIt.use(plugin, params)\n-                 *\n-                 * Load specified plugin with given params into current parser instance.\n-                 * It's just a sugar to call `plugin(md, params)` with curring.\n-                 *\n-                 * ##### Example\n-                 *\n-                 * ```javascript\n-                 * var iterator = require('markdown-it-for-inline');\n-                 * var md = require('markdown-it')()\n-                 *             .use(iterator, 'foo_replace', 'text', function (tokens, idx) {\n-                 *               tokens[idx].content = tokens[idx].content.replace(/foo/g, 'bar');\n-                 *             });\n-                 * ```\n-                 **/\n-                MarkdownIt.prototype.use = function(plugin /*, params, ... */ ) {\n-                    const args = [this].concat(Array.prototype.slice.call(arguments, 1));\n-                    plugin.apply(plugin, args);\n-                    return this;\n-                };\n+                function stringify(obj) {\n+                    return JSON.stringify(obj, null, 2);\n+                }\n \n-                /** internal\n-                 * MarkdownIt.parse(src, env) -> Array\n-                 * - src (String): source string\n-                 * - env (Object): environment sandbox\n-                 *\n-                 * Parse input string and return list of block tokens (special token type\n-                 * \"inline\" will contain list of inline tokens). You should not call this\n-                 * method directly, until you write custom renderer (for example, to produce\n-                 * AST).\n-                 *\n-                 * `env` is used to pass data between \"distributed\" rules and return additional\n-                 * metadata like reference info, needed for the renderer. It also can be used to\n-                 * inject data in specific cases. Usually, you will be ok to pass `{}`,\n-                 * and then pass updated object to renderer.\n-                 **/\n-                MarkdownIt.prototype.parse = function(src, env) {\n-                    if (typeof src !== 'string') {\n-                        throw new Error('Input data should be a String');\n-                    }\n-                    const state = new this.core.State(src, this, env);\n-                    this.core.process(state);\n-                    return state.tokens;\n-                };\n+                function formatSingleError(error) {\n+                    return (0, _chunkLMOQIXV.__spreadProps)((0, _chunkLMOQIXV.__spreadValues)({}, error), {\n+                        // Raise these details even if they're non-enumerable\n+                        message: error.message,\n+                        stack: error.stack\n+                    });\n+                }\n \n-                /**\n-                 * MarkdownIt.render(src [, env]) -> String\n-                 * - src (String): source string\n-                 * - env (Object): environment sandbox\n-                 *\n-                 * Render markdown string into html. It does all magic for you :).\n-                 *\n-                 * `env` can be used to inject additional metadata (`{}` by default).\n-                 * But you will not need it with high probability. See also comment\n-                 * in [[MarkdownIt.parse]].\n-                 **/\n-                MarkdownIt.prototype.render = function(src, env) {\n-                    env = env || {};\n-                    return this.renderer.render(this.parse(src, env), this.options, env);\n-                };\n+                function handleSingleError(error) {\n+                    return error instanceof Error ? formatSingleError(error) : error;\n+                }\n \n-                /** internal\n-                 * MarkdownIt.parseInline(src, env) -> Array\n-                 * - src (String): source string\n-                 * - env (Object): environment sandbox\n-                 *\n-                 * The same as [[MarkdownIt.parse]] but skip all block rules. It returns the\n-                 * block tokens list with the single `inline` element, containing parsed inline\n-                 * tokens in `children` property. Also updates `env` object.\n-                 **/\n-                MarkdownIt.prototype.parseInline = function(src, env) {\n-                    const state = new this.core.State(src, this, env);\n-                    state.inlineMode = true;\n-                    this.core.process(state);\n-                    return state.tokens;\n-                };\n+                function formatError(error) {\n+                    return Array.isArray(error) ? stringify({\n+                        errors: error.map(e => handleSingleError(e))\n+                    }) : stringify({\n+                        errors: [handleSingleError(error)]\n+                    });\n+                }\n \n-                /**\n-                 * MarkdownIt.renderInline(src [, env]) -> String\n-                 * - src (String): source string\n-                 * - env (Object): environment sandbox\n-                 *\n-                 * Similar to [[MarkdownIt.render]] but for single paragraph content. Result\n-                 * will NOT be wrapped into `<p>` tags.\n-                 **/\n-                MarkdownIt.prototype.renderInline = function(src, env) {\n-                    env = env || {};\n-                    return this.renderer.render(this.parseInline(src, env), this.options, env);\n-                };\n-                module.exports = MarkdownIt;\n+                function formatResult(result) {\n+                    return stringify(result);\n+                }\n \n                 /***/\n             }),\n \n         /***/\n-        \"../node_modules/mdurl/build/index.cjs.js\":\n-            /*!************************************************!*\\\n-              !*** ../node_modules/mdurl/build/index.cjs.js ***!\n-              \\************************************************/\n+        \"../../graphiql-toolkit/dist/esm/graphql-helpers/auto-complete.js\":\n+            /*!************************************************************************!*\\\n+              !*** ../../graphiql-toolkit/dist/esm/graphql-helpers/auto-complete.js ***!\n+              \\************************************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports) {\n-\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n-                /* eslint-disable no-bitwise */\n-                const decodeCache = {};\n \n-                function getDecodeCache(exclude) {\n-                    let cache = decodeCache[exclude];\n-                    if (cache) {\n-                        return cache;\n-                    }\n-                    cache = decodeCache[exclude] = [];\n-                    for (let i = 0; i < 128; i++) {\n-                        const ch = String.fromCharCode(i);\n-                        cache.push(ch);\n-                    }\n-                    for (let i = 0; i < exclude.length; i++) {\n-                        const ch = exclude.charCodeAt(i);\n-                        cache[ch] = '%' + ('0' + ch.toString(16).toUpperCase()).slice(-2);\n-                    }\n-                    return cache;\n-                }\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.fillLeafs = fillLeafs;\n+                __webpack_require__( /*! ../chunk-LMOQIXV4.js */ \"../../graphiql-toolkit/dist/esm/chunk-LMOQIXV4.js\");\n+                var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n \n-                // Decode percent-encoded string.\n-                //\n-                function decode(string, exclude) {\n-                    if (typeof exclude !== 'string') {\n-                        exclude = decode.defaultChars;\n+                function fillLeafs(schema, docString, getDefaultFieldNames) {\n+                    const insertions = [];\n+                    if (!schema || !docString) return {\n+                        insertions,\n+                        result: docString\n+                    };\n+                    let ast;\n+                    try {\n+                        ast = (0, _graphql.parse)(docString);\n+                    } catch (e) {\n+                        return {\n+                            insertions,\n+                            result: docString\n+                        };\n                     }\n-                    const cache = getDecodeCache(exclude);\n-                    return string.replace(/(%[a-f0-9]{2})+/gi, function(seq) {\n-                        let result = '';\n-                        for (let i = 0, l = seq.length; i < l; i += 3) {\n-                            const b1 = parseInt(seq.slice(i + 1, i + 3), 16);\n-                            if (b1 < 0x80) {\n-                                result += cache[b1];\n-                                continue;\n-                            }\n-                            if ((b1 & 0xE0) === 0xC0 && i + 3 < l) {\n-                                // 110xxxxx 10xxxxxx\n-                                const b2 = parseInt(seq.slice(i + 4, i + 6), 16);\n-                                if ((b2 & 0xC0) === 0x80) {\n-                                    const chr = b1 << 6 & 0x7C0 | b2 & 0x3F;\n-                                    if (chr < 0x80) {\n-                                        result += '\\ufffd\\ufffd';\n-                                    } else {\n-                                        result += String.fromCharCode(chr);\n-                                    }\n-                                    i += 3;\n-                                    continue;\n-                                }\n-                            }\n-                            if ((b1 & 0xF0) === 0xE0 && i + 6 < l) {\n-                                // 1110xxxx 10xxxxxx 10xxxxxx\n-                                const b2 = parseInt(seq.slice(i + 4, i + 6), 16);\n-                                const b3 = parseInt(seq.slice(i + 7, i + 9), 16);\n-                                if ((b2 & 0xC0) === 0x80 && (b3 & 0xC0) === 0x80) {\n-                                    const chr = b1 << 12 & 0xF000 | b2 << 6 & 0xFC0 | b3 & 0x3F;\n-                                    if (chr < 0x800 || chr >= 0xD800 && chr <= 0xDFFF) {\n-                                        result += '\\ufffd\\ufffd\\ufffd';\n-                                    } else {\n-                                        result += String.fromCharCode(chr);\n-                                    }\n-                                    i += 6;\n-                                    continue;\n-                                }\n-                            }\n-                            if ((b1 & 0xF8) === 0xF0 && i + 9 < l) {\n-                                // 111110xx 10xxxxxx 10xxxxxx 10xxxxxx\n-                                const b2 = parseInt(seq.slice(i + 4, i + 6), 16);\n-                                const b3 = parseInt(seq.slice(i + 7, i + 9), 16);\n-                                const b4 = parseInt(seq.slice(i + 10, i + 12), 16);\n-                                if ((b2 & 0xC0) === 0x80 && (b3 & 0xC0) === 0x80 && (b4 & 0xC0) === 0x80) {\n-                                    let chr = b1 << 18 & 0x1C0000 | b2 << 12 & 0x3F000 | b3 << 6 & 0xFC0 | b4 & 0x3F;\n-                                    if (chr < 0x10000 || chr > 0x10FFFF) {\n-                                        result += '\\ufffd\\ufffd\\ufffd\\ufffd';\n-                                    } else {\n-                                        chr -= 0x10000;\n-                                        result += String.fromCharCode(0xD800 + (chr >> 10), 0xDC00 + (chr & 0x3FF));\n-                                    }\n-                                    i += 9;\n-                                    continue;\n+                    const fieldNameFn = getDefaultFieldNames || defaultGetDefaultFieldNames,\n+                        typeInfo = new _graphql.TypeInfo(schema);\n+                    return (0, _graphql.visit)(ast, {\n+                        leave(node) {\n+                            typeInfo.leave(node);\n+                        },\n+                        enter(node) {\n+                            if (typeInfo.enter(node), node.kind === \"Field\" && !node.selectionSet) {\n+                                const fieldType = typeInfo.getType(),\n+                                    selectionSet = buildSelectionSet(isFieldType(fieldType), fieldNameFn);\n+                                if (selectionSet && node.loc) {\n+                                    const indent = getIndentation(docString, node.loc.start);\n+                                    insertions.push({\n+                                        index: node.loc.end,\n+                                        string: \" \" + (0, _graphql.print)(selectionSet).replaceAll(`\n+`, `\n+` + indent)\n+                                    });\n                                 }\n                             }\n-                            result += '\\ufffd';\n                         }\n-                        return result;\n-                    });\n+                    }), {\n+                        insertions,\n+                        result: withInsertions(docString, insertions)\n+                    };\n                 }\n-                decode.defaultChars = ';/?:@&=+$,#';\n-                decode.componentChars = '';\n-                const encodeCache = {};\n \n-                // Create a lookup array where anything but characters in `chars` string\n-                // and alphanumeric chars is percent-encoded.\n-                //\n-                function getEncodeCache(exclude) {\n-                    let cache = encodeCache[exclude];\n-                    if (cache) {\n-                        return cache;\n-                    }\n-                    cache = encodeCache[exclude] = [];\n-                    for (let i = 0; i < 128; i++) {\n-                        const ch = String.fromCharCode(i);\n-                        if (/^[0-9a-z]$/i.test(ch)) {\n-                            // always allow unencoded alphanumeric characters\n-                            cache.push(ch);\n-                        } else {\n-                            cache.push('%' + ('0' + i.toString(16).toUpperCase()).slice(-2));\n-                        }\n-                    }\n-                    for (let i = 0; i < exclude.length; i++) {\n-                        cache[exclude.charCodeAt(i)] = exclude[i];\n-                    }\n-                    return cache;\n+                function defaultGetDefaultFieldNames(type) {\n+                    if (!(\"getFields\" in type)) return [];\n+                    const fields = type.getFields();\n+                    if (fields.id) return [\"id\"];\n+                    if (fields.edges) return [\"edges\"];\n+                    if (fields.node) return [\"node\"];\n+                    const leafFieldNames = [];\n+                    for (const fieldName of Object.keys(fields))(0, _graphql.isLeafType)(fields[fieldName].type) && leafFieldNames.push(fieldName);\n+                    return leafFieldNames;\n                 }\n \n-                // Encode unsafe characters with percent-encoding, skipping already\n-                // encoded sequences.\n-                //\n-                //  - string       - string to encode\n-                //  - exclude      - list of characters to ignore (in addition to a-zA-Z0-9)\n-                //  - keepEscaped  - don't encode '%' in a correct escape sequence (default: true)\n-                //\n-                function encode(string, exclude, keepEscaped) {\n-                    if (typeof exclude !== 'string') {\n-                        // encode(string, keepEscaped)\n-                        keepEscaped = exclude;\n-                        exclude = encode.defaultChars;\n-                    }\n-                    if (typeof keepEscaped === 'undefined') {\n-                        keepEscaped = true;\n-                    }\n-                    const cache = getEncodeCache(exclude);\n-                    let result = '';\n-                    for (let i = 0, l = string.length; i < l; i++) {\n-                        const code = string.charCodeAt(i);\n-                        if (keepEscaped && code === 0x25 /* % */ && i + 2 < l) {\n-                            if (/^[0-9a-f]{2}$/i.test(string.slice(i + 1, i + 3))) {\n-                                result += string.slice(i, i + 3);\n-                                i += 2;\n-                                continue;\n-                            }\n-                        }\n-                        if (code < 128) {\n-                            result += cache[code];\n-                            continue;\n-                        }\n-                        if (code >= 0xD800 && code <= 0xDFFF) {\n-                            if (code >= 0xD800 && code <= 0xDBFF && i + 1 < l) {\n-                                const nextCode = string.charCodeAt(i + 1);\n-                                if (nextCode >= 0xDC00 && nextCode <= 0xDFFF) {\n-                                    result += encodeURIComponent(string[i] + string[i + 1]);\n-                                    i++;\n-                                    continue;\n-                                }\n-                            }\n-                            result += '%EF%BF%BD';\n-                            continue;\n+                function buildSelectionSet(type, getDefaultFieldNames) {\n+                    const namedType = (0, _graphql.getNamedType)(type);\n+                    if (!type || (0, _graphql.isLeafType)(type)) return;\n+                    const fieldNames = getDefaultFieldNames(namedType);\n+                    if (!(!Array.isArray(fieldNames) || fieldNames.length === 0 || !(\"getFields\" in namedType))) return {\n+                        kind: _graphql.Kind.SELECTION_SET,\n+                        selections: fieldNames.map(fieldName => {\n+                            const fieldDef = namedType.getFields()[fieldName],\n+                                fieldType = fieldDef ? fieldDef.type : null;\n+                            return {\n+                                kind: _graphql.Kind.FIELD,\n+                                name: {\n+                                    kind: _graphql.Kind.NAME,\n+                                    value: fieldName\n+                                },\n+                                // we can use as here, because we already know that fieldType\n+                                // comes from an origin parameter\n+                                selectionSet: buildSelectionSet(fieldType, getDefaultFieldNames)\n+                            };\n+                        })\n+                    };\n+                }\n+\n+                function withInsertions(initial, insertions) {\n+                    if (insertions.length === 0) return initial;\n+                    let edited = \"\",\n+                        prevIndex = 0;\n+                    for (const {\n+                            index,\n+                            string\n                         }\n-                        result += encodeURIComponent(string[i]);\n-                    }\n-                    return result;\n+                        of insertions) edited += initial.slice(prevIndex, index) + string, prevIndex = index;\n+                    return edited += initial.slice(prevIndex), edited;\n                 }\n-                encode.defaultChars = \";/?:@&=+$,-_.!~*'()#\";\n-                encode.componentChars = \"-_.!~*'()\";\n \n-                function format(url) {\n-                    let result = '';\n-                    result += url.protocol || '';\n-                    result += url.slashes ? '//' : '';\n-                    result += url.auth ? url.auth + '@' : '';\n-                    if (url.hostname && url.hostname.indexOf(':') !== -1) {\n-                        // ipv6 address\n-                        result += '[' + url.hostname + ']';\n-                    } else {\n-                        result += url.hostname || '';\n+                function getIndentation(str, index) {\n+                    let indentStart = index,\n+                        indentEnd = index;\n+                    for (; indentStart;) {\n+                        const c = str.charCodeAt(indentStart - 1);\n+                        if (c === 10 || c === 13 || c === 8232 || c === 8233) break;\n+                        indentStart--, c !== 9 && c !== 11 && c !== 12 && c !== 32 && c !== 160 && (indentEnd = indentStart);\n                     }\n-                    result += url.port ? ':' + url.port : '';\n-                    result += url.pathname || '';\n-                    result += url.search || '';\n-                    result += url.hash || '';\n-                    return result;\n+                    return str.slice(indentStart, indentEnd);\n                 }\n \n-                // Copyright Joyent, Inc. and other Node contributors.\n-                //\n-                // Permission is hereby granted, free of charge, to any person obtaining a\n-                // copy of this software and associated documentation files (the\n-                // \"Software\"), to deal in the Software without restriction, including\n-                // without limitation the rights to use, copy, modify, merge, publish,\n-                // distribute, sublicense, and/or sell copies of the Software, and to permit\n-                // persons to whom the Software is furnished to do so, subject to the\n-                // following conditions:\n-                //\n-                // The above copyright notice and this permission notice shall be included\n-                // in all copies or substantial portions of the Software.\n-                //\n-                // THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n-                // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n-                // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n-                // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n-                // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n-                // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n-                // USE OR OTHER DEALINGS IN THE SOFTWARE.\n+                function isFieldType(fieldType) {\n+                    if (fieldType) return fieldType;\n+                }\n \n-                //\n-                // Changes from joyent/node:\n-                //\n-                // 1. No leading slash in paths,\n-                //    e.g. in `url.parse('http://foo?bar')` pathname is ``, not `/`\n-                //\n-                // 2. Backslashes are not replaced with slashes,\n-                //    so `http:\\\\example.org\\` is treated like a relative path\n-                //\n-                // 3. Trailing colon is treated like a part of the path,\n-                //    i.e. in `http://example.org:foo` pathname is `:foo`\n-                //\n-                // 4. Nothing is URL-encoded in the resulting object,\n-                //    (in joyent/node some chars in auth and paths are encoded)\n-                //\n-                // 5. `url.parse()` does not have `parseQueryString` argument\n-                //\n-                // 6. Removed extraneous result properties: `host`, `path`, `query`, etc.,\n-                //    which can be constructed using other parts of the url.\n-                //\n+                /***/\n+            }),\n \n-                function Url() {\n-                    this.protocol = null;\n-                    this.slashes = null;\n-                    this.auth = null;\n-                    this.port = null;\n-                    this.hostname = null;\n-                    this.hash = null;\n-                    this.search = null;\n-                    this.pathname = null;\n-                }\n+        /***/\n+        \"../../graphiql-toolkit/dist/esm/graphql-helpers/index.js\":\n+            /*!****************************************************************!*\\\n+              !*** ../../graphiql-toolkit/dist/esm/graphql-helpers/index.js ***!\n+              \\****************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                // Reference: RFC 3986, RFC 1808, RFC 2396\n+                \"use strict\";\n \n-                // define these here so at least they only have to be\n-                // compiled once on the first module load.\n-                const protocolPattern = /^([a-z0-9.+-]+:)/i;\n-                const portPattern = /:[0-9]*$/;\n \n-                // Special case for a simple path URL\n-                /* eslint-disable-next-line no-useless-escape */\n-                const simplePathPattern = /^(\\/\\/?(?!\\/)[^\\?\\s]*)(\\?[^\\s]*)?$/;\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                var _autoComplete = __webpack_require__( /*! ./auto-complete */ \"../../graphiql-toolkit/dist/esm/graphql-helpers/auto-complete.js\");\n+                Object.keys(_autoComplete).forEach(function(key) {\n+                    if (key === \"default\" || key === \"__esModule\") return;\n+                    if (key in exports && exports[key] === _autoComplete[key]) return;\n+                    Object.defineProperty(exports, key, {\n+                        enumerable: true,\n+                        get: function() {\n+                            return _autoComplete[key];\n+                        }\n+                    });\n+                });\n+                var _mergeAst = __webpack_require__( /*! ./merge-ast */ \"../../graphiql-toolkit/dist/esm/graphql-helpers/merge-ast.js\");\n+                Object.keys(_mergeAst).forEach(function(key) {\n+                    if (key === \"default\" || key === \"__esModule\") return;\n+                    if (key in exports && exports[key] === _mergeAst[key]) return;\n+                    Object.defineProperty(exports, key, {\n+                        enumerable: true,\n+                        get: function() {\n+                            return _mergeAst[key];\n+                        }\n+                    });\n+                });\n+                var _operationName = __webpack_require__( /*! ./operation-name */ \"../../graphiql-toolkit/dist/esm/graphql-helpers/operation-name.js\");\n+                Object.keys(_operationName).forEach(function(key) {\n+                    if (key === \"default\" || key === \"__esModule\") return;\n+                    if (key in exports && exports[key] === _operationName[key]) return;\n+                    Object.defineProperty(exports, key, {\n+                        enumerable: true,\n+                        get: function() {\n+                            return _operationName[key];\n+                        }\n+                    });\n+                });\n \n-                // RFC 2396: characters reserved for delimiting URLs.\n-                // We actually just auto-escape these.\n-                const delims = ['<', '>', '\"', '`', ' ', '\\r', '\\n', '\\t'];\n+                /***/\n+            }),\n \n-                // RFC 2396: characters not allowed for various reasons.\n-                const unwise = ['{', '}', '|', '\\\\', '^', '`'].concat(delims);\n+        /***/\n+        \"../../graphiql-toolkit/dist/esm/graphql-helpers/merge-ast.js\":\n+            /*!********************************************************************!*\\\n+              !*** ../../graphiql-toolkit/dist/esm/graphql-helpers/merge-ast.js ***!\n+              \\********************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                // Allowed by RFCs, but cause of XSS attacks.  Always escape these.\n-                const autoEscape = ['\\''].concat(unwise);\n-                // Characters that are never ever allowed in a hostname.\n-                // Note that any invalid chars are also handled, but these\n-                // are the ones that are *expected* to be seen, so we fast-path\n-                // them.\n-                const nonHostChars = ['%', '/', '?', ';', '#'].concat(autoEscape);\n-                const hostEndingChars = ['/', '?', '#'];\n-                const hostnameMaxLen = 255;\n-                const hostnamePartPattern = /^[+a-z0-9A-Z_-]{0,63}$/;\n-                const hostnamePartStart = /^([+a-z0-9A-Z_-]{0,63})(.*)$/;\n-                // protocols that can allow \"unsafe\" and \"unwise\" chars.\n-                // protocols that never have a hostname.\n-                const hostlessProtocol = {\n-                    javascript: true,\n-                    'javascript:': true\n-                };\n-                // protocols that always contain a // bit.\n-                const slashedProtocol = {\n-                    http: true,\n-                    https: true,\n-                    ftp: true,\n-                    gopher: true,\n-                    file: true,\n-                    'http:': true,\n-                    'https:': true,\n-                    'ftp:': true,\n-                    'gopher:': true,\n-                    'file:': true\n-                };\n+                \"use strict\";\n \n-                function urlParse(url, slashesDenoteHost) {\n-                    if (url && url instanceof Url) return url;\n-                    const u = new Url();\n-                    u.parse(url, slashesDenoteHost);\n-                    return u;\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.mergeAst = mergeAst;\n+                var _chunkLMOQIXV = __webpack_require__( /*! ../chunk-LMOQIXV4.js */ \"../../graphiql-toolkit/dist/esm/chunk-LMOQIXV4.js\");\n+                var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n+\n+                function uniqueBy(array, iteratee) {\n+                    var _a;\n+                    const FilteredMap = /* @__PURE__ */ new Map(),\n+                        result = [];\n+                    for (const item of array)\n+                        if (item.kind === \"Field\") {\n+                            const uniqueValue = iteratee(item),\n+                                existing = FilteredMap.get(uniqueValue);\n+                            if ((_a = item.directives) != null && _a.length) {\n+                                const itemClone = (0, _chunkLMOQIXV.__spreadValues)({}, item);\n+                                result.push(itemClone);\n+                            } else if (existing != null && existing.selectionSet && item.selectionSet) existing.selectionSet.selections = [...existing.selectionSet.selections, ...item.selectionSet.selections];\n+                            else if (!existing) {\n+                                const itemClone = (0, _chunkLMOQIXV.__spreadValues)({}, item);\n+                                FilteredMap.set(uniqueValue, itemClone), result.push(itemClone);\n+                            }\n+                        } else result.push(item);\n+                    return result;\n                 }\n-                Url.prototype.parse = function(url, slashesDenoteHost) {\n-                    let lowerProto, hec, slashes;\n-                    let rest = url;\n \n-                    // trim before proceeding.\n-                    // This is to support parse stuff like \"  http://foo.com  \\n\"\n-                    rest = rest.trim();\n-                    if (!slashesDenoteHost && url.split('#').length === 1) {\n-                        // Try fast path regexp\n-                        const simplePath = simplePathPattern.exec(rest);\n-                        if (simplePath) {\n-                            this.pathname = simplePath[1];\n-                            if (simplePath[2]) {\n-                                this.search = simplePath[2];\n+                function inlineRelevantFragmentSpreads(fragmentDefinitions, selections, selectionSetType) {\n+                    var _a;\n+                    const selectionSetTypeName = selectionSetType ? (0, _graphql.getNamedType)(selectionSetType).name : null,\n+                        outputSelections = [],\n+                        seenSpreads = [];\n+                    for (let selection of selections) {\n+                        if (selection.kind === \"FragmentSpread\") {\n+                            const fragmentName = selection.name.value;\n+                            if (!selection.directives || selection.directives.length === 0) {\n+                                if (seenSpreads.includes(fragmentName)) continue;\n+                                seenSpreads.push(fragmentName);\n+                            }\n+                            const fragmentDefinition = fragmentDefinitions[selection.name.value];\n+                            if (fragmentDefinition) {\n+                                const {\n+                                    typeCondition,\n+                                    directives,\n+                                    selectionSet\n+                                } = fragmentDefinition;\n+                                selection = {\n+                                    kind: _graphql.Kind.INLINE_FRAGMENT,\n+                                    typeCondition,\n+                                    directives,\n+                                    selectionSet\n+                                };\n                             }\n-                            return this;\n                         }\n+                        if (selection.kind === _graphql.Kind.INLINE_FRAGMENT && (\n+                                // Cannot inline if there are directives\n+                                !selection.directives || ((_a = selection.directives) == null ? void 0 : _a.length) === 0)) {\n+                            const fragmentTypeName = selection.typeCondition ? selection.typeCondition.name.value : null;\n+                            if (!fragmentTypeName || fragmentTypeName === selectionSetTypeName) {\n+                                outputSelections.push(...inlineRelevantFragmentSpreads(fragmentDefinitions, selection.selectionSet.selections, selectionSetType));\n+                                continue;\n+                            }\n+                        }\n+                        outputSelections.push(selection);\n                     }\n-                    let proto = protocolPattern.exec(rest);\n-                    if (proto) {\n-                        proto = proto[0];\n-                        lowerProto = proto.toLowerCase();\n-                        this.protocol = proto;\n-                        rest = rest.substr(proto.length);\n-                    }\n+                    return outputSelections;\n+                }\n \n-                    // figure out if it's got a host\n-                    // user@server is *always* interpreted as a hostname, and url\n-                    // resolution will treat //foo/bar as host=foo,path=bar because that's\n-                    // how the browser resolves relative URLs.\n-                    /* eslint-disable-next-line no-useless-escape */\n-                    if (slashesDenoteHost || proto || rest.match(/^\\/\\/[^@\\/]+@[^@\\/]+/)) {\n-                        slashes = rest.substr(0, 2) === '//';\n-                        if (slashes && !(proto && hostlessProtocol[proto])) {\n-                            rest = rest.substr(2);\n-                            this.slashes = true;\n+                function mergeAst(documentAST, schema) {\n+                    const typeInfo = schema ? new _graphql.TypeInfo(schema) : null,\n+                        fragmentDefinitions = /* @__PURE__ */ Object.create(null);\n+                    for (const definition of documentAST.definitions) definition.kind === _graphql.Kind.FRAGMENT_DEFINITION && (fragmentDefinitions[definition.name.value] = definition);\n+                    const flattenVisitors = {\n+                            SelectionSet(node) {\n+                                const selectionSetType = typeInfo ? typeInfo.getParentType() : null;\n+                                let {\n+                                    selections\n+                                } = node;\n+                                return selections = inlineRelevantFragmentSpreads(fragmentDefinitions, selections, selectionSetType), (0, _chunkLMOQIXV.__spreadProps)((0, _chunkLMOQIXV.__spreadValues)({}, node), {\n+                                    selections\n+                                });\n+                            },\n+                            FragmentDefinition() {\n+                                return null;\n+                            }\n+                        },\n+                        flattenedAST = (0, _graphql.visit)(documentAST, typeInfo ? (0, _graphql.visitWithTypeInfo)(typeInfo, flattenVisitors) : flattenVisitors);\n+                    return (0, _graphql.visit)(flattenedAST, {\n+                        SelectionSet(node) {\n+                            let {\n+                                selections\n+                            } = node;\n+                            return selections = uniqueBy(selections, selection => selection.alias ? selection.alias.value : selection.name.value), (0, _chunkLMOQIXV.__spreadProps)((0, _chunkLMOQIXV.__spreadValues)({}, node), {\n+                                selections\n+                            });\n+                        },\n+                        FragmentDefinition() {\n+                            return null;\n                         }\n+                    });\n+                }\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../graphiql-toolkit/dist/esm/graphql-helpers/operation-name.js\":\n+            /*!*************************************************************************!*\\\n+              !*** ../../graphiql-toolkit/dist/esm/graphql-helpers/operation-name.js ***!\n+              \\*************************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.getSelectedOperationName = getSelectedOperationName;\n+                __webpack_require__( /*! ../chunk-LMOQIXV4.js */ \"../../graphiql-toolkit/dist/esm/chunk-LMOQIXV4.js\");\n+\n+                function getSelectedOperationName(prevOperations, prevSelectedOperationName, operations) {\n+                    if (!operations || operations.length < 1) return;\n+                    const names = operations.map(op => {\n+                        var _a;\n+                        return (_a = op.name) == null ? void 0 : _a.value;\n+                    });\n+                    if (prevSelectedOperationName && names.includes(prevSelectedOperationName)) return prevSelectedOperationName;\n+                    if (prevSelectedOperationName && prevOperations) {\n+                        const prevIndex = prevOperations.map(op => {\n+                            var _a;\n+                            return (_a = op.name) == null ? void 0 : _a.value;\n+                        }).indexOf(prevSelectedOperationName);\n+                        if (prevIndex !== -1 && prevIndex < names.length) return names[prevIndex];\n                     }\n-                    if (!hostlessProtocol[proto] && (slashes || proto && !slashedProtocol[proto])) {\n-                        // there's a hostname.\n-                        // the first instance of /, ?, ;, or # ends the host.\n-                        //\n-                        // If there is an @ in the hostname, then non-host chars *are* allowed\n-                        // to the left of the last @ sign, unless some host-ending character\n-                        // comes *before* the @-sign.\n-                        // URLs are obnoxious.\n-                        //\n-                        // ex:\n-                        // http://a@b@c/ => user:a@b host:c\n-                        // http://a@b?@c => user:a host:c path:/?@c\n+                    return names[0];\n+                }\n \n-                        // v0.12 TODO(isaacs): This is not quite how Chrome does things.\n-                        // Review our test case against browsers more comprehensively.\n+                /***/\n+            }),\n \n-                        // find the first instance of any hostEndingChars\n-                        let hostEnd = -1;\n-                        for (let i = 0; i < hostEndingChars.length; i++) {\n-                            hec = rest.indexOf(hostEndingChars[i]);\n-                            if (hec !== -1 && (hostEnd === -1 || hec < hostEnd)) {\n-                                hostEnd = hec;\n-                            }\n-                        }\n+        /***/\n+        \"../../graphiql-toolkit/dist/esm/index.js\":\n+            /*!************************************************!*\\\n+              !*** ../../graphiql-toolkit/dist/esm/index.js ***!\n+              \\************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                        // at this point, either we have an explicit point where the\n-                        // auth portion cannot go past, or the last @ char is the decider.\n-                        let auth, atSign;\n-                        if (hostEnd === -1) {\n-                            // atSign can be anywhere.\n-                            atSign = rest.lastIndexOf('@');\n-                        } else {\n-                            // atSign must be in auth portion.\n-                            // http://a@b/c@d => host:b auth:a path:/c@d\n-                            atSign = rest.lastIndexOf('@', hostEnd);\n-                        }\n+                \"use strict\";\n \n-                        // Now we have a portion which is definitely the auth.\n-                        // Pull that off.\n-                        if (atSign !== -1) {\n-                            auth = rest.slice(0, atSign);\n-                            rest = rest.slice(atSign + 1);\n-                            this.auth = auth;\n-                        }\n \n-                        // the host is the remaining to the left of the first non-host char\n-                        hostEnd = -1;\n-                        for (let i = 0; i < nonHostChars.length; i++) {\n-                            hec = rest.indexOf(nonHostChars[i]);\n-                            if (hec !== -1 && (hostEnd === -1 || hec < hostEnd)) {\n-                                hostEnd = hec;\n-                            }\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                var _asyncHelpers = __webpack_require__( /*! ./async-helpers */ \"../../graphiql-toolkit/dist/esm/async-helpers/index.js\");\n+                Object.keys(_asyncHelpers).forEach(function(key) {\n+                    if (key === \"default\" || key === \"__esModule\") return;\n+                    if (key in exports && exports[key] === _asyncHelpers[key]) return;\n+                    Object.defineProperty(exports, key, {\n+                        enumerable: true,\n+                        get: function() {\n+                            return _asyncHelpers[key];\n                         }\n-                        // if we still have not hit it, then the entire thing is a host.\n-                        if (hostEnd === -1) {\n-                            hostEnd = rest.length;\n+                    });\n+                });\n+                var _createFetcher = __webpack_require__( /*! ./create-fetcher */ \"../../graphiql-toolkit/dist/esm/create-fetcher/index.js\");\n+                Object.keys(_createFetcher).forEach(function(key) {\n+                    if (key === \"default\" || key === \"__esModule\") return;\n+                    if (key in exports && exports[key] === _createFetcher[key]) return;\n+                    Object.defineProperty(exports, key, {\n+                        enumerable: true,\n+                        get: function() {\n+                            return _createFetcher[key];\n                         }\n-                        if (rest[hostEnd - 1] === ':') {\n-                            hostEnd--;\n+                    });\n+                });\n+                var _format = __webpack_require__( /*! ./format */ \"../../graphiql-toolkit/dist/esm/format/index.js\");\n+                Object.keys(_format).forEach(function(key) {\n+                    if (key === \"default\" || key === \"__esModule\") return;\n+                    if (key in exports && exports[key] === _format[key]) return;\n+                    Object.defineProperty(exports, key, {\n+                        enumerable: true,\n+                        get: function() {\n+                            return _format[key];\n                         }\n-                        const host = rest.slice(0, hostEnd);\n-                        rest = rest.slice(hostEnd);\n+                    });\n+                });\n+                var _graphqlHelpers = __webpack_require__( /*! ./graphql-helpers */ \"../../graphiql-toolkit/dist/esm/graphql-helpers/index.js\");\n+                Object.keys(_graphqlHelpers).forEach(function(key) {\n+                    if (key === \"default\" || key === \"__esModule\") return;\n+                    if (key in exports && exports[key] === _graphqlHelpers[key]) return;\n+                    Object.defineProperty(exports, key, {\n+                        enumerable: true,\n+                        get: function() {\n+                            return _graphqlHelpers[key];\n+                        }\n+                    });\n+                });\n+                var _storage = __webpack_require__( /*! ./storage */ \"../../graphiql-toolkit/dist/esm/storage/index.js\");\n+                Object.keys(_storage).forEach(function(key) {\n+                    if (key === \"default\" || key === \"__esModule\") return;\n+                    if (key in exports && exports[key] === _storage[key]) return;\n+                    Object.defineProperty(exports, key, {\n+                        enumerable: true,\n+                        get: function() {\n+                            return _storage[key];\n+                        }\n+                    });\n+                });\n \n-                        // pull out port.\n-                        this.parseHost(host);\n+                /***/\n+            }),\n \n-                        // we've indicated that there is a hostname,\n-                        // so even if it's empty, it has to be present.\n-                        this.hostname = this.hostname || '';\n+        /***/\n+        \"../../graphiql-toolkit/dist/esm/storage/base.js\":\n+            /*!*******************************************************!*\\\n+              !*** ../../graphiql-toolkit/dist/esm/storage/base.js ***!\n+              \\*******************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n-                        // if hostname begins with [ and ends with ]\n-                        // assume that it's an IPv6 address.\n-                        const ipv6Hostname = this.hostname[0] === '[' && this.hostname[this.hostname.length - 1] === ']';\n+                \"use strict\";\n \n-                        // validate a little.\n-                        if (!ipv6Hostname) {\n-                            const hostparts = this.hostname.split(/\\./);\n-                            for (let i = 0, l = hostparts.length; i < l; i++) {\n-                                const part = hostparts[i];\n-                                if (!part) {\n-                                    continue;\n-                                }\n-                                if (!part.match(hostnamePartPattern)) {\n-                                    let newpart = '';\n-                                    for (let j = 0, k = part.length; j < k; j++) {\n-                                        if (part.charCodeAt(j) > 127) {\n-                                            // we replace non-ASCII char with a temporary placeholder\n-                                            // we need this to make sure size of hostname is not\n-                                            // broken by replacing non-ASCII by nothing\n-                                            newpart += 'x';\n-                                        } else {\n-                                            newpart += part[j];\n-                                        }\n-                                    }\n-                                    // we test again with ASCII char only\n-                                    if (!newpart.match(hostnamePartPattern)) {\n-                                        const validParts = hostparts.slice(0, i);\n-                                        const notHost = hostparts.slice(i + 1);\n-                                        const bit = part.match(hostnamePartStart);\n-                                        if (bit) {\n-                                            validParts.push(bit[1]);\n-                                            notHost.unshift(bit[2]);\n-                                        }\n-                                        if (notHost.length) {\n-                                            rest = notHost.join('.') + rest;\n-                                        }\n-                                        this.hostname = validParts.join('.');\n-                                        break;\n-                                    }\n-                                }\n-                            }\n-                        }\n-                        if (this.hostname.length > hostnameMaxLen) {\n-                            this.hostname = '';\n-                        }\n \n-                        // strip [ and ] from the hostname\n-                        // the host field still retains them, though\n-                        if (ipv6Hostname) {\n-                            this.hostname = this.hostname.substr(1, this.hostname.length - 2);\n-                        }\n-                    }\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.StorageAPI = void 0;\n+                __webpack_require__( /*! ../chunk-LMOQIXV4.js */ \"../../graphiql-toolkit/dist/esm/chunk-LMOQIXV4.js\");\n \n-                    // chop off from the tail first.\n-                    const hash = rest.indexOf('#');\n-                    if (hash !== -1) {\n-                        // got a fragment string.\n-                        this.hash = rest.substr(hash);\n-                        rest = rest.slice(0, hash);\n-                    }\n-                    const qm = rest.indexOf('?');\n-                    if (qm !== -1) {\n-                        this.search = rest.substr(qm);\n-                        rest = rest.slice(0, qm);\n-                    }\n-                    if (rest) {\n-                        this.pathname = rest;\n+                function isQuotaError(storage, e) {\n+                    return e instanceof DOMException && (\n+                            // everything except Firefox\n+                            e.code === 22 ||\n+                            // Firefox\n+                            e.code === 1014 ||\n+                            // test name field too, because code might not be present\n+                            // everything except Firefox\n+                            e.name === \"QuotaExceededError\" ||\n+                            // Firefox\n+                            e.name === \"NS_ERROR_DOM_QUOTA_REACHED\") &&\n+                        // acknowledge QuotaExceededError only if there's something already stored\n+                        storage.length !== 0;\n+                }\n+                class StorageAPI {\n+                    constructor(storage) {\n+                        storage ? this.storage = storage : storage === null ? this.storage = null : typeof window == \"undefined\" ? this.storage = null : this.storage = {\n+                            getItem: localStorage.getItem.bind(localStorage),\n+                            setItem: localStorage.setItem.bind(localStorage),\n+                            removeItem: localStorage.removeItem.bind(localStorage),\n+                            get length() {\n+                                let keys = 0;\n+                                for (const key in localStorage) key.indexOf(`${STORAGE_NAMESPACE}:`) === 0 && (keys += 1);\n+                                return keys;\n+                            },\n+                            clear() {\n+                                for (const key in localStorage) key.indexOf(`${STORAGE_NAMESPACE}:`) === 0 && localStorage.removeItem(key);\n+                            }\n+                        };\n                     }\n-                    if (slashedProtocol[lowerProto] && this.hostname && !this.pathname) {\n-                        this.pathname = '';\n+                    get(name) {\n+                        if (!this.storage) return null;\n+                        const key = `${STORAGE_NAMESPACE}:${name}`,\n+                            value = this.storage.getItem(key);\n+                        return value === \"null\" || value === \"undefined\" ? (this.storage.removeItem(key), null) : value || null;\n                     }\n-                    return this;\n-                };\n-                Url.prototype.parseHost = function(host) {\n-                    let port = portPattern.exec(host);\n-                    if (port) {\n-                        port = port[0];\n-                        if (port !== ':') {\n-                            this.port = port.substr(1);\n+                    set(name, value) {\n+                        let quotaError = !1,\n+                            error = null;\n+                        if (this.storage) {\n+                            const key = `${STORAGE_NAMESPACE}:${name}`;\n+                            if (value) try {\n+                                this.storage.setItem(key, value);\n+                            } catch (e) {\n+                                error = e instanceof Error ? e : new Error(`${e}`), quotaError = isQuotaError(this.storage, e);\n+                            } else this.storage.removeItem(key);\n                         }\n-                        host = host.substr(0, host.length - port.length);\n+                        return {\n+                            isQuotaError: quotaError,\n+                            error\n+                        };\n                     }\n-                    if (host) {\n-                        this.hostname = host;\n+                    clear() {\n+                        this.storage && this.storage.clear();\n                     }\n-                };\n-                exports.decode = decode;\n-                exports.encode = encode;\n-                exports.format = format;\n-                exports.parse = urlParse;\n+                }\n+                exports.StorageAPI = StorageAPI;\n+                const STORAGE_NAMESPACE = \"graphiql\";\n \n                 /***/\n             }),\n \n         /***/\n-        \"../node_modules/uc.micro/build/index.cjs.js\":\n-            /*!***************************************************!*\\\n-              !*** ../node_modules/uc.micro/build/index.cjs.js ***!\n-              \\***************************************************/\n+        \"../../graphiql-toolkit/dist/esm/storage/custom.js\":\n+            /*!*********************************************************!*\\\n+              !*** ../../graphiql-toolkit/dist/esm/storage/custom.js ***!\n+              \\*********************************************************/\n             /***/\n-            (function(__unused_webpack_module, exports) {\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n-                var regex$5 = /[\\0-\\uD7FF\\uE000-\\uFFFF]|[\\uD800-\\uDBFF][\\uDC00-\\uDFFF]|[\\uD800-\\uDBFF](?![\\uDC00-\\uDFFF])|(?:[^\\uD800-\\uDBFF]|^)[\\uDC00-\\uDFFF]/;\n-                var regex$4 = /[\\0-\\x1F\\x7F-\\x9F]/;\n-                var regex$3 = /[\\xAD\\u0600-\\u0605\\u061C\\u06DD\\u070F\\u0890\\u0891\\u08E2\\u180E\\u200B-\\u200F\\u202A-\\u202E\\u2060-\\u2064\\u2066-\\u206F\\uFEFF\\uFFF9-\\uFFFB]|\\uD804[\\uDCBD\\uDCCD]|\\uD80D[\\uDC30-\\uDC3F]|\\uD82F[\\uDCA0-\\uDCA3]|\\uD834[\\uDD73-\\uDD7A]|\\uDB40[\\uDC01\\uDC20-\\uDC7F]/;\n-                var regex$2 = /[!-#%-\\*,-\\/:;\\?@\\[-\\]_\\{\\}\\xA1\\xA7\\xAB\\xB6\\xB7\\xBB\\xBF\\u037E\\u0387\\u055A-\\u055F\\u0589\\u058A\\u05BE\\u05C0\\u05C3\\u05C6\\u05F3\\u05F4\\u0609\\u060A\\u060C\\u060D\\u061B\\u061D-\\u061F\\u066A-\\u066D\\u06D4\\u0700-\\u070D\\u07F7-\\u07F9\\u0830-\\u083E\\u085E\\u0964\\u0965\\u0970\\u09FD\\u0A76\\u0AF0\\u0C77\\u0C84\\u0DF4\\u0E4F\\u0E5A\\u0E5B\\u0F04-\\u0F12\\u0F14\\u0F3A-\\u0F3D\\u0F85\\u0FD0-\\u0FD4\\u0FD9\\u0FDA\\u104A-\\u104F\\u10FB\\u1360-\\u1368\\u1400\\u166E\\u169B\\u169C\\u16EB-\\u16ED\\u1735\\u1736\\u17D4-\\u17D6\\u17D8-\\u17DA\\u1800-\\u180A\\u1944\\u1945\\u1A1E\\u1A1F\\u1AA0-\\u1AA6\\u1AA8-\\u1AAD\\u1B5A-\\u1B60\\u1B7D\\u1B7E\\u1BFC-\\u1BFF\\u1C3B-\\u1C3F\\u1C7E\\u1C7F\\u1CC0-\\u1CC7\\u1CD3\\u2010-\\u2027\\u2030-\\u2043\\u2045-\\u2051\\u2053-\\u205E\\u207D\\u207E\\u208D\\u208E\\u2308-\\u230B\\u2329\\u232A\\u2768-\\u2775\\u27C5\\u27C6\\u27E6-\\u27EF\\u2983-\\u2998\\u29D8-\\u29DB\\u29FC\\u29FD\\u2CF9-\\u2CFC\\u2CFE\\u2CFF\\u2D70\\u2E00-\\u2E2E\\u2E30-\\u2E4F\\u2E52-\\u2E5D\\u3001-\\u3003\\u3008-\\u3011\\u3014-\\u301F\\u3030\\u303D\\u30A0\\u30FB\\uA4FE\\uA4FF\\uA60D-\\uA60F\\uA673\\uA67E\\uA6F2-\\uA6F7\\uA874-\\uA877\\uA8CE\\uA8CF\\uA8F8-\\uA8FA\\uA8FC\\uA92E\\uA92F\\uA95F\\uA9C1-\\uA9CD\\uA9DE\\uA9DF\\uAA5C-\\uAA5F\\uAADE\\uAADF\\uAAF0\\uAAF1\\uABEB\\uFD3E\\uFD3F\\uFE10-\\uFE19\\uFE30-\\uFE52\\uFE54-\\uFE61\\uFE63\\uFE68\\uFE6A\\uFE6B\\uFF01-\\uFF03\\uFF05-\\uFF0A\\uFF0C-\\uFF0F\\uFF1A\\uFF1B\\uFF1F\\uFF20\\uFF3B-\\uFF3D\\uFF3F\\uFF5B\\uFF5D\\uFF5F-\\uFF65]|\\uD800[\\uDD00-\\uDD02\\uDF9F\\uDFD0]|\\uD801\\uDD6F|\\uD802[\\uDC57\\uDD1F\\uDD3F\\uDE50-\\uDE58\\uDE7F\\uDEF0-\\uDEF6\\uDF39-\\uDF3F\\uDF99-\\uDF9C]|\\uD803[\\uDEAD\\uDF55-\\uDF59\\uDF86-\\uDF89]|\\uD804[\\uDC47-\\uDC4D\\uDCBB\\uDCBC\\uDCBE-\\uDCC1\\uDD40-\\uDD43\\uDD74\\uDD75\\uDDC5-\\uDDC8\\uDDCD\\uDDDB\\uDDDD-\\uDDDF\\uDE38-\\uDE3D\\uDEA9]|\\uD805[\\uDC4B-\\uDC4F\\uDC5A\\uDC5B\\uDC5D\\uDCC6\\uDDC1-\\uDDD7\\uDE41-\\uDE43\\uDE60-\\uDE6C\\uDEB9\\uDF3C-\\uDF3E]|\\uD806[\\uDC3B\\uDD44-\\uDD46\\uDDE2\\uDE3F-\\uDE46\\uDE9A-\\uDE9C\\uDE9E-\\uDEA2\\uDF00-\\uDF09]|\\uD807[\\uDC41-\\uDC45\\uDC70\\uDC71\\uDEF7\\uDEF8\\uDF43-\\uDF4F\\uDFFF]|\\uD809[\\uDC70-\\uDC74]|\\uD80B[\\uDFF1\\uDFF2]|\\uD81A[\\uDE6E\\uDE6F\\uDEF5\\uDF37-\\uDF3B\\uDF44]|\\uD81B[\\uDE97-\\uDE9A\\uDFE2]|\\uD82F\\uDC9F|\\uD836[\\uDE87-\\uDE8B]|\\uD83A[\\uDD5E\\uDD5F]/;\n-                var regex$1 = /[\\$\\+<->\\^`\\|~\\xA2-\\xA6\\xA8\\xA9\\xAC\\xAE-\\xB1\\xB4\\xB8\\xD7\\xF7\\u02C2-\\u02C5\\u02D2-\\u02DF\\u02E5-\\u02EB\\u02ED\\u02EF-\\u02FF\\u0375\\u0384\\u0385\\u03F6\\u0482\\u058D-\\u058F\\u0606-\\u0608\\u060B\\u060E\\u060F\\u06DE\\u06E9\\u06FD\\u06FE\\u07F6\\u07FE\\u07FF\\u0888\\u09F2\\u09F3\\u09FA\\u09FB\\u0AF1\\u0B70\\u0BF3-\\u0BFA\\u0C7F\\u0D4F\\u0D79\\u0E3F\\u0F01-\\u0F03\\u0F13\\u0F15-\\u0F17\\u0F1A-\\u0F1F\\u0F34\\u0F36\\u0F38\\u0FBE-\\u0FC5\\u0FC7-\\u0FCC\\u0FCE\\u0FCF\\u0FD5-\\u0FD8\\u109E\\u109F\\u1390-\\u1399\\u166D\\u17DB\\u1940\\u19DE-\\u19FF\\u1B61-\\u1B6A\\u1B74-\\u1B7C\\u1FBD\\u1FBF-\\u1FC1\\u1FCD-\\u1FCF\\u1FDD-\\u1FDF\\u1FED-\\u1FEF\\u1FFD\\u1FFE\\u2044\\u2052\\u207A-\\u207C\\u208A-\\u208C\\u20A0-\\u20C0\\u2100\\u2101\\u2103-\\u2106\\u2108\\u2109\\u2114\\u2116-\\u2118\\u211E-\\u2123\\u2125\\u2127\\u2129\\u212E\\u213A\\u213B\\u2140-\\u2144\\u214A-\\u214D\\u214F\\u218A\\u218B\\u2190-\\u2307\\u230C-\\u2328\\u232B-\\u2426\\u2440-\\u244A\\u249C-\\u24E9\\u2500-\\u2767\\u2794-\\u27C4\\u27C7-\\u27E5\\u27F0-\\u2982\\u2999-\\u29D7\\u29DC-\\u29FB\\u29FE-\\u2B73\\u2B76-\\u2B95\\u2B97-\\u2BFF\\u2CE5-\\u2CEA\\u2E50\\u2E51\\u2E80-\\u2E99\\u2E9B-\\u2EF3\\u2F00-\\u2FD5\\u2FF0-\\u2FFF\\u3004\\u3012\\u3013\\u3020\\u3036\\u3037\\u303E\\u303F\\u309B\\u309C\\u3190\\u3191\\u3196-\\u319F\\u31C0-\\u31E3\\u31EF\\u3200-\\u321E\\u322A-\\u3247\\u3250\\u3260-\\u327F\\u328A-\\u32B0\\u32C0-\\u33FF\\u4DC0-\\u4DFF\\uA490-\\uA4C6\\uA700-\\uA716\\uA720\\uA721\\uA789\\uA78A\\uA828-\\uA82B\\uA836-\\uA839\\uAA77-\\uAA79\\uAB5B\\uAB6A\\uAB6B\\uFB29\\uFBB2-\\uFBC2\\uFD40-\\uFD4F\\uFDCF\\uFDFC-\\uFDFF\\uFE62\\uFE64-\\uFE66\\uFE69\\uFF04\\uFF0B\\uFF1C-\\uFF1E\\uFF3E\\uFF40\\uFF5C\\uFF5E\\uFFE0-\\uFFE6\\uFFE8-\\uFFEE\\uFFFC\\uFFFD]|\\uD800[\\uDD37-\\uDD3F\\uDD79-\\uDD89\\uDD8C-\\uDD8E\\uDD90-\\uDD9C\\uDDA0\\uDDD0-\\uDDFC]|\\uD802[\\uDC77\\uDC78\\uDEC8]|\\uD805\\uDF3F|\\uD807[\\uDFD5-\\uDFF1]|\\uD81A[\\uDF3C-\\uDF3F\\uDF45]|\\uD82F\\uDC9C|\\uD833[\\uDF50-\\uDFC3]|\\uD834[\\uDC00-\\uDCF5\\uDD00-\\uDD26\\uDD29-\\uDD64\\uDD6A-\\uDD6C\\uDD83\\uDD84\\uDD8C-\\uDDA9\\uDDAE-\\uDDEA\\uDE00-\\uDE41\\uDE45\\uDF00-\\uDF56]|\\uD835[\\uDEC1\\uDEDB\\uDEFB\\uDF15\\uDF35\\uDF4F\\uDF6F\\uDF89\\uDFA9\\uDFC3]|\\uD836[\\uDC00-\\uDDFF\\uDE37-\\uDE3A\\uDE6D-\\uDE74\\uDE76-\\uDE83\\uDE85\\uDE86]|\\uD838[\\uDD4F\\uDEFF]|\\uD83B[\\uDCAC\\uDCB0\\uDD2E\\uDEF0\\uDEF1]|\\uD83C[\\uDC00-\\uDC2B\\uDC30-\\uDC93\\uDCA0-\\uDCAE\\uDCB1-\\uDCBF\\uDCC1-\\uDCCF\\uDCD1-\\uDCF5\\uDD0D-\\uDDAD\\uDDE6-\\uDE02\\uDE10-\\uDE3B\\uDE40-\\uDE48\\uDE50\\uDE51\\uDE60-\\uDE65\\uDF00-\\uDFFF]|\\uD83D[\\uDC00-\\uDED7\\uDEDC-\\uDEEC\\uDEF0-\\uDEFC\\uDF00-\\uDF76\\uDF7B-\\uDFD9\\uDFE0-\\uDFEB\\uDFF0]|\\uD83E[\\uDC00-\\uDC0B\\uDC10-\\uDC47\\uDC50-\\uDC59\\uDC60-\\uDC87\\uDC90-\\uDCAD\\uDCB0\\uDCB1\\uDD00-\\uDE53\\uDE60-\\uDE6D\\uDE70-\\uDE7C\\uDE80-\\uDE88\\uDE90-\\uDEBD\\uDEBF-\\uDEC5\\uDECE-\\uDEDB\\uDEE0-\\uDEE8\\uDEF0-\\uDEF8\\uDF00-\\uDF92\\uDF94-\\uDFCA]/;\n-                var regex = /[ \\xA0\\u1680\\u2000-\\u200A\\u2028\\u2029\\u202F\\u205F\\u3000]/;\n-                exports.Any = regex$5;\n-                exports.Cc = regex$4;\n-                exports.Cf = regex$3;\n-                exports.P = regex$2;\n-                exports.S = regex$1;\n-                exports.Z = regex;\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.createLocalStorage = createLocalStorage;\n+                __webpack_require__( /*! ../chunk-LMOQIXV4.js */ \"../../graphiql-toolkit/dist/esm/chunk-LMOQIXV4.js\");\n+\n+                function createLocalStorage({\n+                    namespace\n+                }) {\n+                    const storageKeyPrefix = `${namespace}:`,\n+                        getStorageKey = key => `${storageKeyPrefix}${key}`;\n+                    return {\n+                        setItem: (key, value) => localStorage.setItem(getStorageKey(key), value),\n+                        getItem: key => localStorage.getItem(getStorageKey(key)),\n+                        removeItem: key => localStorage.removeItem(getStorageKey(key)),\n+                        get length() {\n+                            let keys = 0;\n+                            for (const key in localStorage) key.indexOf(storageKeyPrefix) === 0 && (keys += 1);\n+                            return keys;\n+                        },\n+                        clear() {\n+                            for (const key in localStorage) key.indexOf(storageKeyPrefix) === 0 && localStorage.removeItem(key);\n+                        }\n+                    };\n+                }\n \n                 /***/\n             }),\n \n         /***/\n-        \"./components/GraphiQL.tsx\":\n-            /*!*********************************!*\\\n-              !*** ./components/GraphiQL.tsx ***!\n-              \\*********************************/\n+        \"../../graphiql-toolkit/dist/esm/storage/history.js\":\n+            /*!**********************************************************!*\\\n+              !*** ../../graphiql-toolkit/dist/esm/storage/history.js ***!\n+              \\**********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports.GraphiQL = GraphiQL;\n-                exports.GraphiQLInterface = GraphiQLInterface;\n-                var _react = _interopRequireWildcard(__webpack_require__( /*! react */ \"react\"));\n-                var _react2 = __webpack_require__( /*! @graphiql/react */ \"../../graphiql-react/dist/index.js\");\n-\n-                function _getRequireWildcardCache(nodeInterop) {\n-                    if (typeof WeakMap !== \"function\") return null;\n-                    var cacheBabelInterop = new WeakMap();\n-                    var cacheNodeInterop = new WeakMap();\n-                    return (_getRequireWildcardCache = function(nodeInterop) {\n-                        return nodeInterop ? cacheNodeInterop : cacheBabelInterop;\n-                    })(nodeInterop);\n+                exports.HistoryStore = void 0;\n+                var _chunkLMOQIXV = __webpack_require__( /*! ../chunk-LMOQIXV4.js */ \"../../graphiql-toolkit/dist/esm/chunk-LMOQIXV4.js\");\n+                var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n+                var _query = __webpack_require__( /*! ./query */ \"../../graphiql-toolkit/dist/esm/storage/query.js\");\n+                const MAX_QUERY_SIZE = 1e5;\n+                class HistoryStore {\n+                    constructor(storage, maxHistoryLength) {\n+                        this.storage = storage;\n+                        this.maxHistoryLength = maxHistoryLength;\n+                        this.updateHistory = ({\n+                            query,\n+                            variables,\n+                            headers,\n+                            operationName\n+                        }) => {\n+                            if (!this.shouldSaveQuery(query, variables, headers, this.history.fetchRecent())) return;\n+                            this.history.push({\n+                                query,\n+                                variables,\n+                                headers,\n+                                operationName\n+                            });\n+                            const historyQueries = this.history.items,\n+                                favoriteQueries = this.favorite.items;\n+                            this.queries = historyQueries.concat(favoriteQueries);\n+                        };\n+                        this.deleteHistory = ({\n+                            query,\n+                            variables,\n+                            headers,\n+                            operationName,\n+                            favorite\n+                        }, clearFavorites = !1) => {\n+                            function deleteFromStore(store) {\n+                                const found = store.items.find(x => x.query === query && x.variables === variables && x.headers === headers && x.operationName === operationName);\n+                                found && store.delete(found);\n+                            }\n+                            (favorite || clearFavorites) && deleteFromStore(this.favorite), (!favorite || clearFavorites) && deleteFromStore(this.history), this.queries = [...this.history.items, ...this.favorite.items];\n+                        };\n+                        this.history = new _query.QueryStore(\"queries\", this.storage, this.maxHistoryLength), this.favorite = new _query.QueryStore(\"favorites\", this.storage, null), this.queries = [...this.history.fetchAll(), ...this.favorite.fetchAll()];\n+                    }\n+                    shouldSaveQuery(query, variables, headers, lastQuerySaved) {\n+                        if (!query) return !1;\n+                        try {\n+                            (0, _graphql.parse)(query);\n+                        } catch (e) {\n+                            return !1;\n+                        }\n+                        return query.length > MAX_QUERY_SIZE ? !1 : lastQuerySaved ? !(JSON.stringify(query) === JSON.stringify(lastQuerySaved.query) && (JSON.stringify(variables) === JSON.stringify(lastQuerySaved.variables) && (JSON.stringify(headers) === JSON.stringify(lastQuerySaved.headers) || headers && !lastQuerySaved.headers) || variables && !lastQuerySaved.variables)) : !0;\n+                    }\n+                    toggleFavorite({\n+                        query,\n+                        variables,\n+                        headers,\n+                        operationName,\n+                        label,\n+                        favorite\n+                    }) {\n+                        const item = {\n+                            query,\n+                            variables,\n+                            headers,\n+                            operationName,\n+                            label\n+                        };\n+                        favorite ? (item.favorite = !1, this.favorite.delete(item), this.history.push(item)) : (item.favorite = !0, this.favorite.push(item), this.history.delete(item)), this.queries = [...this.history.items, ...this.favorite.items];\n+                    }\n+                    editLabel({\n+                        query,\n+                        variables,\n+                        headers,\n+                        operationName,\n+                        label,\n+                        favorite\n+                    }, index) {\n+                        const item = {\n+                            query,\n+                            variables,\n+                            headers,\n+                            operationName,\n+                            label\n+                        };\n+                        favorite ? this.favorite.edit((0, _chunkLMOQIXV.__spreadProps)((0, _chunkLMOQIXV.__spreadValues)({}, item), {\n+                            favorite\n+                        }), index) : this.history.edit(item, index), this.queries = [...this.history.items, ...this.favorite.items];\n+                    }\n                 }\n+                exports.HistoryStore = HistoryStore;\n \n-                function _interopRequireWildcard(obj, nodeInterop) {\n-                    if (!nodeInterop && obj && obj.__esModule) {\n-                        return obj;\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../graphiql-toolkit/dist/esm/storage/index.js\":\n+            /*!********************************************************!*\\\n+              !*** ../../graphiql-toolkit/dist/esm/storage/index.js ***!\n+              \\********************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                var _base = __webpack_require__( /*! ./base */ \"../../graphiql-toolkit/dist/esm/storage/base.js\");\n+                Object.keys(_base).forEach(function(key) {\n+                    if (key === \"default\" || key === \"__esModule\") return;\n+                    if (key in exports && exports[key] === _base[key]) return;\n+                    Object.defineProperty(exports, key, {\n+                        enumerable: true,\n+                        get: function() {\n+                            return _base[key];\n+                        }\n+                    });\n+                });\n+                var _history = __webpack_require__( /*! ./history */ \"../../graphiql-toolkit/dist/esm/storage/history.js\");\n+                Object.keys(_history).forEach(function(key) {\n+                    if (key === \"default\" || key === \"__esModule\") return;\n+                    if (key in exports && exports[key] === _history[key]) return;\n+                    Object.defineProperty(exports, key, {\n+                        enumerable: true,\n+                        get: function() {\n+                            return _history[key];\n+                        }\n+                    });\n+                });\n+                var _query = __webpack_require__( /*! ./query */ \"../../graphiql-toolkit/dist/esm/storage/query.js\");\n+                Object.keys(_query).forEach(function(key) {\n+                    if (key === \"default\" || key === \"__esModule\") return;\n+                    if (key in exports && exports[key] === _query[key]) return;\n+                    Object.defineProperty(exports, key, {\n+                        enumerable: true,\n+                        get: function() {\n+                            return _query[key];\n+                        }\n+                    });\n+                });\n+                var _custom = __webpack_require__( /*! ./custom */ \"../../graphiql-toolkit/dist/esm/storage/custom.js\");\n+                Object.keys(_custom).forEach(function(key) {\n+                    if (key === \"default\" || key === \"__esModule\") return;\n+                    if (key in exports && exports[key] === _custom[key]) return;\n+                    Object.defineProperty(exports, key, {\n+                        enumerable: true,\n+                        get: function() {\n+                            return _custom[key];\n+                        }\n+                    });\n+                });\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../graphiql-toolkit/dist/esm/storage/query.js\":\n+            /*!********************************************************!*\\\n+              !*** ../../graphiql-toolkit/dist/esm/storage/query.js ***!\n+              \\********************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.QueryStore = void 0;\n+                __webpack_require__( /*! ../chunk-LMOQIXV4.js */ \"../../graphiql-toolkit/dist/esm/chunk-LMOQIXV4.js\");\n+                class QueryStore {\n+                    constructor(key, storage, maxSize = null) {\n+                        this.key = key;\n+                        this.storage = storage;\n+                        this.maxSize = maxSize;\n+                        this.items = this.fetchAll();\n                     }\n-                    if (obj === null || typeof obj !== \"object\" && typeof obj !== \"function\") {\n-                        return {\n-                            default: obj\n-                        };\n+                    get length() {\n+                        return this.items.length;\n                     }\n-                    var cache = _getRequireWildcardCache(nodeInterop);\n-                    if (cache && cache.has(obj)) {\n-                        return cache.get(obj);\n-                    }\n-                    var newObj = {};\n-                    var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;\n-                    for (var key in obj) {\n-                        if (key !== \"default\" && Object.prototype.hasOwnProperty.call(obj, key)) {\n-                            var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;\n-                            if (desc && (desc.get || desc.set)) {\n-                                Object.defineProperty(newObj, key, desc);\n-                            } else {\n-                                newObj[key] = obj[key];\n+                    contains(item) {\n+                        return this.items.some(x => x.query === item.query && x.variables === item.variables && x.headers === item.headers && x.operationName === item.operationName);\n+                    }\n+                    edit(item, index) {\n+                        if (typeof index == \"number\" && this.items[index]) {\n+                            const found = this.items[index];\n+                            if (found.query === item.query && found.variables === item.variables && found.headers === item.headers && found.operationName === item.operationName) {\n+                                this.items.splice(index, 1, item), this.save();\n+                                return;\n                             }\n                         }\n+                        const itemIndex = this.items.findIndex(x => x.query === item.query && x.variables === item.variables && x.headers === item.headers && x.operationName === item.operationName);\n+                        itemIndex !== -1 && (this.items.splice(itemIndex, 1, item), this.save());\n                     }\n-                    newObj.default = obj;\n-                    if (cache) {\n-                        cache.set(obj, newObj);\n+                    delete(item) {\n+                        const itemIndex = this.items.findIndex(x => x.query === item.query && x.variables === item.variables && x.headers === item.headers && x.operationName === item.operationName);\n+                        itemIndex !== -1 && (this.items.splice(itemIndex, 1), this.save());\n+                    }\n+                    fetchRecent() {\n+                        return this.items.at(-1);\n+                    }\n+                    fetchAll() {\n+                        const raw = this.storage.get(this.key);\n+                        return raw ? JSON.parse(raw)[this.key] : [];\n+                    }\n+                    push(item) {\n+                        const items = [...this.items, item];\n+                        this.maxSize && items.length > this.maxSize && items.shift();\n+                        for (let attempts = 0; attempts < 5; attempts++) {\n+                            const response = this.storage.set(this.key, JSON.stringify({\n+                                [this.key]: items\n+                            }));\n+                            if (!(response != null && response.error)) this.items = items;\n+                            else if (response.isQuotaError && this.maxSize) items.shift();\n+                            else return;\n+                        }\n+                    }\n+                    save() {\n+                        this.storage.set(this.key, JSON.stringify({\n+                            [this.key]: this.items\n+                        }));\n                     }\n-                    return newObj;\n+                }\n+                exports.QueryStore = QueryStore;\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"./GraphiQL.tsx\":\n+            /*!**********************!*\\\n+              !*** ./GraphiQL.tsx ***!\n+              \\**********************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.GraphiQL = GraphiQL;\n+                exports.GraphiQLInterface = GraphiQLInterface;\n+                var _react = _interopRequireWildcard(__webpack_require__( /*! react */ \"react\"));\n+                var _react2 = __webpack_require__( /*! @graphiql/react */ \"../../graphiql-react/dist/index.js\");\n+\n+                function _getRequireWildcardCache(e) {\n+                    if (\"function\" != typeof WeakMap) return null;\n+                    var r = new WeakMap(),\n+                        t = new WeakMap();\n+                    return (_getRequireWildcardCache = function(e) {\n+                        return e ? t : r;\n+                    })(e);\n+                }\n+\n+                function _interopRequireWildcard(e, r) {\n+                    if (!r && e && e.__esModule) return e;\n+                    if (null === e || \"object\" != typeof e && \"function\" != typeof e) return {\n+                        default: e\n+                    };\n+                    var t = _getRequireWildcardCache(r);\n+                    if (t && t.has(e)) return t.get(e);\n+                    var n = {\n+                            __proto__: null\n+                        },\n+                        a = Object.defineProperty && Object.getOwnPropertyDescriptor;\n+                    for (var u in e)\n+                        if (\"default\" !== u && Object.prototype.hasOwnProperty.call(e, u)) {\n+                            var i = a ? Object.getOwnPropertyDescriptor(e, u) : null;\n+                            i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u];\n+                        } return n.default = e, t && t.set(e, n), n;\n                 }\n \n                 function _extends() {\n                     _extends = Object.assign ? Object.assign.bind() : function(target) {\n                         for (var i = 1; i < arguments.length; i++) {\n                             var source = arguments[i];\n                             for (var key in source) {\n@@ -77993,46 +89299,45 @@\n \n                 /**\n                  * The top-level React component for GraphiQL, intended to encompass the entire\n                  * browser viewport.\n                  *\n                  * @see https://github.com/graphql/graphiql#usage\n                  */\n-\n-                function GraphiQL(_ref) {\n+                function GraphiQL({\n+                    dangerouslyAssumeSchemaIsValid,\n+                    confirmCloseTab,\n+                    defaultQuery,\n+                    defaultTabs,\n+                    externalFragments,\n+                    fetcher,\n+                    getDefaultFieldNames,\n+                    headers,\n+                    inputValueDeprecation,\n+                    introspectionQueryName,\n+                    maxHistoryLength,\n+                    onEditOperationName,\n+                    onSchemaChange,\n+                    onTabChange,\n+                    onTogglePluginVisibility,\n+                    operationName,\n+                    plugins,\n+                    query,\n+                    response,\n+                    schema,\n+                    schemaDescription,\n+                    shouldPersistHeaders,\n+                    storage,\n+                    validationRules,\n+                    variables,\n+                    visiblePlugin,\n+                    defaultHeaders,\n+                    ...props\n+                }) {\n                     var _props$disableTabs;\n-                    let {\n-                        dangerouslyAssumeSchemaIsValid,\n-                        defaultQuery,\n-                        defaultTabs,\n-                        externalFragments,\n-                        fetcher,\n-                        getDefaultFieldNames,\n-                        headers,\n-                        inputValueDeprecation,\n-                        introspectionQueryName,\n-                        maxHistoryLength,\n-                        onEditOperationName,\n-                        onSchemaChange,\n-                        onTabChange,\n-                        onTogglePluginVisibility,\n-                        operationName,\n-                        plugins,\n-                        query,\n-                        response,\n-                        schema,\n-                        schemaDescription,\n-                        shouldPersistHeaders,\n-                        storage,\n-                        validationRules,\n-                        variables,\n-                        visiblePlugin,\n-                        defaultHeaders,\n-                        ...props\n-                    } = _ref;\n                     // Ensure props are correct\n                     if (typeof fetcher !== 'function') {\n                         throw new TypeError('The `GraphiQL` component requires a `fetcher` function to be passed as prop.');\n                     }\n                     return /*#__PURE__*/ _react.default.createElement(_react2.GraphiQLProvider, {\n                         getDefaultFieldNames: getDefaultFieldNames,\n                         dangerouslyAssumeSchemaIsValid: dangerouslyAssumeSchemaIsValid,\n@@ -78057,23 +89362,27 @@\n                         schema: schema,\n                         schemaDescription: schemaDescription,\n                         shouldPersistHeaders: shouldPersistHeaders,\n                         storage: storage,\n                         validationRules: validationRules,\n                         variables: variables\n                     }, /*#__PURE__*/ _react.default.createElement(GraphiQLInterface, _extends({\n+                        confirmCloseTab: confirmCloseTab,\n                         showPersistHeadersSettings: shouldPersistHeaders !== false,\n-                        disableTabs: (_props$disableTabs = props.disableTabs) !== null && _props$disableTabs !== void 0 ? _props$disableTabs : false\n+                        disableTabs: (_props$disableTabs = props.disableTabs) !== null && _props$disableTabs !== void 0 ? _props$disableTabs : false,\n+                        forcedTheme: props.forcedTheme\n                     }, props)));\n                 }\n \n                 // Export main windows/panes to be used separately if desired.\n                 GraphiQL.Logo = GraphiQLLogo;\n                 GraphiQL.Toolbar = GraphiQLToolbar;\n                 GraphiQL.Footer = GraphiQLFooter;\n+                const THEMES = ['light', 'dark', 'system'];\n+                const TAB_CLASS_PREFIX = 'graphiql-session-tab-';\n \n                 function GraphiQLInterface(props) {\n                     var _props$isHeadersEdito, _pluginContext$visibl, _props$toolbar, _props$toolbar2;\n                     const isHeadersEditorEnabled = (_props$isHeadersEdito = props.isHeadersEditorEnabled) !== null && _props$isHeadersEdito !== void 0 ? _props$isHeadersEdito : true;\n                     const editorContext = (0, _react2.useEditorContext)({\n                         nonNull: true\n                     });\n@@ -78081,23 +89390,31 @@\n                         nonNull: true\n                     });\n                     const schemaContext = (0, _react2.useSchemaContext)({\n                         nonNull: true\n                     });\n                     const storageContext = (0, _react2.useStorageContext)();\n                     const pluginContext = (0, _react2.usePluginContext)();\n+                    const forcedTheme = (0, _react.useMemo)(() => props.forcedTheme && THEMES.includes(props.forcedTheme) ? props.forcedTheme : undefined, [props.forcedTheme]);\n                     const copy = (0, _react2.useCopyQuery)({\n                         onCopyQuery: props.onCopyQuery\n                     });\n                     const merge = (0, _react2.useMergeQuery)();\n                     const prettify = (0, _react2.usePrettifyEditors)();\n                     const {\n                         theme,\n                         setTheme\n-                    } = (0, _react2.useTheme)();\n+                    } = (0, _react2.useTheme)(props.defaultTheme);\n+                    (0, _react.useEffect)(() => {\n+                        if (forcedTheme === 'system') {\n+                            setTheme(null);\n+                        } else if (forcedTheme === 'light' || forcedTheme === 'dark') {\n+                            setTheme(forcedTheme);\n+                        }\n+                    }, [forcedTheme, setTheme]);\n                     const PluginContent = pluginContext === null || pluginContext === void 0 ? void 0 : (_pluginContext$visibl = pluginContext.visiblePlugin) === null || _pluginContext$visibl === void 0 ? void 0 : _pluginContext$visibl.content;\n                     const pluginResize = (0, _react2.useDragResize)({\n                         defaultSizeRelation: 1 / 3,\n                         direction: 'horizontal',\n                         initiallyHidden: pluginContext !== null && pluginContext !== void 0 && pluginContext.visiblePlugin ? undefined : 'first',\n                         onHiddenElementChange(resizableElement) {\n                             if (resizableElement === 'first') {\n@@ -78150,15 +89467,15 @@\n                         \"aria-hidden\": \"true\"\n                     })), /*#__PURE__*/ _react.default.createElement(_react2.ToolbarButton, {\n                         onClick: copy,\n                         label: \"Copy query (Shift-Ctrl-C)\"\n                     }, /*#__PURE__*/ _react.default.createElement(_react2.CopyIcon, {\n                         className: \"graphiql-toolbar-icon\",\n                         \"aria-hidden\": \"true\"\n-                    })), ((_props$toolbar = props.toolbar) === null || _props$toolbar === void 0 ? void 0 : _props$toolbar.additionalContent) && props.toolbar.additionalContent, ((_props$toolbar2 = props.toolbar) === null || _props$toolbar2 === void 0 ? void 0 : _props$toolbar2.additionalComponent) && /*#__PURE__*/ _react.default.createElement(props.toolbar.additionalComponent, null));\n+                    })), (_props$toolbar = props.toolbar) === null || _props$toolbar === void 0 ? void 0 : _props$toolbar.additionalContent, ((_props$toolbar2 = props.toolbar) === null || _props$toolbar2 === void 0 ? void 0 : _props$toolbar2.additionalComponent) && /*#__PURE__*/ _react.default.createElement(props.toolbar.additionalComponent, null));\n                     const footer = children.find(child => isChildComponentType(child, GraphiQL.Footer));\n                     const onClickReference = (0, _react.useCallback)(() => {\n                         if (pluginResize.hiddenElement === 'first') {\n                             pluginResize.setHiddenElement(null);\n                         }\n                     }, [pluginResize]);\n                     const handleClearData = (0, _react.useCallback)(() => {\n@@ -78178,17 +89495,17 @@\n                     }, [setTheme]);\n                     const handleAddTab = editorContext.addTab;\n                     const handleRefetchSchema = schemaContext.introspect;\n                     const handleReorder = editorContext.moveTab;\n                     const handleShowDialog = (0, _react.useCallback)(event => {\n                         setShowDialog(event.currentTarget.dataset.value);\n                     }, []);\n-                    const handlePluginClick = (0, _react.useCallback)(e => {\n+                    const handlePluginClick = (0, _react.useCallback)(event => {\n                         const context = pluginContext;\n-                        const pluginIndex = Number(e.currentTarget.dataset.index);\n+                        const pluginIndex = Number(event.currentTarget.dataset.index);\n                         const plugin = context.plugins.find((_, index) => pluginIndex === index);\n                         const isVisible = plugin === context.visiblePlugin;\n                         if (isVisible) {\n                             context.setVisiblePlugin(null);\n                             pluginResize.setHiddenElement('first');\n                         } else {\n                             context.setVisiblePlugin(plugin);\n@@ -78221,35 +89538,64 @@\n                         type: \"button\",\n                         className: \"graphiql-tab-add\",\n                         onClick: handleAddTab,\n                         \"aria-label\": \"Add tab\"\n                     }, /*#__PURE__*/ _react.default.createElement(_react2.PlusIcon, {\n                         \"aria-hidden\": \"true\"\n                     })));\n+                    const className = props.className ? ` ${props.className}` : '';\n+                    const confirmClose = props.confirmCloseTab;\n+                    const handleTabClose = (0, _react.useCallback)(async event => {\n+                        const tabButton = event.currentTarget.previousSibling;\n+                        const index = Number(tabButton.id.replace(TAB_CLASS_PREFIX, ''));\n+\n+                        /** TODO:\n+                         * Move everything after into `editorContext.closeTab` once zustand will be used instead of\n+                         * React context, since now we can't use execution context inside editor context, since editor\n+                         * context is used in execution context.\n+                         */\n+                        const shouldCloseTab = confirmClose ? await confirmClose(index) : true;\n+                        if (!shouldCloseTab) {\n+                            return;\n+                        }\n+                        if (editorContext.activeTabIndex === index) {\n+                            executionContext.stop();\n+                        }\n+                        editorContext.closeTab(index);\n+                    }, [confirmClose, editorContext, executionContext]);\n+                    const handleTabClick = (0, _react.useCallback)(event => {\n+                        const index = Number(event.currentTarget.id.replace(TAB_CLASS_PREFIX, ''));\n+                        /** TODO:\n+                         * Move everything after into `editorContext.changeTab` once zustand will be used instead of\n+                         * React context, since now we can't use execution context inside editor context, since editor\n+                         * context is used in execution context.\n+                         */\n+                        executionContext.stop();\n+                        editorContext.changeTab(index);\n+                    }, [editorContext, executionContext]);\n                     return /*#__PURE__*/ _react.default.createElement(_react2.Tooltip.Provider, null, /*#__PURE__*/ _react.default.createElement(\"div\", {\n                         \"data-testid\": \"graphiql-container\",\n-                        className: \"graphiql-container\"\n+                        className: `graphiql-container${className}`\n                     }, /*#__PURE__*/ _react.default.createElement(\"div\", {\n                         className: \"graphiql-sidebar\"\n                     }, /*#__PURE__*/ _react.default.createElement(\"div\", {\n                         className: \"graphiql-sidebar-section\"\n                     }, pluginContext === null || pluginContext === void 0 ? void 0 : pluginContext.plugins.map((plugin, index) => {\n                         const isVisible = plugin === pluginContext.visiblePlugin;\n                         const label = `${isVisible ? 'Hide' : 'Show'} ${plugin.title}`;\n-                        const Icon = plugin.icon;\n                         return /*#__PURE__*/ _react.default.createElement(_react2.Tooltip, {\n                             key: plugin.title,\n                             label: label\n                         }, /*#__PURE__*/ _react.default.createElement(_react2.UnStyledButton, {\n                             type: \"button\",\n                             className: isVisible ? 'active' : '',\n                             onClick: handlePluginClick,\n                             \"data-index\": index,\n                             \"aria-label\": label\n-                        }, /*#__PURE__*/ _react.default.createElement(Icon, {\n+                        }, /*#__PURE__*/ _react.default.createElement(plugin.icon, {\n                             \"aria-hidden\": \"true\"\n                         })));\n                     })), /*#__PURE__*/ _react.default.createElement(\"div\", {\n                         className: \"graphiql-sidebar-section\"\n                     }, /*#__PURE__*/ _react.default.createElement(_react2.Tooltip, {\n                         label: \"Re-fetch GraphQL schema\"\n                     }, /*#__PURE__*/ _react.default.createElement(_react2.UnStyledButton, {\n@@ -78293,43 +89639,36 @@\n                         className: \"graphiql-horizontal-drag-bar\",\n                         ref: pluginResize.dragBarRef\n                     }), /*#__PURE__*/ _react.default.createElement(\"div\", {\n                         ref: pluginResize.secondRef,\n                         className: \"graphiql-sessions\"\n                     }, /*#__PURE__*/ _react.default.createElement(\"div\", {\n                         className: \"graphiql-session-header\"\n-                    }, props.disableTabs ? null : /*#__PURE__*/ _react.default.createElement(_react2.Tabs, {\n+                    }, !props.disableTabs && /*#__PURE__*/ _react.default.createElement(_react2.Tabs, {\n                         values: editorContext.tabs,\n                         onReorder: handleReorder,\n                         \"aria-label\": \"Select active operation\"\n                     }, editorContext.tabs.length > 1 && /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, editorContext.tabs.map((tab, index) => /*#__PURE__*/ _react.default.createElement(_react2.Tab, {\n                         key: tab.id,\n                         value: tab,\n                         isActive: index === editorContext.activeTabIndex\n                     }, /*#__PURE__*/ _react.default.createElement(_react2.Tab.Button, {\n                         \"aria-controls\": \"graphiql-session\",\n-                        id: `graphiql-session-tab-${index}`,\n-                        onClick: () => {\n-                            executionContext.stop();\n-                            editorContext.changeTab(index);\n-                        }\n+                        id: `${TAB_CLASS_PREFIX}${index}`,\n+                        onClick: handleTabClick\n                     }, tab.title), /*#__PURE__*/ _react.default.createElement(_react2.Tab.Close, {\n-                        onClick: () => {\n-                            if (editorContext.activeTabIndex === index) {\n-                                executionContext.stop();\n-                            }\n-                            editorContext.closeTab(index);\n-                        }\n+                        onClick: handleTabClose\n                     }))), addTab)), /*#__PURE__*/ _react.default.createElement(\"div\", {\n                         className: \"graphiql-session-header-right\"\n                     }, editorContext.tabs.length === 1 && addTab, logo)), /*#__PURE__*/ _react.default.createElement(\"div\", {\n                         role: \"tabpanel\",\n-                        id: \"graphiql-session\",\n+                        id: \"graphiql-session\" // used by aria-controls=\"graphiql-session\"\n+                            ,\n                         className: \"graphiql-session\",\n-                        \"aria-labelledby\": `graphiql-session-tab-${editorContext.activeTabIndex}`\n+                        \"aria-labelledby\": `${TAB_CLASS_PREFIX}${editorContext.activeTabIndex}`\n                     }, /*#__PURE__*/ _react.default.createElement(\"div\", {\n                         ref: editorResize.firstRef\n                     }, /*#__PURE__*/ _react.default.createElement(\"div\", {\n                         className: `graphiql-editors${editorContext.tabs.length === 1 ? ' full-height' : ''}`\n                     }, /*#__PURE__*/ _react.default.createElement(\"div\", {\n                         ref: editorToolsResize.firstRef\n                     }, /*#__PURE__*/ _react.default.createElement(\"section\", {\n@@ -78435,21 +89774,21 @@\n                         \"data-value\": \"true\",\n                         onClick: handlePersistHeaders\n                     }, \"On\"), /*#__PURE__*/ _react.default.createElement(_react2.Button, {\n                         type: \"button\",\n                         id: \"disable-persist-headers\",\n                         className: editorContext.shouldPersistHeaders ? '' : 'active',\n                         onClick: handlePersistHeaders\n-                    }, \"Off\"))) : null, /*#__PURE__*/ _react.default.createElement(\"div\", {\n+                    }, \"Off\"))) : null, !forcedTheme && /*#__PURE__*/ _react.default.createElement(\"div\", {\n                         className: \"graphiql-dialog-section\"\n                     }, /*#__PURE__*/ _react.default.createElement(\"div\", null, /*#__PURE__*/ _react.default.createElement(\"div\", {\n                         className: \"graphiql-dialog-section-title\"\n                     }, \"Theme\"), /*#__PURE__*/ _react.default.createElement(\"div\", {\n                         className: \"graphiql-dialog-section-caption\"\n-                    }, \"Adjust how the interface looks like.\")), /*#__PURE__*/ _react.default.createElement(_react2.ButtonGroup, null, /*#__PURE__*/ _react.default.createElement(_react2.Button, {\n+                    }, \"Adjust how the interface appears.\")), /*#__PURE__*/ _react.default.createElement(_react2.ButtonGroup, null, /*#__PURE__*/ _react.default.createElement(_react2.Button, {\n                         type: \"button\",\n                         className: theme === null ? 'active' : '',\n                         onClick: handleChangeTheme\n                     }, \"System\"), /*#__PURE__*/ _react.default.createElement(_react2.Button, {\n                         type: \"button\",\n                         className: theme === 'light' ? 'active' : '',\n                         \"data-theme\": \"light\",\n@@ -78471,41 +89810,37 @@\n                         disabled: clearStorageStatus === 'success',\n                         onClick: handleClearData\n                     }, {\n                         success: 'Cleared data',\n                         error: 'Failed'\n                     } [clearStorageStatus] || 'Clear data')) : null)));\n                 }\n-                const modifier = typeof window !== 'undefined' && window.navigator.platform.toLowerCase().indexOf('mac') === 0 ? 'Cmd' : 'Ctrl';\n+                const modifier = _react2.isMacOs ? '\u2318' : 'Ctrl';\n                 const SHORT_KEYS = Object.entries({\n                     'Search in editor': [modifier, 'F'],\n                     'Search in documentation': [modifier, 'K'],\n                     'Execute query': [modifier, 'Enter'],\n                     'Prettify editors': ['Ctrl', 'Shift', 'P'],\n                     'Merge fragments definitions into operation definition': ['Ctrl', 'Shift', 'M'],\n                     'Copy query': ['Ctrl', 'Shift', 'C'],\n                     'Re-fetch schema using introspection': ['Ctrl', 'Shift', 'R']\n                 });\n \n-                function ShortKeys(_ref2) {\n-                    let {\n-                        keyMap\n-                    } = _ref2;\n+                function ShortKeys({\n+                    keyMap\n+                }) {\n                     return /*#__PURE__*/ _react.default.createElement(\"div\", null, /*#__PURE__*/ _react.default.createElement(\"table\", {\n                         className: \"graphiql-table\"\n-                    }, /*#__PURE__*/ _react.default.createElement(\"thead\", null, /*#__PURE__*/ _react.default.createElement(\"tr\", null, /*#__PURE__*/ _react.default.createElement(\"th\", null, \"Short Key\"), /*#__PURE__*/ _react.default.createElement(\"th\", null, \"Function\"))), /*#__PURE__*/ _react.default.createElement(\"tbody\", null, SHORT_KEYS.map(_ref3 => {\n-                        let [title, keys] = _ref3;\n-                        return /*#__PURE__*/ _react.default.createElement(\"tr\", {\n-                            key: title\n-                        }, /*#__PURE__*/ _react.default.createElement(\"td\", null, keys.map((key, index, array) => /*#__PURE__*/ _react.default.createElement(_react.Fragment, {\n-                            key: key\n-                        }, /*#__PURE__*/ _react.default.createElement(\"code\", {\n-                            className: \"graphiql-key\"\n-                        }, key), index !== array.length - 1 && ' + '))), /*#__PURE__*/ _react.default.createElement(\"td\", null, title));\n-                    }))), /*#__PURE__*/ _react.default.createElement(\"p\", null, \"The editors use\", ' ', /*#__PURE__*/ _react.default.createElement(\"a\", {\n+                    }, /*#__PURE__*/ _react.default.createElement(\"thead\", null, /*#__PURE__*/ _react.default.createElement(\"tr\", null, /*#__PURE__*/ _react.default.createElement(\"th\", null, \"Short Key\"), /*#__PURE__*/ _react.default.createElement(\"th\", null, \"Function\"))), /*#__PURE__*/ _react.default.createElement(\"tbody\", null, SHORT_KEYS.map(([title, keys]) => /*#__PURE__*/ _react.default.createElement(\"tr\", {\n+                        key: title\n+                    }, /*#__PURE__*/ _react.default.createElement(\"td\", null, keys.map((key, index, array) => /*#__PURE__*/ _react.default.createElement(_react.Fragment, {\n+                        key: key\n+                    }, /*#__PURE__*/ _react.default.createElement(\"code\", {\n+                        className: \"graphiql-key\"\n+                    }, key), index !== array.length - 1 && ' + '))), /*#__PURE__*/ _react.default.createElement(\"td\", null, title))))), /*#__PURE__*/ _react.default.createElement(\"p\", null, \"The editors use\", ' ', /*#__PURE__*/ _react.default.createElement(\"a\", {\n                         href: \"https://codemirror.net/5/doc/manual.html#keymaps\",\n                         target: \"_blank\",\n                         rel: \"noopener noreferrer\"\n                     }, \"CodeMirror Key Maps\"), ' ', \"that add more short keys. This instance of Graph\", /*#__PURE__*/ _react.default.createElement(\"em\", null, \"i\"), \"QL uses\", ' ', /*#__PURE__*/ _react.default.createElement(\"code\", null, keyMap), \".\"));\n                 }\n \n                 // Configure the UI by providing this Component as a child of GraphiQL.\n@@ -78552,14 +89887,15 @@\n         \"../../graphql-language-service/esm/index.js\":\n             /*!***************************************************!*\\\n               !*** ../../graphql-language-service/esm/index.js ***!\n               \\***************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 Object.defineProperty(exports, \"CharacterStream\", ({\n                     enumerable: true,\n@@ -78581,14 +89917,20 @@\n                 }));\n                 Object.defineProperty(exports, \"FileChangeTypeKind\", ({\n                     enumerable: true,\n                     get: function() {\n                         return _types.FileChangeTypeKind;\n                     }\n                 }));\n+                Object.defineProperty(exports, \"GraphQLDocumentMode\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _parser.GraphQLDocumentMode;\n+                    }\n+                }));\n                 Object.defineProperty(exports, \"LexRules\", ({\n                     enumerable: true,\n                     get: function() {\n                         return _parser.LexRules;\n                     }\n                 }));\n                 Object.defineProperty(exports, \"ParseRules\", ({\n@@ -78647,14 +89989,20 @@\n                 }));\n                 Object.defineProperty(exports, \"getAutocompleteSuggestions\", ({\n                     enumerable: true,\n                     get: function() {\n                         return _interface.getAutocompleteSuggestions;\n                     }\n                 }));\n+                Object.defineProperty(exports, \"getDefinitionQueryResultForArgument\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _interface.getDefinitionQueryResultForArgument;\n+                    }\n+                }));\n                 Object.defineProperty(exports, \"getDefinitionQueryResultForDefinitionNode\", ({\n                     enumerable: true,\n                     get: function() {\n                         return _interface.getDefinitionQueryResultForDefinitionNode;\n                     }\n                 }));\n                 Object.defineProperty(exports, \"getDefinitionQueryResultForField\", ({\n@@ -78674,27 +90022,27 @@\n                     get: function() {\n                         return _interface.getDefinitionQueryResultForNamedType;\n                     }\n                 }));\n                 Object.defineProperty(exports, \"getDefinitionState\", ({\n                     enumerable: true,\n                     get: function() {\n-                        return _interface.getDefinitionState;\n+                        return _parser.getDefinitionState;\n                     }\n                 }));\n                 Object.defineProperty(exports, \"getDiagnostics\", ({\n                     enumerable: true,\n                     get: function() {\n                         return _interface.getDiagnostics;\n                     }\n                 }));\n                 Object.defineProperty(exports, \"getFieldDef\", ({\n                     enumerable: true,\n                     get: function() {\n-                        return _interface.getFieldDef;\n+                        return _parser.getFieldDef;\n                     }\n                 }));\n                 Object.defineProperty(exports, \"getFragmentDefinitions\", ({\n                     enumerable: true,\n                     get: function() {\n                         return _interface.getFragmentDefinitions;\n                     }\n@@ -78746,15 +90094,15 @@\n                     get: function() {\n                         return _interface.getRange;\n                     }\n                 }));\n                 Object.defineProperty(exports, \"getTokenAtPosition\", ({\n                     enumerable: true,\n                     get: function() {\n-                        return _interface.getTokenAtPosition;\n+                        return _parser.getTokenAtPosition;\n                     }\n                 }));\n                 Object.defineProperty(exports, \"getTypeInfo\", ({\n                     enumerable: true,\n                     get: function() {\n                         return _interface.getTypeInfo;\n                     }\n@@ -78843,70 +90191,25 @@\n         \"../../graphql-language-service/esm/interface/autocompleteUtils.js\":\n             /*!*************************************************************************!*\\\n               !*** ../../graphql-language-service/esm/interface/autocompleteUtils.js ***!\n               \\*************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports.forEachState = forEachState;\n-                exports.getDefinitionState = getDefinitionState;\n-                exports.getFieldDef = getFieldDef;\n+                exports.getInsertText = exports.getInputInsertText = exports.getFieldInsertText = void 0;\n                 exports.hintList = hintList;\n                 exports.objectValues = objectValues;\n                 var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n \n-                function getDefinitionState(tokenState) {\n-                    let definitionState;\n-                    forEachState(tokenState, state => {\n-                        switch (state.kind) {\n-                            case 'Query':\n-                            case 'ShortQuery':\n-                            case 'Mutation':\n-                            case 'Subscription':\n-                            case 'FragmentDefinition':\n-                                definitionState = state;\n-                                break;\n-                        }\n-                    });\n-                    return definitionState;\n-                }\n-\n-                function getFieldDef(schema, type, fieldName) {\n-                    if (fieldName === _graphql.SchemaMetaFieldDef.name && schema.getQueryType() === type) {\n-                        return _graphql.SchemaMetaFieldDef;\n-                    }\n-                    if (fieldName === _graphql.TypeMetaFieldDef.name && schema.getQueryType() === type) {\n-                        return _graphql.TypeMetaFieldDef;\n-                    }\n-                    if (fieldName === _graphql.TypeNameMetaFieldDef.name && (0, _graphql.isCompositeType)(type)) {\n-                        return _graphql.TypeNameMetaFieldDef;\n-                    }\n-                    if ('getFields' in type) {\n-                        return type.getFields()[fieldName];\n-                    }\n-                    return null;\n-                }\n-\n-                function forEachState(stack, fn) {\n-                    const reverseStateStack = [];\n-                    let state = stack;\n-                    while (state === null || state === void 0 ? void 0 : state.kind) {\n-                        reverseStateStack.push(state);\n-                        state = state.prevState;\n-                    }\n-                    for (let i = reverseStateStack.length - 1; i >= 0; i--) {\n-                        fn(reverseStateStack[i]);\n-                    }\n-                }\n-\n                 function objectValues(object) {\n                     const keys = Object.keys(object);\n                     const len = keys.length;\n                     const values = new Array(len);\n                     for (let i = 0; i < len; ++i) {\n                         values[i] = object[keys[i]];\n                     }\n@@ -78914,15 +90217,15 @@\n                 }\n \n                 function hintList(token, list) {\n                     return filterAndSortList(list, normalizeText(token.string));\n                 }\n \n                 function filterAndSortList(list, text) {\n-                    if (!text) {\n+                    if (!text || text.trim() === '' || text.trim() === ':' || text.trim() === '{') {\n                         return filterNonEmpty(list, entry => !entry.isDeprecated);\n                     }\n                     const byProximity = list.map(entry => ({\n                         proximity: getProximity(normalizeText(entry.label), text),\n                         entry\n                     }));\n                     return filterNonEmpty(filterNonEmpty(byProximity, pair => pair.proximity <= 2), pair => !pair.entry.isDeprecated).sort((a, b) => (a.entry.isDeprecated ? 1 : 0) - (b.entry.isDeprecated ? 1 : 0) || a.proximity - b.proximity || a.entry.label.length - b.entry.label.length).map(pair => pair.entry);\n@@ -78965,48 +90268,86 @@\n                             if (i > 1 && j > 1 && a[i - 1] === b[j - 2] && a[i - 2] === b[j - 1]) {\n                                 d[i][j] = Math.min(d[i][j], d[i - 2][j - 2] + cost);\n                             }\n                         }\n                     }\n                     return d[aLength][bLength];\n                 }\n+                const insertSuffix = n => ` {\\n   $${n !== null && n !== void 0 ? n : 1}\\n}`;\n+                const getInsertText = (prefix, type, fallback) => {\n+                    if (!type) {\n+                        return fallback !== null && fallback !== void 0 ? fallback : prefix;\n+                    }\n+                    const namedType = (0, _graphql.getNamedType)(type);\n+                    if ((0, _graphql.isObjectType)(namedType) || (0, _graphql.isInputObjectType)(namedType) || (0, _graphql.isListType)(namedType) || (0, _graphql.isAbstractType)(namedType)) {\n+                        return prefix + insertSuffix();\n+                    }\n+                    return fallback !== null && fallback !== void 0 ? fallback : prefix;\n+                };\n+                exports.getInsertText = getInsertText;\n+                const getInputInsertText = (prefix, type, fallback) => {\n+                    if ((0, _graphql.isListType)(type)) {\n+                        const baseType = (0, _graphql.getNamedType)(type.ofType);\n+                        return prefix + `[${getInsertText('', baseType, '$1')}]`;\n+                    }\n+                    return getInsertText(prefix, type, fallback);\n+                };\n+                exports.getInputInsertText = getInputInsertText;\n+                const getFieldInsertText = field => {\n+                    const requiredArgs = field.args.filter(arg => arg.type.toString().endsWith('!'));\n+                    if (!requiredArgs.length) {\n+                        return;\n+                    }\n+                    return field.name + `(${requiredArgs.map((arg, i) => `${arg.name}: $${i + 1}`)}) ${getInsertText('', field.type, '\\n')}`;\n+                };\n+                exports.getFieldInsertText = getFieldInsertText;\n \n                 /***/\n             }),\n \n         /***/\n         \"../../graphql-language-service/esm/interface/getAutocompleteSuggestions.js\":\n             /*!**********************************************************************************!*\\\n               !*** ../../graphql-language-service/esm/interface/getAutocompleteSuggestions.js ***!\n               \\**********************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n-                exports.SuggestionCommand = exports.GraphQLDocumentMode = void 0;\n+                exports.SuggestionCommand = void 0;\n                 exports.canUseDirective = canUseDirective;\n                 exports.getAutocompleteSuggestions = getAutocompleteSuggestions;\n                 exports.getFragmentDefinitions = getFragmentDefinitions;\n-                exports.getTokenAtPosition = getTokenAtPosition;\n-                exports.getTypeInfo = getTypeInfo;\n+                Object.defineProperty(exports, \"getTypeInfo\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _parser.getTypeInfo;\n+                    }\n+                }));\n                 exports.getVariableCompletions = getVariableCompletions;\n-                exports.runOnlineParser = runOnlineParser;\n+                Object.defineProperty(exports, \"runOnlineParser\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _parser.runOnlineParser;\n+                    }\n+                }));\n                 var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n                 var _types = __webpack_require__( /*! ../types */ \"../../graphql-language-service/esm/types.js\");\n                 var _parser = __webpack_require__( /*! ../parser */ \"../../graphql-language-service/esm/parser/index.js\");\n                 var _autocompleteUtils = __webpack_require__( /*! ./autocompleteUtils */ \"../../graphql-language-service/esm/interface/autocompleteUtils.js\");\n-                const SuggestionCommand = {\n+                var _vscodeLanguageserverTypes = __webpack_require__( /*! vscode-languageserver-types */ \"../../../node_modules/vscode-languageserver-types/lib/esm/main.js\");\n+                const SuggestionCommand = exports.SuggestionCommand = {\n                     command: 'editor.action.triggerSuggest',\n                     title: 'Suggestions'\n                 };\n-                exports.SuggestionCommand = SuggestionCommand;\n                 const collectFragmentDefs = op => {\n                     const externalFragments = [];\n                     if (op) {\n                         try {\n                             (0, _graphql.visit)((0, _graphql.parse)(op), {\n                                 FragmentDefinition(def) {\n                                     externalFragments.push(def);\n@@ -79014,60 +90355,43 @@\n                             });\n                         } catch (_a) {\n                             return [];\n                         }\n                     }\n                     return externalFragments;\n                 };\n-                const typeSystemKinds = [_graphql.Kind.SCHEMA_DEFINITION, _graphql.Kind.OPERATION_TYPE_DEFINITION, _graphql.Kind.SCALAR_TYPE_DEFINITION, _graphql.Kind.OBJECT_TYPE_DEFINITION, _graphql.Kind.INTERFACE_TYPE_DEFINITION, _graphql.Kind.UNION_TYPE_DEFINITION, _graphql.Kind.ENUM_TYPE_DEFINITION, _graphql.Kind.INPUT_OBJECT_TYPE_DEFINITION, _graphql.Kind.DIRECTIVE_DEFINITION, _graphql.Kind.SCHEMA_EXTENSION, _graphql.Kind.SCALAR_TYPE_EXTENSION, _graphql.Kind.OBJECT_TYPE_EXTENSION, _graphql.Kind.INTERFACE_TYPE_EXTENSION, _graphql.Kind.UNION_TYPE_EXTENSION, _graphql.Kind.ENUM_TYPE_EXTENSION, _graphql.Kind.INPUT_OBJECT_TYPE_EXTENSION];\n-                const hasTypeSystemDefinitions = sdl => {\n-                    let hasTypeSystemDef = false;\n-                    if (sdl) {\n-                        try {\n-                            (0, _graphql.visit)((0, _graphql.parse)(sdl), {\n-                                enter(node) {\n-                                    if (node.kind === 'Document') {\n-                                        return;\n-                                    }\n-                                    if (typeSystemKinds.includes(node.kind)) {\n-                                        hasTypeSystemDef = true;\n-                                        return _graphql.BREAK;\n-                                    }\n-                                    return false;\n-                                }\n-                            });\n-                        } catch (_a) {\n-                            return hasTypeSystemDef;\n-                        }\n-                    }\n-                    return hasTypeSystemDef;\n-                };\n \n                 function getAutocompleteSuggestions(schema, queryText, cursor, contextToken, fragmentDefs, options) {\n                     var _a;\n                     const opts = Object.assign(Object.assign({}, options), {\n                         schema\n                     });\n-                    const token = contextToken || getTokenAtPosition(queryText, cursor, 1);\n-                    const state = token.state.kind === 'Invalid' ? token.state.prevState : token.state;\n-                    const mode = (options === null || options === void 0 ? void 0 : options.mode) || getDocumentMode(queryText, options === null || options === void 0 ? void 0 : options.uri);\n-                    if (!state) {\n+                    const context = (0, _parser.getContextAtPosition)(queryText, cursor, schema, contextToken, options);\n+                    if (!context) {\n                         return [];\n                     }\n                     const {\n+                        state,\n+                        typeInfo,\n+                        mode,\n+                        token\n+                    } = context;\n+                    const {\n                         kind,\n                         step,\n                         prevState\n                     } = state;\n-                    const typeInfo = getTypeInfo(schema, token.state);\n                     if (kind === _parser.RuleKinds.DOCUMENT) {\n-                        if (mode === GraphQLDocumentMode.TYPE_SYSTEM) {\n+                        if (mode === _parser.GraphQLDocumentMode.TYPE_SYSTEM) {\n                             return getSuggestionsForTypeSystemDefinitions(token);\n                         }\n-                        return getSuggestionsForExecutableDefinitions(token);\n+                        if (mode === _parser.GraphQLDocumentMode.EXECUTABLE) {\n+                            return getSuggestionsForExecutableDefinitions(token);\n+                        }\n+                        return getSuggestionsForUnknownDocumentMode(token);\n                     }\n                     if (kind === _parser.RuleKinds.EXTEND_DEF) {\n                         return getSuggestionsForExtensionDefinitions(token);\n                     }\n                     if (((_a = prevState === null || prevState === void 0 ? void 0 : prevState.prevState) === null || _a === void 0 ? void 0 : _a.kind) === _parser.RuleKinds.EXTENSION_DEFINITION && state.name) {\n                         return (0, _autocompleteUtils.hintList)(token, []);\n                     }\n@@ -79118,17 +90442,21 @@\n                             argDefs\n                         } = typeInfo;\n                         if (argDefs) {\n                             return (0, _autocompleteUtils.hintList)(token, argDefs.map(argDef => {\n                                 var _a;\n                                 return {\n                                     label: argDef.name,\n-                                    insertText: argDef.name + ': ',\n+                                    insertText: (0, _autocompleteUtils.getInputInsertText)(argDef.name + ': ', argDef.type),\n+                                    insertTextMode: _vscodeLanguageserverTypes.InsertTextMode.adjustIndentation,\n+                                    insertTextFormat: _types.InsertTextFormat.Snippet,\n                                     command: SuggestionCommand,\n-                                    detail: String(argDef.type),\n+                                    labelDetails: {\n+                                        detail: ' ' + String(argDef.type)\n+                                    },\n                                     documentation: (_a = argDef.description) !== null && _a !== void 0 ? _a : undefined,\n                                     kind: _types.CompletionItemKind.Variable,\n                                     type: argDef.type\n                                 };\n                             }));\n                         }\n                     }\n@@ -79136,17 +90464,21 @@\n                         const objectFields = (0, _autocompleteUtils.objectValues)(typeInfo.objectFieldDefs);\n                         const completionKind = kind === _parser.RuleKinds.OBJECT_VALUE ? _types.CompletionItemKind.Value : _types.CompletionItemKind.Field;\n                         return (0, _autocompleteUtils.hintList)(token, objectFields.map(field => {\n                             var _a;\n                             return {\n                                 label: field.name,\n                                 detail: String(field.type),\n-                                documentation: (_a = field.description) !== null && _a !== void 0 ? _a : undefined,\n+                                documentation: (_a = field === null || field === void 0 ? void 0 : field.description) !== null && _a !== void 0 ? _a : undefined,\n                                 kind: completionKind,\n-                                type: field.type\n+                                type: field.type,\n+                                insertText: (0, _autocompleteUtils.getInputInsertText)(field.name + ': ', field.type),\n+                                insertTextMode: _vscodeLanguageserverTypes.InsertTextMode.adjustIndentation,\n+                                insertTextFormat: _types.InsertTextFormat.Snippet,\n+                                command: SuggestionCommand\n                             };\n                         }));\n                     }\n                     if (kind === _parser.RuleKinds.ENUM_VALUE || kind === _parser.RuleKinds.LIST_VALUE && step === 1 || kind === _parser.RuleKinds.OBJECT_FIELD && step === 2 || kind === _parser.RuleKinds.ARGUMENT && step === 2) {\n                         return getSuggestionsForInputValues(token, typeInfo, queryText, schema);\n                     }\n                     if (kind === _parser.RuleKinds.VARIABLE && step === 1) {\n@@ -79157,122 +90489,98 @@\n                     if (kind === _parser.RuleKinds.TYPE_CONDITION && step === 1 || kind === _parser.RuleKinds.NAMED_TYPE && prevState != null && prevState.kind === _parser.RuleKinds.TYPE_CONDITION) {\n                         return getSuggestionsForFragmentTypeConditions(token, typeInfo, schema, kind);\n                     }\n                     if (kind === _parser.RuleKinds.FRAGMENT_SPREAD && step === 1) {\n                         return getSuggestionsForFragmentSpread(token, typeInfo, schema, queryText, Array.isArray(fragmentDefs) ? fragmentDefs : collectFragmentDefs(fragmentDefs));\n                     }\n                     const unwrappedState = unwrapType(state);\n-                    if (mode === GraphQLDocumentMode.TYPE_SYSTEM && !unwrappedState.needsAdvance && kind === _parser.RuleKinds.NAMED_TYPE || kind === _parser.RuleKinds.LIST_TYPE) {\n-                        if (unwrappedState.kind === _parser.RuleKinds.FIELD_DEF) {\n-                            return (0, _autocompleteUtils.hintList)(token, Object.values(schema.getTypeMap()).filter(type => (0, _graphql.isOutputType)(type) && !type.name.startsWith('__')).map(type => ({\n-                                label: type.name,\n-                                kind: _types.CompletionItemKind.Function\n-                            })));\n-                        }\n-                        if (unwrappedState.kind === _parser.RuleKinds.INPUT_VALUE_DEF) {\n-                            return (0, _autocompleteUtils.hintList)(token, Object.values(schema.getTypeMap()).filter(type => (0, _graphql.isInputType)(type) && !type.name.startsWith('__')).map(type => ({\n-                                label: type.name,\n-                                kind: _types.CompletionItemKind.Function\n-                            })));\n-                        }\n+                    if (unwrappedState.kind === _parser.RuleKinds.FIELD_DEF) {\n+                        return (0, _autocompleteUtils.hintList)(token, Object.values(schema.getTypeMap()).filter(type => (0, _graphql.isOutputType)(type) && !type.name.startsWith('__')).map(type => ({\n+                            label: type.name,\n+                            kind: _types.CompletionItemKind.Function,\n+                            insertText: (options === null || options === void 0 ? void 0 : options.fillLeafsOnComplete) ? type.name + '\\n' : type.name,\n+                            insertTextMode: _vscodeLanguageserverTypes.InsertTextMode.adjustIndentation\n+                        })));\n+                    }\n+                    if (unwrappedState.kind === _parser.RuleKinds.INPUT_VALUE_DEF && step === 2) {\n+                        return (0, _autocompleteUtils.hintList)(token, Object.values(schema.getTypeMap()).filter(type => (0, _graphql.isInputType)(type) && !type.name.startsWith('__')).map(type => ({\n+                            label: type.name,\n+                            kind: _types.CompletionItemKind.Function,\n+                            insertText: (options === null || options === void 0 ? void 0 : options.fillLeafsOnComplete) ? type.name + '\\n$1' : type.name,\n+                            insertTextMode: _vscodeLanguageserverTypes.InsertTextMode.adjustIndentation,\n+                            insertTextFormat: _types.InsertTextFormat.Snippet\n+                        })));\n                     }\n                     if (kind === _parser.RuleKinds.VARIABLE_DEFINITION && step === 2 || kind === _parser.RuleKinds.LIST_TYPE && step === 1 || kind === _parser.RuleKinds.NAMED_TYPE && prevState && (prevState.kind === _parser.RuleKinds.VARIABLE_DEFINITION || prevState.kind === _parser.RuleKinds.LIST_TYPE || prevState.kind === _parser.RuleKinds.NON_NULL_TYPE)) {\n                         return getSuggestionsForVariableDefinition(token, schema, kind);\n                     }\n                     if (kind === _parser.RuleKinds.DIRECTIVE) {\n                         return getSuggestionsForDirective(token, state, schema, kind);\n                     }\n+                    if (kind === _parser.RuleKinds.DIRECTIVE_DEF) {\n+                        return getSuggestionsForDirectiveArguments(token, state, schema, kind);\n+                    }\n                     return [];\n                 }\n-                const insertSuffix = ' {\\n  $1\\n}';\n-                const getInsertText = field => {\n-                    const {\n-                        type\n-                    } = field;\n-                    if ((0, _graphql.isCompositeType)(type)) {\n-                        return insertSuffix;\n-                    }\n-                    if ((0, _graphql.isListType)(type) && (0, _graphql.isCompositeType)(type.ofType)) {\n-                        return insertSuffix;\n-                    }\n-                    if ((0, _graphql.isNonNullType)(type)) {\n-                        if ((0, _graphql.isCompositeType)(type.ofType)) {\n-                            return insertSuffix;\n-                        }\n-                        if ((0, _graphql.isListType)(type.ofType) && (0, _graphql.isCompositeType)(type.ofType.ofType)) {\n-                            return insertSuffix;\n-                        }\n-                    }\n-                    return null;\n-                };\n+                const typeSystemCompletionItems = [{\n+                    label: 'type',\n+                    kind: _types.CompletionItemKind.Function\n+                }, {\n+                    label: 'interface',\n+                    kind: _types.CompletionItemKind.Function\n+                }, {\n+                    label: 'union',\n+                    kind: _types.CompletionItemKind.Function\n+                }, {\n+                    label: 'input',\n+                    kind: _types.CompletionItemKind.Function\n+                }, {\n+                    label: 'scalar',\n+                    kind: _types.CompletionItemKind.Function\n+                }, {\n+                    label: 'schema',\n+                    kind: _types.CompletionItemKind.Function\n+                }];\n+                const executableCompletionItems = [{\n+                    label: 'query',\n+                    kind: _types.CompletionItemKind.Function\n+                }, {\n+                    label: 'mutation',\n+                    kind: _types.CompletionItemKind.Function\n+                }, {\n+                    label: 'subscription',\n+                    kind: _types.CompletionItemKind.Function\n+                }, {\n+                    label: 'fragment',\n+                    kind: _types.CompletionItemKind.Function\n+                }, {\n+                    label: '{',\n+                    kind: _types.CompletionItemKind.Constructor\n+                }];\n \n                 function getSuggestionsForTypeSystemDefinitions(token) {\n                     return (0, _autocompleteUtils.hintList)(token, [{\n                         label: 'extend',\n                         kind: _types.CompletionItemKind.Function\n-                    }, {\n-                        label: 'type',\n-                        kind: _types.CompletionItemKind.Function\n-                    }, {\n-                        label: 'interface',\n-                        kind: _types.CompletionItemKind.Function\n-                    }, {\n-                        label: 'union',\n-                        kind: _types.CompletionItemKind.Function\n-                    }, {\n-                        label: 'input',\n-                        kind: _types.CompletionItemKind.Function\n-                    }, {\n-                        label: 'scalar',\n-                        kind: _types.CompletionItemKind.Function\n-                    }, {\n-                        label: 'schema',\n-                        kind: _types.CompletionItemKind.Function\n-                    }]);\n+                    }, ...typeSystemCompletionItems]);\n                 }\n \n                 function getSuggestionsForExecutableDefinitions(token) {\n+                    return (0, _autocompleteUtils.hintList)(token, executableCompletionItems);\n+                }\n+\n+                function getSuggestionsForUnknownDocumentMode(token) {\n                     return (0, _autocompleteUtils.hintList)(token, [{\n-                        label: 'query',\n-                        kind: _types.CompletionItemKind.Function\n-                    }, {\n-                        label: 'mutation',\n-                        kind: _types.CompletionItemKind.Function\n-                    }, {\n-                        label: 'subscription',\n-                        kind: _types.CompletionItemKind.Function\n-                    }, {\n-                        label: 'fragment',\n+                        label: 'extend',\n                         kind: _types.CompletionItemKind.Function\n-                    }, {\n-                        label: '{',\n-                        kind: _types.CompletionItemKind.Constructor\n-                    }]);\n+                    }, ...executableCompletionItems, ...typeSystemCompletionItems]);\n                 }\n \n                 function getSuggestionsForExtensionDefinitions(token) {\n-                    return (0, _autocompleteUtils.hintList)(token, [{\n-                        label: 'type',\n-                        kind: _types.CompletionItemKind.Function\n-                    }, {\n-                        label: 'interface',\n-                        kind: _types.CompletionItemKind.Function\n-                    }, {\n-                        label: 'union',\n-                        kind: _types.CompletionItemKind.Function\n-                    }, {\n-                        label: 'input',\n-                        kind: _types.CompletionItemKind.Function\n-                    }, {\n-                        label: 'scalar',\n-                        kind: _types.CompletionItemKind.Function\n-                    }, {\n-                        label: 'schema',\n-                        kind: _types.CompletionItemKind.Function\n-                    }]);\n+                    return (0, _autocompleteUtils.hintList)(token, typeSystemCompletionItems);\n                 }\n \n                 function getSuggestionsForFieldNames(token, typeInfo, options) {\n                     var _a;\n                     if (typeInfo.parentType) {\n                         const {\n                             parentType\n@@ -79294,33 +90602,39 @@\n                                 label: field.name,\n                                 detail: String(field.type),\n                                 documentation: (_a = field.description) !== null && _a !== void 0 ? _a : undefined,\n                                 deprecated: Boolean(field.deprecationReason),\n                                 isDeprecated: Boolean(field.deprecationReason),\n                                 deprecationReason: field.deprecationReason,\n                                 kind: _types.CompletionItemKind.Field,\n+                                labelDetails: {\n+                                    detail: ' ' + field.type.toString()\n+                                },\n                                 type: field.type\n                             };\n                             if (options === null || options === void 0 ? void 0 : options.fillLeafsOnComplete) {\n-                                const insertText = getInsertText(field);\n-                                if (insertText) {\n-                                    suggestion.insertText = field.name + insertText;\n+                                suggestion.insertText = (0, _autocompleteUtils.getFieldInsertText)(field);\n+                                if (!suggestion.insertText) {\n+                                    suggestion.insertText = (0, _autocompleteUtils.getInsertText)(field.name, field.type, field.name + (token.state.needsAdvance ? '' : '\\n'));\n+                                }\n+                                if (suggestion.insertText) {\n                                     suggestion.insertTextFormat = _types.InsertTextFormat.Snippet;\n+                                    suggestion.insertTextMode = _vscodeLanguageserverTypes.InsertTextMode.adjustIndentation;\n                                     suggestion.command = SuggestionCommand;\n                                 }\n                             }\n                             return suggestion;\n                         }));\n                     }\n                     return [];\n                 }\n \n                 function getSuggestionsForInputValues(token, typeInfo, queryText, schema) {\n                     const namedInputType = (0, _graphql.getNamedType)(typeInfo.inputType);\n-                    const queryVariables = getVariableCompletions(queryText, schema, token).filter(v => v.detail === namedInputType.name);\n+                    const queryVariables = getVariableCompletions(queryText, schema, token).filter(v => v.detail === (namedInputType === null || namedInputType === void 0 ? void 0 : namedInputType.name));\n                     if (namedInputType instanceof _graphql.GraphQLEnumType) {\n                         const values = namedInputType.getValues();\n                         return (0, _autocompleteUtils.hintList)(token, values.map(value => {\n                             var _a;\n                             return {\n                                 label: value.name,\n                                 detail: String(namedInputType),\n@@ -79353,53 +90667,44 @@\n \n                 function getSuggestionsForImplements(token, tokenState, schema, documentText, typeInfo) {\n                     if (tokenState.needsSeparator) {\n                         return [];\n                     }\n                     const typeMap = schema.getTypeMap();\n                     const schemaInterfaces = (0, _autocompleteUtils.objectValues)(typeMap).filter(_graphql.isInterfaceType);\n-                    const schemaInterfaceNames = schemaInterfaces.map(_ref => {\n-                        let {\n-                            name\n-                        } = _ref;\n-                        return name;\n-                    });\n+                    const schemaInterfaceNames = schemaInterfaces.map(({\n+                        name\n+                    }) => name);\n                     const inlineInterfaces = new Set();\n-                    runOnlineParser(documentText, (_, state) => {\n+                    (0, _parser.runOnlineParser)(documentText, (_, state) => {\n                         var _a, _b, _c, _d, _e;\n                         if (state.name) {\n                             if (state.kind === _parser.RuleKinds.INTERFACE_DEF && !schemaInterfaceNames.includes(state.name)) {\n                                 inlineInterfaces.add(state.name);\n                             }\n                             if (state.kind === _parser.RuleKinds.NAMED_TYPE && ((_a = state.prevState) === null || _a === void 0 ? void 0 : _a.kind) === _parser.RuleKinds.IMPLEMENTS) {\n                                 if (typeInfo.interfaceDef) {\n-                                    const existingType = (_b = typeInfo.interfaceDef) === null || _b === void 0 ? void 0 : _b.getInterfaces().find(_ref2 => {\n-                                        let {\n-                                            name\n-                                        } = _ref2;\n-                                        return name === state.name;\n-                                    });\n+                                    const existingType = (_b = typeInfo.interfaceDef) === null || _b === void 0 ? void 0 : _b.getInterfaces().find(({\n+                                        name\n+                                    }) => name === state.name);\n                                     if (existingType) {\n                                         return;\n                                     }\n                                     const type = schema.getType(state.name);\n                                     const interfaceConfig = (_c = typeInfo.interfaceDef) === null || _c === void 0 ? void 0 : _c.toConfig();\n                                     typeInfo.interfaceDef = new _graphql.GraphQLInterfaceType(Object.assign(Object.assign({}, interfaceConfig), {\n                                         interfaces: [...interfaceConfig.interfaces, type || new _graphql.GraphQLInterfaceType({\n                                             name: state.name,\n                                             fields: {}\n                                         })]\n                                     }));\n                                 } else if (typeInfo.objectTypeDef) {\n-                                    const existingType = (_d = typeInfo.objectTypeDef) === null || _d === void 0 ? void 0 : _d.getInterfaces().find(_ref3 => {\n-                                        let {\n-                                            name\n-                                        } = _ref3;\n-                                        return name === state.name;\n-                                    });\n+                                    const existingType = (_d = typeInfo.objectTypeDef) === null || _d === void 0 ? void 0 : _d.getInterfaces().find(({\n+                                        name\n+                                    }) => name === state.name);\n                                     if (existingType) {\n                                         return;\n                                     }\n                                     const type = schema.getType(state.name);\n                                     const objectTypeConfig = (_e = typeInfo.objectTypeDef) === null || _e === void 0 ? void 0 : _e.toConfig();\n                                     typeInfo.objectTypeDef = new _graphql.GraphQLObjectType(Object.assign(Object.assign({}, objectTypeConfig), {\n                                         interfaces: [...objectTypeConfig.interfaces, type || new _graphql.GraphQLInterfaceType({\n@@ -79409,28 +90714,22 @@\n                                     }));\n                                 }\n                             }\n                         }\n                     });\n                     const currentTypeToExtend = typeInfo.interfaceDef || typeInfo.objectTypeDef;\n                     const siblingInterfaces = (currentTypeToExtend === null || currentTypeToExtend === void 0 ? void 0 : currentTypeToExtend.getInterfaces()) || [];\n-                    const siblingInterfaceNames = siblingInterfaces.map(_ref4 => {\n-                        let {\n-                            name\n-                        } = _ref4;\n-                        return name;\n-                    });\n+                    const siblingInterfaceNames = siblingInterfaces.map(({\n+                        name\n+                    }) => name);\n                     const possibleInterfaces = schemaInterfaces.concat([...inlineInterfaces].map(name => ({\n                         name\n-                    }))).filter(_ref5 => {\n-                        let {\n-                            name\n-                        } = _ref5;\n-                        return name !== (currentTypeToExtend === null || currentTypeToExtend === void 0 ? void 0 : currentTypeToExtend.name) && !siblingInterfaceNames.includes(name);\n-                    });\n+                    }))).filter(({\n+                        name\n+                    }) => name !== (currentTypeToExtend === null || currentTypeToExtend === void 0 ? void 0 : currentTypeToExtend.name) && !siblingInterfaceNames.includes(name));\n                     return (0, _autocompleteUtils.hintList)(token, possibleInterfaces.map(type => {\n                         const result = {\n                             label: type.name,\n                             kind: _types.CompletionItemKind.Interface,\n                             type\n                         };\n                         if (type === null || type === void 0 ? void 0 : type.description) {\n@@ -79471,24 +90770,27 @@\n                 }\n \n                 function getSuggestionsForFragmentSpread(token, typeInfo, schema, queryText, fragmentDefs) {\n                     if (!queryText) {\n                         return [];\n                     }\n                     const typeMap = schema.getTypeMap();\n-                    const defState = (0, _autocompleteUtils.getDefinitionState)(token.state);\n+                    const defState = (0, _parser.getDefinitionState)(token.state);\n                     const fragments = getFragmentDefinitions(queryText);\n                     if (fragmentDefs && fragmentDefs.length > 0) {\n                         fragments.push(...fragmentDefs);\n                     }\n                     const relevantFrags = fragments.filter(frag => typeMap[frag.typeCondition.name.value] && !(defState && defState.kind === _parser.RuleKinds.FRAGMENT_DEFINITION && defState.name === frag.name.value) && (0, _graphql.isCompositeType)(typeInfo.parentType) && (0, _graphql.isCompositeType)(typeMap[frag.typeCondition.name.value]) && (0, _graphql.doTypesOverlap)(schema, typeInfo.parentType, typeMap[frag.typeCondition.name.value]));\n                     return (0, _autocompleteUtils.hintList)(token, relevantFrags.map(frag => ({\n                         label: frag.name.value,\n                         detail: String(typeMap[frag.typeCondition.name.value]),\n                         documentation: `fragment ${frag.name.value} on ${frag.typeCondition.name.value}`,\n+                        labelDetails: {\n+                            detail: `fragment ${frag.name.value} on ${frag.typeCondition.name.value}`\n+                        },\n                         kind: _types.CompletionItemKind.Field,\n                         type: typeMap[frag.typeCondition.name.value]\n                     })));\n                 }\n                 const getParentDefinition = (state, kind) => {\n                     var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;\n                     if (((_a = state.prevState) === null || _a === void 0 ? void 0 : _a.kind) === kind) {\n@@ -79505,42 +90807,45 @@\n                     }\n                 };\n \n                 function getVariableCompletions(queryText, schema, token) {\n                     let variableName = null;\n                     let variableType;\n                     const definitions = Object.create({});\n-                    runOnlineParser(queryText, (_, state) => {\n+                    (0, _parser.runOnlineParser)(queryText, (_, state) => {\n+                        var _a;\n                         if ((state === null || state === void 0 ? void 0 : state.kind) === _parser.RuleKinds.VARIABLE && state.name) {\n                             variableName = state.name;\n                         }\n                         if ((state === null || state === void 0 ? void 0 : state.kind) === _parser.RuleKinds.NAMED_TYPE && variableName) {\n                             const parentDefinition = getParentDefinition(state, _parser.RuleKinds.TYPE);\n                             if (parentDefinition === null || parentDefinition === void 0 ? void 0 : parentDefinition.type) {\n                                 variableType = schema.getType(parentDefinition === null || parentDefinition === void 0 ? void 0 : parentDefinition.type);\n                             }\n                         }\n                         if (variableName && variableType && !definitions[variableName]) {\n+                            const replaceString = token.string === '$' || ((_a = token === null || token === void 0 ? void 0 : token.state) === null || _a === void 0 ? void 0 : _a.kind) === 'Variable' ? variableName : '$' + variableName;\n                             definitions[variableName] = {\n                                 detail: variableType.toString(),\n-                                insertText: token.string === '$' ? variableName : '$' + variableName,\n-                                label: variableName,\n+                                insertText: replaceString,\n+                                label: '$' + variableName,\n+                                rawInsert: replaceString,\n                                 type: variableType,\n                                 kind: _types.CompletionItemKind.Variable\n                             };\n                             variableName = null;\n                             variableType = null;\n                         }\n                     });\n                     return (0, _autocompleteUtils.objectValues)(definitions);\n                 }\n \n                 function getFragmentDefinitions(queryText) {\n                     const fragmentDefs = [];\n-                    runOnlineParser(queryText, (_, state) => {\n+                    (0, _parser.runOnlineParser)(queryText, (_, state) => {\n                         if (state.kind === _parser.RuleKinds.FRAGMENT_DEFINITION && state.name && state.type) {\n                             fragmentDefs.push({\n                                 kind: _parser.RuleKinds.FRAGMENT_DEFINITION,\n                                 name: {\n                                     kind: _graphql.Kind.NAME,\n                                     value: state.name\n                                 },\n@@ -79562,82 +90867,39 @@\n                 }\n \n                 function getSuggestionsForVariableDefinition(token, schema, _kind) {\n                     const inputTypeMap = schema.getTypeMap();\n                     const inputTypes = (0, _autocompleteUtils.objectValues)(inputTypeMap).filter(_graphql.isInputType);\n                     return (0, _autocompleteUtils.hintList)(token, inputTypes.map(type => ({\n                         label: type.name,\n-                        documentation: type.description,\n+                        documentation: (type === null || type === void 0 ? void 0 : type.description) || '',\n                         kind: _types.CompletionItemKind.Variable\n                     })));\n                 }\n \n                 function getSuggestionsForDirective(token, state, schema, _kind) {\n                     var _a;\n                     if ((_a = state.prevState) === null || _a === void 0 ? void 0 : _a.kind) {\n                         const directives = schema.getDirectives().filter(directive => canUseDirective(state.prevState, directive));\n                         return (0, _autocompleteUtils.hintList)(token, directives.map(directive => ({\n                             label: directive.name,\n-                            documentation: directive.description || '',\n+                            documentation: (directive === null || directive === void 0 ? void 0 : directive.description) || '',\n                             kind: _types.CompletionItemKind.Function\n                         })));\n                     }\n                     return [];\n                 }\n \n-                function getTokenAtPosition(queryText, cursor) {\n-                    let offset = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0;\n-                    let styleAtCursor = null;\n-                    let stateAtCursor = null;\n-                    let stringAtCursor = null;\n-                    const token = runOnlineParser(queryText, (stream, state, style, index) => {\n-                        if (index !== cursor.line || stream.getCurrentPosition() + offset < cursor.character + 1) {\n-                            return;\n-                        }\n-                        styleAtCursor = style;\n-                        stateAtCursor = Object.assign({}, state);\n-                        stringAtCursor = stream.current();\n-                        return 'BREAK';\n-                    });\n-                    return {\n-                        start: token.start,\n-                        end: token.end,\n-                        string: stringAtCursor || token.string,\n-                        state: stateAtCursor || token.state,\n-                        style: styleAtCursor || token.style\n-                    };\n-                }\n-\n-                function runOnlineParser(queryText, callback) {\n-                    const lines = queryText.split('\\n');\n-                    const parser = (0, _parser.onlineParser)();\n-                    let state = parser.startState();\n-                    let style = '';\n-                    let stream = new _parser.CharacterStream('');\n-                    for (let i = 0; i < lines.length; i++) {\n-                        stream = new _parser.CharacterStream(lines[i]);\n-                        while (!stream.eol()) {\n-                            style = parser.token(stream, state);\n-                            const code = callback(stream, state, style, i);\n-                            if (code === 'BREAK') {\n-                                break;\n-                            }\n-                        }\n-                        callback(stream, state, style, i);\n-                        if (!state.kind) {\n-                            state = parser.startState();\n-                        }\n-                    }\n-                    return {\n-                        start: stream.getStartOfToken(),\n-                        end: stream.getCurrentPosition(),\n-                        string: stream.current(),\n-                        state,\n-                        style\n-                    };\n+                function getSuggestionsForDirectiveArguments(token, state, schema, _kind) {\n+                    const directive = schema.getDirectives().find(d => d.name === state.name);\n+                    return (0, _autocompleteUtils.hintList)(token, (directive === null || directive === void 0 ? void 0 : directive.args.map(arg => ({\n+                        label: arg.name,\n+                        documentation: arg.description || '',\n+                        kind: _types.CompletionItemKind.Field\n+                    }))) || []);\n                 }\n \n                 function canUseDirective(state, directive) {\n                     if (!(state === null || state === void 0 ? void 0 : state.kind)) {\n                         return false;\n                     }\n                     const {\n@@ -79689,175 +90951,14 @@\n                                 case _parser.RuleKinds.INPUT_DEF:\n                                     return locations.includes(_graphql.DirectiveLocation.INPUT_FIELD_DEFINITION);\n                             }\n                     }\n                     return false;\n                 }\n \n-                function getTypeInfo(schema, tokenState) {\n-                    let argDef;\n-                    let argDefs;\n-                    let directiveDef;\n-                    let enumValue;\n-                    let fieldDef;\n-                    let inputType;\n-                    let objectTypeDef;\n-                    let objectFieldDefs;\n-                    let parentType;\n-                    let type;\n-                    let interfaceDef;\n-                    (0, _autocompleteUtils.forEachState)(tokenState, state => {\n-                        var _a;\n-                        switch (state.kind) {\n-                            case _parser.RuleKinds.QUERY:\n-                            case 'ShortQuery':\n-                                type = schema.getQueryType();\n-                                break;\n-                            case _parser.RuleKinds.MUTATION:\n-                                type = schema.getMutationType();\n-                                break;\n-                            case _parser.RuleKinds.SUBSCRIPTION:\n-                                type = schema.getSubscriptionType();\n-                                break;\n-                            case _parser.RuleKinds.INLINE_FRAGMENT:\n-                            case _parser.RuleKinds.FRAGMENT_DEFINITION:\n-                                if (state.type) {\n-                                    type = schema.getType(state.type);\n-                                }\n-                                break;\n-                            case _parser.RuleKinds.FIELD:\n-                            case _parser.RuleKinds.ALIASED_FIELD: {\n-                                if (!type || !state.name) {\n-                                    fieldDef = null;\n-                                } else {\n-                                    fieldDef = parentType ? (0, _autocompleteUtils.getFieldDef)(schema, parentType, state.name) : null;\n-                                    type = fieldDef ? fieldDef.type : null;\n-                                }\n-                                break;\n-                            }\n-                            case _parser.RuleKinds.SELECTION_SET:\n-                                parentType = (0, _graphql.getNamedType)(type);\n-                                break;\n-                            case _parser.RuleKinds.DIRECTIVE:\n-                                directiveDef = state.name ? schema.getDirective(state.name) : null;\n-                                break;\n-                            case _parser.RuleKinds.INTERFACE_DEF:\n-                                if (state.name) {\n-                                    objectTypeDef = null;\n-                                    interfaceDef = new _graphql.GraphQLInterfaceType({\n-                                        name: state.name,\n-                                        interfaces: [],\n-                                        fields: {}\n-                                    });\n-                                }\n-                                break;\n-                            case _parser.RuleKinds.OBJECT_TYPE_DEF:\n-                                if (state.name) {\n-                                    interfaceDef = null;\n-                                    objectTypeDef = new _graphql.GraphQLObjectType({\n-                                        name: state.name,\n-                                        interfaces: [],\n-                                        fields: {}\n-                                    });\n-                                }\n-                                break;\n-                            case _parser.RuleKinds.ARGUMENTS: {\n-                                if (state.prevState) {\n-                                    switch (state.prevState.kind) {\n-                                        case _parser.RuleKinds.FIELD:\n-                                            argDefs = fieldDef && fieldDef.args;\n-                                            break;\n-                                        case _parser.RuleKinds.DIRECTIVE:\n-                                            argDefs = directiveDef && directiveDef.args;\n-                                            break;\n-                                        case _parser.RuleKinds.ALIASED_FIELD: {\n-                                            const name = (_a = state.prevState) === null || _a === void 0 ? void 0 : _a.name;\n-                                            if (!name) {\n-                                                argDefs = null;\n-                                                break;\n-                                            }\n-                                            const field = parentType ? (0, _autocompleteUtils.getFieldDef)(schema, parentType, name) : null;\n-                                            if (!field) {\n-                                                argDefs = null;\n-                                                break;\n-                                            }\n-                                            argDefs = field.args;\n-                                            break;\n-                                        }\n-                                        default:\n-                                            argDefs = null;\n-                                            break;\n-                                    }\n-                                } else {\n-                                    argDefs = null;\n-                                }\n-                                break;\n-                            }\n-                            case _parser.RuleKinds.ARGUMENT:\n-                                if (argDefs) {\n-                                    for (let i = 0; i < argDefs.length; i++) {\n-                                        if (argDefs[i].name === state.name) {\n-                                            argDef = argDefs[i];\n-                                            break;\n-                                        }\n-                                    }\n-                                }\n-                                inputType = argDef === null || argDef === void 0 ? void 0 : argDef.type;\n-                                break;\n-                            case _parser.RuleKinds.ENUM_VALUE:\n-                                const enumType = (0, _graphql.getNamedType)(inputType);\n-                                enumValue = enumType instanceof _graphql.GraphQLEnumType ? enumType.getValues().find(val => val.value === state.name) : null;\n-                                break;\n-                            case _parser.RuleKinds.LIST_VALUE:\n-                                const nullableType = (0, _graphql.getNullableType)(inputType);\n-                                inputType = nullableType instanceof _graphql.GraphQLList ? nullableType.ofType : null;\n-                                break;\n-                            case _parser.RuleKinds.OBJECT_VALUE:\n-                                const objectType = (0, _graphql.getNamedType)(inputType);\n-                                objectFieldDefs = objectType instanceof _graphql.GraphQLInputObjectType ? objectType.getFields() : null;\n-                                break;\n-                            case _parser.RuleKinds.OBJECT_FIELD:\n-                                const objectField = state.name && objectFieldDefs ? objectFieldDefs[state.name] : null;\n-                                inputType = objectField === null || objectField === void 0 ? void 0 : objectField.type;\n-                                break;\n-                            case _parser.RuleKinds.NAMED_TYPE:\n-                                if (state.name) {\n-                                    type = schema.getType(state.name);\n-                                }\n-                                break;\n-                        }\n-                    });\n-                    return {\n-                        argDef,\n-                        argDefs,\n-                        directiveDef,\n-                        enumValue,\n-                        fieldDef,\n-                        inputType,\n-                        objectFieldDefs,\n-                        parentType,\n-                        type,\n-                        interfaceDef,\n-                        objectTypeDef\n-                    };\n-                }\n-                var GraphQLDocumentMode;\n-                exports.GraphQLDocumentMode = GraphQLDocumentMode;\n-                (function(GraphQLDocumentMode) {\n-                    GraphQLDocumentMode[\"TYPE_SYSTEM\"] = \"TYPE_SYSTEM\";\n-                    GraphQLDocumentMode[\"EXECUTABLE\"] = \"EXECUTABLE\";\n-                })(GraphQLDocumentMode || (exports.GraphQLDocumentMode = GraphQLDocumentMode = {}));\n-\n-                function getDocumentMode(documentText, uri) {\n-                    if (uri === null || uri === void 0 ? void 0 : uri.endsWith('.graphqls')) {\n-                        return GraphQLDocumentMode.TYPE_SYSTEM;\n-                    }\n-                    return hasTypeSystemDefinitions(documentText) ? GraphQLDocumentMode.TYPE_SYSTEM : GraphQLDocumentMode.EXECUTABLE;\n-                }\n-\n                 function unwrapType(state) {\n                     if (state.prevState && state.kind && [_parser.RuleKinds.NAMED_TYPE, _parser.RuleKinds.LIST_TYPE, _parser.RuleKinds.TYPE, _parser.RuleKinds.NON_NULL_TYPE].includes(state.kind)) {\n                         return unwrapType(state.prevState);\n                     }\n                     return state;\n                 }\n \n@@ -79868,20 +90969,22 @@\n         \"../../graphql-language-service/esm/interface/getDefinition.js\":\n             /*!*********************************************************************!*\\\n               !*** ../../graphql-language-service/esm/interface/getDefinition.js ***!\n               \\*********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.LANGUAGE = void 0;\n+                exports.getDefinitionQueryResultForArgument = getDefinitionQueryResultForArgument;\n                 exports.getDefinitionQueryResultForDefinitionNode = getDefinitionQueryResultForDefinitionNode;\n                 exports.getDefinitionQueryResultForField = getDefinitionQueryResultForField;\n                 exports.getDefinitionQueryResultForFragmentSpread = getDefinitionQueryResultForFragmentSpread;\n                 exports.getDefinitionQueryResultForNamedType = getDefinitionQueryResultForNamedType;\n                 var _utils = __webpack_require__( /*! ../utils */ \"../../graphql-language-service/esm/utils/index.js\");\n                 var __awaiter = void 0 && (void 0).__awaiter || function(thisArg, _arguments, P, generator) {\n                     function adopt(value) {\n@@ -79908,16 +91011,15 @@\n \n                         function step(result) {\n                             result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n                         }\n                         step((generator = generator.apply(thisArg, _arguments || [])).next());\n                     });\n                 };\n-                const LANGUAGE = 'GraphQL';\n-                exports.LANGUAGE = LANGUAGE;\n+                const LANGUAGE = exports.LANGUAGE = 'GraphQL';\n \n                 function assert(value, message) {\n                     if (!value) {\n                         throw new Error(message);\n                     }\n                 }\n \n@@ -79932,47 +91034,39 @@\n                     assert(location, 'Expected ASTNode to have a location.');\n                     return (0, _utils.offsetToPosition)(text, location.start);\n                 }\n \n                 function getDefinitionQueryResultForNamedType(text, node, dependencies) {\n                     return __awaiter(this, void 0, void 0, function*() {\n                         const name = node.name.value;\n-                        const defNodes = dependencies.filter(_ref => {\n-                            let {\n-                                definition\n-                            } = _ref;\n-                            return definition.name && definition.name.value === name;\n-                        });\n+                        const defNodes = dependencies.filter(({\n+                            definition\n+                        }) => definition.name && definition.name.value === name);\n                         if (defNodes.length === 0) {\n                             throw new Error(`Definition not found for GraphQL type ${name}`);\n                         }\n-                        const definitions = defNodes.map(_ref2 => {\n-                            let {\n-                                filePath,\n-                                content,\n-                                definition\n-                            } = _ref2;\n-                            return getDefinitionForNodeDefinition(filePath || '', content, definition);\n-                        });\n+                        const definitions = defNodes.map(({\n+                            filePath,\n+                            content,\n+                            definition\n+                        }) => getDefinitionForNodeDefinition(filePath || '', content, definition));\n                         return {\n                             definitions,\n-                            queryRange: definitions.map(_ => getRange(text, node))\n+                            queryRange: definitions.map(_ => getRange(text, node)),\n+                            printedName: name\n                         };\n                     });\n                 }\n \n                 function getDefinitionQueryResultForField(fieldName, typeName, dependencies) {\n                     var _a;\n                     return __awaiter(this, void 0, void 0, function*() {\n-                        const defNodes = dependencies.filter(_ref3 => {\n-                            let {\n-                                definition\n-                            } = _ref3;\n-                            return definition.name && definition.name.value === typeName;\n-                        });\n+                        const defNodes = dependencies.filter(({\n+                            definition\n+                        }) => definition.name && definition.name.value === typeName);\n                         if (defNodes.length === 0) {\n                             throw new Error(`Definition not found for GraphQL type ${typeName}`);\n                         }\n                         const definitions = [];\n                         for (const {\n                                 filePath,\n                                 content,\n@@ -79983,50 +91077,72 @@\n                             if (fieldDefinition == null) {\n                                 continue;\n                             }\n                             definitions.push(getDefinitionForFieldDefinition(filePath || '', content, fieldDefinition));\n                         }\n                         return {\n                             definitions,\n-                            queryRange: []\n+                            queryRange: [],\n+                            printedName: [typeName, fieldName].join('.')\n+                        };\n+                    });\n+                }\n+\n+                function getDefinitionQueryResultForArgument(argumentName, fieldName, typeName, dependencies) {\n+                    var _a, _b, _c;\n+                    return __awaiter(this, void 0, void 0, function*() {\n+                        const definitions = [];\n+                        for (const {\n+                                filePath,\n+                                content,\n+                                definition\n+                            }\n+                            of dependencies) {\n+                            const argDefinition = (_c = (_b = (_a = definition.fields) === null || _a === void 0 ? void 0 : _a.find(item => item.name.value === fieldName)) === null || _b === void 0 ? void 0 : _b.arguments) === null || _c === void 0 ? void 0 : _c.find(item => item.name.value === argumentName);\n+                            if (argDefinition == null) {\n+                                continue;\n+                            }\n+                            definitions.push(getDefinitionForArgumentDefinition(filePath || '', content, argDefinition));\n+                        }\n+                        return {\n+                            definitions,\n+                            queryRange: [],\n+                            printedName: `${[typeName, fieldName].join('.')}(${argumentName})`\n                         };\n                     });\n                 }\n \n                 function getDefinitionQueryResultForFragmentSpread(text, fragment, dependencies) {\n                     return __awaiter(this, void 0, void 0, function*() {\n                         const name = fragment.name.value;\n-                        const defNodes = dependencies.filter(_ref4 => {\n-                            let {\n-                                definition\n-                            } = _ref4;\n-                            return definition.name.value === name;\n-                        });\n+                        const defNodes = dependencies.filter(({\n+                            definition\n+                        }) => definition.name.value === name);\n                         if (defNodes.length === 0) {\n                             throw new Error(`Definition not found for GraphQL fragment ${name}`);\n                         }\n-                        const definitions = defNodes.map(_ref5 => {\n-                            let {\n-                                filePath,\n-                                content,\n-                                definition\n-                            } = _ref5;\n-                            return getDefinitionForFragmentDefinition(filePath || '', content, definition);\n-                        });\n+                        const definitions = defNodes.map(({\n+                            filePath,\n+                            content,\n+                            definition\n+                        }) => getDefinitionForFragmentDefinition(filePath || '', content, definition));\n                         return {\n                             definitions,\n-                            queryRange: definitions.map(_ => getRange(text, fragment))\n+                            queryRange: definitions.map(_ => getRange(text, fragment)),\n+                            printedName: name\n                         };\n                     });\n                 }\n \n                 function getDefinitionQueryResultForDefinitionNode(path, text, definition) {\n+                    var _a;\n                     return {\n                         definitions: [getDefinitionForFragmentDefinition(path, text, definition)],\n-                        queryRange: definition.name ? [getRange(text, definition.name)] : []\n+                        queryRange: definition.name ? [getRange(text, definition.name)] : [],\n+                        printedName: (_a = definition.name) === null || _a === void 0 ? void 0 : _a.value\n                     };\n                 }\n \n                 function getDefinitionForFragmentDefinition(path, text, definition) {\n                     const {\n                         name\n                     } = definition;\n@@ -80069,62 +91185,72 @@\n                         range: getRange(text, definition),\n                         name: name.value || '',\n                         language: LANGUAGE,\n                         projectRoot: path\n                     };\n                 }\n \n+                function getDefinitionForArgumentDefinition(path, text, definition) {\n+                    const {\n+                        name\n+                    } = definition;\n+                    assert(name, 'Expected ASTNode to have a Name.');\n+                    return {\n+                        path,\n+                        position: getPosition(text, definition),\n+                        range: getRange(text, definition),\n+                        name: name.value || '',\n+                        language: LANGUAGE,\n+                        projectRoot: path\n+                    };\n+                }\n+\n                 /***/\n             }),\n \n         /***/\n         \"../../graphql-language-service/esm/interface/getDiagnostics.js\":\n             /*!**********************************************************************!*\\\n               !*** ../../graphql-language-service/esm/interface/getDiagnostics.js ***!\n               \\**********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.SEVERITY = exports.DIAGNOSTIC_SEVERITY = void 0;\n                 exports.getDiagnostics = getDiagnostics;\n                 exports.getRange = getRange;\n                 exports.validateQuery = validateQuery;\n                 var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n                 var _parser = __webpack_require__( /*! ../parser */ \"../../graphql-language-service/esm/parser/index.js\");\n                 var _utils = __webpack_require__( /*! ../utils */ \"../../graphql-language-service/esm/utils/index.js\");\n-                const SEVERITY = {\n+                const SEVERITY = exports.SEVERITY = {\n                     Error: 'Error',\n                     Warning: 'Warning',\n                     Information: 'Information',\n                     Hint: 'Hint'\n                 };\n-                exports.SEVERITY = SEVERITY;\n-                const DIAGNOSTIC_SEVERITY = {\n+                const DIAGNOSTIC_SEVERITY = exports.DIAGNOSTIC_SEVERITY = {\n                     [SEVERITY.Error]: 1,\n                     [SEVERITY.Warning]: 2,\n                     [SEVERITY.Information]: 3,\n                     [SEVERITY.Hint]: 4\n                 };\n-                exports.DIAGNOSTIC_SEVERITY = DIAGNOSTIC_SEVERITY;\n                 const invariant = (condition, message) => {\n                     if (!condition) {\n                         throw new Error(message);\n                     }\n                 };\n \n-                function getDiagnostics(query) {\n-                    let schema = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;\n-                    let customRules = arguments.length > 2 ? arguments[2] : undefined;\n-                    let isRelayCompatMode = arguments.length > 3 ? arguments[3] : undefined;\n-                    let externalFragments = arguments.length > 4 ? arguments[4] : undefined;\n+                function getDiagnostics(query, schema = null, customRules, isRelayCompatMode, externalFragments) {\n                     var _a, _b;\n                     let ast = null;\n                     let fragments = '';\n                     if (externalFragments) {\n                         fragments = typeof externalFragments === 'string' ? externalFragments : externalFragments.reduce((acc, node) => acc + (0, _graphql.print)(node) + '\\n\\n', '');\n                     }\n                     const enhancedQuery = fragments ? `${query}\\n\\n${fragments}` : query;\n@@ -80144,18 +91270,15 @@\n                             }];\n                         }\n                         throw error;\n                     }\n                     return validateQuery(ast, schema, customRules, isRelayCompatMode);\n                 }\n \n-                function validateQuery(ast) {\n-                    let schema = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;\n-                    let customRules = arguments.length > 2 ? arguments[2] : undefined;\n-                    let isRelayCompatMode = arguments.length > 3 ? arguments[3] : undefined;\n+                function validateQuery(ast, schema = null, customRules, isRelayCompatMode) {\n                     if (!schema) {\n                         return [];\n                     }\n                     const validationErrorAnnotations = (0, _utils.validateWithCustomRules)(schema, ast, customRules, isRelayCompatMode).flatMap(error => annotations(error, DIAGNOSTIC_SEVERITY.Error, 'Validation'));\n                     const deprecationWarningAnnotations = (0, _graphql.validate)(schema, ast, [_graphql.NoDeprecatedCustomRule]).flatMap(error => annotations(error, DIAGNOSTIC_SEVERITY.Warning, 'Deprecation'));\n                     return validationErrorAnnotations.concat(deprecationWarningAnnotations);\n                 }\n@@ -80219,37 +91342,46 @@\n         \"../../graphql-language-service/esm/interface/getHoverInformation.js\":\n             /*!***************************************************************************!*\\\n               !*** ../../graphql-language-service/esm/interface/getHoverInformation.js ***!\n               \\***************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.getHoverInformation = getHoverInformation;\n+                exports.renderArg = renderArg;\n+                exports.renderDirective = renderDirective;\n+                exports.renderEnumValue = renderEnumValue;\n+                exports.renderField = renderField;\n+                exports.renderType = renderType;\n                 var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n-                var _getAutocompleteSuggestions = __webpack_require__( /*! ./getAutocompleteSuggestions */ \"../../graphql-language-service/esm/interface/getAutocompleteSuggestions.js\");\n+                var _parser = __webpack_require__( /*! ../parser */ \"../../graphql-language-service/esm/parser/index.js\");\n \n                 function getHoverInformation(schema, queryText, cursor, contextToken, config) {\n-                    const token = contextToken || (0, _getAutocompleteSuggestions.getTokenAtPosition)(queryText, cursor);\n-                    if (!schema || !token || !token.state) {\n+                    const options = Object.assign(Object.assign({}, config), {\n+                        schema\n+                    });\n+                    const context = (0, _parser.getContextAtPosition)(queryText, cursor, schema, contextToken);\n+                    if (!context) {\n                         return '';\n                     }\n                     const {\n+                        typeInfo,\n+                        token\n+                    } = context;\n+                    const {\n                         kind,\n                         step\n                     } = token.state;\n-                    const typeInfo = (0, _getAutocompleteSuggestions.getTypeInfo)(schema, token.state);\n-                    const options = Object.assign(Object.assign({}, config), {\n-                        schema\n-                    });\n-                    if (kind === 'Field' && step === 0 && typeInfo.fieldDef || kind === 'AliasedField' && step === 2 && typeInfo.fieldDef) {\n+                    if (kind === 'Field' && step === 0 && typeInfo.fieldDef || kind === 'AliasedField' && step === 2 && typeInfo.fieldDef || kind === 'ObjectField' && step === 0 && typeInfo.fieldDef) {\n                         const into = [];\n                         renderMdCodeStart(into, options);\n                         renderField(into, typeInfo, options);\n                         renderMdCodeEnd(into, options);\n                         renderDescription(into, options, typeInfo.fieldDef);\n                         return into.join('').trim();\n                     }\n@@ -80257,14 +91389,22 @@\n                         const into = [];\n                         renderMdCodeStart(into, options);\n                         renderDirective(into, typeInfo, options);\n                         renderMdCodeEnd(into, options);\n                         renderDescription(into, options, typeInfo.directiveDef);\n                         return into.join('').trim();\n                     }\n+                    if (kind === 'Variable' && typeInfo.type) {\n+                        const into = [];\n+                        renderMdCodeStart(into, options);\n+                        renderType(into, typeInfo, options, typeInfo.type);\n+                        renderMdCodeEnd(into, options);\n+                        renderDescription(into, options, typeInfo.type);\n+                        return into.join('').trim();\n+                    }\n                     if (kind === 'Argument' && step === 0 && typeInfo.argDef) {\n                         const into = [];\n                         renderMdCodeStart(into, options);\n                         renderArg(into, typeInfo, options);\n                         renderMdCodeEnd(into, options);\n                         renderDescription(into, options, typeInfo.argDef);\n                         return into.join('').trim();\n@@ -80412,14 +91552,15 @@\n         \"../../graphql-language-service/esm/interface/getOutline.js\":\n             /*!******************************************************************!*\\\n               !*** ../../graphql-language-service/esm/interface/getOutline.js ***!\n               \\******************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.getOutline = getOutline;\n                 var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n@@ -80554,14 +91695,15 @@\n         \"../../graphql-language-service/esm/interface/index.js\":\n             /*!*************************************************************!*\\\n               !*** ../../graphql-language-service/esm/interface/index.js ***!\n               \\*************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 var _exportNames = {\n                     getOutline: true,\n@@ -80637,23 +91779,23 @@\n         \"../../graphql-language-service/esm/parser/CharacterStream.js\":\n             /*!********************************************************************!*\\\n               !*** ../../graphql-language-service/esm/parser/CharacterStream.js ***!\n               \\********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports[\"default\"] = void 0;\n                 class CharacterStream {\n                     constructor(sourceText) {\n-                        var _this = this;\n                         this._start = 0;\n                         this._pos = 0;\n                         this.getStartOfToken = () => this._start;\n                         this.getCurrentPosition = () => this._pos;\n                         this.eol = () => this._sourceText.length === this._pos;\n                         this.sol = () => this._pos === 0;\n                         this.peek = () => {\n@@ -80690,32 +91832,30 @@\n                         this.eatSpace = () => this.eatWhile(/[\\s\\u00a0]/);\n                         this.skipToEnd = () => {\n                             this._pos = this._sourceText.length;\n                         };\n                         this.skipTo = position => {\n                             this._pos = position;\n                         };\n-                        this.match = function(pattern) {\n-                            let consume = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n-                            let caseFold = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;\n+                        this.match = (pattern, consume = true, caseFold = false) => {\n                             let token = null;\n                             let match = null;\n                             if (typeof pattern === 'string') {\n                                 const regex = new RegExp(pattern, caseFold ? 'i' : 'g');\n-                                match = regex.test(_this._sourceText.slice(_this._pos, _this._pos + pattern.length));\n+                                match = regex.test(this._sourceText.slice(this._pos, this._pos + pattern.length));\n                                 token = pattern;\n                             } else if (pattern instanceof RegExp) {\n-                                match = _this._sourceText.slice(_this._pos).match(pattern);\n+                                match = this._sourceText.slice(this._pos).match(pattern);\n                                 token = match === null || match === void 0 ? void 0 : match[0];\n                             }\n-                            if (match != null && (typeof pattern === 'string' || match instanceof Array && _this._sourceText.startsWith(match[0], _this._pos))) {\n+                            if (match != null && (typeof pattern === 'string' || match instanceof Array && this._sourceText.startsWith(match[0], this._pos))) {\n                                 if (consume) {\n-                                    _this._start = _this._pos;\n+                                    this._start = this._pos;\n                                     if (token && token.length) {\n-                                        _this._pos += token.length;\n+                                        this._pos += token.length;\n                                     }\n                                 }\n                                 return match;\n                             }\n                             return false;\n                         };\n                         this.backUp = num => {\n@@ -80762,14 +91902,15 @@\n         \"../../graphql-language-service/esm/parser/RuleHelpers.js\":\n             /*!****************************************************************!*\\\n               !*** ../../graphql-language-service/esm/parser/RuleHelpers.js ***!\n               \\****************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.butNot = butNot;\n                 exports.list = list;\n@@ -80824,33 +91965,33 @@\n         \"../../graphql-language-service/esm/parser/Rules.js\":\n             /*!**********************************************************!*\\\n               !*** ../../graphql-language-service/esm/parser/Rules.js ***!\n               \\**********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.isIgnored = exports.ParseRules = exports.LexRules = void 0;\n                 var _RuleHelpers = __webpack_require__( /*! ./RuleHelpers */ \"../../graphql-language-service/esm/parser/RuleHelpers.js\");\n                 var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n                 const isIgnored = ch => ch === ' ' || ch === '\\t' || ch === ',' || ch === '\\n' || ch === '\\r' || ch === '\\uFEFF' || ch === '\\u00A0';\n                 exports.isIgnored = isIgnored;\n-                const LexRules = {\n+                const LexRules = exports.LexRules = {\n                     Name: /^[_A-Za-z][_0-9A-Za-z]*/,\n                     Punctuation: /^(?:!|\\$|\\(|\\)|\\.\\.\\.|:|=|&|@|\\[|]|\\{|\\||\\})/,\n                     Number: /^-?(?:0|(?:[1-9][0-9]*))(?:\\.[0-9]*)?(?:[eE][+-]?[0-9]+)?/,\n                     String: /^(?:\"\"\"(?:\\\\\"\"\"|[^\"]|\"[^\"]|\"\"[^\"])*(?:\"\"\")?|\"(?:[^\"\\\\]|\\\\(?:\"|\\/|\\\\|b|f|n|r|t|u[0-9a-fA-F]{4}))*\"?)/,\n                     Comment: /^#.*/\n                 };\n-                exports.LexRules = LexRules;\n-                const ParseRules = {\n+                const ParseRules = exports.ParseRules = {\n                     Document: [(0, _RuleHelpers.list)('Definition')],\n                     Definition(token) {\n                         switch (token.value) {\n                             case '{':\n                                 return 'ShortQuery';\n                             case 'query':\n                                 return 'Query';\n@@ -80992,15 +92133,14 @@\n                     [_graphql.Kind.SCALAR_TYPE_EXTENSION]: ['ScalarDef'],\n                     [_graphql.Kind.OBJECT_TYPE_EXTENSION]: ['ObjectTypeDef'],\n                     [_graphql.Kind.INTERFACE_TYPE_EXTENSION]: ['InterfaceDef'],\n                     [_graphql.Kind.UNION_TYPE_EXTENSION]: ['UnionDef'],\n                     [_graphql.Kind.ENUM_TYPE_EXTENSION]: ['EnumDef'],\n                     [_graphql.Kind.INPUT_OBJECT_TYPE_EXTENSION]: ['InputDef']\n                 };\n-                exports.ParseRules = ParseRules;\n \n                 function word(value) {\n                     return {\n                         style: 'keyword',\n                         match: token => token.kind === 'Name' && token.value === value\n                     };\n                 }\n@@ -81029,21 +92169,376 @@\n                     };\n                 }\n \n                 /***/\n             }),\n \n         /***/\n+        \"../../graphql-language-service/esm/parser/api.js\":\n+            /*!********************************************************!*\\\n+              !*** ../../graphql-language-service/esm/parser/api.js ***!\n+              \\********************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.TYPE_SYSTEM_KINDS = exports.GraphQLDocumentMode = void 0;\n+                exports.getContextAtPosition = getContextAtPosition;\n+                exports.getDocumentMode = getDocumentMode;\n+                exports.getTokenAtPosition = getTokenAtPosition;\n+                exports.runOnlineParser = runOnlineParser;\n+                var _ = __webpack_require__( /*! . */ \"../../graphql-language-service/esm/parser/index.js\");\n+                var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n+\n+                function runOnlineParser(queryText, callback) {\n+                    const lines = queryText.split('\\n');\n+                    const parser = (0, _.onlineParser)();\n+                    let state = parser.startState();\n+                    let style = '';\n+                    let stream = new _.CharacterStream('');\n+                    for (let i = 0; i < lines.length; i++) {\n+                        stream = new _.CharacterStream(lines[i]);\n+                        while (!stream.eol()) {\n+                            style = parser.token(stream, state);\n+                            const code = callback(stream, state, style, i);\n+                            if (code === 'BREAK') {\n+                                break;\n+                            }\n+                        }\n+                        callback(stream, state, style, i);\n+                        if (!state.kind) {\n+                            state = parser.startState();\n+                        }\n+                    }\n+                    return {\n+                        start: stream.getStartOfToken(),\n+                        end: stream.getCurrentPosition(),\n+                        string: stream.current(),\n+                        state,\n+                        style\n+                    };\n+                }\n+                var GraphQLDocumentMode;\n+                (function(GraphQLDocumentMode) {\n+                    GraphQLDocumentMode[\"TYPE_SYSTEM\"] = \"TYPE_SYSTEM\";\n+                    GraphQLDocumentMode[\"EXECUTABLE\"] = \"EXECUTABLE\";\n+                    GraphQLDocumentMode[\"UNKNOWN\"] = \"UNKNOWN\";\n+                })(GraphQLDocumentMode || (exports.GraphQLDocumentMode = GraphQLDocumentMode = {}));\n+                const TYPE_SYSTEM_KINDS = exports.TYPE_SYSTEM_KINDS = [_graphql.Kind.SCHEMA_DEFINITION, _graphql.Kind.OPERATION_TYPE_DEFINITION, _graphql.Kind.SCALAR_TYPE_DEFINITION, _graphql.Kind.OBJECT_TYPE_DEFINITION, _graphql.Kind.INTERFACE_TYPE_DEFINITION, _graphql.Kind.UNION_TYPE_DEFINITION, _graphql.Kind.ENUM_TYPE_DEFINITION, _graphql.Kind.INPUT_OBJECT_TYPE_DEFINITION, _graphql.Kind.DIRECTIVE_DEFINITION, _graphql.Kind.SCHEMA_EXTENSION, _graphql.Kind.SCALAR_TYPE_EXTENSION, _graphql.Kind.OBJECT_TYPE_EXTENSION, _graphql.Kind.INTERFACE_TYPE_EXTENSION, _graphql.Kind.UNION_TYPE_EXTENSION, _graphql.Kind.ENUM_TYPE_EXTENSION, _graphql.Kind.INPUT_OBJECT_TYPE_EXTENSION];\n+                const getParsedMode = sdl => {\n+                    let mode = GraphQLDocumentMode.UNKNOWN;\n+                    if (sdl) {\n+                        try {\n+                            (0, _graphql.visit)((0, _graphql.parse)(sdl), {\n+                                enter(node) {\n+                                    if (node.kind === 'Document') {\n+                                        mode = GraphQLDocumentMode.EXECUTABLE;\n+                                        return;\n+                                    }\n+                                    if (TYPE_SYSTEM_KINDS.includes(node.kind)) {\n+                                        mode = GraphQLDocumentMode.TYPE_SYSTEM;\n+                                        return _graphql.BREAK;\n+                                    }\n+                                    return false;\n+                                }\n+                            });\n+                        } catch (_a) {\n+                            return mode;\n+                        }\n+                    }\n+                    return mode;\n+                };\n+\n+                function getDocumentMode(documentText, uri) {\n+                    if (uri === null || uri === void 0 ? void 0 : uri.endsWith('.graphqls')) {\n+                        return GraphQLDocumentMode.TYPE_SYSTEM;\n+                    }\n+                    return getParsedMode(documentText);\n+                }\n+\n+                function getTokenAtPosition(queryText, cursor, offset = 0) {\n+                    let styleAtCursor = null;\n+                    let stateAtCursor = null;\n+                    let stringAtCursor = null;\n+                    const token = runOnlineParser(queryText, (stream, state, style, index) => {\n+                        if (index !== cursor.line || stream.getCurrentPosition() + offset < cursor.character + 1) {\n+                            return;\n+                        }\n+                        styleAtCursor = style;\n+                        stateAtCursor = Object.assign({}, state);\n+                        stringAtCursor = stream.current();\n+                        return 'BREAK';\n+                    });\n+                    return {\n+                        start: token.start,\n+                        end: token.end,\n+                        string: stringAtCursor || token.string,\n+                        state: stateAtCursor || token.state,\n+                        style: styleAtCursor || token.style\n+                    };\n+                }\n+\n+                function getContextAtPosition(queryText, cursor, schema, contextToken, options) {\n+                    const token = contextToken || getTokenAtPosition(queryText, cursor, 1);\n+                    if (!token) {\n+                        return null;\n+                    }\n+                    const state = token.state.kind === 'Invalid' ? token.state.prevState : token.state;\n+                    if (!state) {\n+                        return null;\n+                    }\n+                    const typeInfo = (0, _.getTypeInfo)(schema, token.state);\n+                    const mode = (options === null || options === void 0 ? void 0 : options.mode) || getDocumentMode(queryText, options === null || options === void 0 ? void 0 : options.uri);\n+                    return {\n+                        token,\n+                        state,\n+                        typeInfo,\n+                        mode\n+                    };\n+                }\n+\n+                /***/\n+            }),\n+\n+        /***/\n+        \"../../graphql-language-service/esm/parser/getTypeInfo.js\":\n+            /*!****************************************************************!*\\\n+              !*** ../../graphql-language-service/esm/parser/getTypeInfo.js ***!\n+              \\****************************************************************/\n+            /***/\n+            (function(__unused_webpack_module, exports, __webpack_require__) {\n+\n+                \"use strict\";\n+\n+\n+                Object.defineProperty(exports, \"__esModule\", ({\n+                    value: true\n+                }));\n+                exports.forEachState = forEachState;\n+                exports.getDefinitionState = getDefinitionState;\n+                exports.getFieldDef = getFieldDef;\n+                exports.getTypeInfo = getTypeInfo;\n+                var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n+                var _ = __webpack_require__( /*! . */ \"../../graphql-language-service/esm/parser/index.js\");\n+\n+                function getFieldDef(schema, type, fieldName) {\n+                    if (fieldName === _graphql.SchemaMetaFieldDef.name && schema.getQueryType() === type) {\n+                        return _graphql.SchemaMetaFieldDef;\n+                    }\n+                    if (fieldName === _graphql.TypeMetaFieldDef.name && schema.getQueryType() === type) {\n+                        return _graphql.TypeMetaFieldDef;\n+                    }\n+                    if (fieldName === _graphql.TypeNameMetaFieldDef.name && (0, _graphql.isCompositeType)(type)) {\n+                        return _graphql.TypeNameMetaFieldDef;\n+                    }\n+                    if ('getFields' in type) {\n+                        return type.getFields()[fieldName];\n+                    }\n+                    return null;\n+                }\n+\n+                function forEachState(stack, fn) {\n+                    const reverseStateStack = [];\n+                    let state = stack;\n+                    while (state === null || state === void 0 ? void 0 : state.kind) {\n+                        reverseStateStack.push(state);\n+                        state = state.prevState;\n+                    }\n+                    for (let i = reverseStateStack.length - 1; i >= 0; i--) {\n+                        fn(reverseStateStack[i]);\n+                    }\n+                }\n+\n+                function getDefinitionState(tokenState) {\n+                    let definitionState;\n+                    forEachState(tokenState, state => {\n+                        switch (state.kind) {\n+                            case 'Query':\n+                            case 'ShortQuery':\n+                            case 'Mutation':\n+                            case 'Subscription':\n+                            case 'FragmentDefinition':\n+                                definitionState = state;\n+                                break;\n+                        }\n+                    });\n+                    return definitionState;\n+                }\n+\n+                function getTypeInfo(schema, tokenState) {\n+                    let argDef;\n+                    let argDefs;\n+                    let directiveDef;\n+                    let enumValue;\n+                    let fieldDef;\n+                    let inputType;\n+                    let objectTypeDef;\n+                    let objectFieldDefs;\n+                    let parentType;\n+                    let type;\n+                    let interfaceDef;\n+                    forEachState(tokenState, state => {\n+                        var _a;\n+                        switch (state.kind) {\n+                            case _.RuleKinds.QUERY:\n+                            case 'ShortQuery':\n+                                type = schema.getQueryType();\n+                                break;\n+                            case _.RuleKinds.MUTATION:\n+                                type = schema.getMutationType();\n+                                break;\n+                            case _.RuleKinds.SUBSCRIPTION:\n+                                type = schema.getSubscriptionType();\n+                                break;\n+                            case _.RuleKinds.INLINE_FRAGMENT:\n+                            case _.RuleKinds.FRAGMENT_DEFINITION:\n+                                if (state.type) {\n+                                    type = schema.getType(state.type);\n+                                }\n+                                break;\n+                            case _.RuleKinds.FIELD:\n+                            case _.RuleKinds.ALIASED_FIELD: {\n+                                if (!type || !state.name) {\n+                                    fieldDef = null;\n+                                } else {\n+                                    fieldDef = parentType ? getFieldDef(schema, parentType, state.name) : null;\n+                                    type = fieldDef ? fieldDef.type : null;\n+                                }\n+                                break;\n+                            }\n+                            case _.RuleKinds.SELECTION_SET:\n+                                parentType = (0, _graphql.getNamedType)(type);\n+                                break;\n+                            case _.RuleKinds.DIRECTIVE:\n+                                directiveDef = state.name ? schema.getDirective(state.name) : null;\n+                                break;\n+                            case _.RuleKinds.INTERFACE_DEF:\n+                                if (state.name) {\n+                                    objectTypeDef = null;\n+                                    interfaceDef = new _graphql.GraphQLInterfaceType({\n+                                        name: state.name,\n+                                        interfaces: [],\n+                                        fields: {}\n+                                    });\n+                                }\n+                                break;\n+                            case _.RuleKinds.OBJECT_TYPE_DEF:\n+                                if (state.name) {\n+                                    interfaceDef = null;\n+                                    objectTypeDef = new _graphql.GraphQLObjectType({\n+                                        name: state.name,\n+                                        interfaces: [],\n+                                        fields: {}\n+                                    });\n+                                }\n+                                break;\n+                            case _.RuleKinds.ARGUMENTS: {\n+                                if (state.prevState) {\n+                                    switch (state.prevState.kind) {\n+                                        case _.RuleKinds.FIELD:\n+                                            argDefs = fieldDef && fieldDef.args;\n+                                            break;\n+                                        case _.RuleKinds.DIRECTIVE:\n+                                            argDefs = directiveDef && directiveDef.args;\n+                                            break;\n+                                        case _.RuleKinds.ALIASED_FIELD: {\n+                                            const name = (_a = state.prevState) === null || _a === void 0 ? void 0 : _a.name;\n+                                            if (!name) {\n+                                                argDefs = null;\n+                                                break;\n+                                            }\n+                                            const field = parentType ? getFieldDef(schema, parentType, name) : null;\n+                                            if (!field) {\n+                                                argDefs = null;\n+                                                break;\n+                                            }\n+                                            argDefs = field.args;\n+                                            break;\n+                                        }\n+                                        default:\n+                                            argDefs = null;\n+                                            break;\n+                                    }\n+                                } else {\n+                                    argDefs = null;\n+                                }\n+                                break;\n+                            }\n+                            case _.RuleKinds.ARGUMENT:\n+                                if (argDefs) {\n+                                    for (let i = 0; i < argDefs.length; i++) {\n+                                        if (argDefs[i].name === state.name) {\n+                                            argDef = argDefs[i];\n+                                            break;\n+                                        }\n+                                    }\n+                                }\n+                                inputType = argDef === null || argDef === void 0 ? void 0 : argDef.type;\n+                                break;\n+                            case _.RuleKinds.VARIABLE_DEFINITION:\n+                            case _.RuleKinds.VARIABLE:\n+                                type = inputType;\n+                                break;\n+                            case _.RuleKinds.ENUM_VALUE:\n+                                const enumType = (0, _graphql.getNamedType)(inputType);\n+                                enumValue = enumType instanceof _graphql.GraphQLEnumType ? enumType.getValues().find(val => val.value === state.name) : null;\n+                                break;\n+                            case _.RuleKinds.LIST_VALUE:\n+                                const nullableType = (0, _graphql.getNullableType)(inputType);\n+                                inputType = nullableType instanceof _graphql.GraphQLList ? nullableType.ofType : null;\n+                                break;\n+                            case _.RuleKinds.OBJECT_VALUE:\n+                                const objectType = (0, _graphql.getNamedType)(inputType);\n+                                objectFieldDefs = objectType instanceof _graphql.GraphQLInputObjectType ? objectType.getFields() : null;\n+                                break;\n+                            case _.RuleKinds.OBJECT_FIELD:\n+                                const objectField = state.name && objectFieldDefs ? objectFieldDefs[state.name] : null;\n+                                inputType = objectField === null || objectField === void 0 ? void 0 : objectField.type;\n+                                fieldDef = objectField;\n+                                type = fieldDef ? fieldDef.type : null;\n+                                break;\n+                            case _.RuleKinds.NAMED_TYPE:\n+                                if (state.name) {\n+                                    type = schema.getType(state.name);\n+                                }\n+                                break;\n+                        }\n+                    });\n+                    return {\n+                        argDef,\n+                        argDefs,\n+                        directiveDef,\n+                        enumValue,\n+                        fieldDef,\n+                        inputType,\n+                        objectFieldDefs,\n+                        parentType,\n+                        type,\n+                        interfaceDef,\n+                        objectTypeDef\n+                    };\n+                }\n+\n+                /***/\n+            }),\n+\n+        /***/\n         \"../../graphql-language-service/esm/parser/index.js\":\n             /*!**********************************************************!*\\\n               !*** ../../graphql-language-service/esm/parser/index.js ***!\n               \\**********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 var _exportNames = {\n                     CharacterStream: true,\n@@ -81051,22 +92546,36 @@\n                     ParseRules: true,\n                     isIgnored: true,\n                     butNot: true,\n                     list: true,\n                     opt: true,\n                     p: true,\n                     t: true,\n-                    onlineParser: true\n+                    onlineParser: true,\n+                    runOnlineParser: true,\n+                    getTokenAtPosition: true,\n+                    getContextAtPosition: true,\n+                    GraphQLDocumentMode: true,\n+                    getDocumentMode: true,\n+                    getTypeInfo: true,\n+                    getDefinitionState: true,\n+                    getFieldDef: true\n                 };\n                 Object.defineProperty(exports, \"CharacterStream\", ({\n                     enumerable: true,\n                     get: function() {\n                         return _CharacterStream.default;\n                     }\n                 }));\n+                Object.defineProperty(exports, \"GraphQLDocumentMode\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _api.GraphQLDocumentMode;\n+                    }\n+                }));\n                 Object.defineProperty(exports, \"LexRules\", ({\n                     enumerable: true,\n                     get: function() {\n                         return _Rules.LexRules;\n                     }\n                 }));\n                 Object.defineProperty(exports, \"ParseRules\", ({\n@@ -81077,14 +92586,50 @@\n                 }));\n                 Object.defineProperty(exports, \"butNot\", ({\n                     enumerable: true,\n                     get: function() {\n                         return _RuleHelpers.butNot;\n                     }\n                 }));\n+                Object.defineProperty(exports, \"getContextAtPosition\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _api.getContextAtPosition;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"getDefinitionState\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _getTypeInfo.getDefinitionState;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"getDocumentMode\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _api.getDocumentMode;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"getFieldDef\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _getTypeInfo.getFieldDef;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"getTokenAtPosition\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _api.getTokenAtPosition;\n+                    }\n+                }));\n+                Object.defineProperty(exports, \"getTypeInfo\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _getTypeInfo.getTypeInfo;\n+                    }\n+                }));\n                 Object.defineProperty(exports, \"isIgnored\", ({\n                     enumerable: true,\n                     get: function() {\n                         return _Rules.isIgnored;\n                     }\n                 }));\n                 Object.defineProperty(exports, \"list\", ({\n@@ -81107,24 +92652,32 @@\n                 }));\n                 Object.defineProperty(exports, \"p\", ({\n                     enumerable: true,\n                     get: function() {\n                         return _RuleHelpers.p;\n                     }\n                 }));\n+                Object.defineProperty(exports, \"runOnlineParser\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _api.runOnlineParser;\n+                    }\n+                }));\n                 Object.defineProperty(exports, \"t\", ({\n                     enumerable: true,\n                     get: function() {\n                         return _RuleHelpers.t;\n                     }\n                 }));\n                 var _CharacterStream = _interopRequireDefault(__webpack_require__( /*! ./CharacterStream */ \"../../graphql-language-service/esm/parser/CharacterStream.js\"));\n                 var _Rules = __webpack_require__( /*! ./Rules */ \"../../graphql-language-service/esm/parser/Rules.js\");\n                 var _RuleHelpers = __webpack_require__( /*! ./RuleHelpers */ \"../../graphql-language-service/esm/parser/RuleHelpers.js\");\n                 var _onlineParser = _interopRequireDefault(__webpack_require__( /*! ./onlineParser */ \"../../graphql-language-service/esm/parser/onlineParser.js\"));\n+                var _api = __webpack_require__( /*! ./api */ \"../../graphql-language-service/esm/parser/api.js\");\n+                var _getTypeInfo = __webpack_require__( /*! ./getTypeInfo */ \"../../graphql-language-service/esm/parser/getTypeInfo.js\");\n                 var _types = __webpack_require__( /*! ./types */ \"../../graphql-language-service/esm/parser/types.js\");\n                 Object.keys(_types).forEach(function(key) {\n                     if (key === \"default\" || key === \"__esModule\") return;\n                     if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;\n                     if (key in exports && exports[key] === _types[key]) return;\n                     Object.defineProperty(exports, key, {\n                         enumerable: true,\n@@ -81147,30 +92700,30 @@\n         \"../../graphql-language-service/esm/parser/onlineParser.js\":\n             /*!*****************************************************************!*\\\n               !*** ../../graphql-language-service/esm/parser/onlineParser.js ***!\n               \\*****************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports[\"default\"] = onlineParser;\n                 var _Rules = __webpack_require__( /*! ./Rules */ \"../../graphql-language-service/esm/parser/Rules.js\");\n                 var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n \n-                function onlineParser() {\n-                    let options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {\n-                        eatWhitespace: stream => stream.eatWhile(_Rules.isIgnored),\n-                        lexRules: _Rules.LexRules,\n-                        parseRules: _Rules.ParseRules,\n-                        editorConfig: {}\n-                    };\n+                function onlineParser(options = {\n+                    eatWhitespace: stream => stream.eatWhile(_Rules.isIgnored),\n+                    lexRules: _Rules.LexRules,\n+                    parseRules: _Rules.ParseRules,\n+                    editorConfig: {}\n+                }) {\n                     return {\n                         startState() {\n                             const initialState = {\n                                 level: 0,\n                                 step: 0,\n                                 name: null,\n                                 kind: null,\n@@ -81381,22 +92934,23 @@\n         \"../../graphql-language-service/esm/parser/types.js\":\n             /*!**********************************************************!*\\\n               !*** ../../graphql-language-service/esm/parser/types.js ***!\n               \\**********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.RuleKinds = exports.AdditionalRuleKinds = void 0;\n                 var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n-                const AdditionalRuleKinds = {\n+                const AdditionalRuleKinds = exports.AdditionalRuleKinds = {\n                     ALIASED_FIELD: 'AliasedField',\n                     ARGUMENTS: 'Arguments',\n                     SHORT_QUERY: 'ShortQuery',\n                     QUERY: 'Query',\n                     MUTATION: 'Mutation',\n                     SUBSCRIPTION: 'Subscription',\n                     TYPE_CONDITION: 'TypeCondition',\n@@ -81416,52 +92970,57 @@\n                     INPUT_VALUE_DEF: 'InputValueDef',\n                     ARGUMENTS_DEF: 'ArgumentsDef',\n                     EXTEND_DEF: 'ExtendDef',\n                     EXTENSION_DEFINITION: 'ExtensionDefinition',\n                     DIRECTIVE_DEF: 'DirectiveDef',\n                     IMPLEMENTS: 'Implements',\n                     VARIABLE_DEFINITIONS: 'VariableDefinitions',\n-                    TYPE: 'Type'\n+                    TYPE: 'Type',\n+                    VARIABLE: 'Variable'\n                 };\n-                exports.AdditionalRuleKinds = AdditionalRuleKinds;\n-                const RuleKinds = Object.assign(Object.assign({}, _graphql.Kind), AdditionalRuleKinds);\n-                exports.RuleKinds = RuleKinds;\n+                const RuleKinds = exports.RuleKinds = Object.assign(Object.assign({}, _graphql.Kind), AdditionalRuleKinds);\n \n                 /***/\n             }),\n \n         /***/\n         \"../../graphql-language-service/esm/types.js\":\n             /*!***************************************************!*\\\n               !*** ../../graphql-language-service/esm/types.js ***!\n               \\***************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.FileChangeTypeKind = exports.CompletionItemKind = void 0;\n+                Object.defineProperty(exports, \"GraphQLDocumentMode\", ({\n+                    enumerable: true,\n+                    get: function() {\n+                        return _parser.GraphQLDocumentMode;\n+                    }\n+                }));\n                 Object.defineProperty(exports, \"InsertTextFormat\", ({\n                     enumerable: true,\n                     get: function() {\n                         return _vscodeLanguageserverTypes.InsertTextFormat;\n                     }\n                 }));\n                 var _vscodeLanguageserverTypes = __webpack_require__( /*! vscode-languageserver-types */ \"../../../node_modules/vscode-languageserver-types/lib/esm/main.js\");\n-                const FileChangeTypeKind = {\n+                var _parser = __webpack_require__( /*! ./parser */ \"../../graphql-language-service/esm/parser/index.js\");\n+                const FileChangeTypeKind = exports.FileChangeTypeKind = {\n                     Created: 1,\n                     Changed: 2,\n                     Deleted: 3\n                 };\n-                exports.FileChangeTypeKind = FileChangeTypeKind;\n                 var CompletionItemKind;\n-                exports.CompletionItemKind = CompletionItemKind;\n                 (function(CompletionItemKind) {\n                     CompletionItemKind.Text = 1;\n                     CompletionItemKind.Method = 2;\n                     CompletionItemKind.Function = 3;\n                     CompletionItemKind.Constructor = 4;\n                     CompletionItemKind.Field = 5;\n                     CompletionItemKind.Variable = 6;\n@@ -81493,14 +93052,15 @@\n         \"../../graphql-language-service/esm/utils/Range.js\":\n             /*!*********************************************************!*\\\n               !*** ../../graphql-language-service/esm/utils/Range.js ***!\n               \\*********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.Range = exports.Position = void 0;\n                 exports.locToRange = locToRange;\n@@ -81563,14 +93123,15 @@\n         \"../../graphql-language-service/esm/utils/collectVariables.js\":\n             /*!********************************************************************!*\\\n               !*** ../../graphql-language-service/esm/utils/collectVariables.js ***!\n               \\********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.collectVariables = collectVariables;\n                 var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n@@ -81608,14 +93169,15 @@\n         \"../../graphql-language-service/esm/utils/fragmentDependencies.js\":\n             /*!************************************************************************!*\\\n               !*** ../../graphql-language-service/esm/utils/fragmentDependencies.js ***!\n               \\************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.getFragmentDependenciesForAST = exports.getFragmentDependencies = void 0;\n                 var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n@@ -81686,14 +93248,15 @@\n         \"../../graphql-language-service/esm/utils/getASTNodeAtPosition.js\":\n             /*!************************************************************************!*\\\n               !*** ../../graphql-language-service/esm/utils/getASTNodeAtPosition.js ***!\n               \\************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.getASTNodeAtPosition = getASTNodeAtPosition;\n                 exports.pointToOffset = pointToOffset;\n@@ -81731,14 +93294,15 @@\n         \"../../graphql-language-service/esm/utils/getOperationFacts.js\":\n             /*!*********************************************************************!*\\\n               !*** ../../graphql-language-service/esm/utils/getOperationFacts.js ***!\n               \\*********************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports[\"default\"] = getOperationFacts;\n                 exports.getOperationASTFacts = getOperationASTFacts;\n@@ -81769,40 +93333,39 @@\n                         return Object.assign(Object.assign({}, getOperationASTFacts(documentAST, schema)), {\n                             documentAST\n                         });\n                     } catch (_a) {\n                         return;\n                     }\n                 }\n-                const getQueryFacts = getOperationFacts;\n-                exports.getQueryFacts = getQueryFacts;\n+                const getQueryFacts = exports.getQueryFacts = getOperationFacts;\n \n                 /***/\n             }),\n \n         /***/\n         \"../../graphql-language-service/esm/utils/getVariablesJSONSchema.js\":\n             /*!**************************************************************************!*\\\n               !*** ../../graphql-language-service/esm/utils/getVariablesJSONSchema.js ***!\n               \\**************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.defaultJSONSchemaOptions = void 0;\n                 exports.getVariablesJSONSchema = getVariablesJSONSchema;\n                 var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n-                const defaultJSONSchemaOptions = {\n+                const defaultJSONSchemaOptions = exports.defaultJSONSchemaOptions = {\n                     useMarkdownDescription: false\n                 };\n-                exports.defaultJSONSchemaOptions = defaultJSONSchemaOptions;\n \n                 function text(into, newText) {\n                     into.push(newText);\n                 }\n \n                 function renderType(into, t) {\n                     if ((0, _graphql.isNonNullType)(t)) {\n@@ -82032,14 +93595,15 @@\n         \"../../graphql-language-service/esm/utils/index.js\":\n             /*!*********************************************************!*\\\n               !*** ../../graphql-language-service/esm/utils/index.js ***!\n               \\*********************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 Object.defineProperty(exports, \"Position\", ({\n                     enumerable: true,\n@@ -82129,74 +93693,61 @@\n                 var _getVariablesJSONSchema = __webpack_require__( /*! ./getVariablesJSONSchema */ \"../../graphql-language-service/esm/utils/getVariablesJSONSchema.js\");\n                 var _getASTNodeAtPosition = __webpack_require__( /*! ./getASTNodeAtPosition */ \"../../graphql-language-service/esm/utils/getASTNodeAtPosition.js\");\n                 var _Range = __webpack_require__( /*! ./Range */ \"../../graphql-language-service/esm/utils/Range.js\");\n                 var _validateWithCustomRules = __webpack_require__( /*! ./validateWithCustomRules */ \"../../graphql-language-service/esm/utils/validateWithCustomRules.js\");\n                 var _collectVariables = __webpack_require__( /*! ./collectVariables */ \"../../graphql-language-service/esm/utils/collectVariables.js\");\n                 var _getOperationFacts = _interopRequireWildcard(__webpack_require__( /*! ./getOperationFacts */ \"../../graphql-language-service/esm/utils/getOperationFacts.js\"));\n \n-                function _getRequireWildcardCache(nodeInterop) {\n-                    if (typeof WeakMap !== \"function\") return null;\n-                    var cacheBabelInterop = new WeakMap();\n-                    var cacheNodeInterop = new WeakMap();\n-                    return (_getRequireWildcardCache = function(nodeInterop) {\n-                        return nodeInterop ? cacheNodeInterop : cacheBabelInterop;\n-                    })(nodeInterop);\n-                }\n-\n-                function _interopRequireWildcard(obj, nodeInterop) {\n-                    if (!nodeInterop && obj && obj.__esModule) {\n-                        return obj;\n-                    }\n-                    if (obj === null || typeof obj !== \"object\" && typeof obj !== \"function\") {\n-                        return {\n-                            default: obj\n-                        };\n-                    }\n-                    var cache = _getRequireWildcardCache(nodeInterop);\n-                    if (cache && cache.has(obj)) {\n-                        return cache.get(obj);\n-                    }\n-                    var newObj = {};\n-                    var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;\n-                    for (var key in obj) {\n-                        if (key !== \"default\" && Object.prototype.hasOwnProperty.call(obj, key)) {\n-                            var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;\n-                            if (desc && (desc.get || desc.set)) {\n-                                Object.defineProperty(newObj, key, desc);\n-                            } else {\n-                                newObj[key] = obj[key];\n-                            }\n-                        }\n-                    }\n-                    newObj.default = obj;\n-                    if (cache) {\n-                        cache.set(obj, newObj);\n-                    }\n-                    return newObj;\n+                function _getRequireWildcardCache(e) {\n+                    if (\"function\" != typeof WeakMap) return null;\n+                    var r = new WeakMap(),\n+                        t = new WeakMap();\n+                    return (_getRequireWildcardCache = function(e) {\n+                        return e ? t : r;\n+                    })(e);\n+                }\n+\n+                function _interopRequireWildcard(e, r) {\n+                    if (!r && e && e.__esModule) return e;\n+                    if (null === e || \"object\" != typeof e && \"function\" != typeof e) return {\n+                        default: e\n+                    };\n+                    var t = _getRequireWildcardCache(r);\n+                    if (t && t.has(e)) return t.get(e);\n+                    var n = {\n+                            __proto__: null\n+                        },\n+                        a = Object.defineProperty && Object.getOwnPropertyDescriptor;\n+                    for (var u in e)\n+                        if (\"default\" !== u && Object.prototype.hasOwnProperty.call(e, u)) {\n+                            var i = a ? Object.getOwnPropertyDescriptor(e, u) : null;\n+                            i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u];\n+                        } return n.default = e, t && t.set(e, n), n;\n                 }\n \n                 /***/\n             }),\n \n         /***/\n         \"../../graphql-language-service/esm/utils/validateWithCustomRules.js\":\n             /*!***************************************************************************!*\\\n               !*** ../../graphql-language-service/esm/utils/validateWithCustomRules.js ***!\n               \\***************************************************************************/\n             /***/\n             (function(__unused_webpack_module, exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 Object.defineProperty(exports, \"__esModule\", ({\n                     value: true\n                 }));\n                 exports.validateWithCustomRules = validateWithCustomRules;\n                 var _graphql = __webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\");\n-                const specifiedSDLRules = [_graphql.LoneSchemaDefinitionRule, _graphql.UniqueOperationTypesRule, _graphql.UniqueTypeNamesRule, _graphql.UniqueEnumValueNamesRule, _graphql.UniqueFieldDefinitionNamesRule, _graphql.UniqueDirectiveNamesRule, _graphql.KnownTypeNamesRule, _graphql.KnownDirectivesRule, _graphql.UniqueDirectivesPerLocationRule, _graphql.PossibleTypeExtensionsRule, _graphql.UniqueArgumentNamesRule, _graphql.UniqueInputFieldNamesRule];\n+                const specifiedSDLRules = [_graphql.LoneSchemaDefinitionRule, _graphql.UniqueOperationTypesRule, _graphql.UniqueTypeNamesRule, _graphql.UniqueEnumValueNamesRule, _graphql.UniqueFieldDefinitionNamesRule, _graphql.UniqueDirectiveNamesRule, _graphql.KnownTypeNamesRule, _graphql.KnownDirectivesRule, _graphql.UniqueDirectivesPerLocationRule, _graphql.PossibleTypeExtensionsRule, _graphql.UniqueArgumentNamesRule, _graphql.UniqueInputFieldNamesRule, _graphql.UniqueVariableNamesRule, _graphql.FragmentsOnCompositeTypesRule, _graphql.ProvidedRequiredArgumentsRule];\n \n                 function validateWithCustomRules(schema, ast, customRules, isRelayCompatMode, isSchemaDocument) {\n                     const rules = _graphql.specifiedRules.filter(rule => {\n                         if (rule === _graphql.NoUnusedFragmentsRule || rule === _graphql.ExecutableDefinitionsRule) {\n                             return false;\n                         }\n                         if (isRelayCompatMode && rule === _graphql.KnownFragmentNamesRule) {\n@@ -82232,14 +93783,15 @@\n         \"./style.css\":\n             /*!*******************!*\\\n               !*** ./style.css ***!\n               \\*******************/\n             /***/\n             (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {\n \n+                \"use strict\";\n                 __webpack_require__.r(__webpack_exports__);\n                 // extracted by mini-css-extract-plugin\n \n \n                 /***/\n             }),\n \n@@ -82247,14 +93799,15 @@\n         \"../../graphiql-react/dist/style.css\":\n             /*!*******************************************!*\\\n               !*** ../../graphiql-react/dist/style.css ***!\n               \\*******************************************/\n             /***/\n             (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {\n \n+                \"use strict\";\n                 __webpack_require__.r(__webpack_exports__);\n                 // extracted by mini-css-extract-plugin\n \n \n                 /***/\n             }),\n \n@@ -82262,14 +93815,15 @@\n         \"../../graphiql-react/font/fira-code.css\":\n             /*!***********************************************!*\\\n               !*** ../../graphiql-react/font/fira-code.css ***!\n               \\***********************************************/\n             /***/\n             (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {\n \n+                \"use strict\";\n                 __webpack_require__.r(__webpack_exports__);\n                 // extracted by mini-css-extract-plugin\n \n \n                 /***/\n             }),\n \n@@ -82277,14 +93831,15 @@\n         \"../../graphiql-react/font/roboto.css\":\n             /*!********************************************!*\\\n               !*** ../../graphiql-react/font/roboto.css ***!\n               \\********************************************/\n             /***/\n             (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {\n \n+                \"use strict\";\n                 __webpack_require__.r(__webpack_exports__);\n                 // extracted by mini-css-extract-plugin\n \n \n                 /***/\n             }),\n \n@@ -82292,40 +93847,43 @@\n         \"react\":\n             /*!************************!*\\\n               !*** external \"React\" ***!\n               \\************************/\n             /***/\n             (function(module) {\n \n+                \"use strict\";\n                 module.exports = window[\"React\"];\n \n                 /***/\n             }),\n \n         /***/\n         \"react-dom\":\n             /*!***************************!*\\\n               !*** external \"ReactDOM\" ***!\n               \\***************************/\n             /***/\n             (function(module) {\n \n+                \"use strict\";\n                 module.exports = window[\"ReactDOM\"];\n \n                 /***/\n             }),\n \n         /***/\n         \"../../../node_modules/@headlessui/react/dist/headlessui.dev.cjs\":\n             /*!***********************************************************************!*\\\n               !*** ../../../node_modules/@headlessui/react/dist/headlessui.dev.cjs ***!\n               \\***********************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n                 var __create = Object.create;\n                 var __defProp = Object.defineProperty;\n                 var __getOwnPropDesc = Object.getOwnPropertyDescriptor;\n                 var __getOwnPropNames = Object.getOwnPropertyNames;\n                 var __getProtoOf = Object.getPrototypeOf;\n                 var __hasOwnProp = Object.prototype.hasOwnProperty;\n@@ -90632,14 +102190,15 @@\n         \"../../../node_modules/@headlessui/react/dist/index.cjs\":\n             /*!**************************************************************!*\\\n               !*** ../../../node_modules/@headlessui/react/dist/index.cjs ***!\n               \\**************************************************************/\n             /***/\n             (function(module, __unused_webpack_exports, __webpack_require__) {\n \n+                \"use strict\";\n \n \n                 if (false) {} else {\n                     module.exports = __webpack_require__( /*! ./headlessui.dev.cjs */ \"../../../node_modules/@headlessui/react/dist/headlessui.dev.cjs\")\n                 }\n \n \n@@ -90650,14 +102209,15 @@\n         \"../../../node_modules/@babel/runtime/helpers/extends.js\":\n             /*!***************************************************************!*\\\n               !*** ../../../node_modules/@babel/runtime/helpers/extends.js ***!\n               \\***************************************************************/\n             /***/\n             (function(module) {\n \n+                \"use strict\";\n \n \n                 function _extends() {\n                     module.exports = _extends = Object.assign ? Object.assign.bind() : function(target) {\n                         for (var i = 1; i < arguments.length; i++) {\n                             var source = arguments[i];\n                             for (var key in source) {\n@@ -90769,74 +102329,61 @@\n         /******/\n         __webpack_require__.nc = undefined;\n         /******/\n     }();\n     /******/\n     /************************************************************************/\n     var __webpack_exports__ = {};\n-    // This entry need to be wrapped in an IIFE because it need to be isolated against other modules in the chunk.\n+    // This entry need to be wrapped in an IIFE because it need to be in strict mode.\n     ! function() {\n+        \"use strict\";\n         var exports = __webpack_exports__;\n         /*!****************!*\\\n           !*** ./cdn.ts ***!\n           \\****************/\n \n \n         Object.defineProperty(exports, \"__esModule\", ({\n             value: true\n         }));\n         exports[\"default\"] = void 0;\n         var GraphiQLReact = _interopRequireWildcard(__webpack_require__( /*! @graphiql/react */ \"../../graphiql-react/dist/index.js\"));\n-        var _toolkit = __webpack_require__( /*! @graphiql/toolkit */ \"../../graphiql-toolkit/esm/index.js\");\n+        var _toolkit = __webpack_require__( /*! @graphiql/toolkit */ \"../../graphiql-toolkit/dist/esm/index.js\");\n         var GraphQL = _interopRequireWildcard(__webpack_require__( /*! graphql */ \"../../../node_modules/graphql/index.mjs\"));\n-        var _GraphiQL = __webpack_require__( /*! ./components/GraphiQL */ \"./components/GraphiQL.tsx\");\n+        var _GraphiQL = __webpack_require__( /*! ./GraphiQL */ \"./GraphiQL.tsx\");\n         __webpack_require__( /*! @graphiql/react/font/roboto.css */ \"../../graphiql-react/font/roboto.css\");\n         __webpack_require__( /*! @graphiql/react/font/fira-code.css */ \"../../graphiql-react/font/fira-code.css\");\n         __webpack_require__( /*! @graphiql/react/dist/style.css */ \"../../graphiql-react/dist/style.css\");\n         __webpack_require__( /*! ./style.css */ \"./style.css\");\n \n-        function _getRequireWildcardCache(nodeInterop) {\n-            if (typeof WeakMap !== \"function\") return null;\n-            var cacheBabelInterop = new WeakMap();\n-            var cacheNodeInterop = new WeakMap();\n-            return (_getRequireWildcardCache = function(nodeInterop) {\n-                return nodeInterop ? cacheNodeInterop : cacheBabelInterop;\n-            })(nodeInterop);\n+        function _getRequireWildcardCache(e) {\n+            if (\"function\" != typeof WeakMap) return null;\n+            var r = new WeakMap(),\n+                t = new WeakMap();\n+            return (_getRequireWildcardCache = function(e) {\n+                return e ? t : r;\n+            })(e);\n         }\n \n-        function _interopRequireWildcard(obj, nodeInterop) {\n-            if (!nodeInterop && obj && obj.__esModule) {\n-                return obj;\n-            }\n-            if (obj === null || typeof obj !== \"object\" && typeof obj !== \"function\") {\n-                return {\n-                    default: obj\n-                };\n-            }\n-            var cache = _getRequireWildcardCache(nodeInterop);\n-            if (cache && cache.has(obj)) {\n-                return cache.get(obj);\n-            }\n-            var newObj = {};\n-            var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;\n-            for (var key in obj) {\n-                if (key !== \"default\" && Object.prototype.hasOwnProperty.call(obj, key)) {\n-                    var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;\n-                    if (desc && (desc.get || desc.set)) {\n-                        Object.defineProperty(newObj, key, desc);\n-                    } else {\n-                        newObj[key] = obj[key];\n-                    }\n-                }\n-            }\n-            newObj.default = obj;\n-            if (cache) {\n-                cache.set(obj, newObj);\n-            }\n-            return newObj;\n+        function _interopRequireWildcard(e, r) {\n+            if (!r && e && e.__esModule) return e;\n+            if (null === e || \"object\" != typeof e && \"function\" != typeof e) return {\n+                default: e\n+            };\n+            var t = _getRequireWildcardCache(r);\n+            if (t && t.has(e)) return t.get(e);\n+            var n = {\n+                    __proto__: null\n+                },\n+                a = Object.defineProperty && Object.getOwnPropertyDescriptor;\n+            for (var u in e)\n+                if (\"default\" !== u && Object.prototype.hasOwnProperty.call(e, u)) {\n+                    var i = a ? Object.getOwnPropertyDescriptor(e, u) : null;\n+                    i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u];\n+                } return n.default = e, t && t.set(e, n), n;\n         }\n         /**\n          *  Copyright (c) 2021 GraphQL Contributors.\n          *\n          *  This source code is licensed under the MIT license found in the\n          *  LICENSE file in the root directory of this source tree.\n          */\n@@ -90868,14 +102415,13 @@\n         /**\n          * We also add the complete `@graphiql/react` exports. These will be included\n          * in the bundle anyway since they make up the `GraphiQL` component, so by\n          * doing this we can reuse them from plugin CDN bundles.\n          */\n         // @ts-expect-error\n         _GraphiQL.GraphiQL.React = GraphiQLReact;\n-        var _default = _GraphiQL.GraphiQL;\n-        exports[\"default\"] = _default;\n+        var _default = exports[\"default\"] = _GraphiQL.GraphiQL;\n     }();\n     window.GraphiQL = __webpack_exports__[\"default\"];\n     /******/\n })();\n //# sourceMappingURL=graphiql.js.map\n"}]}]}
